@ark-ui/react 0.13.1 → 0.15.0-beta.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 (519) hide show
  1. package/CHANGELOG.md +37 -2
  2. package/accordion/accordion-content.cjs +8 -8
  3. package/accordion/accordion-content.d.ts +7 -10
  4. package/accordion/accordion-content.mjs +8 -8
  5. package/accordion/accordion-context.d.ts +2 -9
  6. package/accordion/accordion-item-context.d.ts +3 -5
  7. package/accordion/accordion-item.d.ts +5 -8
  8. package/accordion/accordion-trigger.d.ts +6 -7
  9. package/accordion/accordion.cjs +3 -2
  10. package/accordion/accordion.d.ts +5 -11
  11. package/accordion/accordion.mjs +3 -2
  12. package/accordion/accordion.stories.d.ts +1 -1
  13. package/accordion/index.d.ts +13 -34
  14. package/accordion/use-accordion.d.ts +4 -9
  15. package/avatar/avatar-context.d.ts +2 -9
  16. package/avatar/avatar-fallback.d.ts +6 -7
  17. package/avatar/avatar-image.d.ts +6 -7
  18. package/avatar/avatar.d.ts +5 -9
  19. package/avatar/avatar.test.d.ts +1 -0
  20. package/avatar/index.d.ts +11 -22
  21. package/avatar/use-avatar.d.ts +4 -8
  22. package/carousel/carousel-context.d.ts +2 -9
  23. package/carousel/carousel-control.d.ts +6 -7
  24. package/carousel/carousel-indicator-group.d.ts +6 -7
  25. package/carousel/carousel-indicator.d.ts +5 -8
  26. package/carousel/carousel-next-slide-trigger.d.ts +6 -7
  27. package/carousel/carousel-prev-slide-trigger.d.ts +6 -7
  28. package/carousel/carousel-slide-group.d.ts +6 -7
  29. package/carousel/carousel-slide.d.ts +5 -8
  30. package/carousel/carousel-viewport.d.ts +6 -7
  31. package/carousel/carousel.d.ts +8 -11
  32. package/carousel/index.d.ts +25 -53
  33. package/carousel/use-carousel.d.ts +4 -8
  34. package/checkbox/checkbox-context.d.ts +2 -9
  35. package/checkbox/checkbox-control.cjs +3 -6
  36. package/checkbox/checkbox-control.d.ts +6 -7
  37. package/checkbox/checkbox-control.mjs +4 -7
  38. package/checkbox/checkbox-label.d.ts +6 -7
  39. package/checkbox/checkbox.cjs +7 -4
  40. package/checkbox/checkbox.d.ts +6 -10
  41. package/checkbox/checkbox.mjs +8 -5
  42. package/checkbox/checkbox.stories.d.ts +1 -1
  43. package/checkbox/index.d.ts +12 -29
  44. package/checkbox/use-checkbox.d.ts +5 -10
  45. package/color-picker/color-picker-area-gradient.d.ts +6 -7
  46. package/color-picker/color-picker-area-thumb.d.ts +6 -7
  47. package/color-picker/color-picker-area.d.ts +5 -8
  48. package/color-picker/color-picker-channel-input.d.ts +6 -7
  49. package/color-picker/color-picker-channel-slider-background.d.ts +6 -7
  50. package/color-picker/color-picker-channel-slider-thumb.d.ts +6 -7
  51. package/color-picker/color-picker-channel-slider-track.d.ts +5 -8
  52. package/color-picker/color-picker-content.d.ts +6 -7
  53. package/color-picker/color-picker-context.d.ts +2 -9
  54. package/color-picker/color-picker-eye-dropper-trigger.d.ts +6 -7
  55. package/color-picker/color-picker-swatch-background.d.ts +6 -7
  56. package/color-picker/color-picker-swatch-group.d.ts +6 -7
  57. package/color-picker/color-picker-swatch.d.ts +5 -8
  58. package/color-picker/index.d.ts +23 -52
  59. package/color-picker/use-color-picker.cjs +2 -7
  60. package/color-picker/use-color-picker.d.ts +4 -9
  61. package/color-picker/use-color-picker.mjs +3 -8
  62. package/combobox/combobox-clear-trigger.cjs +2 -2
  63. package/combobox/combobox-clear-trigger.d.ts +6 -7
  64. package/combobox/combobox-clear-trigger.mjs +2 -2
  65. package/combobox/combobox-content.cjs +8 -9
  66. package/combobox/combobox-content.d.ts +7 -10
  67. package/combobox/combobox-content.mjs +8 -9
  68. package/combobox/combobox-context.d.ts +4 -10
  69. package/combobox/combobox-control.cjs +2 -2
  70. package/combobox/combobox-control.d.ts +6 -7
  71. package/combobox/combobox-control.mjs +2 -2
  72. package/combobox/combobox-input.cjs +2 -2
  73. package/combobox/combobox-input.d.ts +6 -7
  74. package/combobox/combobox-input.mjs +2 -2
  75. package/combobox/combobox-item-context.cjs +15 -0
  76. package/combobox/combobox-item-context.d.ts +5 -0
  77. package/combobox/combobox-item-context.mjs +10 -0
  78. package/combobox/{combobox-option-group.cjs → combobox-item-group-label.cjs} +6 -6
  79. package/combobox/combobox-item-group-label.d.ts +7 -0
  80. package/combobox/{combobox-option-group.mjs → combobox-item-group-label.mjs} +6 -6
  81. package/combobox/{combobox-option-group-label.cjs → combobox-item-group.cjs} +6 -6
  82. package/combobox/combobox-item-group.d.ts +7 -0
  83. package/combobox/{combobox-option-group-label.mjs → combobox-item-group.mjs} +6 -6
  84. package/combobox/combobox-item-indicator.cjs +23 -0
  85. package/combobox/combobox-item-indicator.d.ts +7 -0
  86. package/combobox/combobox-item-indicator.mjs +19 -0
  87. package/combobox/combobox-item-text.cjs +21 -0
  88. package/combobox/combobox-item-text.d.ts +7 -0
  89. package/combobox/combobox-item-text.mjs +17 -0
  90. package/combobox/combobox-item.cjs +25 -0
  91. package/{select/select-option.d.ts → combobox/combobox-item.d.ts} +5 -5
  92. package/combobox/combobox-item.mjs +21 -0
  93. package/combobox/combobox-label.cjs +2 -2
  94. package/combobox/combobox-label.d.ts +6 -7
  95. package/combobox/combobox-label.mjs +2 -2
  96. package/combobox/combobox-positioner.cjs +2 -2
  97. package/combobox/combobox-positioner.d.ts +6 -7
  98. package/combobox/combobox-positioner.mjs +2 -2
  99. package/combobox/combobox-trigger.cjs +2 -2
  100. package/combobox/combobox-trigger.d.ts +6 -7
  101. package/combobox/combobox-trigger.mjs +2 -2
  102. package/combobox/combobox.cjs +20 -18
  103. package/combobox/combobox.d.ts +9 -13
  104. package/combobox/combobox.mjs +20 -18
  105. package/combobox/combobox.stories.d.ts +1 -0
  106. package/combobox/index.cjs +15 -9
  107. package/combobox/index.d.ts +35 -72
  108. package/combobox/index.mjs +11 -7
  109. package/combobox/use-combobox.cjs +24 -3
  110. package/combobox/use-combobox.d.ts +8 -9
  111. package/combobox/use-combobox.mjs +24 -3
  112. package/compose-refs.cjs +0 -1
  113. package/compose-refs.mjs +0 -1
  114. package/create-context.d.ts +3 -2
  115. package/date-picker/date-picker-clear-trigger.d.ts +6 -7
  116. package/date-picker/date-picker-column-header.d.ts +6 -7
  117. package/date-picker/date-picker-content.d.ts +6 -7
  118. package/date-picker/date-picker-context.d.ts +2 -9
  119. package/date-picker/date-picker-control.d.ts +6 -7
  120. package/date-picker/date-picker-day-cell-trigger.d.ts +6 -7
  121. package/date-picker/date-picker-day-cell.d.ts +5 -8
  122. package/date-picker/date-picker-grid.d.ts +5 -8
  123. package/date-picker/date-picker-input.d.ts +6 -7
  124. package/date-picker/date-picker-month-cell-trigger.d.ts +6 -7
  125. package/date-picker/date-picker-month-cell.d.ts +5 -8
  126. package/date-picker/date-picker-month-select.d.ts +6 -7
  127. package/date-picker/date-picker-next-trigger.d.ts +6 -7
  128. package/date-picker/date-picker-positioner.d.ts +6 -7
  129. package/date-picker/date-picker-prev-trigger.d.ts +5 -8
  130. package/date-picker/date-picker-row-group.d.ts +6 -7
  131. package/date-picker/date-picker-row-header.d.ts +6 -7
  132. package/date-picker/date-picker-row.d.ts +6 -7
  133. package/date-picker/date-picker-trigger.d.ts +6 -7
  134. package/date-picker/date-picker-view-trigger.d.ts +5 -8
  135. package/date-picker/date-picker-year-cell-trigger.d.ts +6 -7
  136. package/date-picker/date-picker-year-cell.d.ts +5 -8
  137. package/date-picker/date-picker-year-select.cjs +0 -1
  138. package/date-picker/date-picker-year-select.d.ts +6 -12
  139. package/date-picker/date-picker-year-select.mjs +1 -1
  140. package/date-picker/index.d.ts +56 -111
  141. package/date-picker/use-date-picker.d.ts +4 -8
  142. package/dialog/dialog-backdrop.cjs +14 -8
  143. package/dialog/dialog-backdrop.d.ts +7 -10
  144. package/dialog/dialog-backdrop.mjs +14 -8
  145. package/dialog/dialog-close-trigger.d.ts +6 -7
  146. package/dialog/dialog-container.d.ts +6 -7
  147. package/dialog/dialog-content.cjs +8 -9
  148. package/dialog/dialog-content.d.ts +7 -10
  149. package/dialog/dialog-content.mjs +8 -9
  150. package/dialog/dialog-context.d.ts +2 -9
  151. package/dialog/dialog-description.d.ts +6 -7
  152. package/dialog/dialog-title.d.ts +6 -7
  153. package/dialog/dialog-trigger.d.ts +6 -7
  154. package/dialog/index.d.ts +14 -32
  155. package/dialog/use-dialog.d.ts +4 -8
  156. package/editable/editable-area.d.ts +6 -7
  157. package/editable/editable-cancel-trigger.d.ts +6 -7
  158. package/editable/editable-context.d.ts +2 -9
  159. package/editable/editable-control.d.ts +6 -7
  160. package/editable/editable-edit-trigger.d.ts +6 -7
  161. package/editable/editable-input.d.ts +6 -7
  162. package/editable/editable-label.d.ts +6 -7
  163. package/editable/editable-preview.d.ts +6 -7
  164. package/editable/editable-submit-trigger.d.ts +6 -7
  165. package/editable/editable.d.ts +7 -14
  166. package/editable/index.d.ts +24 -57
  167. package/editable/use-editable.d.ts +4 -9
  168. package/factory.cjs +2 -2
  169. package/factory.d.ts +4 -1
  170. package/factory.mjs +1 -1
  171. package/hover-card/hover-card-arrow-tip.d.ts +6 -7
  172. package/hover-card/hover-card-arrow.d.ts +6 -7
  173. package/hover-card/hover-card-content.cjs +8 -9
  174. package/hover-card/hover-card-content.d.ts +7 -10
  175. package/hover-card/hover-card-content.mjs +8 -9
  176. package/hover-card/hover-card-context.d.ts +2 -9
  177. package/hover-card/hover-card-positioner.d.ts +6 -7
  178. package/hover-card/hover-card-trigger.d.ts +6 -7
  179. package/hover-card/hover-card.stories.d.ts +1 -1
  180. package/hover-card/index.d.ts +11 -23
  181. package/hover-card/use-hover-card.d.ts +4 -8
  182. package/index.cjs +36 -21
  183. package/index.d.ts +1 -0
  184. package/index.mjs +17 -8
  185. package/menu/index.d.ts +21 -54
  186. package/menu/menu-arrow-tip.d.ts +6 -7
  187. package/menu/menu-arrow.d.ts +6 -7
  188. package/menu/menu-content.cjs +11 -2
  189. package/menu/menu-content.d.ts +7 -8
  190. package/menu/menu-content.mjs +11 -2
  191. package/menu/menu-context-trigger.d.ts +6 -7
  192. package/menu/menu-context.d.ts +2 -3
  193. package/menu/menu-item-group-label.d.ts +5 -8
  194. package/menu/menu-item-group.d.ts +5 -8
  195. package/menu/menu-item.d.ts +6 -12
  196. package/menu/menu-option-item.d.ts +5 -10
  197. package/menu/menu-positioner.d.ts +6 -7
  198. package/menu/menu-separator.d.ts +6 -7
  199. package/menu/menu-trigger-item.d.ts +6 -7
  200. package/menu/menu-trigger.d.ts +6 -7
  201. package/menu/menu.d.ts +2 -1
  202. package/menu/menu.stories.d.ts +1 -1
  203. package/menu/use-menu.d.ts +3 -2
  204. package/number-input/index.d.ts +18 -41
  205. package/number-input/number-input-context.d.ts +2 -9
  206. package/number-input/number-input-control.d.ts +6 -7
  207. package/number-input/number-input-decrement-trigger.d.ts +6 -7
  208. package/number-input/number-input-field.d.ts +6 -7
  209. package/number-input/number-input-increment-trigger.d.ts +6 -7
  210. package/number-input/number-input-label.d.ts +6 -7
  211. package/number-input/number-input-scrubber.d.ts +6 -7
  212. package/number-input/number-input.d.ts +5 -11
  213. package/number-input/number-input.stories.d.ts +2 -0
  214. package/number-input/use-number-input.cjs +2 -7
  215. package/number-input/use-number-input.d.ts +4 -9
  216. package/number-input/use-number-input.mjs +3 -8
  217. package/package.json +61 -53
  218. package/pagination/index.d.ts +20 -49
  219. package/pagination/pagination-context.d.ts +2 -9
  220. package/pagination/pagination-ellipsis.d.ts +5 -8
  221. package/pagination/pagination-list-item.d.ts +6 -7
  222. package/pagination/pagination-list.d.ts +6 -7
  223. package/pagination/pagination-next-page-trigger.d.ts +6 -7
  224. package/pagination/pagination-page-trigger.d.ts +5 -8
  225. package/pagination/pagination-prev-page-trigger.d.ts +6 -7
  226. package/pagination/pagination.d.ts +6 -10
  227. package/pagination/use-pagination.d.ts +4 -9
  228. package/pin-input/index.d.ts +11 -30
  229. package/pin-input/pin-input-context.d.ts +2 -9
  230. package/pin-input/pin-input-control.cjs +3 -6
  231. package/pin-input/pin-input-control.d.ts +6 -7
  232. package/pin-input/pin-input-control.mjs +4 -7
  233. package/pin-input/pin-input-field.d.ts +5 -8
  234. package/pin-input/pin-input-label.d.ts +6 -7
  235. package/pin-input/pin-input.cjs +6 -3
  236. package/pin-input/pin-input.d.ts +5 -11
  237. package/pin-input/pin-input.mjs +7 -4
  238. package/pin-input/use-pin-input.d.ts +4 -9
  239. package/popover/index.d.ts +19 -39
  240. package/popover/popover-anchor.d.ts +6 -7
  241. package/popover/popover-arrow-tip.d.ts +6 -7
  242. package/popover/popover-arrow.d.ts +6 -7
  243. package/popover/popover-close-trigger.d.ts +6 -7
  244. package/popover/popover-content.cjs +8 -9
  245. package/popover/popover-content.d.ts +7 -10
  246. package/popover/popover-content.mjs +8 -9
  247. package/popover/popover-context.d.ts +2 -9
  248. package/popover/popover-description.d.ts +6 -7
  249. package/popover/popover-positioner.d.ts +6 -7
  250. package/popover/popover-title.d.ts +6 -7
  251. package/popover/popover-trigger.d.ts +6 -7
  252. package/popover/use-popover.d.ts +4 -8
  253. package/presence/presence.d.ts +2 -2
  254. package/presence/use-presence.d.ts +3 -2
  255. package/pressable/index.d.ts +4 -24
  256. package/pressable/pressable.d.ts +5 -15
  257. package/pressable/use-pressable.d.ts +4 -8
  258. package/radio-group/index.d.ts +15 -45
  259. package/radio-group/radio-context.d.ts +2 -12
  260. package/radio-group/radio-control.cjs +4 -7
  261. package/radio-group/radio-control.d.ts +6 -7
  262. package/radio-group/radio-control.mjs +5 -8
  263. package/radio-group/radio-group-context.d.ts +2 -9
  264. package/radio-group/radio-group-label.d.ts +6 -7
  265. package/radio-group/radio-group.cjs +0 -1
  266. package/radio-group/radio-group.d.ts +5 -11
  267. package/radio-group/radio-group.mjs +0 -1
  268. package/radio-group/radio-label.d.ts +6 -7
  269. package/radio-group/radio.cjs +12 -4
  270. package/radio-group/radio.d.ts +6 -18
  271. package/radio-group/radio.mjs +13 -5
  272. package/radio-group/use-radio-group.d.ts +4 -9
  273. package/range-slider/index.d.ts +23 -65
  274. package/range-slider/range-slider-context.d.ts +2 -9
  275. package/range-slider/range-slider-control.d.ts +6 -7
  276. package/range-slider/range-slider-label.d.ts +6 -7
  277. package/range-slider/range-slider-marker-group.d.ts +6 -7
  278. package/range-slider/range-slider-marker.d.ts +5 -8
  279. package/range-slider/range-slider-output.d.ts +4 -8
  280. package/range-slider/range-slider-range.d.ts +6 -7
  281. package/range-slider/range-slider-thumb.cjs +5 -5
  282. package/range-slider/range-slider-thumb.d.ts +5 -8
  283. package/range-slider/range-slider-thumb.mjs +5 -5
  284. package/range-slider/range-slider-track.d.ts +6 -7
  285. package/range-slider/range-slider.cjs +3 -0
  286. package/range-slider/range-slider.d.ts +4 -11
  287. package/range-slider/range-slider.mjs +3 -0
  288. package/range-slider/use-range-slider.cjs +3 -1
  289. package/range-slider/use-range-slider.d.ts +4 -9
  290. package/range-slider/use-range-slider.mjs +3 -1
  291. package/rating-group/index.d.ts +11 -34
  292. package/rating-group/rating-group-context.d.ts +2 -9
  293. package/rating-group/rating-group-control.cjs +4 -7
  294. package/rating-group/rating-group-control.d.ts +6 -10
  295. package/rating-group/rating-group-control.mjs +5 -8
  296. package/rating-group/rating-group-label.d.ts +6 -7
  297. package/rating-group/rating-group.cjs +6 -3
  298. package/rating-group/rating-group.d.ts +5 -11
  299. package/rating-group/rating-group.mjs +7 -4
  300. package/rating-group/rating-group.stories.d.ts +1 -1
  301. package/rating-group/rating.d.ts +4 -8
  302. package/rating-group/use-rating-group.d.ts +4 -9
  303. package/run-if-fn.d.ts +0 -1
  304. package/segment-group/index.d.ts +18 -50
  305. package/segment-group/segment-context.d.ts +2 -12
  306. package/segment-group/segment-control.cjs +4 -7
  307. package/segment-group/segment-control.d.ts +6 -7
  308. package/segment-group/segment-control.mjs +5 -8
  309. package/segment-group/segment-group-context.d.ts +2 -9
  310. package/segment-group/segment-group-indicator.d.ts +6 -7
  311. package/segment-group/segment-group-label.d.ts +6 -7
  312. package/segment-group/segment-group.cjs +0 -1
  313. package/segment-group/segment-group.d.ts +5 -11
  314. package/segment-group/segment-group.mjs +0 -1
  315. package/segment-group/segment-label.d.ts +6 -7
  316. package/segment-group/segment.cjs +12 -4
  317. package/segment-group/segment.d.ts +6 -18
  318. package/segment-group/segment.mjs +13 -5
  319. package/segment-group/use-segment-group.d.ts +4 -9
  320. package/select/index.cjs +30 -18
  321. package/select/index.d.ts +44 -46
  322. package/select/index.mjs +19 -9
  323. package/select/select-clear-trigger.cjs +21 -0
  324. package/select/select-clear-trigger.d.ts +7 -0
  325. package/select/select-clear-trigger.mjs +17 -0
  326. package/select/select-content.cjs +8 -9
  327. package/select/select-content.d.ts +7 -10
  328. package/select/select-content.mjs +8 -9
  329. package/select/select-context.d.ts +4 -10
  330. package/select/select-control.cjs +19 -0
  331. package/select/select-control.d.ts +7 -0
  332. package/select/select-control.mjs +15 -0
  333. package/select/select-item-context.cjs +15 -0
  334. package/select/select-item-context.d.ts +5 -0
  335. package/select/select-item-context.mjs +10 -0
  336. package/select/{select-option-group.cjs → select-item-group-label.cjs} +8 -6
  337. package/select/select-item-group-label.d.ts +7 -0
  338. package/select/{select-option-group.mjs → select-item-group-label.mjs} +8 -6
  339. package/select/select-item-group.cjs +21 -0
  340. package/select/select-item-group.d.ts +7 -0
  341. package/select/select-item-group.mjs +17 -0
  342. package/select/{select-option-group-label.cjs → select-item-indicator.cjs} +7 -6
  343. package/select/select-item-indicator.d.ts +7 -0
  344. package/select/select-item-indicator.mjs +19 -0
  345. package/select/select-item-text.cjs +21 -0
  346. package/select/select-item-text.d.ts +7 -0
  347. package/select/select-item-text.mjs +17 -0
  348. package/select/select-item.cjs +25 -0
  349. package/select/select-item.d.ts +11 -0
  350. package/select/select-item.mjs +21 -0
  351. package/select/select-label.cjs +2 -2
  352. package/select/select-label.d.ts +6 -7
  353. package/select/select-label.mjs +2 -2
  354. package/select/select-positioner.cjs +2 -2
  355. package/select/select-positioner.d.ts +6 -7
  356. package/select/select-positioner.mjs +2 -2
  357. package/select/select-trigger.cjs +2 -2
  358. package/select/select-trigger.d.ts +6 -7
  359. package/select/select-trigger.mjs +2 -2
  360. package/select/select-value.cjs +19 -0
  361. package/select/select-value.d.ts +7 -0
  362. package/select/select-value.mjs +15 -0
  363. package/select/select.anatomy.cjs +12 -0
  364. package/select/select.anatomy.d.ts +3 -1
  365. package/select/select.anatomy.mjs +7 -0
  366. package/select/select.cjs +43 -30
  367. package/select/select.d.ts +9 -6
  368. package/select/select.mjs +43 -30
  369. package/select/select.stories.d.ts +3 -0
  370. package/select/use-select.cjs +13 -3
  371. package/select/use-select.d.ts +8 -11
  372. package/select/use-select.mjs +13 -3
  373. package/slider/index.d.ts +22 -59
  374. package/slider/slider-context.d.ts +2 -9
  375. package/slider/slider-control.d.ts +6 -7
  376. package/slider/slider-label.d.ts +6 -7
  377. package/slider/slider-marker-group.d.ts +6 -7
  378. package/slider/slider-marker.d.ts +5 -8
  379. package/slider/slider-output.d.ts +5 -8
  380. package/slider/slider-range.d.ts +6 -7
  381. package/slider/slider-thumb.cjs +3 -6
  382. package/slider/slider-thumb.d.ts +6 -7
  383. package/slider/slider-thumb.mjs +4 -7
  384. package/slider/slider-track.d.ts +6 -7
  385. package/slider/slider.cjs +9 -4
  386. package/slider/slider.d.ts +4 -8
  387. package/slider/slider.mjs +10 -5
  388. package/slider/use-slider.cjs +2 -7
  389. package/slider/use-slider.d.ts +4 -9
  390. package/slider/use-slider.mjs +3 -8
  391. package/splitter/index.d.ts +12 -46
  392. package/splitter/splitter-context.d.ts +2 -9
  393. package/splitter/splitter-panel.d.ts +5 -8
  394. package/splitter/splitter-resize-trigger.d.ts +5 -8
  395. package/splitter/splitter.d.ts +4 -17
  396. package/splitter/splitter.stories.d.ts +1 -1
  397. package/splitter/use-splitter.d.ts +4 -9
  398. package/switch/index.cjs +0 -3
  399. package/switch/index.d.ts +16 -42
  400. package/switch/index.mjs +1 -3
  401. package/switch/switch-context.d.ts +2 -9
  402. package/switch/switch-control.cjs +2 -2
  403. package/switch/switch-control.d.ts +6 -7
  404. package/switch/switch-control.mjs +2 -2
  405. package/switch/switch-label.d.ts +6 -7
  406. package/switch/switch-thumb.d.ts +6 -7
  407. package/switch/switch.cjs +4 -2
  408. package/switch/switch.d.ts +6 -11
  409. package/switch/switch.mjs +5 -3
  410. package/switch/switch.stories.d.ts +1 -0
  411. package/switch/switch.test.d.ts +1 -0
  412. package/switch/use-switch.d.ts +5 -10
  413. package/tabs/index.d.ts +15 -35
  414. package/tabs/tab-content.d.ts +6 -7
  415. package/tabs/tab-indicator.d.ts +6 -7
  416. package/tabs/tab-list.d.ts +6 -7
  417. package/tabs/tab-trigger.d.ts +5 -8
  418. package/tabs/tabs-context.d.ts +2 -9
  419. package/tabs/tabs.cjs +0 -1
  420. package/tabs/tabs.d.ts +5 -11
  421. package/tabs/tabs.mjs +0 -1
  422. package/tabs/tabs.stories.d.ts +1 -1
  423. package/tabs/use-tabs.cjs +21 -2
  424. package/tabs/use-tabs.d.ts +6 -11
  425. package/tabs/use-tabs.mjs +3 -3
  426. package/tags-input/index.d.ts +19 -46
  427. package/tags-input/tag-delete-trigger.d.ts +5 -8
  428. package/tags-input/tag-input.d.ts +5 -8
  429. package/tags-input/tag.d.ts +5 -8
  430. package/tags-input/tags-input-clear-trigger.d.ts +6 -7
  431. package/tags-input/tags-input-context.d.ts +2 -9
  432. package/tags-input/tags-input-control.cjs +3 -6
  433. package/tags-input/tags-input-control.d.ts +6 -7
  434. package/tags-input/tags-input-control.mjs +4 -7
  435. package/tags-input/tags-input-field.d.ts +6 -7
  436. package/tags-input/tags-input-label.d.ts +6 -7
  437. package/tags-input/tags-input.cjs +8 -6
  438. package/tags-input/tags-input.d.ts +6 -10
  439. package/tags-input/tags-input.mjs +9 -7
  440. package/tags-input/use-tags-input.d.ts +4 -9
  441. package/toast/index.d.ts +14 -31
  442. package/toast/toast-close-trigger.d.ts +6 -7
  443. package/toast/toast-description.d.ts +6 -7
  444. package/toast/toast-group.d.ts +6 -10
  445. package/toast/toast-item-context.d.ts +2 -9
  446. package/toast/toast-provider.cjs +0 -1
  447. package/toast/toast-provider.d.ts +4 -60
  448. package/toast/toast-provider.mjs +1 -1
  449. package/toast/toast-title.d.ts +6 -7
  450. package/toast/toast.d.ts +5 -8
  451. package/toast/toast.stories.d.ts +1 -1
  452. package/toast/use-toast-item.d.ts +2 -7
  453. package/toggle-group/index.cjs +17 -0
  454. package/toggle-group/index.d.ts +19 -0
  455. package/toggle-group/index.mjs +11 -0
  456. package/toggle-group/toggle-group-context.cjs +15 -0
  457. package/toggle-group/toggle-group-context.d.ts +5 -0
  458. package/toggle-group/toggle-group-context.mjs +10 -0
  459. package/toggle-group/toggle-group.cjs +35 -0
  460. package/toggle-group/toggle-group.d.ts +7 -0
  461. package/toggle-group/toggle-group.mjs +31 -0
  462. package/toggle-group/toggle-group.stories.d.ts +9 -0
  463. package/toggle-group/toggle-group.test.d.ts +1 -0
  464. package/toggle-group/toggle.cjs +21 -0
  465. package/toggle-group/toggle.d.ts +11 -0
  466. package/toggle-group/toggle.mjs +17 -0
  467. package/toggle-group/use-toggle-group.cjs +49 -0
  468. package/toggle-group/use-toggle-group.d.ts +7 -0
  469. package/toggle-group/use-toggle-group.mjs +26 -0
  470. package/tooltip/index.d.ts +11 -23
  471. package/tooltip/tooltip-arrow-tip.d.ts +6 -7
  472. package/tooltip/tooltip-arrow.d.ts +6 -7
  473. package/tooltip/tooltip-content.cjs +5 -6
  474. package/tooltip/tooltip-content.d.ts +7 -10
  475. package/tooltip/tooltip-content.mjs +5 -6
  476. package/tooltip/tooltip-context.d.ts +2 -9
  477. package/tooltip/tooltip-positioner.d.ts +6 -7
  478. package/tooltip/tooltip-trigger.d.ts +6 -7
  479. package/tooltip/use-tooltip.d.ts +4 -8
  480. package/types.d.ts +1 -0
  481. package/use-event.cjs +23 -0
  482. package/use-event.d.ts +12 -0
  483. package/use-event.mjs +19 -0
  484. package/use-latest-ref.cjs +14 -0
  485. package/use-latest-ref.mjs +10 -0
  486. package/accordion/accordion-item-presence.cjs +0 -16
  487. package/accordion/accordion-item-presence.d.ts +0 -4
  488. package/accordion/accordion-item-presence.mjs +0 -12
  489. package/combobox/combobox-option-group-label.d.ts +0 -10
  490. package/combobox/combobox-option-group.d.ts +0 -10
  491. package/combobox/combobox-option.cjs +0 -27
  492. package/combobox/combobox-option.d.ts +0 -14
  493. package/combobox/combobox-option.mjs +0 -23
  494. package/combobox/combobox-presence.cjs +0 -16
  495. package/combobox/combobox-presence.d.ts +0 -4
  496. package/combobox/combobox-presence.mjs +0 -12
  497. package/dialog/dialog-presence.cjs +0 -16
  498. package/dialog/dialog-presence.d.ts +0 -4
  499. package/dialog/dialog-presence.mjs +0 -12
  500. package/hover-card/hover-card-presence.cjs +0 -16
  501. package/hover-card/hover-card-presence.d.ts +0 -4
  502. package/hover-card/hover-card-presence.mjs +0 -12
  503. package/popover/popover-presence.cjs +0 -16
  504. package/popover/popover-presence.d.ts +0 -4
  505. package/popover/popover-presence.mjs +0 -12
  506. package/select/select-option-group-label.d.ts +0 -13
  507. package/select/select-option-group-label.mjs +0 -18
  508. package/select/select-option-group.d.ts +0 -10
  509. package/select/select-option.cjs +0 -26
  510. package/select/select-option.mjs +0 -22
  511. package/select/select-presence.cjs +0 -16
  512. package/select/select-presence.d.ts +0 -4
  513. package/select/select-presence.mjs +0 -12
  514. package/switch/switch-input.cjs +0 -19
  515. package/switch/switch-input.d.ts +0 -8
  516. package/switch/switch-input.mjs +0 -15
  517. package/tooltip/tooltip-presence.cjs +0 -16
  518. package/tooltip/tooltip-presence.d.ts +0 -4
  519. package/tooltip/tooltip-presence.mjs +0 -12
@@ -6,14 +6,14 @@ import { createSplitProps } from '../create-split-props.mjs';
6
6
  import { ark } from '../factory.mjs';
7
7
  import { useComboboxContext } from './combobox-context.mjs';
8
8
 
9
- const ComboboxOptionGroupLabel = forwardRef(
9
+ const ComboboxItemGroup = forwardRef(
10
10
  (props, ref) => {
11
- const [optionProps, labelProps] = createSplitProps()(props, ["htmlFor"]);
12
- const { getOptionGroupLabelProps } = useComboboxContext();
13
- const mergedProps = mergeProps(getOptionGroupLabelProps(optionProps), labelProps);
11
+ const [itemProps, localProps] = createSplitProps()(props, ["id"]);
12
+ const api = useComboboxContext();
13
+ const mergedProps = mergeProps(api.getItemGroupProps(itemProps), localProps);
14
14
  return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
15
15
  }
16
16
  );
17
- ComboboxOptionGroupLabel.displayName = "ComboboxOptionGroupLabel";
17
+ ComboboxItemGroup.displayName = "ComboboxItemGroup";
18
18
 
19
- export { ComboboxOptionGroupLabel };
19
+ export { ComboboxItemGroup };
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const factory = require('../factory.cjs');
10
+ const comboboxContext = require('./combobox-context.cjs');
11
+ const comboboxItemContext = require('./combobox-item-context.cjs');
12
+
13
+ const ComboboxItemIndicator = react.forwardRef(
14
+ (props, ref) => {
15
+ const api = comboboxContext.useComboboxContext();
16
+ const item = comboboxItemContext.useComboboxItemContext();
17
+ const mergedProps = react$1.mergeProps(api.getItemIndicatorProps(item), props);
18
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref });
19
+ }
20
+ );
21
+ ComboboxItemIndicator.displayName = "ComboboxItemIndicator";
22
+
23
+ exports.ComboboxItemIndicator = ComboboxItemIndicator;
@@ -0,0 +1,7 @@
1
+ import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefAttributes } from 'react';
2
+ /// <reference types="react" />
3
+ import { type HTMLArkProps } from '../factory';
4
+ export type ComboboxItemIndicatorProps = HTMLArkProps<'div'>;
5
+ export declare const ComboboxItemIndicator: ForwardRefExoticComponent<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
6
+ asChild?: boolean | undefined;
7
+ } & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,19 @@
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.mjs';
6
+ import { useComboboxContext } from './combobox-context.mjs';
7
+ import { useComboboxItemContext } from './combobox-item-context.mjs';
8
+
9
+ const ComboboxItemIndicator = forwardRef(
10
+ (props, ref) => {
11
+ const api = useComboboxContext();
12
+ const item = useComboboxItemContext();
13
+ const mergedProps = mergeProps(api.getItemIndicatorProps(item), props);
14
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
15
+ }
16
+ );
17
+ ComboboxItemIndicator.displayName = "ComboboxItemIndicator";
18
+
19
+ export { ComboboxItemIndicator };
@@ -0,0 +1,21 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const factory = require('../factory.cjs');
10
+ const comboboxContext = require('./combobox-context.cjs');
11
+ const comboboxItemContext = require('./combobox-item-context.cjs');
12
+
13
+ const ComboboxItemText = react.forwardRef((props, ref) => {
14
+ const api = comboboxContext.useComboboxContext();
15
+ const itemProps = comboboxItemContext.useComboboxItemContext();
16
+ const mergedProps = react$1.mergeProps(api.getItemTextProps(itemProps), props);
17
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.span, { ...mergedProps, ref });
18
+ });
19
+ ComboboxItemText.displayName = "ComboboxItemText";
20
+
21
+ exports.ComboboxItemText = ComboboxItemText;
@@ -0,0 +1,7 @@
1
+ import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefAttributes } from 'react';
2
+ /// <reference types="react" />
3
+ import { type HTMLArkProps } from '../factory';
4
+ export type ComboboxItemTextProps = HTMLArkProps<'span'>;
5
+ export declare const ComboboxItemText: ForwardRefExoticComponent<Omit<DetailedHTMLProps<HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "ref"> & {
6
+ asChild?: boolean | undefined;
7
+ } & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,17 @@
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.mjs';
6
+ import { useComboboxContext } from './combobox-context.mjs';
7
+ import { useComboboxItemContext } from './combobox-item-context.mjs';
8
+
9
+ const ComboboxItemText = forwardRef((props, ref) => {
10
+ const api = useComboboxContext();
11
+ const itemProps = useComboboxItemContext();
12
+ const mergedProps = mergeProps(api.getItemTextProps(itemProps), props);
13
+ return /* @__PURE__ */ jsx(ark.span, { ...mergedProps, ref });
14
+ });
15
+ ComboboxItemText.displayName = "ComboboxItemText";
16
+
17
+ export { ComboboxItemText };
@@ -0,0 +1,25 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const createSplitProps = require('../create-split-props.cjs');
10
+ const factory = require('../factory.cjs');
11
+ const runIfFn = require('../run-if-fn.cjs');
12
+ const comboboxContext = require('./combobox-context.cjs');
13
+ const comboboxItemContext = require('./combobox-item-context.cjs');
14
+
15
+ const ComboboxItem = react.forwardRef((props, ref) => {
16
+ const [itemProps, { children, ...localProps }] = createSplitProps.createSplitProps()(props, ["item"]);
17
+ const api = comboboxContext.useComboboxContext();
18
+ const mergedProps = react$1.mergeProps(api.getItemProps(itemProps), localProps);
19
+ const itemState = api.getItemState(itemProps);
20
+ const view = runIfFn.runIfFn(children, itemState);
21
+ return /* @__PURE__ */ jsxRuntime.jsx(comboboxItemContext.ComboboxItemProvider, { value: itemProps, children: /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref, children: view }) });
22
+ });
23
+ ComboboxItem.displayName = "ComboboxItem";
24
+
25
+ exports.ComboboxItem = ComboboxItem;
@@ -1,10 +1,10 @@
1
- import type { OptionProps } from '@zag-js/select';
1
+ import type { ItemProps } from '@zag-js/combobox';
2
2
  import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefObject, RefAttributes, type ComponentPropsWithoutRef } from 'react';
3
3
  import { ark } from '../factory';
4
- import type { Assign } from '../types';
5
- export type SelectOptionProps = Assign<ComponentPropsWithoutRef<typeof ark.div>, OptionProps>;
6
- export declare const SelectOption: ForwardRefExoticComponent<Omit<Omit<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
4
+ import { type Assign } from '../types';
5
+ export type ComboboxItemProps = Assign<ComponentPropsWithoutRef<typeof ark.div>, ItemProps>;
6
+ export declare const ComboboxItem: ForwardRefExoticComponent<Omit<Omit<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
7
7
  ref?: ((instance: HTMLDivElement | null) => void) | RefObject<HTMLDivElement> | null | undefined;
8
8
  } & {
9
9
  asChild?: boolean | undefined;
10
- }, "ref">, keyof OptionProps> & OptionProps & RefAttributes<HTMLDivElement>>;
10
+ }, "ref">, "item"> & ItemProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,21 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { createSplitProps } from '../create-split-props.mjs';
6
+ import { ark } from '../factory.mjs';
7
+ import { runIfFn } from '../run-if-fn.mjs';
8
+ import { useComboboxContext } from './combobox-context.mjs';
9
+ import { ComboboxItemProvider } from './combobox-item-context.mjs';
10
+
11
+ const ComboboxItem = forwardRef((props, ref) => {
12
+ const [itemProps, { children, ...localProps }] = createSplitProps()(props, ["item"]);
13
+ const api = useComboboxContext();
14
+ const mergedProps = mergeProps(api.getItemProps(itemProps), localProps);
15
+ const itemState = api.getItemState(itemProps);
16
+ const view = runIfFn(children, itemState);
17
+ return /* @__PURE__ */ jsx(ComboboxItemProvider, { value: itemProps, children: /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref, children: view }) });
18
+ });
19
+ ComboboxItem.displayName = "ComboboxItem";
20
+
21
+ export { ComboboxItem };
@@ -10,8 +10,8 @@ const factory = require('../factory.cjs');
10
10
  const comboboxContext = require('./combobox-context.cjs');
11
11
 
12
12
  const ComboboxLabel = react.forwardRef((props, ref) => {
13
- const { labelProps } = comboboxContext.useComboboxContext();
14
- const mergedProps = react$1.mergeProps(labelProps, props);
13
+ const api = comboboxContext.useComboboxContext();
14
+ const mergedProps = react$1.mergeProps(api.labelProps, props);
15
15
  return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.label, { ...mergedProps, ref });
16
16
  });
17
17
  ComboboxLabel.displayName = "ComboboxLabel";
@@ -1,8 +1,7 @@
1
- import { ForwardRefExoticComponent, DetailedHTMLProps, LabelHTMLAttributes, RefObject, RefAttributes, type ComponentPropsWithoutRef } from 'react';
2
- import { ark } from '../factory';
3
- export type ComboboxLabelProps = ComponentPropsWithoutRef<typeof ark.label>;
4
- export declare const ComboboxLabel: ForwardRefExoticComponent<Omit<Omit<DetailedHTMLProps<LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>, "ref"> & {
5
- ref?: ((instance: HTMLLabelElement | null) => void) | RefObject<HTMLLabelElement> | null | undefined;
6
- } & {
1
+ import { ForwardRefExoticComponent, DetailedHTMLProps, LabelHTMLAttributes, RefAttributes } from 'react';
2
+ /// <reference types="react" />
3
+ import { type HTMLArkProps } from '../factory';
4
+ export type ComboboxLabelProps = HTMLArkProps<'label'>;
5
+ export declare const ComboboxLabel: ForwardRefExoticComponent<Omit<DetailedHTMLProps<LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>, "ref"> & {
7
6
  asChild?: boolean | undefined;
8
- }, "ref"> & RefAttributes<HTMLLabelElement>>;
7
+ } & RefAttributes<HTMLLabelElement>>;
@@ -6,8 +6,8 @@ import { ark } from '../factory.mjs';
6
6
  import { useComboboxContext } from './combobox-context.mjs';
7
7
 
8
8
  const ComboboxLabel = forwardRef((props, ref) => {
9
- const { labelProps } = useComboboxContext();
10
- const mergedProps = mergeProps(labelProps, props);
9
+ const api = useComboboxContext();
10
+ const mergedProps = mergeProps(api.labelProps, props);
11
11
  return /* @__PURE__ */ jsx(ark.label, { ...mergedProps, ref });
12
12
  });
13
13
  ComboboxLabel.displayName = "ComboboxLabel";
@@ -11,8 +11,8 @@ const comboboxContext = require('./combobox-context.cjs');
11
11
 
12
12
  const ComboboxPositioner = react.forwardRef(
13
13
  (props, ref) => {
14
- const { positionerProps } = comboboxContext.useComboboxContext();
15
- const mergedProps = react$1.mergeProps(positionerProps, props);
14
+ const api = comboboxContext.useComboboxContext();
15
+ const mergedProps = react$1.mergeProps(api.positionerProps, props);
16
16
  return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref });
17
17
  }
18
18
  );
@@ -1,8 +1,7 @@
1
- import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefObject, RefAttributes, type ComponentPropsWithoutRef } from 'react';
2
- import { ark } from '../factory';
3
- export type ComboboxPositionerProps = ComponentPropsWithoutRef<typeof ark.div>;
4
- export declare const ComboboxPositioner: ForwardRefExoticComponent<Omit<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
5
- ref?: ((instance: HTMLDivElement | null) => void) | RefObject<HTMLDivElement> | null | undefined;
6
- } & {
1
+ import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefAttributes } from 'react';
2
+ /// <reference types="react" />
3
+ import { type HTMLArkProps } from '../factory';
4
+ export type ComboboxPositionerProps = HTMLArkProps<'div'>;
5
+ export declare const ComboboxPositioner: ForwardRefExoticComponent<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
7
6
  asChild?: boolean | undefined;
8
- }, "ref"> & RefAttributes<HTMLDivElement>>;
7
+ } & RefAttributes<HTMLDivElement>>;
@@ -7,8 +7,8 @@ import { useComboboxContext } from './combobox-context.mjs';
7
7
 
8
8
  const ComboboxPositioner = forwardRef(
9
9
  (props, ref) => {
10
- const { positionerProps } = useComboboxContext();
11
- const mergedProps = mergeProps(positionerProps, props);
10
+ const api = useComboboxContext();
11
+ const mergedProps = mergeProps(api.positionerProps, props);
12
12
  return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
13
13
  }
14
14
  );
@@ -10,8 +10,8 @@ const factory = require('../factory.cjs');
10
10
  const comboboxContext = require('./combobox-context.cjs');
11
11
 
12
12
  const ComboboxTrigger = react.forwardRef((props, ref) => {
13
- const { triggerProps } = comboboxContext.useComboboxContext();
14
- const mergedProps = react$1.mergeProps(triggerProps, props);
13
+ const api = comboboxContext.useComboboxContext();
14
+ const mergedProps = react$1.mergeProps(api.triggerProps, props);
15
15
  return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.button, { ...mergedProps, ref });
16
16
  });
17
17
  ComboboxTrigger.displayName = "ComboboxTrigger";
@@ -1,8 +1,7 @@
1
- import { ForwardRefExoticComponent, DetailedHTMLProps, ButtonHTMLAttributes, RefObject, RefAttributes, type ComponentPropsWithoutRef } from 'react';
2
- import { ark } from '../factory';
3
- export type ComboboxTriggerProps = ComponentPropsWithoutRef<typeof ark.button>;
4
- export declare const ComboboxTrigger: ForwardRefExoticComponent<Omit<Omit<DetailedHTMLProps<ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
5
- ref?: ((instance: HTMLButtonElement | null) => void) | RefObject<HTMLButtonElement> | null | undefined;
6
- } & {
1
+ import { ForwardRefExoticComponent, DetailedHTMLProps, ButtonHTMLAttributes, RefAttributes } from 'react';
2
+ /// <reference types="react" />
3
+ import { type HTMLArkProps } from '../factory';
4
+ export type ComboboxTriggerProps = HTMLArkProps<'button'>;
5
+ export declare const ComboboxTrigger: ForwardRefExoticComponent<Omit<DetailedHTMLProps<ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
7
6
  asChild?: boolean | undefined;
8
- }, "ref"> & RefAttributes<HTMLButtonElement>>;
7
+ } & RefAttributes<HTMLButtonElement>>;
@@ -6,8 +6,8 @@ import { ark } from '../factory.mjs';
6
6
  import { useComboboxContext } from './combobox-context.mjs';
7
7
 
8
8
  const ComboboxTrigger = forwardRef((props, ref) => {
9
- const { triggerProps } = useComboboxContext();
10
- const mergedProps = mergeProps(triggerProps, props);
9
+ const api = useComboboxContext();
10
+ const mergedProps = mergeProps(api.triggerProps, props);
11
11
  return /* @__PURE__ */ jsx(ark.button, { ...mergedProps, ref });
12
12
  });
13
13
  ComboboxTrigger.displayName = "ComboboxTrigger";
@@ -12,52 +12,54 @@ const runIfFn = require('../run-if-fn.cjs');
12
12
  const comboboxContext = require('./combobox-context.cjs');
13
13
  const useCombobox = require('./use-combobox.cjs');
14
14
 
15
- const Combobox = react.forwardRef((props, ref) => {
16
- const [useComboboxProps, { children, ...divProps }] = createSplitProps.createSplitProps()(
15
+ const ComboboxImpl = (props, ref) => {
16
+ const [useComboboxProps, { children, ...localProps }] = createSplitProps.createSplitProps()(
17
17
  props,
18
18
  [
19
19
  "allowCustomValue",
20
- "ariaHidden",
21
20
  "autoFocus",
22
- "blurOnSelect",
21
+ "closeOnSelect",
22
+ "defaultValue",
23
23
  "dir",
24
24
  "disabled",
25
- "focusOnClear",
26
25
  "form",
27
26
  "getRootNode",
27
+ "highlightedValue",
28
28
  "id",
29
29
  "ids",
30
30
  "inputBehavior",
31
31
  "inputValue",
32
32
  "invalid",
33
- "isCustomValue",
33
+ "isItemDisabled",
34
+ "items",
35
+ "itemToString",
36
+ "itemToValue",
34
37
  "loop",
38
+ "multiple",
35
39
  "name",
40
+ "onChange",
36
41
  "onClose",
37
42
  "onFocusOutside",
38
43
  "onHighlight",
39
44
  "onInputChange",
40
- "onInputChange",
41
45
  "onInteractOutside",
42
46
  "onOpen",
43
47
  "onPointerDownOutside",
44
- "onSelect",
45
48
  "openOnClick",
46
49
  "placeholder",
47
50
  "positioning",
48
51
  "readOnly",
49
- "selectInputOnFocus",
50
52
  "selectionBehavior",
51
- "selectionData",
52
- "selectOnTab",
53
- "translations"
53
+ "selectOnBlur",
54
+ "translations",
55
+ "value"
54
56
  ]
55
57
  );
56
- const combobox = useCombobox.useCombobox(useComboboxProps);
57
- const mergedProps = react$1.mergeProps(combobox.rootProps, divProps);
58
- const view = runIfFn.runIfFn(children, combobox);
59
- return /* @__PURE__ */ jsxRuntime.jsx(comboboxContext.ComboboxProvider, { value: combobox, children: /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref, children: view }) });
60
- });
61
- Combobox.displayName = "Combobox";
58
+ const api = useCombobox.useCombobox(useComboboxProps);
59
+ const view = runIfFn.runIfFn(children, api);
60
+ const mergedProps = react$1.mergeProps(api.rootProps, localProps);
61
+ return /* @__PURE__ */ jsxRuntime.jsx(comboboxContext.ComboboxProvider, { value: api, children: /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref, children: view }) });
62
+ };
63
+ const Combobox = react.forwardRef(ComboboxImpl);
62
64
 
63
65
  exports.Combobox = Combobox;
@@ -1,15 +1,11 @@
1
- import { Context } from '@zag-js/combobox';
2
- import { ForwardRefExoticComponent, DetailedHTMLProps, HTMLAttributes, RefObject, ReactNode, RefAttributes, type ComponentPropsWithoutRef } from 'react';
3
- import { ark } from '../factory';
4
- import { type Assign } from '../types';
1
+ import { type ReactNode } from 'react';
2
+ import { type HTMLArkProps } from '../factory';
3
+ import { type Assign, type CollectionItem } from '../types';
5
4
  import { type UseComboboxProps, type UseComboboxReturn } from './use-combobox';
6
- export type ComboboxProps = Assign<Omit<ComponentPropsWithoutRef<typeof ark.div>, 'children'>, UseComboboxProps> & {
7
- children?: React.ReactNode | ((props: UseComboboxReturn) => React.ReactNode);
5
+ export type ComboboxProps<T extends CollectionItem> = Assign<HTMLArkProps<'div'>, UseComboboxProps<T>> & {
6
+ children?: ReactNode | ((state: UseComboboxReturn<T>) => ReactNode);
8
7
  };
9
- export declare const Combobox: ForwardRefExoticComponent<Omit<Omit<Omit<Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
10
- ref?: ((instance: HTMLDivElement | null) => void) | RefObject<HTMLDivElement> | null | undefined;
11
- } & {
12
- asChild?: boolean | undefined;
13
- }, "ref">, "children">, "name" | "getRootNode" | "form" | "id" | "ids" | "onOpen" | "onClose" | "positioning" | "disabled" | "onSelect" | "autoFocus" | "dir" | "placeholder" | "loop" | "readOnly" | "invalid" | "inputValue" | "selectionData" | "inputBehavior" | "blurOnSelect" | "selectionBehavior" | "selectOnTab" | "selectInputOnFocus" | "focusOnClear" | "openOnClick" | "allowCustomValue" | "ariaHidden" | "isCustomValue" | "onInputChange" | "onHighlight" | "translations" | "onPointerDownOutside" | "onFocusOutside" | "onInteractOutside"> & Pick<Partial<Context>, "id"> & Omit<Context, "id"> & {
14
- children?: ReactNode | ((props: UseComboboxReturn) => React.ReactNode);
15
- } & RefAttributes<HTMLDivElement>>;
8
+ export interface ComboboxComponent {
9
+ <T extends CollectionItem>(props: ComboboxProps<T> & React.RefAttributes<HTMLDivElement>): JSX.Element;
10
+ }
11
+ export declare const Combobox: ComboboxComponent;
@@ -8,52 +8,54 @@ import { runIfFn } from '../run-if-fn.mjs';
8
8
  import { ComboboxProvider } from './combobox-context.mjs';
9
9
  import { useCombobox } from './use-combobox.mjs';
10
10
 
11
- const Combobox = forwardRef((props, ref) => {
12
- const [useComboboxProps, { children, ...divProps }] = createSplitProps()(
11
+ const ComboboxImpl = (props, ref) => {
12
+ const [useComboboxProps, { children, ...localProps }] = createSplitProps()(
13
13
  props,
14
14
  [
15
15
  "allowCustomValue",
16
- "ariaHidden",
17
16
  "autoFocus",
18
- "blurOnSelect",
17
+ "closeOnSelect",
18
+ "defaultValue",
19
19
  "dir",
20
20
  "disabled",
21
- "focusOnClear",
22
21
  "form",
23
22
  "getRootNode",
23
+ "highlightedValue",
24
24
  "id",
25
25
  "ids",
26
26
  "inputBehavior",
27
27
  "inputValue",
28
28
  "invalid",
29
- "isCustomValue",
29
+ "isItemDisabled",
30
+ "items",
31
+ "itemToString",
32
+ "itemToValue",
30
33
  "loop",
34
+ "multiple",
31
35
  "name",
36
+ "onChange",
32
37
  "onClose",
33
38
  "onFocusOutside",
34
39
  "onHighlight",
35
40
  "onInputChange",
36
- "onInputChange",
37
41
  "onInteractOutside",
38
42
  "onOpen",
39
43
  "onPointerDownOutside",
40
- "onSelect",
41
44
  "openOnClick",
42
45
  "placeholder",
43
46
  "positioning",
44
47
  "readOnly",
45
- "selectInputOnFocus",
46
48
  "selectionBehavior",
47
- "selectionData",
48
- "selectOnTab",
49
- "translations"
49
+ "selectOnBlur",
50
+ "translations",
51
+ "value"
50
52
  ]
51
53
  );
52
- const combobox = useCombobox(useComboboxProps);
53
- const mergedProps = mergeProps(combobox.rootProps, divProps);
54
- const view = runIfFn(children, combobox);
55
- return /* @__PURE__ */ jsx(ComboboxProvider, { value: combobox, children: /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref, children: view }) });
56
- });
57
- Combobox.displayName = "Combobox";
54
+ const api = useCombobox(useComboboxProps);
55
+ const view = runIfFn(children, api);
56
+ const mergedProps = mergeProps(api.rootProps, localProps);
57
+ return /* @__PURE__ */ jsx(ComboboxProvider, { value: api, children: /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref, children: view }) });
58
+ };
59
+ const Combobox = forwardRef(ComboboxImpl);
58
60
 
59
61
  export { Combobox };
@@ -5,3 +5,4 @@ type ComboboxType = typeof Combobox;
5
5
  declare const meta: Meta<ComboboxType>;
6
6
  export default meta;
7
7
  export declare const Basic: () => JSX.Element;
8
+ export declare const Advanced: () => JSX.Element;
@@ -9,10 +9,12 @@ const comboboxContent = require('./combobox-content.cjs');
9
9
  const comboboxContext = require('./combobox-context.cjs');
10
10
  const comboboxControl = require('./combobox-control.cjs');
11
11
  const comboboxInput = require('./combobox-input.cjs');
12
+ const comboboxItem = require('./combobox-item.cjs');
13
+ const comboboxItemGroup = require('./combobox-item-group.cjs');
14
+ const comboboxItemGroupLabel = require('./combobox-item-group-label.cjs');
15
+ const comboboxItemIndicator = require('./combobox-item-indicator.cjs');
16
+ const comboboxItemText = require('./combobox-item-text.cjs');
12
17
  const comboboxLabel = require('./combobox-label.cjs');
13
- const comboboxOption = require('./combobox-option.cjs');
14
- const comboboxOptionGroup = require('./combobox-option-group.cjs');
15
- const comboboxOptionGroupLabel = require('./combobox-option-group-label.cjs');
16
18
  const comboboxPositioner = require('./combobox-positioner.cjs');
17
19
  const comboboxTrigger = require('./combobox-trigger.cjs');
18
20
  const combobox = require('@zag-js/combobox');
@@ -23,10 +25,12 @@ const Combobox = Object.assign(combobox$1.Combobox, {
23
25
  Content: comboboxContent.ComboboxContent,
24
26
  Control: comboboxControl.ComboboxControl,
25
27
  Input: comboboxInput.ComboboxInput,
28
+ Item: comboboxItem.ComboboxItem,
29
+ ItemGroup: comboboxItemGroup.ComboboxItemGroup,
30
+ ItemGroupLabel: comboboxItemGroupLabel.ComboboxItemGroupLabel,
31
+ ItemIndicator: comboboxItemIndicator.ComboboxItemIndicator,
32
+ ItemText: comboboxItemText.ComboboxItemText,
26
33
  Label: comboboxLabel.ComboboxLabel,
27
- Option: comboboxOption.ComboboxOption,
28
- OptionGroup: comboboxOptionGroup.ComboboxOptionGroup,
29
- OptionGroupLabel: comboboxOptionGroupLabel.ComboboxOptionGroupLabel,
30
34
  Positioner: comboboxPositioner.ComboboxPositioner,
31
35
  Trigger: comboboxTrigger.ComboboxTrigger
32
36
  });
@@ -36,10 +40,12 @@ exports.ComboboxContent = comboboxContent.ComboboxContent;
36
40
  exports.useComboboxContext = comboboxContext.useComboboxContext;
37
41
  exports.ComboboxControl = comboboxControl.ComboboxControl;
38
42
  exports.ComboboxInput = comboboxInput.ComboboxInput;
43
+ exports.ComboboxItem = comboboxItem.ComboboxItem;
44
+ exports.ComboboxItemGroup = comboboxItemGroup.ComboboxItemGroup;
45
+ exports.ComboboxItemGroupLabel = comboboxItemGroupLabel.ComboboxItemGroupLabel;
46
+ exports.ComboboxItemIndicator = comboboxItemIndicator.ComboboxItemIndicator;
47
+ exports.ComboboxItemText = comboboxItemText.ComboboxItemText;
39
48
  exports.ComboboxLabel = comboboxLabel.ComboboxLabel;
40
- exports.ComboboxOption = comboboxOption.ComboboxOption;
41
- exports.ComboboxOptionGroup = comboboxOptionGroup.ComboboxOptionGroup;
42
- exports.ComboboxOptionGroupLabel = comboboxOptionGroupLabel.ComboboxOptionGroupLabel;
43
49
  exports.ComboboxPositioner = comboboxPositioner.ComboboxPositioner;
44
50
  exports.ComboboxTrigger = comboboxTrigger.ComboboxTrigger;
45
51
  Object.defineProperty(exports, 'comboboxAnatomy', {