@proyecto-viviana/solidaria 0.2.5 → 0.3.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 (555) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +31 -236
  3. package/dist/actiongroup/createActionGroup.d.ts +29 -0
  4. package/dist/actiongroup/createActionGroup.d.ts.map +1 -0
  5. package/dist/actiongroup/index.d.ts +2 -0
  6. package/dist/actiongroup/index.d.ts.map +1 -0
  7. package/dist/autocomplete/createAutocomplete.d.ts +16 -12
  8. package/dist/autocomplete/createAutocomplete.d.ts.map +1 -1
  9. package/dist/autocomplete/index.d.ts +1 -1
  10. package/dist/autocomplete/index.d.ts.map +1 -1
  11. package/dist/breadcrumbs/createBreadcrumbs.d.ts +11 -7
  12. package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +1 -1
  13. package/dist/breadcrumbs/index.d.ts +1 -1
  14. package/dist/button/createButton.d.ts +1 -1
  15. package/dist/button/createButton.d.ts.map +1 -1
  16. package/dist/button/createToggleButton.d.ts +3 -3
  17. package/dist/button/createToggleButtonGroup.d.ts +32 -0
  18. package/dist/button/createToggleButtonGroup.d.ts.map +1 -0
  19. package/dist/button/index.d.ts +6 -4
  20. package/dist/button/index.d.ts.map +1 -1
  21. package/dist/button/types.d.ts +18 -12
  22. package/dist/button/types.d.ts.map +1 -1
  23. package/dist/calendar/createCalendar.d.ts +15 -5
  24. package/dist/calendar/createCalendar.d.ts.map +1 -1
  25. package/dist/calendar/createCalendarCell.d.ts +8 -2
  26. package/dist/calendar/createCalendarCell.d.ts.map +1 -1
  27. package/dist/calendar/createCalendarGrid.d.ts +4 -4
  28. package/dist/calendar/createCalendarGrid.d.ts.map +1 -1
  29. package/dist/calendar/createRangeCalendar.d.ts +15 -5
  30. package/dist/calendar/createRangeCalendar.d.ts.map +1 -1
  31. package/dist/calendar/createRangeCalendarCell.d.ts +7 -3
  32. package/dist/calendar/createRangeCalendarCell.d.ts.map +1 -1
  33. package/dist/calendar/index.d.ts +5 -5
  34. package/dist/calendar/index.d.ts.map +1 -1
  35. package/dist/calendar/intl/index.d.ts +12 -0
  36. package/dist/calendar/intl/index.d.ts.map +1 -0
  37. package/dist/calendar/utils.d.ts +12 -0
  38. package/dist/calendar/utils.d.ts.map +1 -0
  39. package/dist/checkbox/createCheckbox.d.ts +6 -6
  40. package/dist/checkbox/createCheckbox.d.ts.map +1 -1
  41. package/dist/checkbox/createCheckboxGroup.d.ts +11 -7
  42. package/dist/checkbox/createCheckboxGroup.d.ts.map +1 -1
  43. package/dist/checkbox/createCheckboxGroupItem.d.ts +4 -4
  44. package/dist/checkbox/createCheckboxGroupItem.d.ts.map +1 -1
  45. package/dist/checkbox/createCheckboxGroupState.d.ts +2 -2
  46. package/dist/checkbox/createCheckboxGroupState.d.ts.map +1 -1
  47. package/dist/checkbox/index.d.ts +8 -8
  48. package/dist/checkbox/index.d.ts.map +1 -1
  49. package/dist/collections/index.d.ts +56 -0
  50. package/dist/collections/index.d.ts.map +1 -0
  51. package/dist/color/createColorArea.d.ts +3 -3
  52. package/dist/color/createColorArea.d.ts.map +1 -1
  53. package/dist/color/createColorField.d.ts +4 -4
  54. package/dist/color/createColorField.d.ts.map +1 -1
  55. package/dist/color/createColorSlider.d.ts +4 -4
  56. package/dist/color/createColorSlider.d.ts.map +1 -1
  57. package/dist/color/createColorSwatch.d.ts +2 -2
  58. package/dist/color/createColorSwatch.d.ts.map +1 -1
  59. package/dist/color/createColorWheel.d.ts +3 -3
  60. package/dist/color/createColorWheel.d.ts.map +1 -1
  61. package/dist/color/index.d.ts +6 -6
  62. package/dist/color/types.d.ts +98 -16
  63. package/dist/color/types.d.ts.map +1 -1
  64. package/dist/combobox/createComboBox.d.ts +16 -7
  65. package/dist/combobox/createComboBox.d.ts.map +1 -1
  66. package/dist/combobox/index.d.ts +1 -1
  67. package/dist/combobox/intl/index.d.ts +1 -1
  68. package/dist/datepicker/createDateField.d.ts +18 -6
  69. package/dist/datepicker/createDateField.d.ts.map +1 -1
  70. package/dist/datepicker/createDatePicker.d.ts +57 -5
  71. package/dist/datepicker/createDatePicker.d.ts.map +1 -1
  72. package/dist/datepicker/createDatePickerGroup.d.ts +19 -0
  73. package/dist/datepicker/createDatePickerGroup.d.ts.map +1 -0
  74. package/dist/datepicker/createDateRangePicker.d.ts +42 -0
  75. package/dist/datepicker/createDateRangePicker.d.ts.map +1 -0
  76. package/dist/datepicker/createDateSegment.d.ts +11 -3
  77. package/dist/datepicker/createDateSegment.d.ts.map +1 -1
  78. package/dist/datepicker/createTimeField.d.ts +11 -5
  79. package/dist/datepicker/createTimeField.d.ts.map +1 -1
  80. package/dist/datepicker/createTimeSegment.d.ts +29 -0
  81. package/dist/datepicker/createTimeSegment.d.ts.map +1 -0
  82. package/dist/datepicker/index.d.ts +7 -4
  83. package/dist/datepicker/index.d.ts.map +1 -1
  84. package/dist/dialog/createDialog.d.ts +5 -5
  85. package/dist/dialog/createDialog.d.ts.map +1 -1
  86. package/dist/dialog/index.d.ts +2 -2
  87. package/dist/dialog/index.d.ts.map +1 -1
  88. package/dist/dialog/types.d.ts +4 -4
  89. package/dist/disclosure/createDisclosure.d.ts +5 -2
  90. package/dist/disclosure/createDisclosure.d.ts.map +1 -1
  91. package/dist/disclosure/createDisclosureGroup.d.ts +4 -3
  92. package/dist/disclosure/createDisclosureGroup.d.ts.map +1 -1
  93. package/dist/disclosure/index.d.ts +2 -2
  94. package/dist/dnd/createDrag.d.ts +2 -2
  95. package/dist/dnd/createDrag.d.ts.map +1 -1
  96. package/dist/dnd/createDraggableCollection.d.ts +6 -2
  97. package/dist/dnd/createDraggableCollection.d.ts.map +1 -1
  98. package/dist/dnd/createDraggableItem.d.ts +3 -3
  99. package/dist/dnd/createDraggableItem.d.ts.map +1 -1
  100. package/dist/dnd/createDrop.d.ts +2 -2
  101. package/dist/dnd/createDrop.d.ts.map +1 -1
  102. package/dist/dnd/createDroppableCollection.d.ts +55 -4
  103. package/dist/dnd/createDroppableCollection.d.ts.map +1 -1
  104. package/dist/dnd/createDroppableItem.d.ts +3 -3
  105. package/dist/dnd/createDroppableItem.d.ts.map +1 -1
  106. package/dist/dnd/index.d.ts +12 -12
  107. package/dist/dnd/index.d.ts.map +1 -1
  108. package/dist/dnd/types.d.ts +2 -2
  109. package/dist/dnd/types.d.ts.map +1 -1
  110. package/dist/dnd/utils.d.ts +1 -1
  111. package/dist/dnd/utils.d.ts.map +1 -1
  112. package/dist/focus/FocusScope.d.ts +1 -1
  113. package/dist/focus/FocusScope.d.ts.map +1 -1
  114. package/dist/focus/createAutoFocus.d.ts.map +1 -1
  115. package/dist/focus/createFocusRestore.d.ts.map +1 -1
  116. package/dist/focus/createVirtualFocus.d.ts +4 -4
  117. package/dist/focus/createVirtualFocus.d.ts.map +1 -1
  118. package/dist/focus/index.d.ts +4 -4
  119. package/dist/focus/index.d.ts.map +1 -1
  120. package/dist/form/createFormReset.d.ts +1 -1
  121. package/dist/form/createFormValidation.d.ts +3 -3
  122. package/dist/form/createFormValidation.d.ts.map +1 -1
  123. package/dist/form/index.d.ts +2 -2
  124. package/dist/form/index.d.ts.map +1 -1
  125. package/dist/grid/GridKeyboardDelegate.d.ts +5 -5
  126. package/dist/grid/createGrid.d.ts +3 -3
  127. package/dist/grid/createGrid.d.ts.map +1 -1
  128. package/dist/grid/createGridCell.d.ts +3 -3
  129. package/dist/grid/createGridRow.d.ts +3 -3
  130. package/dist/grid/index.d.ts +5 -5
  131. package/dist/grid/types.d.ts +8 -8
  132. package/dist/gridlist/createGridList.d.ts +6 -4
  133. package/dist/gridlist/createGridList.d.ts.map +1 -1
  134. package/dist/gridlist/createGridListItem.d.ts +4 -4
  135. package/dist/gridlist/createGridListItem.d.ts.map +1 -1
  136. package/dist/gridlist/createGridListSelectionCheckbox.d.ts +3 -3
  137. package/dist/gridlist/createGridListSelectionCheckbox.d.ts.map +1 -1
  138. package/dist/gridlist/index.d.ts +4 -4
  139. package/dist/gridlist/types.d.ts +11 -7
  140. package/dist/gridlist/types.d.ts.map +1 -1
  141. package/dist/i18n/createCollator.d.ts.map +1 -1
  142. package/dist/i18n/createDateFormatter.d.ts.map +1 -1
  143. package/dist/i18n/createFilter.d.ts.map +1 -1
  144. package/dist/i18n/createNumberFormatter.d.ts +1 -1
  145. package/dist/i18n/createNumberFormatter.d.ts.map +1 -1
  146. package/dist/i18n/createStringFormatter.d.ts +2 -2
  147. package/dist/i18n/createStringFormatter.d.ts.map +1 -1
  148. package/dist/i18n/index.d.ts +8 -8
  149. package/dist/i18n/index.d.ts.map +1 -1
  150. package/dist/i18n/locale.d.ts +2 -2
  151. package/dist/i18n/locale.d.ts.map +1 -1
  152. package/dist/i18n/utils.d.ts.map +1 -1
  153. package/dist/index.d.ts +52 -49
  154. package/dist/index.d.ts.map +1 -1
  155. package/dist/index.js +18089 -15690
  156. package/dist/index.js.map +1 -7
  157. package/dist/index.jsx +18242 -0
  158. package/dist/index.jsx.map +1 -0
  159. package/dist/interactions/FocusableProvider.d.ts +2 -2
  160. package/dist/interactions/FocusableProvider.d.ts.map +1 -1
  161. package/dist/interactions/PressEvent.d.ts +2 -2
  162. package/dist/interactions/createFocus.d.ts +1 -1
  163. package/dist/interactions/createFocus.d.ts.map +1 -1
  164. package/dist/interactions/createFocusRing.d.ts +1 -1
  165. package/dist/interactions/createFocusRing.d.ts.map +1 -1
  166. package/dist/interactions/createFocusWithin.d.ts +1 -1
  167. package/dist/interactions/createFocusWithin.d.ts.map +1 -1
  168. package/dist/interactions/createFocusable.d.ts +3 -3
  169. package/dist/interactions/createFocusable.d.ts.map +1 -1
  170. package/dist/interactions/createHover.d.ts +5 -5
  171. package/dist/interactions/createHover.d.ts.map +1 -1
  172. package/dist/interactions/createInteractionModality.d.ts +3 -3
  173. package/dist/interactions/createInteractionModality.d.ts.map +1 -1
  174. package/dist/interactions/createKeyboard.d.ts +1 -1
  175. package/dist/interactions/createLongPress.d.ts +5 -5
  176. package/dist/interactions/createMove.d.ts +5 -5
  177. package/dist/interactions/createMove.d.ts.map +1 -1
  178. package/dist/interactions/createPress.d.ts +4 -4
  179. package/dist/interactions/createPress.d.ts.map +1 -1
  180. package/dist/interactions/index.d.ts +12 -12
  181. package/dist/interactions/index.d.ts.map +1 -1
  182. package/dist/label/createField.d.ts +4 -4
  183. package/dist/label/createField.d.ts.map +1 -1
  184. package/dist/label/createLabel.d.ts +7 -7
  185. package/dist/label/createLabel.d.ts.map +1 -1
  186. package/dist/label/createLabels.d.ts +1 -1
  187. package/dist/label/createLabels.d.ts.map +1 -1
  188. package/dist/label/index.d.ts +5 -5
  189. package/dist/landmark/createLandmark.d.ts +5 -5
  190. package/dist/landmark/createLandmark.d.ts.map +1 -1
  191. package/dist/landmark/index.d.ts +1 -1
  192. package/dist/link/createLink.d.ts +23 -7
  193. package/dist/link/createLink.d.ts.map +1 -1
  194. package/dist/link/index.d.ts +1 -1
  195. package/dist/listbox/createListBox.d.ts +12 -6
  196. package/dist/listbox/createListBox.d.ts.map +1 -1
  197. package/dist/listbox/createOption.d.ts +21 -4
  198. package/dist/listbox/createOption.d.ts.map +1 -1
  199. package/dist/listbox/index.d.ts +2 -2
  200. package/dist/listbox/index.d.ts.map +1 -1
  201. package/dist/live-announcer/announce.d.ts +2 -2
  202. package/dist/live-announcer/announce.d.ts.map +1 -1
  203. package/dist/live-announcer/index.d.ts +1 -1
  204. package/dist/menu/createMenu.d.ts +8 -7
  205. package/dist/menu/createMenu.d.ts.map +1 -1
  206. package/dist/menu/createMenuItem.d.ts +16 -4
  207. package/dist/menu/createMenuItem.d.ts.map +1 -1
  208. package/dist/menu/createMenuTrigger.d.ts +4 -4
  209. package/dist/menu/index.d.ts +3 -3
  210. package/dist/menu/index.d.ts.map +1 -1
  211. package/dist/meter/createMeter.d.ts +6 -6
  212. package/dist/meter/createMeter.d.ts.map +1 -1
  213. package/dist/meter/index.d.ts +1 -1
  214. package/dist/numberfield/createNumberField.d.ts +27 -8
  215. package/dist/numberfield/createNumberField.d.ts.map +1 -1
  216. package/dist/numberfield/index.d.ts +1 -1
  217. package/dist/overlays/ariaHideOutside.d.ts.map +1 -1
  218. package/dist/overlays/createModal.d.ts +19 -3
  219. package/dist/overlays/createModal.d.ts.map +1 -1
  220. package/dist/overlays/createOverlay.d.ts +1 -1
  221. package/dist/overlays/createOverlay.d.ts.map +1 -1
  222. package/dist/overlays/createOverlayTrigger.d.ts +6 -6
  223. package/dist/overlays/index.d.ts +6 -6
  224. package/dist/overlays/index.d.ts.map +1 -1
  225. package/dist/popover/calculatePosition.d.ts +4 -4
  226. package/dist/popover/calculatePosition.d.ts.map +1 -1
  227. package/dist/popover/createOverlayPosition.d.ts +3 -3
  228. package/dist/popover/createOverlayPosition.d.ts.map +1 -1
  229. package/dist/popover/createPopover.d.ts +4 -4
  230. package/dist/popover/createPopover.d.ts.map +1 -1
  231. package/dist/popover/index.d.ts +3 -3
  232. package/dist/progress/createProgressBar.d.ts +7 -5
  233. package/dist/progress/createProgressBar.d.ts.map +1 -1
  234. package/dist/progress/index.d.ts +1 -1
  235. package/dist/radio/createRadio.d.ts +7 -7
  236. package/dist/radio/createRadio.d.ts.map +1 -1
  237. package/dist/radio/createRadioGroup.d.ts +11 -11
  238. package/dist/radio/createRadioGroup.d.ts.map +1 -1
  239. package/dist/radio/createRadioGroupState.d.ts +3 -3
  240. package/dist/radio/createRadioGroupState.d.ts.map +1 -1
  241. package/dist/radio/index.d.ts +3 -3
  242. package/dist/radio/index.d.ts.map +1 -1
  243. package/dist/searchfield/createSearchField.d.ts +7 -7
  244. package/dist/searchfield/createSearchField.d.ts.map +1 -1
  245. package/dist/searchfield/index.d.ts +2 -2
  246. package/dist/select/createHiddenSelect.d.ts +4 -4
  247. package/dist/select/createHiddenSelect.d.ts.map +1 -1
  248. package/dist/select/createSelect.d.ts +14 -6
  249. package/dist/select/createSelect.d.ts.map +1 -1
  250. package/dist/select/index.d.ts +2 -2
  251. package/dist/select/index.d.ts.map +1 -1
  252. package/dist/selection/createTypeSelect.d.ts +2 -2
  253. package/dist/selection/index.d.ts +1 -1
  254. package/dist/separator/createSeparator.d.ts +9 -5
  255. package/dist/separator/createSeparator.d.ts.map +1 -1
  256. package/dist/separator/index.d.ts +1 -1
  257. package/dist/slider/createSlider.d.ts +11 -7
  258. package/dist/slider/createSlider.d.ts.map +1 -1
  259. package/dist/slider/index.d.ts +2 -2
  260. package/dist/ssr/index.d.ts +1 -1
  261. package/dist/ssr/index.d.ts.map +1 -1
  262. package/dist/steplist/createStepList.d.ts +36 -0
  263. package/dist/steplist/createStepList.d.ts.map +1 -0
  264. package/dist/steplist/index.d.ts +2 -0
  265. package/dist/steplist/index.d.ts.map +1 -0
  266. package/dist/switch/createSwitch.d.ts +6 -4
  267. package/dist/switch/createSwitch.d.ts.map +1 -1
  268. package/dist/switch/index.d.ts +1 -1
  269. package/dist/table/createTable.d.ts +3 -3
  270. package/dist/table/createTable.d.ts.map +1 -1
  271. package/dist/table/createTableCell.d.ts +3 -3
  272. package/dist/table/createTableCell.d.ts.map +1 -1
  273. package/dist/table/createTableColumnHeader.d.ts +3 -3
  274. package/dist/table/createTableColumnHeader.d.ts.map +1 -1
  275. package/dist/table/createTableColumnResize.d.ts +41 -0
  276. package/dist/table/createTableColumnResize.d.ts.map +1 -0
  277. package/dist/table/createTableHeaderRow.d.ts +3 -3
  278. package/dist/table/createTableRow.d.ts +3 -3
  279. package/dist/table/createTableRow.d.ts.map +1 -1
  280. package/dist/table/createTableRowGroup.d.ts +2 -2
  281. package/dist/table/createTableRowGroup.d.ts.map +1 -1
  282. package/dist/table/createTableSelectAllCheckbox.d.ts +3 -3
  283. package/dist/table/createTableSelectAllCheckbox.d.ts.map +1 -1
  284. package/dist/table/createTableSelectionCheckbox.d.ts +3 -3
  285. package/dist/table/index.d.ts +11 -9
  286. package/dist/table/index.d.ts.map +1 -1
  287. package/dist/table/types.d.ts +15 -7
  288. package/dist/table/types.d.ts.map +1 -1
  289. package/dist/tabs/createTabs.d.ts +28 -25
  290. package/dist/tabs/createTabs.d.ts.map +1 -1
  291. package/dist/tabs/index.d.ts +1 -1
  292. package/dist/tag/createTag.d.ts +2 -2
  293. package/dist/tag/createTag.d.ts.map +1 -1
  294. package/dist/tag/createTagGroup.d.ts +5 -5
  295. package/dist/tag/createTagGroup.d.ts.map +1 -1
  296. package/dist/tag/index.d.ts +2 -2
  297. package/dist/tag/index.d.ts.map +1 -1
  298. package/dist/textfield/createTextField.d.ts +17 -11
  299. package/dist/textfield/createTextField.d.ts.map +1 -1
  300. package/dist/textfield/index.d.ts +1 -1
  301. package/dist/textfield/index.d.ts.map +1 -1
  302. package/dist/toast/createToast.d.ts +6 -2
  303. package/dist/toast/createToast.d.ts.map +1 -1
  304. package/dist/toast/createToastRegion.d.ts +5 -3
  305. package/dist/toast/createToastRegion.d.ts.map +1 -1
  306. package/dist/toast/index.d.ts +2 -2
  307. package/dist/toast/index.d.ts.map +1 -1
  308. package/dist/toggle/createToggle.d.ts +9 -9
  309. package/dist/toggle/createToggle.d.ts.map +1 -1
  310. package/dist/toggle/createToggleState.d.ts +2 -2
  311. package/dist/toggle/createToggleState.d.ts.map +1 -1
  312. package/dist/toggle/index.d.ts +4 -4
  313. package/dist/toggle/index.d.ts.map +1 -1
  314. package/dist/toolbar/createToolbar.d.ts +9 -9
  315. package/dist/toolbar/createToolbar.d.ts.map +1 -1
  316. package/dist/toolbar/index.d.ts +1 -1
  317. package/dist/toolbar/index.d.ts.map +1 -1
  318. package/dist/tooltip/createTooltip.d.ts +5 -5
  319. package/dist/tooltip/createTooltip.d.ts.map +1 -1
  320. package/dist/tooltip/createTooltipTrigger.d.ts +10 -5
  321. package/dist/tooltip/createTooltipTrigger.d.ts.map +1 -1
  322. package/dist/tooltip/index.d.ts +2 -2
  323. package/dist/tree/createTree.d.ts +3 -3
  324. package/dist/tree/createTree.d.ts.map +1 -1
  325. package/dist/tree/createTreeItem.d.ts +4 -4
  326. package/dist/tree/createTreeItem.d.ts.map +1 -1
  327. package/dist/tree/createTreeSelectionCheckbox.d.ts +3 -3
  328. package/dist/tree/createTreeSelectionCheckbox.d.ts.map +1 -1
  329. package/dist/tree/index.d.ts +4 -4
  330. package/dist/tree/types.d.ts +13 -5
  331. package/dist/tree/types.d.ts.map +1 -1
  332. package/dist/utils/createDescription.d.ts +2 -2
  333. package/dist/utils/createDescription.d.ts.map +1 -1
  334. package/dist/utils/dom.d.ts.map +1 -1
  335. package/dist/utils/env.d.ts +1 -1
  336. package/dist/utils/env.d.ts.map +1 -1
  337. package/dist/utils/focus.d.ts +1 -1
  338. package/dist/utils/focus.d.ts.map +1 -1
  339. package/dist/utils/geometry.d.ts.map +1 -1
  340. package/dist/utils/index.d.ts +12 -12
  341. package/dist/utils/index.d.ts.map +1 -1
  342. package/dist/utils/mergeProps.d.ts.map +1 -1
  343. package/dist/utils/platform.d.ts.map +1 -1
  344. package/dist/utils/reactivity.d.ts +1 -1
  345. package/dist/visually-hidden/createVisuallyHidden.d.ts +2 -2
  346. package/dist/visually-hidden/createVisuallyHidden.d.ts.map +1 -1
  347. package/dist/visually-hidden/index.d.ts +1 -1
  348. package/package.json +34 -32
  349. package/src/actiongroup/createActionGroup.ts +334 -0
  350. package/src/actiongroup/index.ts +8 -0
  351. package/src/autocomplete/createAutocomplete.ts +137 -131
  352. package/src/autocomplete/index.ts +1 -1
  353. package/src/breadcrumbs/createBreadcrumbs.ts +37 -51
  354. package/src/breadcrumbs/index.ts +1 -1
  355. package/src/button/createButton.ts +102 -73
  356. package/src/button/createToggleButton.ts +10 -10
  357. package/src/button/createToggleButtonGroup.ts +121 -0
  358. package/src/button/index.ts +10 -4
  359. package/src/button/types.ts +18 -12
  360. package/src/calendar/createCalendar.ts +62 -29
  361. package/src/calendar/createCalendarCell.ts +102 -48
  362. package/src/calendar/createCalendarGrid.ts +78 -47
  363. package/src/calendar/createRangeCalendar.ts +66 -31
  364. package/src/calendar/createRangeCalendarCell.ts +115 -37
  365. package/src/calendar/index.ts +5 -9
  366. package/src/calendar/intl/index.ts +210 -0
  367. package/src/calendar/utils.ts +227 -0
  368. package/src/checkbox/createCheckbox.ts +13 -21
  369. package/src/checkbox/createCheckboxGroup.ts +86 -45
  370. package/src/checkbox/createCheckboxGroupItem.ts +16 -27
  371. package/src/checkbox/createCheckboxGroupState.ts +3 -22
  372. package/src/checkbox/index.ts +8 -10
  373. package/src/collections/index.ts +246 -0
  374. package/src/color/createColorArea.ts +458 -314
  375. package/src/color/createColorField.ts +186 -137
  376. package/src/color/createColorSlider.ts +444 -197
  377. package/src/color/createColorSwatch.ts +65 -40
  378. package/src/color/createColorWheel.ts +343 -208
  379. package/src/color/index.ts +24 -24
  380. package/src/color/types.ts +198 -116
  381. package/src/combobox/createComboBox.ts +727 -647
  382. package/src/combobox/index.ts +6 -6
  383. package/src/combobox/intl/index.ts +5 -5
  384. package/src/datepicker/createDateField.ts +192 -39
  385. package/src/datepicker/createDatePicker.ts +294 -63
  386. package/src/datepicker/createDatePickerGroup.ts +149 -0
  387. package/src/datepicker/createDateRangePicker.ts +294 -0
  388. package/src/datepicker/createDateSegment.ts +316 -75
  389. package/src/datepicker/createTimeField.ts +38 -34
  390. package/src/datepicker/createTimeSegment.ts +352 -0
  391. package/src/datepicker/index.ts +24 -11
  392. package/src/dialog/createDialog.ts +127 -120
  393. package/src/dialog/index.ts +2 -2
  394. package/src/dialog/types.ts +19 -19
  395. package/src/disclosure/createDisclosure.ts +138 -33
  396. package/src/disclosure/createDisclosureGroup.ts +8 -18
  397. package/src/disclosure/index.ts +2 -2
  398. package/src/dnd/createDrag.ts +218 -209
  399. package/src/dnd/createDraggableCollection.ts +96 -63
  400. package/src/dnd/createDraggableItem.ts +260 -243
  401. package/src/dnd/createDrop.ts +313 -321
  402. package/src/dnd/createDroppableCollection.ts +799 -293
  403. package/src/dnd/createDroppableItem.ts +215 -213
  404. package/src/dnd/index.ts +66 -47
  405. package/src/dnd/types.ts +86 -89
  406. package/src/dnd/utils.ts +281 -294
  407. package/src/focus/FocusScope.tsx +155 -164
  408. package/src/focus/createAutoFocus.ts +305 -321
  409. package/src/focus/createFocusRestore.ts +300 -313
  410. package/src/focus/createVirtualFocus.ts +380 -396
  411. package/src/focus/index.ts +4 -8
  412. package/src/form/createFormReset.ts +4 -4
  413. package/src/form/createFormValidation.ts +201 -224
  414. package/src/form/index.ts +8 -11
  415. package/src/grid/GridKeyboardDelegate.ts +30 -30
  416. package/src/grid/createGrid.ts +38 -36
  417. package/src/grid/createGridCell.ts +18 -18
  418. package/src/grid/createGridRow.ts +14 -14
  419. package/src/grid/index.ts +5 -5
  420. package/src/grid/types.ts +8 -8
  421. package/src/gridlist/createGridList.ts +45 -24
  422. package/src/gridlist/createGridListItem.ts +68 -23
  423. package/src/gridlist/createGridListSelectionCheckbox.ts +12 -9
  424. package/src/gridlist/index.ts +4 -4
  425. package/src/gridlist/types.ts +11 -7
  426. package/src/i18n/createCollator.ts +66 -79
  427. package/src/i18n/createDateFormatter.ts +75 -83
  428. package/src/i18n/createFilter.ts +118 -131
  429. package/src/i18n/createNumberFormatter.ts +50 -52
  430. package/src/i18n/createStringFormatter.ts +19 -15
  431. package/src/i18n/index.ts +37 -40
  432. package/src/i18n/locale.tsx +163 -188
  433. package/src/i18n/utils.ts +95 -99
  434. package/src/index.ts +114 -164
  435. package/src/interactions/FocusableProvider.tsx +3 -7
  436. package/src/interactions/PressEvent.ts +4 -4
  437. package/src/interactions/createFocus.ts +16 -11
  438. package/src/interactions/createFocusRing.ts +21 -19
  439. package/src/interactions/createFocusWithin.ts +24 -16
  440. package/src/interactions/createFocusable.ts +15 -16
  441. package/src/interactions/createHover.ts +70 -55
  442. package/src/interactions/createInteractionModality.ts +75 -82
  443. package/src/interactions/createKeyboard.ts +2 -2
  444. package/src/interactions/createLongPress.ts +174 -174
  445. package/src/interactions/createMove.ts +299 -289
  446. package/src/interactions/createPress.ts +168 -91
  447. package/src/interactions/index.ts +24 -16
  448. package/src/label/createField.ts +18 -19
  449. package/src/label/createLabel.ts +18 -30
  450. package/src/label/createLabels.ts +8 -12
  451. package/src/label/index.ts +5 -5
  452. package/src/landmark/createLandmark.ts +356 -377
  453. package/src/landmark/index.ts +8 -8
  454. package/src/link/createLink.ts +96 -54
  455. package/src/link/index.ts +1 -1
  456. package/src/listbox/createListBox.ts +319 -269
  457. package/src/listbox/createOption.ts +208 -151
  458. package/src/listbox/index.ts +8 -12
  459. package/src/live-announcer/announce.ts +295 -322
  460. package/src/live-announcer/index.ts +9 -9
  461. package/src/menu/createMenu.ts +434 -396
  462. package/src/menu/createMenuItem.ts +201 -149
  463. package/src/menu/createMenuTrigger.ts +88 -88
  464. package/src/menu/index.ts +9 -18
  465. package/src/meter/createMeter.ts +7 -20
  466. package/src/meter/index.ts +1 -1
  467. package/src/numberfield/createNumberField.ts +368 -268
  468. package/src/numberfield/index.ts +5 -5
  469. package/src/overlays/ariaHideOutside.ts +223 -219
  470. package/src/overlays/createInteractOutside.ts +152 -149
  471. package/src/overlays/createModal.tsx +238 -202
  472. package/src/overlays/createOverlay.ts +195 -155
  473. package/src/overlays/createOverlayTrigger.ts +85 -85
  474. package/src/overlays/createPreventScroll.ts +288 -266
  475. package/src/overlays/index.ts +37 -44
  476. package/src/popover/calculatePosition.ts +117 -119
  477. package/src/popover/createOverlayPosition.ts +52 -43
  478. package/src/popover/createPopover.ts +63 -24
  479. package/src/popover/index.ts +3 -3
  480. package/src/progress/createProgressBar.ts +36 -32
  481. package/src/progress/index.ts +1 -1
  482. package/src/radio/createRadio.ts +95 -73
  483. package/src/radio/createRadioGroup.ts +142 -62
  484. package/src/radio/createRadioGroupState.ts +7 -31
  485. package/src/radio/index.ts +3 -8
  486. package/src/searchfield/createSearchField.ts +269 -186
  487. package/src/searchfield/index.ts +2 -2
  488. package/src/select/createHiddenSelect.tsx +276 -236
  489. package/src/select/createSelect.ts +430 -395
  490. package/src/select/index.ts +9 -14
  491. package/src/selection/createTypeSelect.ts +11 -11
  492. package/src/selection/index.ts +1 -1
  493. package/src/separator/createSeparator.ts +20 -25
  494. package/src/separator/index.ts +1 -1
  495. package/src/slider/createSlider.ts +333 -349
  496. package/src/slider/index.ts +2 -2
  497. package/src/ssr/index.tsx +331 -370
  498. package/src/steplist/createStepList.ts +106 -0
  499. package/src/steplist/index.ts +8 -0
  500. package/src/switch/createSwitch.ts +9 -14
  501. package/src/switch/index.ts +1 -1
  502. package/src/table/createTable.ts +155 -86
  503. package/src/table/createTableCell.ts +17 -16
  504. package/src/table/createTableColumnHeader.ts +67 -20
  505. package/src/table/createTableColumnResize.ts +256 -0
  506. package/src/table/createTableHeaderRow.ts +7 -7
  507. package/src/table/createTableRow.ts +149 -29
  508. package/src/table/createTableRowGroup.ts +5 -7
  509. package/src/table/createTableSelectAllCheckbox.ts +12 -11
  510. package/src/table/createTableSelectionCheckbox.ts +8 -8
  511. package/src/table/index.ts +14 -9
  512. package/src/table/types.ts +15 -7
  513. package/src/tabs/createTabs.ts +138 -127
  514. package/src/tabs/index.ts +1 -1
  515. package/src/tag/createTag.ts +171 -40
  516. package/src/tag/createTagGroup.ts +50 -39
  517. package/src/tag/index.ts +2 -6
  518. package/src/textfield/createTextField.ts +67 -35
  519. package/src/textfield/index.ts +1 -5
  520. package/src/toast/createToast.ts +34 -26
  521. package/src/toast/createToastRegion.ts +169 -27
  522. package/src/toast/index.ts +2 -6
  523. package/src/toggle/createToggle.ts +95 -53
  524. package/src/toggle/createToggleState.ts +2 -10
  525. package/src/toggle/index.ts +4 -5
  526. package/src/toolbar/createToolbar.ts +226 -169
  527. package/src/toolbar/index.ts +1 -1
  528. package/src/tooltip/createTooltip.ts +66 -79
  529. package/src/tooltip/createTooltipTrigger.ts +238 -222
  530. package/src/tooltip/index.ts +6 -6
  531. package/src/tree/createTree.ts +259 -246
  532. package/src/tree/createTreeItem.ts +282 -233
  533. package/src/tree/createTreeSelectionCheckbox.ts +71 -68
  534. package/src/tree/index.ts +16 -16
  535. package/src/tree/types.ts +95 -87
  536. package/src/utils/createDescription.ts +6 -23
  537. package/src/utils/dom.ts +61 -54
  538. package/src/utils/env.ts +53 -54
  539. package/src/utils/events.ts +7 -7
  540. package/src/utils/filterDOMProps.ts +49 -49
  541. package/src/utils/focus.ts +60 -68
  542. package/src/utils/geometry.ts +1 -4
  543. package/src/utils/globalListeners.ts +9 -9
  544. package/src/utils/index.ts +12 -22
  545. package/src/utils/mergeProps.ts +42 -15
  546. package/src/utils/platform.ts +16 -6
  547. package/src/utils/reactivity.ts +3 -3
  548. package/src/utils/textSelection.ts +16 -16
  549. package/src/visually-hidden/createVisuallyHidden.ts +127 -124
  550. package/src/visually-hidden/index.ts +6 -6
  551. package/dist/i18n/NumberFormatter.d.ts +0 -43
  552. package/dist/i18n/NumberFormatter.d.ts.map +0 -1
  553. package/dist/index.ssr.js +0 -15875
  554. package/dist/index.ssr.js.map +0 -7
  555. package/src/i18n/NumberFormatter.ts +0 -266
@@ -1,321 +1,313 @@
1
- /**
2
- * createDrop - ARIA hook for drop operations.
3
- *
4
- * Provides accessibility props for drop target elements with support for
5
- * mouse, touch, and keyboard interactions.
6
- */
7
-
8
- import { createMemo, type Accessor } from 'solid-js';
9
- import { createDropState } from '@proyecto-viviana/solid-stately';
10
- import type { AriaDropOptions, DropAria } from './types';
11
- import {
12
- readFromDataTransfer,
13
- DragTypesImpl,
14
- DROP_OPERATION,
15
- DROP_OPERATION_ALLOWED,
16
- DROP_OPERATION_TO_DROP_EFFECT,
17
- DROP_EFFECT_TO_DROP_OPERATION,
18
- setGlobalDropEffect,
19
- getGlobalAllowedDropOperations,
20
- } from './utils';
21
- import type { DropOperation } from '@proyecto-viviana/solid-stately';
22
-
23
- const DROP_ACTIVATE_TIMEOUT = 800;
24
-
25
- /**
26
- * Creates ARIA props for a drop target element.
27
- *
28
- * @param props - Accessor returning drop options
29
- * @returns Drop ARIA props and state
30
- */
31
- export function createDrop(props: Accessor<AriaDropOptions>): DropAria {
32
- const getProps = createMemo(() => props());
33
-
34
- // Create drop state
35
- const state = createDropState(() => ({
36
- getDropOperation: getProps().getDropOperation,
37
- onDropEnter: getProps().onDropEnter,
38
- onDropMove: getProps().onDropMove,
39
- onDropActivate: getProps().onDropActivate,
40
- onDropExit: getProps().onDropExit,
41
- onDrop: getProps().onDrop,
42
- isDisabled: getProps().isDisabled,
43
- }));
44
-
45
- // Track internal state
46
- let x = 0;
47
- let y = 0;
48
- let dragOverElements = new Set<Element>();
49
- let dropEffect: DataTransfer['dropEffect'] = 'none';
50
- let allowedOperations = DROP_OPERATION.all;
51
- let dropActivateTimer: ReturnType<typeof setTimeout> | undefined;
52
-
53
- const fireDropEnter = (e: DragEvent) => {
54
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
55
- state.enterTarget(e.clientX - rect.x, e.clientY - rect.y);
56
- };
57
-
58
- const fireDropExit = (e: DragEvent) => {
59
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
60
- state.exitTarget(e.clientX - rect.x, e.clientY - rect.y);
61
- };
62
-
63
- const getAllowedOperations = (e: DragEvent): number => {
64
- let allowed = DROP_OPERATION_ALLOWED[e.dataTransfer?.effectAllowed ?? 'none'] ?? DROP_OPERATION.none;
65
-
66
- // Use global allowed operations if set (for internal drags)
67
- const globalAllowed = getGlobalAllowedDropOperations();
68
- if (globalAllowed) {
69
- allowed &= globalAllowed;
70
- }
71
-
72
- // Handle modifier keys for operation switching
73
- let modifierAllowed = DROP_OPERATION.none;
74
-
75
- // macOS: Alt=copy, Ctrl=link, Cmd=move
76
- // Windows/Linux: Alt=link, Shift=move, Ctrl=copy
77
- const isMac = typeof navigator !== 'undefined' && /mac/i.test(navigator.platform);
78
-
79
- if (isMac) {
80
- if (e.altKey) modifierAllowed |= DROP_OPERATION.copy;
81
- if (e.ctrlKey) modifierAllowed |= DROP_OPERATION.link;
82
- if (e.metaKey) modifierAllowed |= DROP_OPERATION.move;
83
- } else {
84
- if (e.altKey) modifierAllowed |= DROP_OPERATION.link;
85
- if (e.shiftKey) modifierAllowed |= DROP_OPERATION.move;
86
- if (e.ctrlKey) modifierAllowed |= DROP_OPERATION.copy;
87
- }
88
-
89
- if (modifierAllowed) {
90
- return allowed & modifierAllowed;
91
- }
92
-
93
- return allowed;
94
- };
95
-
96
- const allowedOperationsToArray = (ops: number): DropOperation[] => {
97
- const result: DropOperation[] = [];
98
- if (ops & DROP_OPERATION.move) result.push('move');
99
- if (ops & DROP_OPERATION.copy) result.push('copy');
100
- if (ops & DROP_OPERATION.link) result.push('link');
101
- return result;
102
- };
103
-
104
- const getDropOperationForAllowed = (allowed: number, operation: DropOperation): DropOperation => {
105
- const op = DROP_OPERATION[operation];
106
- return allowed & op ? operation : 'cancel';
107
- };
108
-
109
- const onDragEnter = (e: DragEvent) => {
110
- e.preventDefault();
111
- e.stopPropagation();
112
-
113
- dragOverElements.add(e.target as Element);
114
- if (dragOverElements.size > 1) {
115
- return;
116
- }
117
-
118
- const p = getProps();
119
- const allowedOpsBits = getAllowedOperations(e);
120
- const allowedOps = allowedOperationsToArray(allowedOpsBits);
121
- let dropOp: DropOperation = allowedOps[0] ?? 'cancel';
122
-
123
- if (typeof p.getDropOperation === 'function' && e.dataTransfer) {
124
- const types = new DragTypesImpl(e.dataTransfer);
125
- dropOp = getDropOperationForAllowed(
126
- allowedOpsBits,
127
- p.getDropOperation(types, allowedOps)
128
- );
129
- }
130
-
131
- if (typeof p.getDropOperationForPoint === 'function' && e.dataTransfer) {
132
- const types = new DragTypesImpl(e.dataTransfer);
133
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
134
- dropOp = getDropOperationForAllowed(
135
- allowedOpsBits,
136
- p.getDropOperationForPoint(types, allowedOps, e.clientX - rect.x, e.clientY - rect.y)
137
- );
138
- }
139
-
140
- x = e.clientX;
141
- y = e.clientY;
142
- allowedOperations = allowedOpsBits;
143
- dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || 'none') as DataTransfer['dropEffect'];
144
-
145
- if (e.dataTransfer) {
146
- e.dataTransfer.dropEffect = dropEffect;
147
- }
148
-
149
- if (dropOp !== 'cancel') {
150
- fireDropEnter(e);
151
- }
152
- };
153
-
154
- const onDragOver = (e: DragEvent) => {
155
- e.preventDefault();
156
- e.stopPropagation();
157
-
158
- const allowedOpsBits = getAllowedOperations(e);
159
-
160
- // Skip if position and operations haven't changed
161
- if (e.clientX === x && e.clientY === y && allowedOpsBits === allowedOperations) {
162
- if (e.dataTransfer) {
163
- e.dataTransfer.dropEffect = dropEffect;
164
- }
165
- return;
166
- }
167
-
168
- x = e.clientX;
169
- y = e.clientY;
170
-
171
- const prevDropEffect = dropEffect;
172
- const p = getProps();
173
-
174
- // Update drop effect if allowed operations changed
175
- if (allowedOpsBits !== allowedOperations) {
176
- const allowedOps = allowedOperationsToArray(allowedOpsBits);
177
- let dropOp: DropOperation = allowedOps[0] ?? 'cancel';
178
-
179
- if (typeof p.getDropOperation === 'function' && e.dataTransfer) {
180
- const types = new DragTypesImpl(e.dataTransfer);
181
- dropOp = getDropOperationForAllowed(
182
- allowedOpsBits,
183
- p.getDropOperation(types, allowedOps)
184
- );
185
- }
186
- dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || 'none') as DataTransfer['dropEffect'];
187
- }
188
-
189
- // Check point-specific operation
190
- if (typeof p.getDropOperationForPoint === 'function' && e.dataTransfer) {
191
- const types = new DragTypesImpl(e.dataTransfer);
192
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
193
- const dropOp = getDropOperationForAllowed(
194
- allowedOpsBits,
195
- p.getDropOperationForPoint(types, allowedOperationsToArray(allowedOpsBits), x - rect.x, y - rect.y)
196
- );
197
- dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || 'none') as DataTransfer['dropEffect'];
198
- }
199
-
200
- allowedOperations = allowedOpsBits;
201
-
202
- if (e.dataTransfer) {
203
- e.dataTransfer.dropEffect = dropEffect;
204
- }
205
-
206
- // Fire enter/exit events on drop effect change
207
- if (dropEffect === 'none' && prevDropEffect !== 'none') {
208
- fireDropExit(e);
209
- } else if (dropEffect !== 'none' && prevDropEffect === 'none') {
210
- fireDropEnter(e);
211
- }
212
-
213
- // Fire move event
214
- if (dropEffect !== 'none') {
215
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
216
- state.moveInTarget(x - rect.x, y - rect.y);
217
- }
218
-
219
- // Handle drop activate timer
220
- clearTimeout(dropActivateTimer);
221
-
222
- if (typeof p.onDropActivate === 'function' && dropEffect !== 'none') {
223
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
224
- const activateX = x - rect.x;
225
- const activateY = y - rect.y;
226
- dropActivateTimer = setTimeout(() => {
227
- state.activateTarget(activateX, activateY);
228
- }, DROP_ACTIVATE_TIMEOUT);
229
- }
230
- };
231
-
232
- const onDragLeave = (e: DragEvent) => {
233
- e.preventDefault();
234
- e.stopPropagation();
235
-
236
- // Track drag over elements (WebKit workaround for relatedTarget being null)
237
- dragOverElements.delete(e.target as Element);
238
-
239
- // Remove elements no longer in DOM
240
- for (const element of dragOverElements) {
241
- if (!e.currentTarget || !(e.currentTarget as Element).contains(element)) {
242
- dragOverElements.delete(element);
243
- }
244
- }
245
-
246
- if (dragOverElements.size > 0) {
247
- return;
248
- }
249
-
250
- if (dropEffect !== 'none') {
251
- fireDropExit(e);
252
- }
253
-
254
- clearTimeout(dropActivateTimer);
255
- };
256
-
257
- const onDropHandler = (e: DragEvent) => {
258
- e.preventDefault();
259
- e.stopPropagation();
260
-
261
- // Track drop effect globally for Chrome Android
262
- setGlobalDropEffect(dropEffect);
263
-
264
- const p = getProps();
265
- if (typeof p.onDrop === 'function' && e.dataTransfer) {
266
- const items = readFromDataTransfer(e.dataTransfer);
267
- const dropOperation = DROP_EFFECT_TO_DROP_OPERATION[dropEffect];
268
- const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
269
-
270
- state.drop(e.clientX - rect.x, e.clientY - rect.y, items, dropOperation);
271
- }
272
-
273
- dragOverElements.clear();
274
- fireDropExit(e);
275
- clearTimeout(dropActivateTimer);
276
- };
277
-
278
- const dropProps = createMemo(() => {
279
- const p = getProps();
280
-
281
- if (p.isDisabled) {
282
- return {};
283
- }
284
-
285
- const baseProps: Record<string, unknown> = {
286
- onDragEnter,
287
- onDragOver,
288
- onDragLeave,
289
- onDrop: onDropHandler,
290
- };
291
-
292
- return baseProps;
293
- });
294
-
295
- const dropButtonProps = createMemo(() => {
296
- const p = getProps();
297
-
298
- if (p.isDisabled) {
299
- return {
300
- disabled: true,
301
- };
302
- }
303
-
304
- return {
305
- type: 'button' as const,
306
- 'aria-label': 'Drop',
307
- };
308
- });
309
-
310
- return {
311
- get dropProps() {
312
- return dropProps() as DropAria['dropProps'];
313
- },
314
- get isDropTarget() {
315
- return state.isDropTarget;
316
- },
317
- get dropButtonProps() {
318
- return dropButtonProps() as DropAria['dropButtonProps'];
319
- },
320
- };
321
- }
1
+ /**
2
+ * createDrop - ARIA hook for drop operations.
3
+ *
4
+ * Provides accessibility props for drop target elements with support for
5
+ * mouse, touch, and keyboard interactions.
6
+ */
7
+
8
+ import { createMemo, type Accessor } from "solid-js";
9
+ import { createDropState } from "@proyecto-viviana/solid-stately";
10
+ import type { AriaDropOptions, DropAria } from "./types";
11
+ import {
12
+ readFromDataTransfer,
13
+ DragTypesImpl,
14
+ DROP_OPERATION,
15
+ DROP_OPERATION_ALLOWED,
16
+ DROP_OPERATION_TO_DROP_EFFECT,
17
+ DROP_EFFECT_TO_DROP_OPERATION,
18
+ setGlobalDropEffect,
19
+ getGlobalAllowedDropOperations,
20
+ } from "./utils";
21
+ import type { DropOperation } from "@proyecto-viviana/solid-stately";
22
+
23
+ const DROP_ACTIVATE_TIMEOUT = 800;
24
+
25
+ /**
26
+ * Creates ARIA props for a drop target element.
27
+ *
28
+ * @param props - Accessor returning drop options
29
+ * @returns Drop ARIA props and state
30
+ */
31
+ export function createDrop(props: Accessor<AriaDropOptions>): DropAria {
32
+ const getProps = createMemo(() => props());
33
+
34
+ const state = createDropState(() => ({
35
+ getDropOperation: getProps().getDropOperation,
36
+ onDropEnter: getProps().onDropEnter,
37
+ onDropMove: getProps().onDropMove,
38
+ onDropActivate: getProps().onDropActivate,
39
+ onDropExit: getProps().onDropExit,
40
+ onDrop: getProps().onDrop,
41
+ hasDropButton: getProps().hasDropButton,
42
+ isDisabled: getProps().isDisabled,
43
+ }));
44
+
45
+ let x = 0;
46
+ let y = 0;
47
+ let dragOverElements = new Set<Element>();
48
+ let dropEffect: DataTransfer["dropEffect"] = "none";
49
+ let allowedOperations = DROP_OPERATION.all;
50
+ let dropActivateTimer: ReturnType<typeof setTimeout> | undefined;
51
+
52
+ const fireDropEnter = (e: DragEvent) => {
53
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
54
+ state.enterTarget(e.clientX - rect.x, e.clientY - rect.y);
55
+ };
56
+
57
+ const fireDropExit = (e: DragEvent) => {
58
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
59
+ state.exitTarget(e.clientX - rect.x, e.clientY - rect.y);
60
+ };
61
+
62
+ const getAllowedOperations = (e: DragEvent): number => {
63
+ let allowed =
64
+ DROP_OPERATION_ALLOWED[e.dataTransfer?.effectAllowed ?? "none"] ?? DROP_OPERATION.none;
65
+
66
+ // Use global allowed operations if set (for internal drags)
67
+ const globalAllowed = getGlobalAllowedDropOperations();
68
+ if (globalAllowed) {
69
+ allowed &= globalAllowed;
70
+ }
71
+
72
+ let modifierAllowed = DROP_OPERATION.none;
73
+
74
+ // macOS: Alt=copy, Ctrl=link, Cmd=move
75
+ // Windows/Linux: Alt=link, Shift=move, Ctrl=copy
76
+ const isMac = typeof navigator !== "undefined" && /mac/i.test(navigator.platform);
77
+
78
+ if (isMac) {
79
+ if (e.altKey) modifierAllowed |= DROP_OPERATION.copy;
80
+ if (e.ctrlKey) modifierAllowed |= DROP_OPERATION.link;
81
+ if (e.metaKey) modifierAllowed |= DROP_OPERATION.move;
82
+ } else {
83
+ if (e.altKey) modifierAllowed |= DROP_OPERATION.link;
84
+ if (e.shiftKey) modifierAllowed |= DROP_OPERATION.move;
85
+ if (e.ctrlKey) modifierAllowed |= DROP_OPERATION.copy;
86
+ }
87
+
88
+ if (modifierAllowed) {
89
+ return allowed & modifierAllowed;
90
+ }
91
+
92
+ return allowed;
93
+ };
94
+
95
+ const allowedOperationsToArray = (ops: number): DropOperation[] => {
96
+ const result: DropOperation[] = [];
97
+ if (ops & DROP_OPERATION.move) result.push("move");
98
+ if (ops & DROP_OPERATION.copy) result.push("copy");
99
+ if (ops & DROP_OPERATION.link) result.push("link");
100
+ return result;
101
+ };
102
+
103
+ const getDropOperationForAllowed = (allowed: number, operation: DropOperation): DropOperation => {
104
+ const op = DROP_OPERATION[operation];
105
+ return allowed & op ? operation : "cancel";
106
+ };
107
+
108
+ const onDragEnter = (e: DragEvent) => {
109
+ e.preventDefault();
110
+ e.stopPropagation();
111
+
112
+ dragOverElements.add(e.target as Element);
113
+ if (dragOverElements.size > 1) {
114
+ return;
115
+ }
116
+
117
+ const p = getProps();
118
+ const allowedOpsBits = getAllowedOperations(e);
119
+ const allowedOps = allowedOperationsToArray(allowedOpsBits);
120
+ let dropOp: DropOperation = allowedOps[0] ?? "cancel";
121
+
122
+ if (typeof p.getDropOperation === "function" && e.dataTransfer) {
123
+ const types = new DragTypesImpl(e.dataTransfer);
124
+ dropOp = getDropOperationForAllowed(allowedOpsBits, p.getDropOperation(types, allowedOps));
125
+ }
126
+
127
+ if (typeof p.getDropOperationForPoint === "function" && e.dataTransfer) {
128
+ const types = new DragTypesImpl(e.dataTransfer);
129
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
130
+ dropOp = getDropOperationForAllowed(
131
+ allowedOpsBits,
132
+ p.getDropOperationForPoint(types, allowedOps, e.clientX - rect.x, e.clientY - rect.y),
133
+ );
134
+ }
135
+
136
+ x = e.clientX;
137
+ y = e.clientY;
138
+ allowedOperations = allowedOpsBits;
139
+ dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || "none") as DataTransfer["dropEffect"];
140
+
141
+ if (e.dataTransfer) {
142
+ e.dataTransfer.dropEffect = dropEffect;
143
+ }
144
+
145
+ if (dropOp !== "cancel") {
146
+ fireDropEnter(e);
147
+ }
148
+ };
149
+
150
+ const onDragOver = (e: DragEvent) => {
151
+ e.preventDefault();
152
+ e.stopPropagation();
153
+
154
+ const allowedOpsBits = getAllowedOperations(e);
155
+
156
+ // Skip if position and operations haven't changed
157
+ if (e.clientX === x && e.clientY === y && allowedOpsBits === allowedOperations) {
158
+ if (e.dataTransfer) {
159
+ e.dataTransfer.dropEffect = dropEffect;
160
+ }
161
+ return;
162
+ }
163
+
164
+ x = e.clientX;
165
+ y = e.clientY;
166
+
167
+ const prevDropEffect = dropEffect;
168
+ const p = getProps();
169
+
170
+ if (allowedOpsBits !== allowedOperations) {
171
+ const allowedOps = allowedOperationsToArray(allowedOpsBits);
172
+ let dropOp: DropOperation = allowedOps[0] ?? "cancel";
173
+
174
+ if (typeof p.getDropOperation === "function" && e.dataTransfer) {
175
+ const types = new DragTypesImpl(e.dataTransfer);
176
+ dropOp = getDropOperationForAllowed(allowedOpsBits, p.getDropOperation(types, allowedOps));
177
+ }
178
+ dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || "none") as DataTransfer["dropEffect"];
179
+ }
180
+
181
+ if (typeof p.getDropOperationForPoint === "function" && e.dataTransfer) {
182
+ const types = new DragTypesImpl(e.dataTransfer);
183
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
184
+ const dropOp = getDropOperationForAllowed(
185
+ allowedOpsBits,
186
+ p.getDropOperationForPoint(
187
+ types,
188
+ allowedOperationsToArray(allowedOpsBits),
189
+ x - rect.x,
190
+ y - rect.y,
191
+ ),
192
+ );
193
+ dropEffect = (DROP_OPERATION_TO_DROP_EFFECT[dropOp] || "none") as DataTransfer["dropEffect"];
194
+ }
195
+
196
+ allowedOperations = allowedOpsBits;
197
+
198
+ if (e.dataTransfer) {
199
+ e.dataTransfer.dropEffect = dropEffect;
200
+ }
201
+
202
+ if (dropEffect === "none" && prevDropEffect !== "none") {
203
+ fireDropExit(e);
204
+ } else if (dropEffect !== "none" && prevDropEffect === "none") {
205
+ fireDropEnter(e);
206
+ }
207
+
208
+ if (dropEffect !== "none") {
209
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
210
+ state.moveInTarget(x - rect.x, y - rect.y);
211
+ }
212
+
213
+ clearTimeout(dropActivateTimer);
214
+
215
+ if (typeof p.onDropActivate === "function" && dropEffect !== "none") {
216
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
217
+ const activateX = x - rect.x;
218
+ const activateY = y - rect.y;
219
+ dropActivateTimer = setTimeout(() => {
220
+ state.activateTarget(activateX, activateY);
221
+ }, DROP_ACTIVATE_TIMEOUT);
222
+ }
223
+ };
224
+
225
+ const onDragLeave = (e: DragEvent) => {
226
+ e.preventDefault();
227
+ e.stopPropagation();
228
+
229
+ // Track drag over elements (WebKit workaround for relatedTarget being null)
230
+ dragOverElements.delete(e.target as Element);
231
+
232
+ for (const element of dragOverElements) {
233
+ if (!e.currentTarget || !(e.currentTarget as Element).contains(element)) {
234
+ dragOverElements.delete(element);
235
+ }
236
+ }
237
+
238
+ if (dragOverElements.size > 0) {
239
+ return;
240
+ }
241
+
242
+ if (dropEffect !== "none") {
243
+ fireDropExit(e);
244
+ }
245
+
246
+ clearTimeout(dropActivateTimer);
247
+ };
248
+
249
+ const onDropHandler = (e: DragEvent) => {
250
+ e.preventDefault();
251
+ e.stopPropagation();
252
+
253
+ // Track drop effect globally for Chrome Android
254
+ setGlobalDropEffect(dropEffect);
255
+
256
+ const p = getProps();
257
+ if (typeof p.onDrop === "function" && e.dataTransfer) {
258
+ const items = readFromDataTransfer(e.dataTransfer);
259
+ const dropOperation = DROP_EFFECT_TO_DROP_OPERATION[dropEffect];
260
+ const rect = (e.currentTarget as HTMLElement).getBoundingClientRect();
261
+
262
+ state.drop(e.clientX - rect.x, e.clientY - rect.y, items, dropOperation);
263
+ }
264
+
265
+ dragOverElements.clear();
266
+ fireDropExit(e);
267
+ clearTimeout(dropActivateTimer);
268
+ };
269
+
270
+ const dropProps = createMemo(() => {
271
+ const p = getProps();
272
+
273
+ if (p.isDisabled) {
274
+ return {};
275
+ }
276
+
277
+ const baseProps: Record<string, unknown> = {
278
+ onDragEnter,
279
+ onDragOver,
280
+ onDragLeave,
281
+ onDrop: onDropHandler,
282
+ };
283
+
284
+ return baseProps;
285
+ });
286
+
287
+ const dropButtonProps = createMemo(() => {
288
+ const p = getProps();
289
+
290
+ if (p.isDisabled) {
291
+ return {
292
+ disabled: true,
293
+ };
294
+ }
295
+
296
+ return {
297
+ type: "button" as const,
298
+ "aria-label": "Drop",
299
+ };
300
+ });
301
+
302
+ return {
303
+ get dropProps() {
304
+ return dropProps() as DropAria["dropProps"];
305
+ },
306
+ get isDropTarget() {
307
+ return state.isDropTarget;
308
+ },
309
+ get dropButtonProps() {
310
+ return dropButtonProps() as DropAria["dropButtonProps"];
311
+ },
312
+ };
313
+ }