ui-ingredients 0.0.36 → 0.0.38

Sign up to get free protection for your applications and to get access to all the features.
Files changed (536) hide show
  1. package/README.md +11 -0
  2. package/dist/accordion/context.svelte.d.ts +2 -3
  3. package/dist/accordion/context.svelte.js +3 -3
  4. package/dist/accordion/create-accordion.svelte.js +5 -3
  5. package/dist/accordion/index.d.ts +1 -0
  6. package/dist/accordion/index.js +1 -0
  7. package/dist/accordion/item-content.svelte +4 -4
  8. package/dist/accordion/item-indicator.svelte +4 -4
  9. package/dist/accordion/item-trigger.svelte +4 -4
  10. package/dist/accordion/item.svelte +4 -4
  11. package/dist/accordion/root.svelte +2 -2
  12. package/dist/avatar/context.svelte.d.ts +1 -2
  13. package/dist/avatar/context.svelte.js +2 -2
  14. package/dist/avatar/create-avatar.svelte.js +5 -3
  15. package/dist/avatar/fallback.svelte +2 -2
  16. package/dist/avatar/image.svelte +2 -2
  17. package/dist/avatar/index.d.ts +1 -0
  18. package/dist/avatar/index.js +1 -0
  19. package/dist/avatar/root.svelte +2 -2
  20. package/dist/carousel/context.svelte.d.ts +1 -2
  21. package/dist/carousel/context.svelte.js +2 -2
  22. package/dist/carousel/create-carousel.svelte.js +5 -3
  23. package/dist/carousel/index.d.ts +1 -0
  24. package/dist/carousel/index.js +1 -0
  25. package/dist/carousel/indicator-group.svelte +2 -2
  26. package/dist/carousel/indicator.svelte +2 -2
  27. package/dist/carousel/item-group.svelte +2 -2
  28. package/dist/carousel/item.svelte +2 -2
  29. package/dist/carousel/next-trigger.svelte +2 -2
  30. package/dist/carousel/prev-trigger.svelte +2 -2
  31. package/dist/carousel/root.svelte +2 -2
  32. package/dist/carousel/viewport.svelte +2 -2
  33. package/dist/checkbox/context.svelte.d.ts +1 -2
  34. package/dist/checkbox/context.svelte.js +2 -2
  35. package/dist/checkbox/control.svelte +2 -2
  36. package/dist/checkbox/create-checkbox.svelte.js +16 -3
  37. package/dist/checkbox/hidden-input.svelte +3 -5
  38. package/dist/checkbox/index.d.ts +1 -0
  39. package/dist/checkbox/index.js +1 -0
  40. package/dist/checkbox/indicator.svelte +2 -2
  41. package/dist/checkbox/label.svelte +2 -2
  42. package/dist/checkbox/root.svelte +2 -2
  43. package/dist/clipboard/context.svelte.d.ts +1 -2
  44. package/dist/clipboard/context.svelte.js +2 -2
  45. package/dist/clipboard/control.svelte +2 -2
  46. package/dist/clipboard/create-clipboard.svelte.js +5 -3
  47. package/dist/clipboard/index.d.ts +1 -0
  48. package/dist/clipboard/index.js +1 -0
  49. package/dist/clipboard/indicator.svelte +2 -2
  50. package/dist/clipboard/input.svelte +2 -2
  51. package/dist/clipboard/label.svelte +2 -2
  52. package/dist/clipboard/root.svelte +2 -2
  53. package/dist/clipboard/trigger.svelte +2 -2
  54. package/dist/collapsible/content.svelte +2 -2
  55. package/dist/collapsible/context.svelte.d.ts +1 -2
  56. package/dist/collapsible/context.svelte.js +2 -2
  57. package/dist/collapsible/create-collapsible.svelte.js +5 -3
  58. package/dist/collapsible/index.d.ts +1 -0
  59. package/dist/collapsible/index.js +1 -0
  60. package/dist/collapsible/root.svelte +2 -2
  61. package/dist/collapsible/trigger.svelte +2 -2
  62. package/dist/color-picker/area-background.svelte +4 -4
  63. package/dist/color-picker/area-thumb.svelte +4 -4
  64. package/dist/color-picker/area.svelte +4 -4
  65. package/dist/color-picker/channel-input.svelte +2 -2
  66. package/dist/color-picker/channel-slider-label.svelte +4 -4
  67. package/dist/color-picker/channel-slider-thumb.svelte +4 -4
  68. package/dist/color-picker/channel-slider-track.svelte +4 -4
  69. package/dist/color-picker/channel-slider-value-text.svelte +6 -6
  70. package/dist/color-picker/channel-slider.svelte +4 -4
  71. package/dist/color-picker/content.svelte +2 -2
  72. package/dist/color-picker/context.svelte.d.ts +5 -6
  73. package/dist/color-picker/context.svelte.js +6 -6
  74. package/dist/color-picker/control.svelte +2 -2
  75. package/dist/color-picker/create-color-picker.svelte.js +5 -3
  76. package/dist/color-picker/eye-dropper-trigger.svelte +2 -2
  77. package/dist/color-picker/format-select.svelte +2 -2
  78. package/dist/color-picker/format-trigger.svelte +2 -2
  79. package/dist/color-picker/hidden-input.svelte +2 -2
  80. package/dist/color-picker/index.d.ts +1 -0
  81. package/dist/color-picker/index.js +1 -0
  82. package/dist/color-picker/label.svelte +2 -2
  83. package/dist/color-picker/positioner.svelte +2 -2
  84. package/dist/color-picker/root.svelte +34 -49
  85. package/dist/color-picker/swatch-group.svelte +2 -2
  86. package/dist/color-picker/swatch-indicator.svelte +4 -4
  87. package/dist/color-picker/swatch-trigger.svelte +4 -4
  88. package/dist/color-picker/swatch.svelte +4 -4
  89. package/dist/color-picker/transparency-grid.svelte +2 -2
  90. package/dist/color-picker/trigger.svelte +2 -2
  91. package/dist/color-picker/value-text.svelte +2 -2
  92. package/dist/combobox/clear-trigger.svelte +2 -2
  93. package/dist/combobox/content.svelte +2 -2
  94. package/dist/combobox/context.svelte.d.ts +3 -4
  95. package/dist/combobox/context.svelte.js +4 -4
  96. package/dist/combobox/control.svelte +2 -2
  97. package/dist/combobox/create-combobox.svelte.d.ts +3 -5
  98. package/dist/combobox/create-combobox.svelte.js +28 -15
  99. package/dist/combobox/input.svelte +3 -5
  100. package/dist/combobox/item-group-label.svelte +4 -4
  101. package/dist/combobox/item-group.svelte +4 -4
  102. package/dist/combobox/item-indicator.svelte +6 -3
  103. package/dist/combobox/item-text.svelte +6 -3
  104. package/dist/combobox/item.svelte +6 -3
  105. package/dist/combobox/label.svelte +2 -2
  106. package/dist/combobox/list.svelte +2 -2
  107. package/dist/combobox/positioner.svelte +2 -2
  108. package/dist/combobox/root.svelte +2 -2
  109. package/dist/combobox/trigger.svelte +2 -2
  110. package/dist/create-context.svelte.d.ts +5 -0
  111. package/dist/{context.svelte.js → create-context.svelte.js} +8 -13
  112. package/dist/date-picker/clear-trigger.svelte +2 -2
  113. package/dist/date-picker/content.svelte +2 -2
  114. package/dist/date-picker/context.svelte.d.ts +5 -6
  115. package/dist/date-picker/context.svelte.js +6 -6
  116. package/dist/date-picker/control.svelte +2 -2
  117. package/dist/date-picker/create-date-picker.svelte.js +5 -3
  118. package/dist/date-picker/day-table-cell-trigger.svelte +4 -4
  119. package/dist/date-picker/day-table-cell.svelte +4 -4
  120. package/dist/date-picker/index.d.ts +1 -0
  121. package/dist/date-picker/index.js +1 -0
  122. package/dist/date-picker/input.svelte +2 -2
  123. package/dist/date-picker/label.svelte +2 -2
  124. package/dist/date-picker/month-select.svelte +2 -2
  125. package/dist/date-picker/month-table-cell-trigger.svelte +4 -4
  126. package/dist/date-picker/month-table-cell.svelte +4 -4
  127. package/dist/date-picker/next-trigger.svelte +4 -4
  128. package/dist/date-picker/positioner.svelte +2 -2
  129. package/dist/date-picker/preset-trigger.svelte +2 -2
  130. package/dist/date-picker/prev-trigger.svelte +4 -4
  131. package/dist/date-picker/range-text.svelte +2 -2
  132. package/dist/date-picker/root.svelte +2 -2
  133. package/dist/date-picker/table-body.svelte +4 -4
  134. package/dist/date-picker/table-head.svelte +4 -4
  135. package/dist/date-picker/table-header.svelte +4 -4
  136. package/dist/date-picker/table-row.svelte +4 -4
  137. package/dist/date-picker/table.svelte +6 -6
  138. package/dist/date-picker/trigger.svelte +2 -2
  139. package/dist/date-picker/view-control.svelte +4 -4
  140. package/dist/date-picker/view-trigger.svelte +4 -4
  141. package/dist/date-picker/view.svelte +4 -4
  142. package/dist/date-picker/year-select.svelte +2 -2
  143. package/dist/date-picker/year-table-cell-trigger.svelte +4 -4
  144. package/dist/date-picker/year-table-cell.svelte +4 -4
  145. package/dist/dialog/backdrop.svelte +2 -2
  146. package/dist/dialog/close-trigger.svelte +2 -2
  147. package/dist/dialog/content.svelte +2 -2
  148. package/dist/dialog/context.svelte.d.ts +1 -2
  149. package/dist/dialog/context.svelte.js +2 -2
  150. package/dist/dialog/create-dialog.svelte.js +5 -3
  151. package/dist/dialog/description.svelte +2 -2
  152. package/dist/dialog/index.d.ts +1 -0
  153. package/dist/dialog/index.js +1 -0
  154. package/dist/dialog/positioner.svelte +2 -2
  155. package/dist/dialog/root.svelte +2 -2
  156. package/dist/dialog/title.svelte +2 -2
  157. package/dist/dialog/trigger.svelte +2 -2
  158. package/dist/editable/area.svelte +2 -2
  159. package/dist/editable/cancel-trigger.svelte +2 -2
  160. package/dist/editable/context.svelte.d.ts +1 -2
  161. package/dist/editable/context.svelte.js +2 -2
  162. package/dist/editable/control.svelte +2 -2
  163. package/dist/editable/create-editable.svelte.js +16 -3
  164. package/dist/editable/edit-trigger.svelte +2 -2
  165. package/dist/editable/index.d.ts +1 -0
  166. package/dist/editable/index.js +1 -0
  167. package/dist/editable/input.svelte +3 -5
  168. package/dist/editable/label.svelte +2 -2
  169. package/dist/editable/preview.svelte +2 -2
  170. package/dist/editable/root.svelte +2 -2
  171. package/dist/editable/submit-trigger.svelte +2 -2
  172. package/dist/environment-provider/context.svelte.d.ts +1 -3
  173. package/dist/environment-provider/context.svelte.js +2 -3
  174. package/dist/environment-provider/root.svelte +2 -2
  175. package/dist/field/context.svelte.d.ts +1 -3
  176. package/dist/field/context.svelte.js +2 -3
  177. package/dist/field/create-field.svelte.js +1 -0
  178. package/dist/field/error-text.svelte +2 -2
  179. package/dist/field/helper-text.svelte +2 -2
  180. package/dist/field/index.d.ts +3 -2
  181. package/dist/field/index.js +2 -1
  182. package/dist/field/input.svelte +2 -2
  183. package/dist/field/label.svelte +2 -2
  184. package/dist/field/root.svelte +2 -2
  185. package/dist/field/select.svelte +2 -2
  186. package/dist/field/textarea.svelte +2 -2
  187. package/dist/file-upload/context.svelte.d.ts +2 -3
  188. package/dist/file-upload/context.svelte.js +3 -3
  189. package/dist/file-upload/create-file-upload.svelte.js +16 -3
  190. package/dist/file-upload/dropzone.svelte +2 -2
  191. package/dist/file-upload/hidden-input.svelte +3 -5
  192. package/dist/file-upload/index.d.ts +1 -0
  193. package/dist/file-upload/index.js +1 -0
  194. package/dist/file-upload/item-delete-trigger.svelte +4 -4
  195. package/dist/file-upload/item-group.svelte +2 -2
  196. package/dist/file-upload/item-name.svelte +4 -4
  197. package/dist/file-upload/item-preview-image.svelte +4 -4
  198. package/dist/file-upload/item-preview.svelte +4 -4
  199. package/dist/file-upload/item-size-text.svelte +4 -4
  200. package/dist/file-upload/item.svelte +4 -4
  201. package/dist/file-upload/label.svelte +2 -2
  202. package/dist/file-upload/root.svelte +2 -2
  203. package/dist/file-upload/trigger.svelte +2 -2
  204. package/dist/hover-card/arrow-tip.svelte +2 -2
  205. package/dist/hover-card/arrow.svelte +2 -2
  206. package/dist/hover-card/content.svelte +2 -2
  207. package/dist/hover-card/context.svelte.d.ts +1 -2
  208. package/dist/hover-card/context.svelte.js +2 -2
  209. package/dist/hover-card/create-hover-card.svelte.js +5 -3
  210. package/dist/hover-card/index.d.ts +1 -0
  211. package/dist/hover-card/index.js +1 -0
  212. package/dist/hover-card/positioner.svelte +2 -2
  213. package/dist/hover-card/root.svelte +2 -2
  214. package/dist/hover-card/trigger.svelte +2 -2
  215. package/dist/locale-provider/context.svelte.d.ts +1 -3
  216. package/dist/locale-provider/context.svelte.js +2 -3
  217. package/dist/locale-provider/root.svelte +2 -2
  218. package/dist/menu/arrow-tip.svelte +2 -2
  219. package/dist/menu/arrow.svelte +2 -2
  220. package/dist/menu/content.svelte +2 -2
  221. package/dist/menu/context-trigger.svelte +2 -2
  222. package/dist/menu/context.svelte.d.ts +3 -4
  223. package/dist/menu/context.svelte.js +4 -4
  224. package/dist/menu/create-menu.svelte.js +5 -3
  225. package/dist/menu/index.d.ts +1 -0
  226. package/dist/menu/index.js +1 -0
  227. package/dist/menu/indicator.svelte +2 -2
  228. package/dist/menu/item-group-label.svelte +6 -3
  229. package/dist/menu/item-group.svelte +6 -3
  230. package/dist/menu/item.svelte +2 -2
  231. package/dist/menu/option-item-indicator.svelte +6 -3
  232. package/dist/menu/option-item-text.svelte +6 -3
  233. package/dist/menu/option-item.svelte +6 -3
  234. package/dist/menu/positioner.svelte +2 -2
  235. package/dist/menu/root.svelte +2 -2
  236. package/dist/menu/separator.svelte +2 -2
  237. package/dist/menu/trigger-item.svelte +2 -2
  238. package/dist/menu/trigger.svelte +2 -2
  239. package/dist/number-input/context.svelte.d.ts +1 -2
  240. package/dist/number-input/context.svelte.js +2 -2
  241. package/dist/number-input/control.svelte +2 -2
  242. package/dist/number-input/create-number-input.svelte.js +16 -3
  243. package/dist/number-input/decrement-trigger.svelte +2 -2
  244. package/dist/number-input/increment-trigger.svelte +2 -2
  245. package/dist/number-input/index.d.ts +1 -0
  246. package/dist/number-input/index.js +1 -0
  247. package/dist/number-input/input.svelte +3 -5
  248. package/dist/number-input/label.svelte +2 -2
  249. package/dist/number-input/root.svelte +2 -2
  250. package/dist/number-input/scrubber.svelte +2 -2
  251. package/dist/pagination/context.svelte.d.ts +1 -2
  252. package/dist/pagination/context.svelte.js +2 -2
  253. package/dist/pagination/create-pagination.svelte.js +5 -3
  254. package/dist/pagination/ellipsis.svelte +2 -2
  255. package/dist/pagination/index.d.ts +1 -0
  256. package/dist/pagination/index.js +1 -0
  257. package/dist/pagination/item.svelte +2 -2
  258. package/dist/pagination/next-trigger.svelte +2 -2
  259. package/dist/pagination/prev-trigger.svelte +2 -2
  260. package/dist/pagination/root.svelte +2 -2
  261. package/dist/pin-input/clear-trigger.svelte +2 -2
  262. package/dist/pin-input/context.svelte.d.ts +1 -2
  263. package/dist/pin-input/context.svelte.js +2 -2
  264. package/dist/pin-input/create-pin-input.svelte.js +11 -3
  265. package/dist/pin-input/hidden-input.svelte +3 -5
  266. package/dist/pin-input/index.d.ts +1 -0
  267. package/dist/pin-input/index.js +1 -0
  268. package/dist/pin-input/input.svelte +2 -2
  269. package/dist/pin-input/label.svelte +2 -2
  270. package/dist/pin-input/root.svelte +2 -2
  271. package/dist/popover/arrow-tip.svelte +2 -2
  272. package/dist/popover/arrow.svelte +2 -2
  273. package/dist/popover/close-trigger.svelte +2 -2
  274. package/dist/popover/content.svelte +2 -2
  275. package/dist/popover/context.svelte.d.ts +1 -2
  276. package/dist/popover/context.svelte.js +2 -2
  277. package/dist/popover/create-popover.svelte.js +5 -3
  278. package/dist/popover/description.svelte +2 -2
  279. package/dist/popover/index.d.ts +2 -0
  280. package/dist/popover/index.js +2 -0
  281. package/dist/popover/popover.d.ts +0 -1
  282. package/dist/popover/popover.js +0 -1
  283. package/dist/popover/positioner.svelte +2 -2
  284. package/dist/popover/root.svelte +2 -2
  285. package/dist/popover/title.svelte +2 -2
  286. package/dist/popover/trigger.svelte +2 -2
  287. package/dist/presence/context.svelte.d.ts +1 -2
  288. package/dist/presence/context.svelte.js +2 -2
  289. package/dist/presence/create-presence.svelte.js +4 -3
  290. package/dist/progress/circle-range.svelte +2 -2
  291. package/dist/progress/circle-track.svelte +2 -2
  292. package/dist/progress/circle.svelte +2 -2
  293. package/dist/progress/context.svelte.d.ts +1 -2
  294. package/dist/progress/context.svelte.js +2 -2
  295. package/dist/progress/create-progress.svelte.js +5 -3
  296. package/dist/progress/index.d.ts +1 -0
  297. package/dist/progress/index.js +1 -0
  298. package/dist/progress/label.svelte +2 -2
  299. package/dist/progress/range.svelte +2 -2
  300. package/dist/progress/root.svelte +2 -2
  301. package/dist/progress/track.svelte +2 -2
  302. package/dist/progress/value-text.svelte +2 -2
  303. package/dist/progress/view.svelte +2 -2
  304. package/dist/qr-code/context.svelte.d.ts +1 -2
  305. package/dist/qr-code/context.svelte.js +2 -2
  306. package/dist/qr-code/create-qr-code.svelte.js +5 -3
  307. package/dist/qr-code/frame.svelte +2 -2
  308. package/dist/qr-code/index.d.ts +1 -0
  309. package/dist/qr-code/index.js +1 -0
  310. package/dist/qr-code/overlay.svelte +2 -2
  311. package/dist/qr-code/pattern.svelte +2 -2
  312. package/dist/qr-code/root.svelte +2 -2
  313. package/dist/radio-group/context.svelte.d.ts +2 -3
  314. package/dist/radio-group/context.svelte.js +3 -3
  315. package/dist/radio-group/create-radio-group.svelte.js +5 -3
  316. package/dist/radio-group/index.d.ts +1 -0
  317. package/dist/radio-group/index.js +1 -0
  318. package/dist/radio-group/indicator.svelte +2 -2
  319. package/dist/radio-group/item-control.svelte +4 -4
  320. package/dist/radio-group/item-hidden-input.svelte +4 -4
  321. package/dist/radio-group/item-text.svelte +4 -4
  322. package/dist/radio-group/item.svelte +5 -4
  323. package/dist/radio-group/label.svelte +2 -2
  324. package/dist/radio-group/root.svelte +2 -2
  325. package/dist/rating-group/context.svelte.d.ts +1 -2
  326. package/dist/rating-group/context.svelte.js +2 -2
  327. package/dist/rating-group/control.svelte +2 -2
  328. package/dist/rating-group/create-rating-group.svelte.js +16 -3
  329. package/dist/rating-group/hidden-input.svelte +3 -5
  330. package/dist/rating-group/index.d.ts +1 -0
  331. package/dist/rating-group/index.js +1 -0
  332. package/dist/rating-group/item.svelte +2 -2
  333. package/dist/rating-group/label.svelte +2 -2
  334. package/dist/rating-group/root.svelte +2 -2
  335. package/dist/segment-group/context.svelte.d.ts +2 -3
  336. package/dist/segment-group/context.svelte.js +3 -3
  337. package/dist/segment-group/create-segment-group.svelte.js +5 -3
  338. package/dist/segment-group/index.d.ts +1 -0
  339. package/dist/segment-group/index.js +1 -0
  340. package/dist/segment-group/indicator.svelte +2 -2
  341. package/dist/segment-group/item-control.svelte +4 -4
  342. package/dist/segment-group/item-hidden-input.svelte +4 -4
  343. package/dist/segment-group/item-text.svelte +4 -4
  344. package/dist/segment-group/item.svelte +4 -4
  345. package/dist/segment-group/label.svelte +2 -2
  346. package/dist/segment-group/root.svelte +2 -2
  347. package/dist/select/clear-trigger.svelte +2 -2
  348. package/dist/select/content.svelte +2 -2
  349. package/dist/select/context.svelte.d.ts +3 -4
  350. package/dist/select/context.svelte.js +4 -4
  351. package/dist/select/control.svelte +2 -2
  352. package/dist/select/create-select.svelte.d.ts +3 -5
  353. package/dist/select/create-select.svelte.js +26 -14
  354. package/dist/select/hidden-select.svelte +3 -5
  355. package/dist/select/index.d.ts +1 -0
  356. package/dist/select/index.js +1 -0
  357. package/dist/select/indicator.svelte +2 -2
  358. package/dist/select/item-group-label.svelte +5 -4
  359. package/dist/select/item-group.svelte +4 -4
  360. package/dist/select/item-indicator.svelte +6 -3
  361. package/dist/select/item-text.svelte +6 -3
  362. package/dist/select/item.svelte +6 -3
  363. package/dist/select/label.svelte +2 -2
  364. package/dist/select/list.svelte +2 -2
  365. package/dist/select/positioner.svelte +2 -2
  366. package/dist/select/root.svelte +2 -2
  367. package/dist/select/trigger.svelte +2 -2
  368. package/dist/select/value-text.svelte +2 -2
  369. package/dist/signature-pad/clear-trigger.svelte +2 -2
  370. package/dist/signature-pad/context.svelte.d.ts +1 -2
  371. package/dist/signature-pad/context.svelte.js +2 -2
  372. package/dist/signature-pad/control.svelte +2 -2
  373. package/dist/signature-pad/create-signature-pad.svelte.js +5 -3
  374. package/dist/signature-pad/current-segment-path.svelte +2 -2
  375. package/dist/signature-pad/guide.svelte +2 -2
  376. package/dist/signature-pad/hidden-input.svelte +2 -2
  377. package/dist/signature-pad/index.d.ts +1 -0
  378. package/dist/signature-pad/index.js +1 -0
  379. package/dist/signature-pad/label.svelte +2 -2
  380. package/dist/signature-pad/root.svelte +2 -2
  381. package/dist/signature-pad/segment-path.svelte +2 -2
  382. package/dist/signature-pad/segment.svelte +2 -2
  383. package/dist/slider/context.svelte.d.ts +2 -3
  384. package/dist/slider/context.svelte.js +3 -3
  385. package/dist/slider/control.svelte +2 -2
  386. package/dist/slider/create-slider.svelte.js +5 -3
  387. package/dist/slider/hidden-input.svelte +6 -3
  388. package/dist/slider/index.d.ts +1 -0
  389. package/dist/slider/index.js +1 -0
  390. package/dist/slider/label.svelte +2 -2
  391. package/dist/slider/marker-group.svelte +2 -2
  392. package/dist/slider/marker.svelte +2 -2
  393. package/dist/slider/range.svelte +2 -2
  394. package/dist/slider/root.svelte +2 -2
  395. package/dist/slider/thumb.svelte +6 -3
  396. package/dist/slider/track.svelte +2 -2
  397. package/dist/slider/value-text.svelte +2 -2
  398. package/dist/splitter/context.svelte.d.ts +1 -2
  399. package/dist/splitter/context.svelte.js +2 -2
  400. package/dist/splitter/create-splitter.svelte.js +3 -2
  401. package/dist/splitter/index.d.ts +1 -0
  402. package/dist/splitter/index.js +1 -0
  403. package/dist/splitter/panel.svelte +2 -2
  404. package/dist/splitter/resize-trigger.svelte +2 -2
  405. package/dist/splitter/root.svelte +2 -2
  406. package/dist/steps/completed-content.svelte +2 -2
  407. package/dist/steps/content.svelte +2 -2
  408. package/dist/steps/context.svelte.d.ts +2 -3
  409. package/dist/steps/context.svelte.js +3 -3
  410. package/dist/steps/create-steps.svelte.js +5 -3
  411. package/dist/steps/index.d.ts +1 -0
  412. package/dist/steps/index.js +1 -0
  413. package/dist/steps/indicator.svelte +3 -3
  414. package/dist/steps/item.svelte +3 -3
  415. package/dist/steps/list.svelte +2 -2
  416. package/dist/steps/next-trigger.svelte +2 -2
  417. package/dist/steps/prev-trigger.svelte +2 -2
  418. package/dist/steps/progress.svelte +2 -2
  419. package/dist/steps/root.svelte +2 -2
  420. package/dist/steps/separator.svelte +3 -3
  421. package/dist/steps/trigger.svelte +3 -3
  422. package/dist/switch/context.svelte.d.ts +1 -2
  423. package/dist/switch/context.svelte.js +2 -2
  424. package/dist/switch/control.svelte +2 -2
  425. package/dist/switch/create-switch.svelte.js +16 -3
  426. package/dist/switch/hidden-input.svelte +3 -5
  427. package/dist/switch/index.d.ts +1 -0
  428. package/dist/switch/index.js +1 -0
  429. package/dist/switch/label.svelte +2 -2
  430. package/dist/switch/root.svelte +2 -2
  431. package/dist/switch/thumb.svelte +2 -2
  432. package/dist/tabs/content.svelte +2 -2
  433. package/dist/tabs/context.svelte.d.ts +1 -2
  434. package/dist/tabs/context.svelte.js +2 -2
  435. package/dist/tabs/create-tabs.svelte.js +5 -3
  436. package/dist/tabs/index.d.ts +1 -0
  437. package/dist/tabs/index.js +1 -0
  438. package/dist/tabs/list.svelte +2 -2
  439. package/dist/tabs/root.svelte +2 -2
  440. package/dist/tabs/trigger.svelte +2 -2
  441. package/dist/tags-input/clear-trigger.svelte +2 -2
  442. package/dist/tags-input/context.svelte.d.ts +2 -3
  443. package/dist/tags-input/context.svelte.js +3 -3
  444. package/dist/tags-input/control.svelte +2 -2
  445. package/dist/tags-input/create-tags-input.svelte.js +16 -3
  446. package/dist/tags-input/hidden-input.svelte +3 -5
  447. package/dist/tags-input/index.d.ts +1 -0
  448. package/dist/tags-input/index.js +1 -0
  449. package/dist/tags-input/input.svelte +2 -2
  450. package/dist/tags-input/item-delete-trigger.svelte +4 -4
  451. package/dist/tags-input/item-input.svelte +4 -4
  452. package/dist/tags-input/item-preview.svelte +4 -4
  453. package/dist/tags-input/item-text.svelte +4 -4
  454. package/dist/tags-input/item.svelte +4 -4
  455. package/dist/tags-input/label.svelte +2 -2
  456. package/dist/tags-input/root.svelte +2 -2
  457. package/dist/time-picker/clear-trigger.svelte +2 -2
  458. package/dist/time-picker/column.svelte +2 -2
  459. package/dist/time-picker/content.svelte +2 -2
  460. package/dist/time-picker/context.svelte.d.ts +1 -2
  461. package/dist/time-picker/context.svelte.js +2 -2
  462. package/dist/time-picker/control.svelte +2 -2
  463. package/dist/time-picker/create-time-picker.svelte.js +5 -3
  464. package/dist/time-picker/hour-cell.svelte +2 -2
  465. package/dist/time-picker/index.d.ts +1 -0
  466. package/dist/time-picker/index.js +1 -0
  467. package/dist/time-picker/input.svelte +2 -2
  468. package/dist/time-picker/label.svelte +2 -2
  469. package/dist/time-picker/minute-cell.svelte +2 -2
  470. package/dist/time-picker/period-cell.svelte +2 -2
  471. package/dist/time-picker/positioner.svelte +2 -2
  472. package/dist/time-picker/root.svelte +2 -2
  473. package/dist/time-picker/second-cell.svelte +2 -2
  474. package/dist/time-picker/spacer.svelte +2 -2
  475. package/dist/time-picker/trigger.svelte +2 -2
  476. package/dist/timer/action-trigger.svelte +2 -2
  477. package/dist/timer/context.svelte.d.ts +2 -3
  478. package/dist/timer/context.svelte.js +3 -3
  479. package/dist/timer/create-timer.svelte.js +5 -3
  480. package/dist/timer/index.d.ts +1 -0
  481. package/dist/timer/index.js +1 -0
  482. package/dist/timer/item-label.svelte +3 -3
  483. package/dist/timer/item-value.svelte +3 -3
  484. package/dist/timer/item.svelte +3 -3
  485. package/dist/timer/root.svelte +2 -2
  486. package/dist/timer/separator.svelte +2 -2
  487. package/dist/toast/action-trigger.svelte +2 -2
  488. package/dist/toast/actor.svelte +2 -2
  489. package/dist/toast/close-trigger.svelte +2 -2
  490. package/dist/toast/context.svelte.d.ts +1 -2
  491. package/dist/toast/context.svelte.js +2 -2
  492. package/dist/toast/create-toaster.svelte.js +2 -1
  493. package/dist/toast/description.svelte +2 -2
  494. package/dist/toast/ghost-after.svelte +2 -2
  495. package/dist/toast/ghost-before.svelte +2 -2
  496. package/dist/toast/index.d.ts +1 -0
  497. package/dist/toast/index.js +1 -0
  498. package/dist/toast/root.svelte +2 -2
  499. package/dist/toast/title.svelte +2 -2
  500. package/dist/toggle-group/context.svelte.d.ts +1 -2
  501. package/dist/toggle-group/context.svelte.js +2 -2
  502. package/dist/toggle-group/create-toggle-group.svelte.js +5 -3
  503. package/dist/toggle-group/index.d.ts +1 -0
  504. package/dist/toggle-group/index.js +1 -0
  505. package/dist/toggle-group/item.svelte +2 -2
  506. package/dist/toggle-group/root.svelte +2 -2
  507. package/dist/tooltip/arrow-tip.svelte +2 -2
  508. package/dist/tooltip/arrow.svelte +2 -2
  509. package/dist/tooltip/content.svelte +2 -2
  510. package/dist/tooltip/context.svelte.d.ts +1 -2
  511. package/dist/tooltip/context.svelte.js +2 -2
  512. package/dist/tooltip/create-tooltip.svelte.js +5 -3
  513. package/dist/tooltip/index.d.ts +1 -0
  514. package/dist/tooltip/index.js +1 -0
  515. package/dist/tooltip/positioner.svelte +2 -2
  516. package/dist/tooltip/root.svelte +2 -2
  517. package/dist/tooltip/trigger.svelte +2 -2
  518. package/dist/tree-view/branch-content.svelte +4 -4
  519. package/dist/tree-view/branch-control.svelte +4 -4
  520. package/dist/tree-view/branch-indicator.svelte +4 -4
  521. package/dist/tree-view/branch-text.svelte +4 -4
  522. package/dist/tree-view/branch-trigger.svelte +4 -4
  523. package/dist/tree-view/branch.svelte +4 -4
  524. package/dist/tree-view/context.svelte.d.ts +3 -4
  525. package/dist/tree-view/context.svelte.js +4 -4
  526. package/dist/tree-view/create-tree-view.svelte.js +5 -3
  527. package/dist/tree-view/index.d.ts +1 -0
  528. package/dist/tree-view/index.js +1 -0
  529. package/dist/tree-view/item-indicator.svelte +6 -3
  530. package/dist/tree-view/item-text.svelte +6 -3
  531. package/dist/tree-view/item.svelte +6 -3
  532. package/dist/tree-view/label.svelte +2 -2
  533. package/dist/tree-view/root.svelte +2 -2
  534. package/dist/tree-view/tree.svelte +2 -2
  535. package/package.json +1 -1
  536. package/dist/context.svelte.d.ts +0 -8
@@ -8,7 +8,8 @@ export function createRatingGroup(props) {
8
8
  const field = getFieldContext();
9
9
  const locale = getLocaleContext();
10
10
  const environment = getEnvironmentContext();
11
- const [state, send] = useMachine(ratingGroup.machine({
11
+ const id = uid();
12
+ const context = $derived(reflect(() => ({
12
13
  ids: {
13
14
  label: field?.ids.label,
14
15
  hiddenInput: field?.ids.control,
@@ -17,10 +18,22 @@ export function createRatingGroup(props) {
17
18
  disabled: field?.disabled,
18
19
  readOnly: field?.readOnly,
19
20
  ...props,
20
- id: props.id ?? uid(),
21
+ id: props.id ?? id,
21
22
  dir: locale?.dir,
22
23
  getRootNode: environment?.getRootNode,
24
+ })));
25
+ const [state, send] = useMachine(ratingGroup.machine(context), { context });
26
+ const api = $derived(reflect(() => {
27
+ const o = ratingGroup.connect(state, send, normalizeProps);
28
+ return {
29
+ ...o,
30
+ getHiddenInputProps() {
31
+ return {
32
+ 'aria-describedby': field?.['aria-describedby'],
33
+ ...o.getHiddenInputProps(),
34
+ };
35
+ },
36
+ };
23
37
  }));
24
- const api = $derived(reflect(() => ratingGroup.connect(state, send, normalizeProps)));
25
38
  return api;
26
39
  }
@@ -5,18 +5,16 @@
5
5
  </script>
6
6
 
7
7
  <script lang="ts">
8
- import {getFieldContext} from '../field/context.svelte.js';
9
8
  import {mergeProps} from '../merge-props.js';
10
- import {ratingGroupContext} from './context.svelte.js';
9
+ import {getRatingGroupContext} from './context.svelte.js';
11
10
 
12
11
  let {...props}: RatingGroupHiddenInputProps = $props();
13
12
 
14
- let field = getFieldContext();
15
- let radioGroup = ratingGroupContext.get();
13
+ let radioGroup = getRatingGroupContext();
16
14
 
17
15
  let mergedProps = $derived(
18
16
  mergeProps(props, radioGroup.getHiddenInputProps()),
19
17
  );
20
18
  </script>
21
19
 
22
- <input aria-describedby={field?.['aria-describedby']} {...mergedProps} />
20
+ <input {...mergedProps} />
@@ -5,3 +5,4 @@ export type { RatingGroupItemProps } from './item.svelte';
5
5
  export type { RatingGroupLabelProps } from './label.svelte';
6
6
  export type { RatingGroupProps } from './root.svelte';
7
7
  export { anatomy as ratingGroupAnatomy } from '@zag-js/rating-group';
8
+ export { getRatingGroupContext } from './context.svelte.js';
@@ -1,2 +1,3 @@
1
1
  export * as RatingGroup from './rating-group.js';
2
2
  export { anatomy as ratingGroupAnatomy } from '@zag-js/rating-group';
3
+ export { getRatingGroupContext } from './context.svelte.js';
@@ -12,11 +12,11 @@
12
12
 
13
13
  <script lang="ts">
14
14
  import {mergeProps} from '../merge-props.js';
15
- import {ratingGroupContext} from './context.svelte.js';
15
+ import {getRatingGroupContext} from './context.svelte.js';
16
16
 
17
17
  let {index, asChild, children, ...props}: RatingGroupItemProps = $props();
18
18
 
19
- let ratingGroup = ratingGroupContext.get();
19
+ let ratingGroup = getRatingGroupContext();
20
20
 
21
21
  let itemState = $derived(ratingGroup.getItemState({index}));
22
22
  let mergedProps = $derived(
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {ratingGroupContext} from './context.svelte.js';
11
+ import {getRatingGroupContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: RatingGroupLabelProps = $props();
14
14
 
15
- let ratingGroup = ratingGroupContext.get();
15
+ let ratingGroup = getRatingGroupContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, ratingGroup.getLabelProps()));
18
18
  </script>
@@ -17,7 +17,7 @@
17
17
  import {mergeProps} from '../merge-props.js';
18
18
  import {reflect} from '@zag-js/svelte';
19
19
  import {createSplitProps} from '@zag-js/utils';
20
- import {ratingGroupContext} from './context.svelte.js';
20
+ import {setRatingGroupContext} from './context.svelte.js';
21
21
  import {createRatingGroup} from './create-rating-group.svelte.js';
22
22
 
23
23
  let {asChild, children, ...props}: RatingGroupProps = $props();
@@ -47,7 +47,7 @@
47
47
  mergeProps(otherProps, ratingGroup.getRootProps()),
48
48
  );
49
49
 
50
- ratingGroupContext.set(ratingGroup);
50
+ setRatingGroupContext(ratingGroup);
51
51
  </script>
52
52
 
53
53
  {#if asChild}
@@ -1,5 +1,4 @@
1
- import { Context } from '../context.svelte.js';
2
1
  import type { ItemProps } from '@zag-js/radio-group';
3
2
  import type { CreateSegmentGroupReturn } from './create-segment-group.svelte.js';
4
- export declare const segmentGroupContext: Context<CreateSegmentGroupReturn>;
5
- export declare const segmentGroupItemPropsContext: Context<ItemProps>;
3
+ export declare const getSegmentGroupContext: () => CreateSegmentGroupReturn, setSegmentGroupContext: (context: CreateSegmentGroupReturn | (() => CreateSegmentGroupReturn)) => void;
4
+ export declare const getSegmentGroupItemPropsContext: () => ItemProps, setSegmentGroupItemPropsContext: (context: ItemProps | (() => ItemProps)) => void;
@@ -1,3 +1,3 @@
1
- import { Context } from '../context.svelte.js';
2
- export const segmentGroupContext = new Context('SegmentGroup');
3
- export const segmentGroupItemPropsContext = new Context('SegmentGroupItem');
1
+ import { createContext } from '../create-context.svelte.js';
2
+ export const [getSegmentGroupContext, setSegmentGroupContext] = createContext('SegmentGroup');
3
+ export const [getSegmentGroupItemPropsContext, setSegmentGroupItemPropsContext,] = createContext('SegmentGroupItem');
@@ -6,12 +6,14 @@ import { uid } from 'uid';
6
6
  export function createSegmentGroup(props) {
7
7
  const locale = getLocaleContext();
8
8
  const environment = getEnvironmentContext();
9
- const [state, send] = useMachine(segmentGroup.machine({
9
+ const id = uid();
10
+ const context = $derived(reflect(() => ({
10
11
  ...props,
11
- id: props.id ?? uid(),
12
+ id: props.id ?? id,
12
13
  dir: locale?.dir,
13
14
  getRootNode: environment?.getRootNode,
14
- }));
15
+ })));
16
+ const [state, send] = useMachine(segmentGroup.machine(context));
15
17
  const api = $derived(reflect(() => segmentGroup.connect(state, send, normalizeProps)));
16
18
  return api;
17
19
  }
@@ -7,3 +7,4 @@ export type { SegmentGroupItemProps } from './item.svelte';
7
7
  export type { SegmentGroupLabelProps } from './label.svelte';
8
8
  export type { SegmentGroupProps } from './root.svelte';
9
9
  export { anatomy as segmentGroupAnatomy } from './anatomy.js';
10
+ export { getSegmentGroupContext } from './context.svelte.js';
@@ -1,2 +1,3 @@
1
1
  export * as SegmentGroup from './segment-group.js';
2
2
  export { anatomy as segmentGroupAnatomy } from './anatomy.js';
3
+ export { getSegmentGroupContext } from './context.svelte.js';
@@ -9,11 +9,11 @@
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {parts} from './anatomy.js';
12
- import {segmentGroupContext} from './context.svelte.js';
12
+ import {getSegmentGroupContext} from './context.svelte.js';
13
13
 
14
14
  let {asChild, children, ...props}: SegmentGroupIndicatorProps = $props();
15
15
 
16
- let segmentGroup = segmentGroupContext.get();
16
+ let segmentGroup = getSegmentGroupContext();
17
17
 
18
18
  let mergedProps = $derived(
19
19
  mergeProps(props, segmentGroup.getIndicatorProps(), parts.indicator.attrs),
@@ -10,14 +10,14 @@
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {parts} from './anatomy.js';
12
12
  import {
13
- segmentGroupContext,
14
- segmentGroupItemPropsContext,
13
+ getSegmentGroupContext,
14
+ getSegmentGroupItemPropsContext,
15
15
  } from './context.svelte.js';
16
16
 
17
17
  let {asChild, children, ...props}: SegmentGroupItemControlProps = $props();
18
18
 
19
- let segmentGroup = segmentGroupContext.get();
20
- let itemProps = segmentGroupItemPropsContext.get();
19
+ let segmentGroup = getSegmentGroupContext();
20
+ let itemProps = getSegmentGroupItemPropsContext();
21
21
 
22
22
  let mergedProps = $derived(
23
23
  mergeProps(
@@ -8,14 +8,14 @@
8
8
  <script lang="ts">
9
9
  import {mergeProps} from '../merge-props.js';
10
10
  import {
11
- segmentGroupContext,
12
- segmentGroupItemPropsContext,
11
+ getSegmentGroupContext,
12
+ getSegmentGroupItemPropsContext,
13
13
  } from './context.svelte.js';
14
14
 
15
15
  let {...props}: SegmentGroupItemHiddenInputProps = $props();
16
16
 
17
- let segmentGroup = segmentGroupContext.get();
18
- let itemProps = segmentGroupItemPropsContext.get();
17
+ let segmentGroup = getSegmentGroupContext();
18
+ let itemProps = getSegmentGroupItemPropsContext();
19
19
 
20
20
  let mergedProps = $derived(
21
21
  mergeProps(props, segmentGroup.getItemHiddenInputProps(itemProps)),
@@ -10,14 +10,14 @@
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {parts} from './anatomy.js';
12
12
  import {
13
- segmentGroupContext,
14
- segmentGroupItemPropsContext,
13
+ getSegmentGroupContext,
14
+ getSegmentGroupItemPropsContext,
15
15
  } from './context.svelte.js';
16
16
 
17
17
  let {asChild, children, ...props}: SegmentGroupItemTextProps = $props();
18
18
 
19
- let segmentGroup = segmentGroupContext.get();
20
- let itemProps = segmentGroupItemPropsContext.get();
19
+ let segmentGroup = getSegmentGroupContext();
20
+ let itemProps = getSegmentGroupItemPropsContext();
21
21
 
22
22
  let mergedProps = $derived(
23
23
  mergeProps(
@@ -15,13 +15,13 @@
15
15
  import {createSplitProps} from '@zag-js/utils';
16
16
  import {parts} from './anatomy.js';
17
17
  import {
18
- segmentGroupContext,
19
- segmentGroupItemPropsContext,
18
+ getSegmentGroupContext,
19
+ setSegmentGroupItemPropsContext,
20
20
  } from './context.svelte.js';
21
21
 
22
22
  let {children, asChild, ...props}: SegmentGroupItemProps = $props();
23
23
 
24
- let segmentGroup = segmentGroupContext.get();
24
+ let segmentGroup = getSegmentGroupContext();
25
25
 
26
26
  let [itemProps, otherProps] = $derived(
27
27
  createSplitProps<ItemProps>(['value', 'invalid', 'disabled'])(props),
@@ -36,7 +36,7 @@
36
36
  ),
37
37
  );
38
38
 
39
- segmentGroupItemPropsContext.set(() => itemProps);
39
+ setSegmentGroupItemPropsContext(() => itemProps);
40
40
  </script>
41
41
 
42
42
  {#if asChild}
@@ -9,11 +9,11 @@
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {parts} from './anatomy.js';
12
- import {segmentGroupContext} from './context.svelte.js';
12
+ import {getSegmentGroupContext} from './context.svelte.js';
13
13
 
14
14
  let {asChild, children, ...props}: SegmentGroupLabelProps = $props();
15
15
 
16
- let segmentGroup = segmentGroupContext.get();
16
+ let segmentGroup = getSegmentGroupContext();
17
17
 
18
18
  let mergedProps = $derived(
19
19
  mergeProps(props, segmentGroup.getLabelProps(), parts.label.attrs),
@@ -21,7 +21,7 @@
21
21
  import {reflect} from '@zag-js/svelte';
22
22
  import {createSplitProps} from '@zag-js/utils';
23
23
  import {parts} from './anatomy.js';
24
- import {segmentGroupContext} from './context.svelte.js';
24
+ import {setSegmentGroupContext} from './context.svelte.js';
25
25
  import {createSegmentGroup} from './create-segment-group.svelte.js';
26
26
 
27
27
  let {asChild, children, ...props}: SegmentGroupProps = $props();
@@ -46,7 +46,7 @@
46
46
  mergeProps(otherProps, segmentGroup.getRootProps(), parts.root.attrs),
47
47
  );
48
48
 
49
- segmentGroupContext.set(segmentGroup);
49
+ setSegmentGroupContext(segmentGroup);
50
50
  </script>
51
51
 
52
52
  {#if asChild}
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectClearTriggerProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getClearTriggerProps()));
18
18
  </script>
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectContentProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getContentProps()));
18
18
  </script>
@@ -1,6 +1,5 @@
1
- import { Context } from '../context.svelte.js';
2
1
  import type { ItemGroupProps, ItemProps } from '@zag-js/select';
3
2
  import type { CreateSelectReturn } from './create-select.svelte.js';
4
- export declare const selectContext: Context<CreateSelectReturn>;
5
- export declare const selectItemPropsContext: Context<ItemProps<any>>;
6
- export declare const selectItemGroupPropsContext: Context<ItemGroupProps>;
3
+ export declare const getSelectContext: () => CreateSelectReturn, setSelectContext: (context: CreateSelectReturn | (() => CreateSelectReturn)) => void;
4
+ export declare const getSelectItemPropsContext: () => ItemProps<any>, setSelectItemPropsContext: (context: ItemProps<any> | (() => ItemProps<any>)) => void;
5
+ export declare const getSelectItemGroupPropsContext: () => ItemGroupProps, setSelectItemGroupPropsContext: (context: ItemGroupProps | (() => ItemGroupProps)) => void;
@@ -1,4 +1,4 @@
1
- import { Context } from '../context.svelte.js';
2
- export const selectContext = new Context('Select');
3
- export const selectItemPropsContext = new Context('SelectItem');
4
- export const selectItemGroupPropsContext = new Context('SelectItemGroup');
1
+ import { createContext } from '../create-context.svelte.js';
2
+ export const [getSelectContext, setSelectContext] = createContext('Select');
3
+ export const [getSelectItemPropsContext, setSelectItemPropsContext] = createContext('SelectItem');
4
+ export const [getSelectItemGroupPropsContext, setSelectItemGroupPropsContext] = createContext('SelectItemGroup');
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectControlProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getControlProps()));
18
18
  </script>
@@ -1,12 +1,10 @@
1
1
  import * as select from '@zag-js/select';
2
- export interface CreateSelectProps<T> extends Omit<select.Context, 'id' | 'dir' | 'getRootNode' | 'collection' | 'open.controlled'> {
2
+ type Omitted = 'id' | 'dir' | 'getRootNode' | 'collection' | 'open.controlled';
3
+ export interface CreateSelectProps<T> extends select.CollectionOptions<T>, Omit<select.Context, Omitted> {
3
4
  id?: string | null;
4
- items: T[];
5
- itemToString?: (item: T) => string;
6
- itemToValue?: (item: T) => string;
7
- isItemDisabled?: (item: T) => boolean;
8
5
  defaultOpen?: boolean;
9
6
  }
10
7
  export interface CreateSelectReturn extends select.Api {
11
8
  }
12
9
  export declare function createSelect<T>(props: CreateSelectProps<T>): any;
10
+ export {};
@@ -3,18 +3,21 @@ import { getFieldContext } from '../field/context.svelte.js';
3
3
  import { getLocaleContext } from '../locale-provider/context.svelte.js';
4
4
  import * as select from '@zag-js/select';
5
5
  import { normalizeProps, reflect, useMachine } from '@zag-js/svelte';
6
+ import { createSplitProps } from '@zag-js/utils';
6
7
  import { uid } from 'uid';
7
8
  export function createSelect(props) {
8
- const collection = $derived(select.collection({
9
- items: props.items,
10
- itemToValue: (item) => props.itemToValue ? props.itemToValue(item) : String(item),
11
- itemToString: (item) => props.itemToString ? props.itemToString(item) : String(item),
12
- isItemDisabled: (item) => props.isItemDisabled ? props.isItemDisabled(item) : false,
13
- }));
9
+ const [collectionProps, selectProps] = $derived(createSplitProps([
10
+ 'items',
11
+ 'itemToValue',
12
+ 'itemToString',
13
+ 'isItemDisabled',
14
+ ])(props));
15
+ const collection = $derived(select.collection(collectionProps));
14
16
  const field = getFieldContext();
15
17
  const locale = getLocaleContext();
16
18
  const environment = getEnvironmentContext();
17
- const [state, send] = useMachine(select.machine({
19
+ const id = uid();
20
+ const context = $derived({
18
21
  ids: {
19
22
  label: field?.ids.label,
20
23
  hiddenSelect: field?.ids.control,
@@ -23,17 +26,26 @@ export function createSelect(props) {
23
26
  disabled: field?.disabled,
24
27
  readOnly: field?.readOnly,
25
28
  required: field?.required,
26
- ...props,
27
- id: props.id ?? uid(),
29
+ ...selectProps,
30
+ id: props.id ?? id,
28
31
  dir: locale?.dir,
29
32
  open: props.defaultOpen ?? props.open,
33
+ 'open.controlled': props.open != null,
30
34
  getRootNode: environment?.getRootNode,
31
35
  collection,
32
- 'open.controlled': props.open != null,
36
+ });
37
+ const [state, send] = useMachine(select.machine(context));
38
+ const api = $derived(reflect(() => {
39
+ const o = select.connect(state, send, normalizeProps);
40
+ return {
41
+ ...o,
42
+ getHiddenSelectProps() {
43
+ return {
44
+ 'aria-describedby': field?.['aria-describedby'],
45
+ ...o.getHiddenSelectProps(),
46
+ };
47
+ },
48
+ };
33
49
  }));
34
- const api = $derived(reflect(() => ({
35
- ...select.connect(state, send, normalizeProps),
36
- collection,
37
- })));
38
50
  return api;
39
51
  }
@@ -5,18 +5,16 @@
5
5
  </script>
6
6
 
7
7
  <script lang="ts">
8
- import {getFieldContext} from '../field/context.svelte.js';
9
8
  import {mergeProps} from '../merge-props.js';
10
- import {selectContext} from './context.svelte.js';
9
+ import {getSelectContext} from './context.svelte.js';
11
10
 
12
11
  let {children, ...props}: SelectHiddenSelectProps = $props();
13
12
 
14
- let field = getFieldContext();
15
- let select = selectContext.get();
13
+ let select = getSelectContext();
16
14
 
17
15
  let mergedProps = $derived(mergeProps(props, select.getHiddenSelectProps()));
18
16
  </script>
19
17
 
20
- <select aria-describedby={field?.['aria-describedby']} {...mergedProps}>
18
+ <select {...mergedProps}>
21
19
  {@render children?.()}
22
20
  </select>
@@ -16,3 +16,4 @@ export type { SelectProps } from './root.svelte';
16
16
  export type { SelectTriggerProps } from './trigger.svelte';
17
17
  export type { SelectValueTextProps } from './value-text.svelte';
18
18
  export { anatomy as selectAnatomy } from '@zag-js/select';
19
+ export { getSelectContext } from './context.svelte.js';
@@ -1,2 +1,3 @@
1
1
  export * as Select from './select.js';
2
2
  export { anatomy as selectAnatomy } from '@zag-js/select';
3
+ export { getSelectContext } from './context.svelte.js';
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectIndicatorProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getIndicatorProps()));
18
18
  </script>
@@ -9,14 +9,15 @@
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {
12
- selectContext,
13
- selectItemGroupPropsContext,
12
+ getSelectContext,
13
+ getSelectItemGroupPropsContext,
14
14
  } from './context.svelte.js';
15
15
 
16
16
  let {asChild, children, ...props}: SelectItemGroupLabelProps = $props();
17
17
 
18
- let select = selectContext.get();
19
- let itemGroupProps = selectItemGroupPropsContext.get();
18
+ let select = getSelectContext();
19
+
20
+ let itemGroupProps = getSelectItemGroupPropsContext();
20
21
 
21
22
  let mergedProps = $derived(
22
23
  mergeProps(
@@ -10,13 +10,13 @@
10
10
  import {mergeProps} from '../merge-props.js';
11
11
  import {uid} from 'uid';
12
12
  import {
13
- selectContext,
14
- selectItemGroupPropsContext,
13
+ getSelectContext,
14
+ setSelectItemGroupPropsContext,
15
15
  } from './context.svelte.js';
16
16
 
17
17
  let {id, asChild, children, ...props}: SelectItemGroupProps = $props();
18
18
 
19
- let select = selectContext.get();
19
+ let select = getSelectContext();
20
20
 
21
21
  let id_ = uid();
22
22
 
@@ -28,7 +28,7 @@
28
28
  mergeProps(props, select.getItemGroupProps(itemGroupProps)),
29
29
  );
30
30
 
31
- selectItemGroupPropsContext.set(() => itemGroupProps);
31
+ setSelectItemGroupPropsContext(() => itemGroupProps);
32
32
  </script>
33
33
 
34
34
  {#if asChild}
@@ -8,12 +8,15 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext, selectItemPropsContext} from './context.svelte.js';
11
+ import {
12
+ getSelectContext,
13
+ getSelectItemPropsContext,
14
+ } from './context.svelte.js';
12
15
 
13
16
  let {asChild, children, ...props}: SelectItemIndicatorProps = $props();
14
17
 
15
- let select = selectContext.get();
16
- let itemProps = selectItemPropsContext.get();
18
+ let select = getSelectContext();
19
+ let itemProps = getSelectItemPropsContext();
17
20
 
18
21
  let mergedProps = $derived(
19
22
  mergeProps(props, select.getItemIndicatorProps(itemProps)),
@@ -8,12 +8,15 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext, selectItemPropsContext} from './context.svelte.js';
11
+ import {
12
+ getSelectContext,
13
+ getSelectItemPropsContext,
14
+ } from './context.svelte.js';
12
15
 
13
16
  let {asChild, children, ...props}: SelectItemTextProps = $props();
14
17
 
15
- let select = selectContext.get();
16
- let itemProps = selectItemPropsContext.get();
18
+ let select = getSelectContext();
19
+ let itemProps = getSelectItemPropsContext();
17
20
 
18
21
  let mergedProps = $derived(
19
22
  mergeProps(props, select.getItemTextProps(itemProps)),
@@ -13,11 +13,14 @@
13
13
  <script lang="ts">
14
14
  import {mergeProps} from '../merge-props.js';
15
15
  import {createSplitProps} from '@zag-js/utils';
16
- import {selectContext, selectItemPropsContext} from './context.svelte.js';
16
+ import {
17
+ getSelectContext,
18
+ setSelectItemPropsContext,
19
+ } from './context.svelte.js';
17
20
 
18
21
  let {asChild, children, ...props}: SelectItemProps = $props();
19
22
 
20
- let select = selectContext.get();
23
+ let select = getSelectContext();
21
24
 
22
25
  let [itemProps, otherProps] = $derived(
23
26
  createSplitProps<ItemProps>(['item', 'persistFocus'])(props),
@@ -28,7 +31,7 @@
28
31
  mergeProps(otherProps, select.getItemProps(itemProps)),
29
32
  );
30
33
 
31
- selectItemPropsContext.set(() => itemProps);
34
+ setSelectItemPropsContext(() => itemProps);
32
35
  </script>
33
36
 
34
37
  {#if asChild}
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectLabelProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getLabelProps()));
18
18
  </script>
@@ -8,11 +8,11 @@
8
8
 
9
9
  <script lang="ts">
10
10
  import {mergeProps} from '../merge-props.js';
11
- import {selectContext} from './context.svelte.js';
11
+ import {getSelectContext} from './context.svelte.js';
12
12
 
13
13
  let {asChild, children, ...props}: SelectListProps = $props();
14
14
 
15
- let select = selectContext.get();
15
+ let select = getSelectContext();
16
16
 
17
17
  let mergedProps = $derived(mergeProps(props, select.getListProps()));
18
18
  </script>