@ark-ui/solid 1.2.0 → 2.0.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 (430) hide show
  1. package/CHANGELOG.md +82 -0
  2. package/README.md +2 -0
  3. package/cjs/index.js +1211 -1267
  4. package/cjs/index.js.map +1 -1
  5. package/esm/index.js +1392 -1504
  6. package/esm/index.js.map +1 -1
  7. package/package.json +57 -54
  8. package/source/accordion/accordion-item-trigger.jsx +0 -1
  9. package/source/accordion/{accordion.jsx → accordion-root.jsx} +1 -1
  10. package/source/accordion/index.js +4 -4
  11. package/source/avatar/{avatar.jsx → avatar-root.jsx} +1 -1
  12. package/source/avatar/index.js +4 -4
  13. package/source/carousel/{carousel.jsx → carousel-root.jsx} +1 -1
  14. package/source/carousel/index.js +6 -6
  15. package/source/checkbox/{checkbox.jsx → checkbox-root.jsx} +1 -1
  16. package/source/checkbox/index.js +4 -4
  17. package/source/color-picker/{color-picker.jsx → color-picker-root.jsx} +1 -1
  18. package/source/color-picker/index.js +4 -4
  19. package/source/combobox/{combobox.jsx → combobox-root.jsx} +1 -1
  20. package/source/combobox/index.js +4 -4
  21. package/source/combobox/use-combobox.js +3 -3
  22. package/source/date-picker/{date-picker.jsx → date-picker-root.jsx} +1 -1
  23. package/source/date-picker/index.js +4 -4
  24. package/source/dialog/{dialog.jsx → dialog-root.jsx} +1 -1
  25. package/source/dialog/dialog-trigger.jsx +0 -1
  26. package/source/dialog/index.js +5 -5
  27. package/source/editable/{editable.jsx → editable-root.jsx} +1 -1
  28. package/source/editable/index.js +4 -4
  29. package/source/environment/index.js +1 -4
  30. package/source/factory.jsx +10 -23
  31. package/source/file-upload/{file-upload.jsx → file-upload-root.jsx} +1 -1
  32. package/source/file-upload/index.js +4 -4
  33. package/source/hover-card/{hover-card.jsx → hover-card-root.jsx} +1 -1
  34. package/source/hover-card/index.js +4 -4
  35. package/source/index.jsx +2 -0
  36. package/source/menu/index.js +4 -4
  37. package/source/menu/{menu.jsx → menu-root.jsx} +1 -1
  38. package/source/menu/menu-trigger.jsx +0 -1
  39. package/source/number-input/index.js +4 -4
  40. package/source/number-input/{number-input.jsx → number-input-root.jsx} +1 -1
  41. package/source/pagination/index.js +4 -4
  42. package/source/pagination/{pagination.jsx → pagination-root.jsx} +1 -1
  43. package/source/pin-input/index.js +4 -4
  44. package/source/pin-input/{pin-input.jsx → pin-input-root.jsx} +1 -1
  45. package/source/popover/index.js +4 -4
  46. package/source/popover/popover-description.jsx +1 -1
  47. package/source/popover/{popover.jsx → popover-root.jsx} +1 -1
  48. package/source/popover/popover-trigger.jsx +0 -1
  49. package/source/presence/index.js +1 -4
  50. package/source/progress/index.js +22 -0
  51. package/source/progress/progress-circle-range.jsx +8 -0
  52. package/source/progress/progress-circle-track.jsx +8 -0
  53. package/source/progress/progress-circle.jsx +8 -0
  54. package/source/progress/progress-context.js +5 -0
  55. package/source/progress/progress-label.jsx +8 -0
  56. package/source/progress/progress-range.jsx +8 -0
  57. package/source/progress/progress-root.jsx +24 -0
  58. package/source/progress/progress-track.jsx +8 -0
  59. package/source/progress/progress-value-text.jsx +10 -0
  60. package/source/progress/progress-view.jsx +10 -0
  61. package/source/progress/use-progress.js +10 -0
  62. package/source/radio-group/index.js +4 -4
  63. package/source/radio-group/{radio-group.jsx → radio-group-root.jsx} +1 -1
  64. package/source/rating-group/index.js +4 -4
  65. package/source/rating-group/{rating-group.jsx → rating-group-root.jsx} +1 -1
  66. package/source/segment-group/index.js +4 -4
  67. package/source/segment-group/{segment-group.jsx → segment-group-root.jsx} +1 -1
  68. package/source/select/index.js +4 -4
  69. package/source/select/{select.jsx → select-root.jsx} +1 -1
  70. package/source/select/use-select.js +3 -3
  71. package/source/slider/index.js +4 -4
  72. package/source/slider/{slider.jsx → slider-root.jsx} +1 -1
  73. package/source/splitter/index.js +4 -4
  74. package/source/splitter/{splitter.jsx → splitter-root.jsx} +1 -1
  75. package/source/switch/index.js +4 -4
  76. package/source/switch/{switch.jsx → switch-root.jsx} +1 -1
  77. package/source/tabs/index.js +4 -4
  78. package/source/tabs/{tabs.jsx → tabs-root.jsx} +1 -1
  79. package/source/tags-input/index.js +6 -4
  80. package/source/tags-input/tags-input-item-preview.jsx +10 -0
  81. package/source/tags-input/{tags-input.jsx → tags-input-root.jsx} +1 -1
  82. package/source/toast/index.js +4 -4
  83. package/source/toast/{toast.jsx → toast-root.jsx} +1 -1
  84. package/source/toggle-group/index.js +4 -4
  85. package/source/toggle-group/{toggle-group.jsx → toggle-group-root.jsx} +1 -1
  86. package/source/tooltip/index.js +4 -4
  87. package/source/tooltip/{tooltip.jsx → tooltip-root.jsx} +1 -1
  88. package/source/tree-view/index.js +26 -0
  89. package/source/tree-view/tree-view-branch-content.jsx +15 -0
  90. package/source/tree-view/tree-view-branch-control.jsx +15 -0
  91. package/source/tree-view/tree-view-branch-indicator.jsx +16 -0
  92. package/source/tree-view/tree-view-branch-text.jsx +15 -0
  93. package/source/tree-view/tree-view-branch-trigger.jsx +15 -0
  94. package/source/tree-view/tree-view-branch.jsx +17 -0
  95. package/source/tree-view/tree-view-context.js +5 -0
  96. package/source/tree-view/tree-view-item-text.jsx +12 -0
  97. package/source/tree-view/tree-view-item.jsx +13 -0
  98. package/source/tree-view/tree-view-label.jsx +8 -0
  99. package/source/tree-view/tree-view-root.jsx +27 -0
  100. package/source/tree-view/tree-view-tree.jsx +8 -0
  101. package/source/tree-view/use-tree-view.js +10 -0
  102. package/types/accordion/accordion-item-content.d.ts +2 -2
  103. package/types/accordion/accordion-item-indicator.d.ts +2 -2
  104. package/types/accordion/accordion-item-trigger.d.ts +2 -2
  105. package/types/accordion/accordion-item.d.ts +7 -5
  106. package/types/accordion/accordion-root.d.ts +10 -0
  107. package/types/avatar/avatar-fallback.d.ts +2 -2
  108. package/types/avatar/avatar-image.d.ts +2 -2
  109. package/types/avatar/avatar-root.d.ts +6 -0
  110. package/types/avatar/index.d.ts +8 -7
  111. package/types/carousel/carousel-control.d.ts +2 -2
  112. package/types/carousel/carousel-indicator-group.d.ts +2 -2
  113. package/types/carousel/carousel-indicator.d.ts +2 -2
  114. package/types/carousel/carousel-item-group.d.ts +4 -0
  115. package/types/carousel/{carousel-slide.d.ts → carousel-item.d.ts} +2 -2
  116. package/types/carousel/carousel-next-trigger.d.ts +2 -2
  117. package/types/carousel/carousel-prev-trigger.d.ts +2 -2
  118. package/types/carousel/carousel-root.d.ts +11 -0
  119. package/types/carousel/carousel-viewport.d.ts +2 -2
  120. package/types/checkbox/checkbox-control.d.ts +2 -2
  121. package/types/checkbox/checkbox-indicator.d.ts +2 -2
  122. package/types/checkbox/checkbox-label.d.ts +2 -2
  123. package/types/checkbox/checkbox-root.d.ts +11 -0
  124. package/types/color-picker/color-picker-area-background.d.ts +2 -2
  125. package/types/color-picker/color-picker-area-thumb.d.ts +2 -2
  126. package/types/color-picker/color-picker-area.d.ts +2 -2
  127. package/types/color-picker/color-picker-channel-input.d.ts +3 -3
  128. package/types/color-picker/color-picker-channel-slider-thumb.d.ts +2 -2
  129. package/types/color-picker/color-picker-channel-slider-track.d.ts +2 -2
  130. package/types/color-picker/color-picker-channel-slider.d.ts +2 -2
  131. package/types/color-picker/color-picker-content.d.ts +2 -2
  132. package/types/color-picker/color-picker-control.d.ts +2 -2
  133. package/types/color-picker/color-picker-eye-dropper-trigger.d.ts +2 -2
  134. package/types/color-picker/color-picker-format-select.d.ts +2 -2
  135. package/types/color-picker/color-picker-format-trigger.d.ts +2 -2
  136. package/types/color-picker/color-picker-label.d.ts +2 -2
  137. package/types/color-picker/color-picker-positioner.d.ts +2 -2
  138. package/types/color-picker/color-picker-root.d.ts +12 -0
  139. package/types/color-picker/color-picker-swatch-group.d.ts +2 -2
  140. package/types/color-picker/color-picker-swatch-indicator.d.ts +2 -2
  141. package/types/color-picker/color-picker-swatch-trigger.d.ts +2 -2
  142. package/types/color-picker/color-picker-swatch.d.ts +2 -2
  143. package/types/color-picker/color-picker-transparency-grid.d.ts +2 -2
  144. package/types/color-picker/color-picker-trigger.d.ts +2 -2
  145. package/types/color-picker/color-picker-value-text.d.ts +6 -3
  146. package/types/combobox/combobox-clear-trigger.d.ts +2 -2
  147. package/types/combobox/combobox-content.d.ts +2 -2
  148. package/types/combobox/combobox-control.d.ts +2 -2
  149. package/types/combobox/combobox-input.d.ts +2 -2
  150. package/types/combobox/combobox-item-group-label.d.ts +2 -2
  151. package/types/combobox/combobox-item-group.d.ts +2 -2
  152. package/types/combobox/combobox-item-indicator.d.ts +2 -2
  153. package/types/combobox/combobox-item-text.d.ts +2 -2
  154. package/types/combobox/combobox-item.d.ts +6 -4
  155. package/types/combobox/combobox-label.d.ts +2 -2
  156. package/types/combobox/combobox-positioner.d.ts +2 -2
  157. package/types/combobox/{combobox.d.ts → combobox-root.d.ts} +2 -2
  158. package/types/combobox/combobox-trigger.d.ts +2 -2
  159. package/types/create-split-props.d.ts +1 -1
  160. package/types/date-picker/date-picker-clear-trigger.d.ts +2 -2
  161. package/types/date-picker/date-picker-content.d.ts +2 -2
  162. package/types/date-picker/date-picker-control.d.ts +2 -2
  163. package/types/date-picker/date-picker-input.d.ts +2 -2
  164. package/types/date-picker/date-picker-label.d.ts +2 -2
  165. package/types/date-picker/date-picker-month-select.d.ts +2 -2
  166. package/types/date-picker/date-picker-next-trigger.d.ts +2 -2
  167. package/types/date-picker/date-picker-positioner.d.ts +2 -2
  168. package/types/date-picker/date-picker-prev-trigger.d.ts +2 -2
  169. package/types/date-picker/date-picker-range-text.d.ts +2 -2
  170. package/types/date-picker/date-picker-root.d.ts +12 -0
  171. package/types/date-picker/date-picker-table-body.d.ts +2 -2
  172. package/types/date-picker/date-picker-table-cell-trigger.d.ts +2 -2
  173. package/types/date-picker/date-picker-table-cell.d.ts +2 -2
  174. package/types/date-picker/date-picker-table-head.d.ts +2 -2
  175. package/types/date-picker/date-picker-table-header.d.ts +2 -2
  176. package/types/date-picker/date-picker-table-row.d.ts +2 -2
  177. package/types/date-picker/date-picker-table.d.ts +2 -2
  178. package/types/date-picker/date-picker-trigger.d.ts +2 -2
  179. package/types/date-picker/date-picker-view-control.d.ts +2 -2
  180. package/types/date-picker/date-picker-view-trigger.d.ts +2 -2
  181. package/types/date-picker/date-picker-view.d.ts +6 -4
  182. package/types/date-picker/date-picker-year-select.d.ts +2 -2
  183. package/types/dialog/dialog-backdrop.d.ts +2 -2
  184. package/types/dialog/dialog-close-trigger.d.ts +2 -2
  185. package/types/dialog/dialog-content.d.ts +2 -2
  186. package/types/dialog/dialog-description.d.ts +2 -2
  187. package/types/dialog/dialog-positioner.d.ts +2 -2
  188. package/types/dialog/{dialog.d.ts → dialog-root.d.ts} +2 -2
  189. package/types/dialog/dialog-title.d.ts +2 -2
  190. package/types/dialog/dialog-trigger.d.ts +2 -2
  191. package/types/dialog/index.d.ts +13 -12
  192. package/types/editable/editable-area.d.ts +2 -2
  193. package/types/editable/editable-cancel-trigger.d.ts +2 -2
  194. package/types/editable/editable-control.d.ts +2 -2
  195. package/types/editable/editable-edit-trigger.d.ts +2 -2
  196. package/types/editable/editable-input.d.ts +2 -2
  197. package/types/editable/editable-label.d.ts +2 -2
  198. package/types/editable/editable-preview.d.ts +2 -2
  199. package/types/editable/editable-root.d.ts +11 -0
  200. package/types/editable/editable-submit-trigger.d.ts +2 -2
  201. package/types/editable/index.d.ts +14 -13
  202. package/types/environment/index.d.ts +1 -4
  203. package/types/factory.d.ts +12 -8
  204. package/types/file-upload/file-upload-dropzone.d.ts +2 -2
  205. package/types/file-upload/file-upload-item-delete-trigger.d.ts +2 -2
  206. package/types/file-upload/file-upload-item-group.d.ts +6 -4
  207. package/types/file-upload/file-upload-item-name.d.ts +2 -2
  208. package/types/file-upload/file-upload-item-preview-image.d.ts +2 -2
  209. package/types/file-upload/file-upload-item-preview.d.ts +6 -3
  210. package/types/file-upload/file-upload-item-size-text.d.ts +2 -2
  211. package/types/file-upload/file-upload-item.d.ts +2 -2
  212. package/types/file-upload/file-upload-label.d.ts +2 -2
  213. package/types/file-upload/file-upload-root.d.ts +11 -0
  214. package/types/file-upload/file-upload-trigger.d.ts +2 -2
  215. package/types/hover-card/hover-card-arrow-tip.d.ts +2 -2
  216. package/types/hover-card/hover-card-arrow.d.ts +2 -2
  217. package/types/hover-card/hover-card-content.d.ts +2 -2
  218. package/types/hover-card/hover-card-positioner.d.ts +2 -2
  219. package/types/hover-card/{hover-card.d.ts → hover-card-root.d.ts} +2 -2
  220. package/types/hover-card/hover-card-trigger.d.ts +2 -2
  221. package/types/hover-card/index.d.ts +11 -10
  222. package/types/index.d.ts +2 -0
  223. package/types/menu/menu-arrow-tip.d.ts +2 -2
  224. package/types/menu/menu-arrow.d.ts +2 -2
  225. package/types/menu/menu-content.d.ts +2 -2
  226. package/types/menu/menu-context-trigger.d.ts +2 -2
  227. package/types/menu/menu-item-group-label.d.ts +2 -2
  228. package/types/menu/menu-item-group.d.ts +2 -2
  229. package/types/menu/menu-item.d.ts +2 -2
  230. package/types/menu/menu-option-item.d.ts +6 -4
  231. package/types/menu/menu-positioner.d.ts +2 -2
  232. package/types/menu/{menu.d.ts → menu-root.d.ts} +2 -2
  233. package/types/menu/menu-separator.d.ts +2 -2
  234. package/types/menu/menu-trigger-item.d.ts +2 -2
  235. package/types/menu/menu-trigger.d.ts +2 -2
  236. package/types/number-input/number-input-control.d.ts +2 -2
  237. package/types/number-input/number-input-decrement-trigger.d.ts +2 -2
  238. package/types/number-input/number-input-increment-trigger.d.ts +2 -2
  239. package/types/number-input/number-input-input.d.ts +2 -2
  240. package/types/number-input/number-input-label.d.ts +2 -2
  241. package/types/number-input/number-input-root.d.ts +11 -0
  242. package/types/number-input/number-input-scrubber.d.ts +2 -2
  243. package/types/pagination/index.d.ts +10 -9
  244. package/types/pagination/pagination-ellipsis.d.ts +2 -2
  245. package/types/pagination/pagination-item.d.ts +2 -2
  246. package/types/pagination/pagination-next-trigger.d.ts +2 -2
  247. package/types/pagination/pagination-prev-trigger.d.ts +2 -2
  248. package/types/pagination/pagination-root.d.ts +11 -0
  249. package/types/pin-input/index.d.ts +11 -8
  250. package/types/pin-input/pin-input-control.d.ts +2 -2
  251. package/types/pin-input/pin-input-input.d.ts +4 -2
  252. package/types/pin-input/pin-input-label.d.ts +2 -2
  253. package/types/pin-input/pin-input-root.d.ts +6 -0
  254. package/types/popover/index.d.ts +16 -15
  255. package/types/popover/popover-anchor.d.ts +2 -2
  256. package/types/popover/popover-arrow-tip.d.ts +2 -2
  257. package/types/popover/popover-arrow.d.ts +2 -2
  258. package/types/popover/popover-close-trigger.d.ts +2 -2
  259. package/types/popover/popover-content.d.ts +2 -2
  260. package/types/popover/popover-description.d.ts +3 -3
  261. package/types/popover/popover-indicator.d.ts +2 -2
  262. package/types/popover/popover-positioner.d.ts +2 -2
  263. package/types/popover/{popover.d.ts → popover-root.d.ts} +2 -2
  264. package/types/popover/popover-title.d.ts +2 -2
  265. package/types/popover/popover-trigger.d.ts +2 -2
  266. package/types/presence/index.d.ts +1 -4
  267. package/types/presence/presence.d.ts +2 -2
  268. package/types/presence/split-presence-props.d.ts +1 -1
  269. package/types/progress/index.d.ts +23 -0
  270. package/types/progress/progress-circle-range.d.ts +4 -0
  271. package/types/progress/progress-circle-track.d.ts +4 -0
  272. package/types/progress/progress-circle.d.ts +4 -0
  273. package/types/progress/progress-context.d.ts +4 -0
  274. package/types/progress/progress-label.d.ts +4 -0
  275. package/types/progress/progress-range.d.ts +4 -0
  276. package/types/progress/progress-root.d.ts +11 -0
  277. package/types/progress/progress-track.d.ts +4 -0
  278. package/types/progress/progress-value-text.d.ts +4 -0
  279. package/types/progress/progress-view.d.ts +6 -0
  280. package/types/progress/use-progress.d.ts +9 -0
  281. package/types/radio-group/index.d.ts +11 -10
  282. package/types/radio-group/radio-group-indicator.d.ts +2 -2
  283. package/types/radio-group/radio-group-item-control.d.ts +2 -2
  284. package/types/radio-group/radio-group-item-text.d.ts +2 -2
  285. package/types/radio-group/radio-group-item.d.ts +6 -4
  286. package/types/radio-group/radio-group-label.d.ts +2 -2
  287. package/types/radio-group/radio-group-root.d.ts +6 -0
  288. package/types/rating-group/rating-group-control.d.ts +6 -4
  289. package/types/rating-group/rating-group-item.d.ts +6 -4
  290. package/types/rating-group/rating-group-label.d.ts +2 -2
  291. package/types/rating-group/rating-group-root.d.ts +6 -0
  292. package/types/segment-group/segment-group-indicator.d.ts +2 -2
  293. package/types/segment-group/segment-group-item-control.d.ts +2 -2
  294. package/types/segment-group/segment-group-item-text.d.ts +2 -2
  295. package/types/segment-group/segment-group-item.d.ts +7 -5
  296. package/types/segment-group/segment-group-label.d.ts +2 -2
  297. package/types/segment-group/segment-group-root.d.ts +6 -0
  298. package/types/select/select-clear-trigger.d.ts +2 -2
  299. package/types/select/select-content.d.ts +2 -2
  300. package/types/select/select-control.d.ts +2 -2
  301. package/types/select/select-indicator.d.ts +2 -2
  302. package/types/select/select-item-group-label.d.ts +2 -2
  303. package/types/select/select-item-group.d.ts +2 -2
  304. package/types/select/select-item-indicator.d.ts +2 -2
  305. package/types/select/select-item-text.d.ts +2 -2
  306. package/types/select/select-item.d.ts +6 -4
  307. package/types/select/select-label.d.ts +2 -2
  308. package/types/select/select-positioner.d.ts +2 -2
  309. package/types/select/{select.d.ts → select-root.d.ts} +2 -2
  310. package/types/select/select-trigger.d.ts +2 -2
  311. package/types/select/select-value-text.d.ts +6 -3
  312. package/types/slider/index.d.ts +14 -13
  313. package/types/slider/slider-control.d.ts +2 -2
  314. package/types/slider/slider-label.d.ts +2 -2
  315. package/types/slider/slider-marker-group.d.ts +2 -2
  316. package/types/slider/slider-marker.d.ts +2 -2
  317. package/types/slider/slider-range.d.ts +2 -2
  318. package/types/slider/slider-root.d.ts +11 -0
  319. package/types/slider/slider-thumb.d.ts +2 -2
  320. package/types/slider/slider-track.d.ts +2 -2
  321. package/types/slider/slider-value-text.d.ts +2 -2
  322. package/types/splitter/index.d.ts +8 -7
  323. package/types/splitter/splitter-panel.d.ts +2 -2
  324. package/types/splitter/splitter-resize-trigger.d.ts +2 -2
  325. package/types/splitter/splitter-root.d.ts +11 -0
  326. package/types/switch/index.d.ts +9 -8
  327. package/types/switch/switch-control.d.ts +2 -2
  328. package/types/switch/switch-label.d.ts +2 -2
  329. package/types/switch/switch-root.d.ts +11 -0
  330. package/types/switch/switch-thumb.d.ts +2 -2
  331. package/types/tabs/index.d.ts +10 -9
  332. package/types/tabs/tab-content.d.ts +2 -2
  333. package/types/tabs/tab-indicator.d.ts +2 -2
  334. package/types/tabs/tab-list.d.ts +2 -2
  335. package/types/tabs/tab-trigger.d.ts +2 -2
  336. package/types/tabs/tabs-root.d.ts +10 -0
  337. package/types/tags-input/tags-input-clear-trigger.d.ts +2 -2
  338. package/types/tags-input/tags-input-control.d.ts +2 -2
  339. package/types/tags-input/tags-input-input.d.ts +2 -2
  340. package/types/tags-input/tags-input-item-delete-trigger.d.ts +2 -2
  341. package/types/tags-input/tags-input-item-input.d.ts +2 -2
  342. package/types/tags-input/tags-input-item-preview.d.ts +4 -0
  343. package/types/tags-input/tags-input-item-text.d.ts +2 -2
  344. package/types/tags-input/tags-input-item.d.ts +6 -4
  345. package/types/tags-input/tags-input-label.d.ts +2 -2
  346. package/types/tags-input/tags-input-root.d.ts +11 -0
  347. package/types/toast/index.d.ts +9 -9
  348. package/types/toast/toast-close-trigger.d.ts +2 -2
  349. package/types/toast/toast-description.d.ts +2 -2
  350. package/types/toast/toast-group.d.ts +2 -2
  351. package/types/toast/toast-root.d.ts +4 -0
  352. package/types/toast/toast-title.d.ts +2 -2
  353. package/types/toggle-group/index.d.ts +7 -6
  354. package/types/toggle-group/toggle-group-item.d.ts +2 -2
  355. package/types/toggle-group/toggle-group-root.d.ts +6 -0
  356. package/types/tooltip/index.d.ts +11 -10
  357. package/types/tooltip/tooltip-arrow-tip.d.ts +2 -2
  358. package/types/tooltip/tooltip-arrow.d.ts +2 -2
  359. package/types/tooltip/tooltip-content.d.ts +2 -2
  360. package/types/tooltip/tooltip-positioner.d.ts +2 -2
  361. package/types/tooltip/{tooltip.d.ts → tooltip-root.d.ts} +2 -2
  362. package/types/tooltip/tooltip-trigger.d.ts +2 -2
  363. package/types/tree-view/tree-view-branch-content.d.ts +6 -0
  364. package/types/tree-view/tree-view-branch-control.d.ts +6 -0
  365. package/types/tree-view/tree-view-branch-indicator.d.ts +6 -0
  366. package/types/tree-view/tree-view-branch-text.d.ts +6 -0
  367. package/types/tree-view/tree-view-branch-trigger.d.ts +6 -0
  368. package/types/tree-view/tree-view-branch.d.ts +11 -0
  369. package/types/tree-view/tree-view-context.d.ts +20 -0
  370. package/types/tree-view/tree-view-item-text.d.ts +6 -0
  371. package/types/tree-view/tree-view-item.d.ts +11 -0
  372. package/types/tree-view/tree-view-label.d.ts +4 -0
  373. package/types/tree-view/tree-view-root.d.ts +11 -0
  374. package/types/tree-view/tree-view-tree.d.ts +4 -0
  375. package/types/tree-view/use-tree-view.d.ts +9 -0
  376. package/source/constants.js +0 -27
  377. package/source/filter-object.js +0 -7
  378. package/source/is-empty.js +0 -4
  379. package/source/is-function.js +0 -1
  380. package/source/merge-style.js +0 -30
  381. package/source/parse-template.js +0 -248
  382. package/source/pipe.js +0 -1
  383. package/source/spread.js +0 -39
  384. package/source/ssr-spread.js +0 -19
  385. package/types/accordion/accordion.d.ts +0 -7
  386. package/types/accordion/index.d.ts +0 -16
  387. package/types/avatar/avatar.d.ts +0 -6
  388. package/types/carousel/carousel-slide-group.d.ts +0 -4
  389. package/types/carousel/carousel.d.ts +0 -9
  390. package/types/carousel/index.d.ts +0 -23
  391. package/types/checkbox/checkbox.d.ts +0 -9
  392. package/types/checkbox/index.d.ts +0 -14
  393. package/types/color-picker/color-picker.d.ts +0 -10
  394. package/types/color-picker/index.d.ts +0 -54
  395. package/types/combobox/index.d.ts +0 -32
  396. package/types/constants.d.ts +0 -1
  397. package/types/date-picker/date-picker.d.ts +0 -10
  398. package/types/date-picker/index.d.ts +0 -54
  399. package/types/editable/editable.d.ts +0 -9
  400. package/types/file-upload/file-upload.d.ts +0 -9
  401. package/types/file-upload/index.d.ts +0 -27
  402. package/types/filter-object.d.ts +0 -8
  403. package/types/is-empty.d.ts +0 -1
  404. package/types/is-function.d.ts +0 -1
  405. package/types/menu/index.d.ts +0 -31
  406. package/types/merge-style.d.ts +0 -6
  407. package/types/number-input/index.d.ts +0 -19
  408. package/types/number-input/number-input.d.ts +0 -9
  409. package/types/pagination/pagination.d.ts +0 -9
  410. package/types/parse-template.d.ts +0 -45
  411. package/types/pin-input/pin-input.d.ts +0 -6
  412. package/types/pipe.d.ts +0 -10
  413. package/types/radio-group/radio-group.d.ts +0 -6
  414. package/types/rating-group/index.d.ts +0 -14
  415. package/types/rating-group/rating-group.d.ts +0 -6
  416. package/types/segment-group/index.d.ts +0 -18
  417. package/types/segment-group/segment-group.d.ts +0 -6
  418. package/types/select/index.d.ts +0 -35
  419. package/types/slider/slider.d.ts +0 -9
  420. package/types/splitter/splitter.d.ts +0 -9
  421. package/types/spread.d.ts +0 -1
  422. package/types/ssr-spread.d.ts +0 -10
  423. package/types/switch/switch.d.ts +0 -9
  424. package/types/tabs/tabs.d.ts +0 -7
  425. package/types/tags-input/index.d.ts +0 -24
  426. package/types/tags-input/tags-input.d.ts +0 -9
  427. package/types/toast/toast.d.ts +0 -4
  428. package/types/toggle-group/toggle-group.d.ts +0 -6
  429. /package/source/carousel/{carousel-slide-group.jsx → carousel-item-group.jsx} +0 -0
  430. /package/source/carousel/{carousel-slide.jsx → carousel-item.jsx} +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ark-ui/solid",
3
- "version": "1.2.0",
3
+ "version": "2.0.0",
4
4
  "description": "A collection of unstyled, accessible UI components for Solid, utilizing state machines for seamless interaction.",
5
5
  "keywords": [
6
6
  "accordion",
@@ -21,6 +21,7 @@
21
21
  "pin input",
22
22
  "popover",
23
23
  "presence",
24
+ "progress",
24
25
  "radio group",
25
26
  "rating group",
26
27
  "segment group",
@@ -32,7 +33,8 @@
32
33
  "tags input",
33
34
  "toast",
34
35
  "toggle group",
35
- "tooltip"
36
+ "tooltip",
37
+ "tree view"
36
38
  ],
37
39
  "homepage": "https://ark-ui.com",
38
40
  "license": "MIT",
@@ -80,74 +82,75 @@
80
82
  "release-it": "release-it --config ../../../release-it.json"
81
83
  },
82
84
  "dependencies": {
83
- "@ark-ui/anatomy": "1.2.0",
84
- "@zag-js/accordion": "0.31.1",
85
- "@zag-js/avatar": "0.31.1",
86
- "@zag-js/carousel": "0.31.1",
87
- "@zag-js/checkbox": "0.31.1",
88
- "@zag-js/color-picker": "0.31.1",
89
- "@zag-js/combobox": "0.31.1",
90
- "@zag-js/date-picker": "0.31.1",
91
- "@zag-js/dialog": "0.31.1",
92
- "@zag-js/editable": "0.31.1",
93
- "@zag-js/file-upload": "0.31.1",
94
- "@zag-js/hover-card": "0.31.1",
95
- "@zag-js/menu": "0.31.1",
96
- "@zag-js/number-input": "0.31.1",
97
- "@zag-js/pagination": "0.31.1",
98
- "@zag-js/pin-input": "0.31.1",
99
- "@zag-js/popover": "0.31.1",
100
- "@zag-js/presence": "0.31.1",
101
- "@zag-js/radio-group": "0.31.1",
102
- "@zag-js/rating-group": "0.31.1",
103
- "@zag-js/select": "0.31.1",
104
- "@zag-js/slider": "0.31.1",
105
- "@zag-js/solid": "0.31.1",
106
- "@zag-js/splitter": "0.31.1",
107
- "@zag-js/switch": "0.31.1",
108
- "@zag-js/tabs": "0.31.1",
109
- "@zag-js/tags-input": "0.31.1",
110
- "@zag-js/toast": "0.31.1",
111
- "@zag-js/toggle-group": "0.31.1",
112
- "@zag-js/tooltip": "0.31.1",
113
- "@zag-js/types": "0.31.1"
85
+ "@ark-ui/anatomy": "2.1.0",
86
+ "@zag-js/accordion": "0.34.0",
87
+ "@zag-js/avatar": "0.34.0",
88
+ "@zag-js/carousel": "0.34.0",
89
+ "@zag-js/checkbox": "0.34.0",
90
+ "@zag-js/color-picker": "0.34.0",
91
+ "@zag-js/combobox": "0.34.0",
92
+ "@zag-js/date-picker": "0.34.0",
93
+ "@zag-js/dialog": "0.34.0",
94
+ "@zag-js/editable": "0.34.0",
95
+ "@zag-js/file-upload": "0.34.0",
96
+ "@zag-js/hover-card": "0.34.0",
97
+ "@zag-js/menu": "0.34.0",
98
+ "@zag-js/number-input": "0.34.0",
99
+ "@zag-js/pagination": "0.34.0",
100
+ "@zag-js/pin-input": "0.34.0",
101
+ "@zag-js/popover": "0.34.0",
102
+ "@zag-js/presence": "0.34.0",
103
+ "@zag-js/progress": "0.34.0",
104
+ "@zag-js/radio-group": "0.34.0",
105
+ "@zag-js/rating-group": "0.34.0",
106
+ "@zag-js/select": "0.34.0",
107
+ "@zag-js/slider": "0.34.0",
108
+ "@zag-js/solid": "0.34.0",
109
+ "@zag-js/splitter": "0.34.0",
110
+ "@zag-js/switch": "0.34.0",
111
+ "@zag-js/tabs": "0.34.0",
112
+ "@zag-js/tags-input": "0.34.0",
113
+ "@zag-js/toast": "0.34.0",
114
+ "@zag-js/toggle-group": "0.34.0",
115
+ "@zag-js/tooltip": "0.34.0",
116
+ "@zag-js/tree-view": "0.34.0",
117
+ "@zag-js/types": "0.34.0"
114
118
  },
115
119
  "devDependencies": {
116
120
  "@release-it/keep-a-changelog": "5.0.0",
117
- "@solidjs/testing-library": "0.8.4",
118
- "@storybook/addon-essentials": "7.6.4",
119
- "@storybook/addon-interactions": "7.6.4",
120
- "@storybook/addon-links": "7.6.4",
121
- "@storybook/blocks": "7.6.4",
121
+ "@solidjs/testing-library": "0.8.5",
122
+ "@storybook/addon-essentials": "7.6.10",
123
+ "@storybook/addon-interactions": "7.6.10",
124
+ "@storybook/addon-links": "7.6.10",
125
+ "@storybook/blocks": "7.6.10",
122
126
  "@storybook/testing-library": "0.2.2",
123
- "@testing-library/dom": "9.3.3",
124
- "@testing-library/jest-dom": "6.1.5",
125
- "@testing-library/user-event": "14.5.1",
127
+ "@testing-library/dom": "9.3.4",
128
+ "@testing-library/jest-dom": "6.3.0",
129
+ "@testing-library/user-event": "14.5.2",
126
130
  "@types/jsdom": "21.1.6",
127
131
  "@types/testing-library__jest-dom": "5.14.9",
128
- "@typescript-eslint/eslint-plugin": "6.14.0",
129
- "@typescript-eslint/parser": "6.14.0",
130
- "@vitest/coverage-v8": "0.34.6",
131
- "eslint": "8.55.0",
132
+ "@typescript-eslint/eslint-plugin": "6.20.0",
133
+ "@typescript-eslint/parser": "6.20.0",
134
+ "@vitest/coverage-v8": "1.2.2",
135
+ "eslint": "8.56.0",
132
136
  "eslint-plugin-jest-dom": "5.1.0",
133
137
  "eslint-plugin-testing-library": "6.2.0",
134
138
  "globby": "14.0.0",
135
- "jsdom": "23.0.1",
136
- "lucide-solid": "0.294.0",
139
+ "jsdom": "24.0.0",
137
140
  "react": "18.2.0",
138
141
  "react-dom": "18.2.0",
139
- "release-it": "17.0.1",
142
+ "release-it": "17.0.3",
140
143
  "resize-observer-polyfill": "1.5.1",
141
- "rollup": "4.9.0",
144
+ "rollup": "4.9.6",
142
145
  "rollup-preset-solid": "2.0.1",
143
- "solid-js": "1.8.7",
144
- "storybook": "7.6.4",
146
+ "solid-js": "1.8.12",
147
+ "storybook": "7.6.10",
145
148
  "storybook-solidjs": "1.0.0-beta.2",
146
149
  "storybook-solidjs-vite": "1.0.0-beta.2",
147
150
  "typescript": "5.3.3",
148
- "vite": "5.0.8",
149
- "vite-plugin-solid": "2.8.0",
150
- "vitest": "0.34.2"
151
+ "vite": "5.0.12",
152
+ "vite-plugin-solid": "2.9.1",
153
+ "vitest": "1.2.2"
151
154
  },
152
155
  "peerDependencies": {
153
156
  "solid-js": ">=1.6.0"
@@ -8,6 +8,5 @@ export const AccordionItemTrigger = (props) => {
8
8
  const item = useAccordionItemContext();
9
9
  const presenceApi = usePresenceContext();
10
10
  const mergedProps = mergeProps(() => api().getItemTriggerProps(item), () => ({ 'aria-controls': presenceApi().isUnmounted && null }), props);
11
- // @ts-expect-error we want aria-controls to be null to remove them if the popover if lazy mounted
12
11
  return <ark.button {...mergedProps}/>;
13
12
  };
@@ -4,7 +4,7 @@ import { ark } from '../factory';
4
4
  import { PresencePropsProvider, splitPresenceProps } from '../presence';
5
5
  import { AccordionProvider } from './accordion-context';
6
6
  import { useAccordion } from './use-accordion';
7
- export const Accordion = (props) => {
7
+ export const AccordionRoot = (props) => {
8
8
  const [presenceProps, accordionProps] = splitPresenceProps(props);
9
9
  const [useAccordionProps, localProps] = createSplitProps()(accordionProps, [
10
10
  'collapsible',
@@ -1,15 +1,15 @@
1
- import { Accordion as AccordionRoot } from './accordion';
2
1
  import { useAccordionContext } from './accordion-context';
3
2
  import { AccordionItem } from './accordion-item';
4
3
  import { AccordionItemContent } from './accordion-item-content';
5
4
  import { useAccordionItemContext } from './accordion-item-context';
6
5
  import { AccordionItemIndicator, } from './accordion-item-indicator';
7
6
  import { AccordionItemTrigger } from './accordion-item-trigger';
8
- const Accordion = Object.assign(AccordionRoot, {
7
+ import { AccordionRoot } from './accordion-root';
8
+ export const Accordion = {
9
9
  Root: AccordionRoot,
10
10
  Item: AccordionItem,
11
11
  ItemContent: AccordionItemContent,
12
12
  ItemIndicator: AccordionItemIndicator,
13
13
  ItemTrigger: AccordionItemTrigger,
14
- });
15
- export { Accordion, AccordionItem, AccordionItemContent, AccordionItemIndicator, AccordionItemTrigger, useAccordionContext, useAccordionItemContext, };
14
+ };
15
+ export { AccordionItem, AccordionItemContent, AccordionItemIndicator, AccordionItemTrigger, AccordionRoot, useAccordionContext, useAccordionItemContext, };
@@ -3,7 +3,7 @@ import { createSplitProps } from '../create-split-props';
3
3
  import { ark } from '../factory';
4
4
  import { AvatarProvider } from './avatar-context';
5
5
  import { useAvatar } from './use-avatar';
6
- export const Avatar = (props) => {
6
+ export const AvatarRoot = (props) => {
7
7
  const [params, localProps] = createSplitProps()(props, [
8
8
  'dir',
9
9
  'getRootNode',
@@ -1,10 +1,10 @@
1
- import { Avatar as AvatarRoot } from './avatar';
2
1
  import { useAvatarContext } from './avatar-context';
3
2
  import { AvatarFallback } from './avatar-fallback';
4
3
  import { AvatarImage } from './avatar-image';
5
- const Avatar = Object.assign(AvatarRoot, {
4
+ import { AvatarRoot } from './avatar-root';
5
+ export const Avatar = {
6
6
  Root: AvatarRoot,
7
7
  Fallback: AvatarFallback,
8
8
  Image: AvatarImage,
9
- });
10
- export { Avatar, AvatarFallback, AvatarImage, useAvatarContext };
9
+ };
10
+ export { AvatarFallback, AvatarImage, AvatarRoot, useAvatarContext };
@@ -4,7 +4,7 @@ import { ark } from '../factory';
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { CarouselProvider } from './carousel-context';
6
6
  import { useCarousel } from './use-carousel';
7
- export const Carousel = (props) => {
7
+ export const CarouselRoot = (props) => {
8
8
  const [useCarouselProps, localProps] = createSplitProps()(props, [
9
9
  'align',
10
10
  'dir',
@@ -1,14 +1,14 @@
1
- import { Carousel as CarouselRoot } from './carousel';
2
1
  import { useCarouselContext } from './carousel-context';
3
2
  import { CarouselControl } from './carousel-control';
4
3
  import { CarouselIndicator } from './carousel-indicator';
5
4
  import { CarouselIndicatorGroup, } from './carousel-indicator-group';
5
+ import { CarouselItem } from './carousel-item';
6
+ import { CarouselItemGroup } from './carousel-item-group';
6
7
  import { CarouselNextTrigger } from './carousel-next-trigger';
7
8
  import { CarouselPrevTrigger } from './carousel-prev-trigger';
8
- import { CarouselItem } from './carousel-slide';
9
- import { CarouselItemGroup } from './carousel-slide-group';
9
+ import { CarouselRoot } from './carousel-root';
10
10
  import { CarouselViewport } from './carousel-viewport';
11
- const Carousel = Object.assign(CarouselRoot, {
11
+ export const Carousel = {
12
12
  Root: CarouselRoot,
13
13
  Control: CarouselControl,
14
14
  Indicator: CarouselIndicator,
@@ -18,5 +18,5 @@ const Carousel = Object.assign(CarouselRoot, {
18
18
  Item: CarouselItem,
19
19
  ItemGroup: CarouselItemGroup,
20
20
  Viewport: CarouselViewport,
21
- });
22
- export { Carousel, CarouselControl, CarouselIndicator, CarouselIndicatorGroup, CarouselItem, CarouselItemGroup, CarouselNextTrigger, CarouselPrevTrigger, CarouselViewport, useCarouselContext, };
21
+ };
22
+ export { CarouselControl, CarouselIndicator, CarouselIndicatorGroup, CarouselItem, CarouselItemGroup, CarouselNextTrigger, CarouselPrevTrigger, CarouselRoot, CarouselViewport, useCarouselContext, };
@@ -4,7 +4,7 @@ import { ark } from '../factory';
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { CheckboxProvider } from './checkbox-context';
6
6
  import { useCheckbox } from './use-checkbox';
7
- export const Checkbox = (props) => {
7
+ export const CheckboxRoot = (props) => {
8
8
  const [useCheckboxProps, labelprops] = createSplitProps()(props, [
9
9
  'checked',
10
10
  'dir',
@@ -1,12 +1,12 @@
1
- import { Checkbox as CheckboxRoot } from './checkbox';
2
1
  import { useCheckboxContext } from './checkbox-context';
3
2
  import { CheckboxControl } from './checkbox-control';
4
3
  import { CheckboxIndicator } from './checkbox-indicator';
5
4
  import { CheckboxLabel } from './checkbox-label';
6
- const Checkbox = Object.assign(CheckboxRoot, {
5
+ import { CheckboxRoot } from './checkbox-root';
6
+ export const Checkbox = {
7
7
  Root: CheckboxRoot,
8
8
  Control: CheckboxControl,
9
9
  Label: CheckboxLabel,
10
10
  Indicator: CheckboxIndicator,
11
- });
12
- export { Checkbox, CheckboxControl, CheckboxIndicator, CheckboxLabel, useCheckboxContext };
11
+ };
12
+ export { CheckboxControl, CheckboxIndicator, CheckboxLabel, CheckboxRoot, useCheckboxContext };
@@ -5,7 +5,7 @@ import { PresenceProvider, splitPresenceProps, usePresence, } from '../presence'
5
5
  import { runIfFn } from '../run-if-fn';
6
6
  import { ColorPickerProvider } from './color-picker-context';
7
7
  import { useColorPicker, } from './use-color-picker';
8
- export const ColorPicker = (props) => {
8
+ export const ColorPickerRoot = (props) => {
9
9
  const [presenceProps, colorPickerProps] = splitPresenceProps(props);
10
10
  const [useColorPickerProps, localProps] = createSplitProps()(colorPickerProps, [
11
11
  'closeOnSelect',
@@ -1,4 +1,3 @@
1
- import { ColorPicker as ColorPickerRoot } from './color-picker';
2
1
  import { ColorPickerArea } from './color-picker-area';
3
2
  import { ColorPickerAreaBackground, } from './color-picker-area-background';
4
3
  import { useColorPickerAreaContext } from './color-picker-area-context';
@@ -16,6 +15,7 @@ import { ColorPickerFormatSelect, } from './color-picker-format-select';
16
15
  import { ColorPickerFormatTrigger, } from './color-picker-format-trigger';
17
16
  import { ColorPickerLabel } from './color-picker-label';
18
17
  import { ColorPickerPositioner } from './color-picker-positioner';
18
+ import { ColorPickerRoot } from './color-picker-root';
19
19
  import { ColorPickerSwatch } from './color-picker-swatch';
20
20
  import { ColorPickerSwatchGroup, } from './color-picker-swatch-group';
21
21
  import { ColorPickerSwatchIndicator, } from './color-picker-swatch-indicator';
@@ -24,7 +24,7 @@ import { ColorPickerTransparencyGrid, } from './color-picker-transparency-grid';
24
24
  import { ColorPickerTrigger } from './color-picker-trigger';
25
25
  import { ColorPickerValueText } from './color-picker-value-text';
26
26
  import { ColorPickerView } from './color-picker-view';
27
- const ColorPicker = Object.assign(ColorPickerRoot, {
27
+ export const ColorPicker = {
28
28
  Root: ColorPickerRoot,
29
29
  Area: ColorPickerArea,
30
30
  AreaBackground: ColorPickerAreaBackground,
@@ -48,5 +48,5 @@ const ColorPicker = Object.assign(ColorPickerRoot, {
48
48
  Trigger: ColorPickerTrigger,
49
49
  ValueText: ColorPickerValueText,
50
50
  View: ColorPickerView,
51
- });
52
- export { ColorPicker, ColorPickerArea, ColorPickerAreaBackground, ColorPickerAreaThumb, ColorPickerChannelInput, ColorPickerChannelSlider, ColorPickerChannelSliderThumb, ColorPickerChannelSliderTrack, ColorPickerContent, ColorPickerControl, ColorPickerEyeDropperTrigger, ColorPickerFormatSelect, ColorPickerFormatTrigger, ColorPickerLabel, ColorPickerPositioner, ColorPickerSwatch, ColorPickerSwatchGroup, ColorPickerSwatchIndicator, ColorPickerSwatchTrigger, ColorPickerTransparencyGrid, ColorPickerTrigger, ColorPickerValueText, ColorPickerView, useColorPickerAreaContext, useColorPickerChannelSliderContext, useColorPickerContext, };
51
+ };
52
+ export { ColorPickerArea, ColorPickerAreaBackground, ColorPickerAreaThumb, ColorPickerChannelInput, ColorPickerChannelSlider, ColorPickerChannelSliderThumb, ColorPickerChannelSliderTrack, ColorPickerContent, ColorPickerControl, ColorPickerEyeDropperTrigger, ColorPickerFormatSelect, ColorPickerFormatTrigger, ColorPickerLabel, ColorPickerPositioner, ColorPickerRoot, ColorPickerSwatch, ColorPickerSwatchGroup, ColorPickerSwatchIndicator, ColorPickerSwatchTrigger, ColorPickerTransparencyGrid, ColorPickerTrigger, ColorPickerValueText, ColorPickerView, useColorPickerAreaContext, useColorPickerChannelSliderContext, useColorPickerContext, };
@@ -5,7 +5,7 @@ import { PresenceProvider, splitPresenceProps, usePresence, } from '../presence'
5
5
  import { runIfFn } from '../run-if-fn';
6
6
  import { ComboboxProvider } from './combobox-context';
7
7
  import { useCombobox } from './use-combobox';
8
- export const Combobox = (props) => {
8
+ export const ComboboxRoot = (props) => {
9
9
  const [presenceProps, comboboxProps] = splitPresenceProps(props);
10
10
  const [useComboboxProps, localProps] = createSplitProps()(comboboxProps, [
11
11
  'allowCustomValue',
@@ -1,4 +1,3 @@
1
- import { Combobox as ComboboxRoot } from './combobox';
2
1
  import { ComboboxClearTrigger } from './combobox-clear-trigger';
3
2
  import { ComboboxContent } from './combobox-content';
4
3
  import { useComboboxContext } from './combobox-context';
@@ -11,8 +10,9 @@ import { ComboboxItemIndicator } from './combobox-item-indicator';
11
10
  import { ComboboxItemText } from './combobox-item-text';
12
11
  import { ComboboxLabel } from './combobox-label';
13
12
  import { ComboboxPositioner } from './combobox-positioner';
13
+ import { ComboboxRoot } from './combobox-root';
14
14
  import { ComboboxTrigger } from './combobox-trigger';
15
- const Combobox = Object.assign(ComboboxRoot, {
15
+ export const Combobox = {
16
16
  Root: ComboboxRoot,
17
17
  ClearTrigger: ComboboxClearTrigger,
18
18
  Content: ComboboxContent,
@@ -26,5 +26,5 @@ const Combobox = Object.assign(ComboboxRoot, {
26
26
  Label: ComboboxLabel,
27
27
  Positioner: ComboboxPositioner,
28
28
  Trigger: ComboboxTrigger,
29
- });
30
- export { Combobox, ComboboxClearTrigger, ComboboxContent, ComboboxControl, ComboboxInput, ComboboxItem, ComboboxItemGroup, ComboboxItemGroupLabel, ComboboxItemIndicator, ComboboxItemText, ComboboxLabel, ComboboxPositioner, ComboboxTrigger, useComboboxContext, };
29
+ };
30
+ export { ComboboxClearTrigger, ComboboxContent, ComboboxControl, ComboboxInput, ComboboxItem, ComboboxItemGroup, ComboboxItemGroupLabel, ComboboxItemIndicator, ComboboxItemText, ComboboxLabel, ComboboxPositioner, ComboboxRoot, ComboboxTrigger, useComboboxContext, };
@@ -10,10 +10,10 @@ export const useCombobox = (props) => {
10
10
  'itemToString',
11
11
  'items',
12
12
  ]);
13
- const collection = combobox.collection(collectionOptions);
13
+ const collection = () => combobox.collection(collectionOptions);
14
14
  const getRootNode = useEnvironmentContext();
15
- const context = mergeProps({ id: createUniqueId(), getRootNode, collection }, rest);
16
- const [state, send] = useMachine(combobox.machine(context), {
15
+ const context = () => mergeProps({ id: createUniqueId(), getRootNode, collection: collection() }, rest);
16
+ const [state, send] = useMachine(combobox.machine(context()), {
17
17
  context,
18
18
  });
19
19
  return createMemo(() => combobox.connect(state, send, normalizeProps));
@@ -5,7 +5,7 @@ import { PresenceProvider, splitPresenceProps, usePresence, } from '../presence'
5
5
  import { runIfFn } from '../run-if-fn';
6
6
  import { DatePickerProvider } from './date-picker-context';
7
7
  import { useDatePicker } from './use-date-picker';
8
- export const DatePicker = (props) => {
8
+ export const DatePickerRoot = (props) => {
9
9
  const [presenceProps, datePickerProps] = splitPresenceProps(props);
10
10
  const [useDatePickerProps, localProps] = createSplitProps()(datePickerProps, [
11
11
  'closeOnSelect',
@@ -1,4 +1,3 @@
1
- import { DatePicker as DatePickerRoot } from './date-picker';
2
1
  import { DatePickerClearTrigger, } from './date-picker-clear-trigger';
3
2
  import { DatePickerContent } from './date-picker-content';
4
3
  import { useDatePickerContext } from './date-picker-context';
@@ -10,6 +9,7 @@ import { DatePickerNextTrigger } from './date-picker-next-trigger';
10
9
  import { DatePickerPositioner } from './date-picker-positioner';
11
10
  import { DatePickerPrevTrigger } from './date-picker-prev-trigger';
12
11
  import { DatePickerRangeText } from './date-picker-range-text';
12
+ import { DatePickerRoot } from './date-picker-root';
13
13
  import { DatePickerTable } from './date-picker-table';
14
14
  import { DatePickerTableBody } from './date-picker-table-body';
15
15
  import { DatePickerTableCell } from './date-picker-table-cell';
@@ -25,7 +25,7 @@ import { useDatePickerViewContext } from './date-picker-view-context';
25
25
  import { DatePickerViewControl } from './date-picker-view-control';
26
26
  import { DatePickerViewTrigger } from './date-picker-view-trigger';
27
27
  import { DatePickerYearSelect } from './date-picker-year-select';
28
- const DatePicker = Object.assign(DatePickerRoot, {
28
+ export const DatePicker = {
29
29
  Root: DatePickerRoot,
30
30
  ClearTrigger: DatePickerClearTrigger,
31
31
  Content: DatePickerContent,
@@ -49,5 +49,5 @@ const DatePicker = Object.assign(DatePickerRoot, {
49
49
  ViewControl: DatePickerViewControl,
50
50
  ViewTrigger: DatePickerViewTrigger,
51
51
  YearSelect: DatePickerYearSelect,
52
- });
53
- export { DatePicker, DatePickerClearTrigger, DatePickerContent, DatePickerControl, DatePickerInput, DatePickerLabel, DatePickerMonthSelect, DatePickerNextTrigger, DatePickerPositioner, DatePickerPrevTrigger, DatePickerRangeText, DatePickerTable, DatePickerTableBody, DatePickerTableCell, DatePickerTableCellTrigger, DatePickerTableHead, DatePickerTableHeader, DatePickerTableRow, DatePickerTrigger, DatePickerView, DatePickerViewControl, DatePickerViewTrigger, DatePickerYearSelect, useDatePickerContext, useDatePickerTableCellContext, useDatePickerTableContext, useDatePickerViewContext, };
52
+ };
53
+ export { DatePickerClearTrigger, DatePickerContent, DatePickerControl, DatePickerInput, DatePickerLabel, DatePickerMonthSelect, DatePickerNextTrigger, DatePickerPositioner, DatePickerPrevTrigger, DatePickerRangeText, DatePickerRoot, DatePickerTable, DatePickerTableBody, DatePickerTableCell, DatePickerTableCellTrigger, DatePickerTableHead, DatePickerTableHeader, DatePickerTableRow, DatePickerTrigger, DatePickerView, DatePickerViewControl, DatePickerViewTrigger, DatePickerYearSelect, useDatePickerContext, useDatePickerTableCellContext, useDatePickerTableContext, useDatePickerViewContext, };
@@ -4,7 +4,7 @@ import { PresencePropsProvider, PresenceProvider, splitPresenceProps, usePresenc
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { DialogProvider } from './dialog-context';
6
6
  import { useDialog } from './use-dialog';
7
- export const Dialog = (props) => {
7
+ export const DialogRoot = (props) => {
8
8
  const [presenceProps, dialogProps] = splitPresenceProps(props);
9
9
  const [useDialogProps, localProps] = createSplitProps()(dialogProps, [
10
10
  'aria-label',
@@ -6,6 +6,5 @@ export const DialogTrigger = (props) => {
6
6
  const api = useDialogContext();
7
7
  const presenceApi = usePresenceContext();
8
8
  const mergedProps = mergeProps(() => api().triggerProps, () => ({ 'aria-controls': presenceApi().isUnmounted && null }), props);
9
- // @ts-expect-error we want aria-controls to be null to remove them if the popover if lazy mounted
10
9
  return <ark.button {...mergedProps}/>;
11
10
  };
@@ -1,20 +1,20 @@
1
- import { Dialog as DialogRoot } from './dialog';
2
1
  import { DialogBackdrop } from './dialog-backdrop';
3
2
  import { DialogCloseTrigger } from './dialog-close-trigger';
4
3
  import { DialogContent } from './dialog-content';
5
4
  import { useDialogContext } from './dialog-context';
6
5
  import { DialogDescription } from './dialog-description';
7
6
  import { DialogPositioner } from './dialog-positioner';
7
+ import { DialogRoot } from './dialog-root';
8
8
  import { DialogTitle } from './dialog-title';
9
9
  import { DialogTrigger } from './dialog-trigger';
10
- const Dialog = Object.assign(DialogRoot, {
10
+ export const Dialog = {
11
11
  Root: DialogRoot,
12
12
  Backdrop: DialogBackdrop,
13
13
  CloseTrigger: DialogCloseTrigger,
14
- Positioner: DialogPositioner,
15
14
  Content: DialogContent,
16
15
  Description: DialogDescription,
16
+ Positioner: DialogPositioner,
17
17
  Title: DialogTitle,
18
18
  Trigger: DialogTrigger,
19
- });
20
- export { Dialog, DialogBackdrop, DialogCloseTrigger, DialogContent, DialogDescription, DialogPositioner, DialogTitle, DialogTrigger, useDialogContext, };
19
+ };
20
+ export { DialogBackdrop, DialogCloseTrigger, DialogContent, DialogDescription, DialogPositioner, DialogRoot, DialogTitle, DialogTrigger, useDialogContext, };
@@ -4,7 +4,7 @@ import { ark } from '../factory';
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { EditableProvider } from './editable-context';
6
6
  import { useEditable } from './use-editable';
7
- export const Editable = (props) => {
7
+ export const EditableRoot = (props) => {
8
8
  const [useEditableProps, localProps] = createSplitProps()(props, [
9
9
  'activationMode',
10
10
  'autoResize',
@@ -1,4 +1,3 @@
1
- import { Editable as EditableRoot } from './editable';
2
1
  import { EditableArea } from './editable-area';
3
2
  import { EditableCancelTrigger } from './editable-cancel-trigger';
4
3
  import { useEditableContext } from './editable-context';
@@ -7,8 +6,9 @@ import { EditableEditTrigger } from './editable-edit-trigger';
7
6
  import { EditableInput } from './editable-input';
8
7
  import { EditableLabel } from './editable-label';
9
8
  import { EditablePreview } from './editable-preview';
9
+ import { EditableRoot } from './editable-root';
10
10
  import { EditableSubmitTrigger } from './editable-submit-trigger';
11
- const Editable = Object.assign(EditableRoot, {
11
+ export const Editable = {
12
12
  Root: EditableRoot,
13
13
  Area: EditableArea,
14
14
  CancelTrigger: EditableCancelTrigger,
@@ -18,5 +18,5 @@ const Editable = Object.assign(EditableRoot, {
18
18
  Label: EditableLabel,
19
19
  Preview: EditablePreview,
20
20
  SubmitTrigger: EditableSubmitTrigger,
21
- });
22
- export { Editable, EditableArea, EditableCancelTrigger, EditableControl, EditableEditTrigger, EditableInput, EditableLabel, EditablePreview, EditableSubmitTrigger, useEditableContext, };
21
+ };
22
+ export { EditableArea, EditableCancelTrigger, EditableControl, EditableEditTrigger, EditableInput, EditableLabel, EditablePreview, EditableRoot, EditableSubmitTrigger, useEditableContext, };
@@ -1,6 +1,3 @@
1
- import { Environment as EnvironmentRoot } from './environment';
1
+ import { Environment } from './environment';
2
2
  import { useEnvironmentContext } from './environment-context';
3
- const Environment = Object.assign(EnvironmentRoot, {
4
- Root: EnvironmentRoot,
5
- });
6
3
  export { Environment, useEnvironmentContext };
@@ -1,35 +1,22 @@
1
- import { children, createEffect, splitProps, } from 'solid-js';
1
+ import { splitProps } from 'solid-js';
2
2
  import { Dynamic } from 'solid-js/web';
3
- import { spread } from './spread';
4
- import { ssrSpread } from './ssr-spread';
5
- function withAsChild(Component) {
6
- return function jsx(props) {
7
- const [localProps, restProps] = splitProps(props, ['asChild', 'children']);
8
- if (!localProps.asChild) {
9
- return (<Dynamic component={Component} {...restProps}>
10
- {localProps.children}
11
- </Dynamic>);
12
- }
13
- const getChildren = children(() => ssrSpread(localProps.children, restProps));
14
- createEffect(() => {
15
- const children = getChildren();
16
- if (children instanceof HTMLElement) {
17
- spread(children, restProps);
18
- }
19
- });
20
- return getChildren;
3
+ export const withAsProp = (Component) => {
4
+ const ArkComponent = (props) => {
5
+ const [localProps, otherProps] = splitProps(props, ['as']);
6
+ return <Dynamic component={localProps.as || Component} {...otherProps}/>;
21
7
  };
22
- }
8
+ return ArkComponent;
9
+ };
23
10
  function jsxFactory() {
24
11
  const cache = new Map();
25
- return new Proxy(withAsChild, {
12
+ return new Proxy(withAsProp, {
26
13
  apply(target, thisArg, argArray) {
27
- return withAsChild(argArray[0]);
14
+ return withAsProp(argArray[0]);
28
15
  },
29
16
  get(_, element) {
30
17
  const asElement = element;
31
18
  if (!cache.has(asElement)) {
32
- cache.set(asElement, withAsChild(asElement));
19
+ cache.set(asElement, withAsProp(asElement));
33
20
  }
34
21
  return cache.get(asElement);
35
22
  },
@@ -4,7 +4,7 @@ import { ark } from '../factory';
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { FileUploadProvider } from './file-upload-context';
6
6
  import { useFileUpload } from './use-file-upload';
7
- export const FileUpload = (props) => {
7
+ export const FileUploadRoot = (props) => {
8
8
  const [fileUploadProps, localProps] = createSplitProps()(props, [
9
9
  'accept',
10
10
  'allowDrop',
@@ -1,4 +1,3 @@
1
- import { FileUpload as FileUploadRoot } from './file-upload';
2
1
  import { useFileUploadContext } from './file-upload-context';
3
2
  import { FileUploadDropzone } from './file-upload-dropzone';
4
3
  import { FileUploadItem } from './file-upload-item';
@@ -9,8 +8,9 @@ import { FileUploadItemPreview } from './file-upload-item-preview';
9
8
  import { FileUploadItemPreviewImage, } from './file-upload-item-preview-image';
10
9
  import { FileUploadItemSizeText, } from './file-upload-item-size-text';
11
10
  import { FileUploadLabel } from './file-upload-label';
11
+ import { FileUploadRoot } from './file-upload-root';
12
12
  import { FileUploadTrigger } from './file-upload-trigger';
13
- const FileUpload = Object.assign(FileUploadRoot, {
13
+ export const FileUpload = {
14
14
  Root: FileUploadRoot,
15
15
  Dropzone: FileUploadDropzone,
16
16
  Item: FileUploadItem,
@@ -22,5 +22,5 @@ const FileUpload = Object.assign(FileUploadRoot, {
22
22
  ItemSizeText: FileUploadItemSizeText,
23
23
  Label: FileUploadLabel,
24
24
  Trigger: FileUploadTrigger,
25
- });
26
- export { FileUpload, FileUploadDropzone, FileUploadItem, FileUploadItemDeleteTrigger, FileUploadItemGroup, FileUploadItemName, FileUploadItemPreviewImage, FileUploadItemSizeText, FileUploadLabel, FileUploadTrigger, useFileUploadContext, };
25
+ };
26
+ export { FileUploadDropzone, FileUploadItem, FileUploadItemDeleteTrigger, FileUploadItemGroup, FileUploadItemName, FileUploadItemPreviewImage, FileUploadItemSizeText, FileUploadLabel, FileUploadRoot, FileUploadTrigger, useFileUploadContext, };
@@ -4,7 +4,7 @@ import { PresenceProvider, splitPresenceProps, usePresence, } from '../presence'
4
4
  import { runIfFn } from '../run-if-fn';
5
5
  import { HoverCardProvider } from './hover-card-context';
6
6
  import { useHoverCard } from './use-hover-card';
7
- export const HoverCard = (props) => {
7
+ export const HoverCardRoot = (props) => {
8
8
  const [presenceProps, hoverCardProps] = splitPresenceProps(props);
9
9
  const [useHoverCardProps, localProps] = createSplitProps()(hoverCardProps, [
10
10
  'closeDelay',
@@ -1,16 +1,16 @@
1
- import { HoverCard as HoverCardRoot } from './hover-card';
2
1
  import { HoverCardArrow } from './hover-card-arrow';
3
2
  import { HoverCardArrowTip } from './hover-card-arrow-tip';
4
3
  import { HoverCardContent } from './hover-card-content';
5
4
  import { useHoverCardContext } from './hover-card-context';
6
5
  import { HoverCardPositioner } from './hover-card-positioner';
6
+ import { HoverCardRoot } from './hover-card-root';
7
7
  import { HoverCardTrigger } from './hover-card-trigger';
8
- const HoverCard = Object.assign(HoverCardRoot, {
8
+ export const HoverCard = {
9
9
  Root: HoverCardRoot,
10
10
  Arrow: HoverCardArrow,
11
11
  ArrowTip: HoverCardArrowTip,
12
12
  Content: HoverCardContent,
13
13
  Positioner: HoverCardPositioner,
14
14
  Trigger: HoverCardTrigger,
15
- });
16
- export { HoverCard, HoverCardArrow, HoverCardArrowTip, HoverCardContent, HoverCardPositioner, HoverCardTrigger, useHoverCardContext, };
15
+ };
16
+ export { HoverCardArrow, HoverCardArrowTip, HoverCardContent, HoverCardPositioner, HoverCardRoot, HoverCardTrigger, useHoverCardContext, };