@vuu-ui/vuu-ui-controls 0.0.26

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 (823) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +0 -0
  3. package/cjs/calendar/Calendar.css.js +6 -0
  4. package/cjs/calendar/Calendar.css.js.map +1 -0
  5. package/cjs/calendar/Calendar.js +74 -0
  6. package/cjs/calendar/Calendar.js.map +1 -0
  7. package/cjs/calendar/internal/CalendarCarousel.css.js +6 -0
  8. package/cjs/calendar/internal/CalendarCarousel.css.js.map +1 -0
  9. package/cjs/calendar/internal/CalendarCarousel.js +97 -0
  10. package/cjs/calendar/internal/CalendarCarousel.js.map +1 -0
  11. package/cjs/calendar/internal/CalendarContext.js +19 -0
  12. package/cjs/calendar/internal/CalendarContext.js.map +1 -0
  13. package/cjs/calendar/internal/CalendarDay.css.js +6 -0
  14. package/cjs/calendar/internal/CalendarDay.css.js.map +1 -0
  15. package/cjs/calendar/internal/CalendarDay.js +83 -0
  16. package/cjs/calendar/internal/CalendarDay.js.map +1 -0
  17. package/cjs/calendar/internal/CalendarMonth.css.js +6 -0
  18. package/cjs/calendar/internal/CalendarMonth.css.js.map +1 -0
  19. package/cjs/calendar/internal/CalendarMonth.js +73 -0
  20. package/cjs/calendar/internal/CalendarMonth.js.map +1 -0
  21. package/cjs/calendar/internal/CalendarNavigation.css.js +6 -0
  22. package/cjs/calendar/internal/CalendarNavigation.css.js.map +1 -0
  23. package/cjs/calendar/internal/CalendarNavigation.js +250 -0
  24. package/cjs/calendar/internal/CalendarNavigation.js.map +1 -0
  25. package/cjs/calendar/internal/CalendarWeekHeader.css.js +6 -0
  26. package/cjs/calendar/internal/CalendarWeekHeader.css.js.map +1 -0
  27. package/cjs/calendar/internal/CalendarWeekHeader.js +43 -0
  28. package/cjs/calendar/internal/CalendarWeekHeader.js.map +1 -0
  29. package/cjs/calendar/internal/useFocusManagement.js +63 -0
  30. package/cjs/calendar/internal/useFocusManagement.js.map +1 -0
  31. package/cjs/calendar/internal/utils.js +63 -0
  32. package/cjs/calendar/internal/utils.js.map +1 -0
  33. package/cjs/calendar/useCalendar.js +131 -0
  34. package/cjs/calendar/useCalendar.js.map +1 -0
  35. package/cjs/calendar/useCalendarDay.js +70 -0
  36. package/cjs/calendar/useCalendarDay.js.map +1 -0
  37. package/cjs/calendar/useSelection.js +242 -0
  38. package/cjs/calendar/useSelection.js.map +1 -0
  39. package/cjs/combo-box/ComboBox.js +191 -0
  40. package/cjs/combo-box/ComboBox.js.map +1 -0
  41. package/cjs/combo-box/useCombobox.js +358 -0
  42. package/cjs/combo-box/useCombobox.js.map +1 -0
  43. package/cjs/common-hooks/collectionProvider.js +24 -0
  44. package/cjs/common-hooks/collectionProvider.js.map +1 -0
  45. package/cjs/common-hooks/isPlainObject.js +6 -0
  46. package/cjs/common-hooks/isPlainObject.js.map +1 -0
  47. package/cjs/common-hooks/itemToString.js +24 -0
  48. package/cjs/common-hooks/itemToString.js.map +1 -0
  49. package/cjs/common-hooks/selectionTypes.js +18 -0
  50. package/cjs/common-hooks/selectionTypes.js.map +1 -0
  51. package/cjs/common-hooks/use-resize-observer.js +123 -0
  52. package/cjs/common-hooks/use-resize-observer.js.map +1 -0
  53. package/cjs/common-hooks/useCollectionItems.js +309 -0
  54. package/cjs/common-hooks/useCollectionItems.js.map +1 -0
  55. package/cjs/common-hooks/useControlled.js +58 -0
  56. package/cjs/common-hooks/useControlled.js.map +1 -0
  57. package/cjs/common-hooks/useSelection.js +212 -0
  58. package/cjs/common-hooks/useSelection.js.map +1 -0
  59. package/cjs/common-hooks/useStateRef.js +23 -0
  60. package/cjs/common-hooks/useStateRef.js.map +1 -0
  61. package/cjs/cycle-state-button/CycleStateButton.js +54 -0
  62. package/cjs/cycle-state-button/CycleStateButton.js.map +1 -0
  63. package/cjs/date-input/DateInput.css.js +6 -0
  64. package/cjs/date-input/DateInput.css.js.map +1 -0
  65. package/cjs/date-input/DateInput.js +90 -0
  66. package/cjs/date-input/DateInput.js.map +1 -0
  67. package/cjs/date-input/DateRangeInput.js +77 -0
  68. package/cjs/date-input/DateRangeInput.js.map +1 -0
  69. package/cjs/date-input/useDatePicker.js +20 -0
  70. package/cjs/date-input/useDatePicker.js.map +1 -0
  71. package/cjs/date-popup/DatePopup.js +90 -0
  72. package/cjs/date-popup/DatePopup.js.map +1 -0
  73. package/cjs/date-popup/useDatePopup.js +77 -0
  74. package/cjs/date-popup/useDatePopup.js.map +1 -0
  75. package/cjs/drag-drop/DragDropProvider.js +145 -0
  76. package/cjs/drag-drop/DragDropProvider.js.map +1 -0
  77. package/cjs/drag-drop/DragDropState.js +29 -0
  78. package/cjs/drag-drop/DragDropState.js.map +1 -0
  79. package/cjs/drag-drop/Draggable.css.js +6 -0
  80. package/cjs/drag-drop/Draggable.css.js.map +1 -0
  81. package/cjs/drag-drop/Draggable.js +95 -0
  82. package/cjs/drag-drop/Draggable.js.map +1 -0
  83. package/cjs/drag-drop/dragDropTypes.js +8 -0
  84. package/cjs/drag-drop/dragDropTypes.js.map +1 -0
  85. package/cjs/drag-drop/drop-target-utils.js +245 -0
  86. package/cjs/drag-drop/drop-target-utils.js.map +1 -0
  87. package/cjs/drag-drop/useAutoScroll.js +71 -0
  88. package/cjs/drag-drop/useAutoScroll.js.map +1 -0
  89. package/cjs/drag-drop/useDragDisplacers.js +160 -0
  90. package/cjs/drag-drop/useDragDisplacers.js.map +1 -0
  91. package/cjs/drag-drop/useDragDrop.js +499 -0
  92. package/cjs/drag-drop/useDragDrop.js.map +1 -0
  93. package/cjs/drag-drop/useDragDropCopy.js +34 -0
  94. package/cjs/drag-drop/useDragDropCopy.js.map +1 -0
  95. package/cjs/drag-drop/useDragDropIndicator.js +251 -0
  96. package/cjs/drag-drop/useDragDropIndicator.js.map +1 -0
  97. package/cjs/drag-drop/useDragDropNaturalMovement.js +264 -0
  98. package/cjs/drag-drop/useDragDropNaturalMovement.js.map +1 -0
  99. package/cjs/drag-drop/useDropIndicator.js +27 -0
  100. package/cjs/drag-drop/useDropIndicator.js.map +1 -0
  101. package/cjs/drag-drop/useGlobalDragDrop.js +89 -0
  102. package/cjs/drag-drop/useGlobalDragDrop.js.map +1 -0
  103. package/cjs/dropdown/Dropdown.css.js +6 -0
  104. package/cjs/dropdown/Dropdown.css.js.map +1 -0
  105. package/cjs/dropdown/Dropdown.js +150 -0
  106. package/cjs/dropdown/Dropdown.js.map +1 -0
  107. package/cjs/dropdown/DropdownBase.js +121 -0
  108. package/cjs/dropdown/DropdownBase.js.map +1 -0
  109. package/cjs/dropdown/DropdownButton.css.js +6 -0
  110. package/cjs/dropdown/DropdownButton.css.js.map +1 -0
  111. package/cjs/dropdown/DropdownButton.js +72 -0
  112. package/cjs/dropdown/DropdownButton.js.map +1 -0
  113. package/cjs/dropdown/useClickAway.js +67 -0
  114. package/cjs/dropdown/useClickAway.js.map +1 -0
  115. package/cjs/dropdown/useDropdown.js +115 -0
  116. package/cjs/dropdown/useDropdown.js.map +1 -0
  117. package/cjs/dropdown/useDropdownBase.js +169 -0
  118. package/cjs/dropdown/useDropdownBase.js.map +1 -0
  119. package/cjs/editable/editable-utils.js +37 -0
  120. package/cjs/editable/editable-utils.js.map +1 -0
  121. package/cjs/editable/useEditableText.js +106 -0
  122. package/cjs/editable/useEditableText.js.map +1 -0
  123. package/cjs/editable-label/EditableLabel.css.js +6 -0
  124. package/cjs/editable-label/EditableLabel.css.js.map +1 -0
  125. package/cjs/editable-label/EditableLabel.js +138 -0
  126. package/cjs/editable-label/EditableLabel.js.map +1 -0
  127. package/cjs/expando-input/ExpandoInput.css.js +6 -0
  128. package/cjs/expando-input/ExpandoInput.css.js.map +1 -0
  129. package/cjs/expando-input/ExpandoInput.js +53 -0
  130. package/cjs/expando-input/ExpandoInput.js.map +1 -0
  131. package/cjs/icon-button/Icon.css.js +6 -0
  132. package/cjs/icon-button/Icon.css.js.map +1 -0
  133. package/cjs/icon-button/Icon.js +37 -0
  134. package/cjs/icon-button/Icon.js.map +1 -0
  135. package/cjs/icon-button/IconButton.css.js +6 -0
  136. package/cjs/icon-button/IconButton.css.js.map +1 -0
  137. package/cjs/icon-button/IconButton.js +26 -0
  138. package/cjs/icon-button/IconButton.js.map +1 -0
  139. package/cjs/index.js +231 -0
  140. package/cjs/index.js.map +1 -0
  141. package/cjs/inputs/Checkbox.css.js +6 -0
  142. package/cjs/inputs/Checkbox.css.js.map +1 -0
  143. package/cjs/inputs/Checkbox.js +32 -0
  144. package/cjs/inputs/Checkbox.js.map +1 -0
  145. package/cjs/inputs/RadioButton.css.js +6 -0
  146. package/cjs/inputs/RadioButton.css.js.map +1 -0
  147. package/cjs/inputs/RadioButton.js +39 -0
  148. package/cjs/inputs/RadioButton.js.map +1 -0
  149. package/cjs/instrument-picker/InstrumentPicker.css.js +6 -0
  150. package/cjs/instrument-picker/InstrumentPicker.css.js.map +1 -0
  151. package/cjs/instrument-picker/InstrumentPicker.js +113 -0
  152. package/cjs/instrument-picker/InstrumentPicker.js.map +1 -0
  153. package/cjs/instrument-picker/SearchCell.css.js +6 -0
  154. package/cjs/instrument-picker/SearchCell.css.js.map +1 -0
  155. package/cjs/instrument-picker/SearchCell.js +33 -0
  156. package/cjs/instrument-picker/SearchCell.js.map +1 -0
  157. package/cjs/instrument-picker/useInstrumentPicker.js +87 -0
  158. package/cjs/instrument-picker/useInstrumentPicker.js.map +1 -0
  159. package/cjs/instrument-search/InstrumentSearch.css.js +6 -0
  160. package/cjs/instrument-search/InstrumentSearch.css.js.map +1 -0
  161. package/cjs/instrument-search/InstrumentSearch.js +96 -0
  162. package/cjs/instrument-search/InstrumentSearch.js.map +1 -0
  163. package/cjs/instrument-search/SearchCell.css.js +6 -0
  164. package/cjs/instrument-search/SearchCell.css.js.map +1 -0
  165. package/cjs/instrument-search/SearchCell.js +33 -0
  166. package/cjs/instrument-search/SearchCell.js.map +1 -0
  167. package/cjs/instrument-search/useInstrumentSearch.js +39 -0
  168. package/cjs/instrument-search/useInstrumentSearch.js.map +1 -0
  169. package/cjs/list/CheckboxIcon.css.js +6 -0
  170. package/cjs/list/CheckboxIcon.css.js.map +1 -0
  171. package/cjs/list/CheckboxIcon.js +33 -0
  172. package/cjs/list/CheckboxIcon.js.map +1 -0
  173. package/cjs/list/ChevronIcon.css.js +6 -0
  174. package/cjs/list/ChevronIcon.css.js.map +1 -0
  175. package/cjs/list/ChevronIcon.js +22 -0
  176. package/cjs/list/ChevronIcon.js.map +1 -0
  177. package/cjs/list/Highlighter.css.js +6 -0
  178. package/cjs/list/Highlighter.css.js.map +1 -0
  179. package/cjs/list/Highlighter.js +36 -0
  180. package/cjs/list/Highlighter.js.map +1 -0
  181. package/cjs/list/List.css.js +6 -0
  182. package/cjs/list/List.css.js.map +1 -0
  183. package/cjs/list/List.js +317 -0
  184. package/cjs/list/List.js.map +1 -0
  185. package/cjs/list/ListItem.css.js +6 -0
  186. package/cjs/list/ListItem.css.js.map +1 -0
  187. package/cjs/list/ListItem.js +84 -0
  188. package/cjs/list/ListItem.js.map +1 -0
  189. package/cjs/list/ListItemGroup.js +6 -0
  190. package/cjs/list/ListItemGroup.js.map +1 -0
  191. package/cjs/list/ListItemHeader.js +6 -0
  192. package/cjs/list/ListItemHeader.js.map +1 -0
  193. package/cjs/list/RadioIcon.css.js +6 -0
  194. package/cjs/list/RadioIcon.css.js.map +1 -0
  195. package/cjs/list/RadioIcon.js +27 -0
  196. package/cjs/list/RadioIcon.js.map +1 -0
  197. package/cjs/list/common-hooks/keyUtils.js +78 -0
  198. package/cjs/list/common-hooks/keyUtils.js.map +1 -0
  199. package/cjs/list/common-hooks/list-dom-utils.js +25 -0
  200. package/cjs/list/common-hooks/list-dom-utils.js.map +1 -0
  201. package/cjs/list/common-hooks/useCollapsibleGroups.js +82 -0
  202. package/cjs/list/common-hooks/useCollapsibleGroups.js.map +1 -0
  203. package/cjs/list/common-hooks/useImperativeScrollingAPI.js +52 -0
  204. package/cjs/list/common-hooks/useImperativeScrollingAPI.js.map +1 -0
  205. package/cjs/list/common-hooks/useKeyboardNavigation.js +289 -0
  206. package/cjs/list/common-hooks/useKeyboardNavigation.js.map +1 -0
  207. package/cjs/list/common-hooks/useTypeahead.js +74 -0
  208. package/cjs/list/common-hooks/useTypeahead.js.map +1 -0
  209. package/cjs/list/common-hooks/useViewportTracking.js +133 -0
  210. package/cjs/list/common-hooks/useViewportTracking.js.map +1 -0
  211. package/cjs/list/common-hooks/utils/collection-item-utils.js +181 -0
  212. package/cjs/list/common-hooks/utils/collection-item-utils.js.map +1 -0
  213. package/cjs/list/common-hooks/utils/filter-utils.js +11 -0
  214. package/cjs/list/common-hooks/utils/filter-utils.js.map +1 -0
  215. package/cjs/list/common-hooks/utils/isSelected.js +9 -0
  216. package/cjs/list/common-hooks/utils/isSelected.js.map +1 -0
  217. package/cjs/list/useList.js +278 -0
  218. package/cjs/list/useList.js.map +1 -0
  219. package/cjs/list/useListDrop.js +92 -0
  220. package/cjs/list/useListDrop.js.map +1 -0
  221. package/cjs/list/useListHeight.js +77 -0
  222. package/cjs/list/useListHeight.js.map +1 -0
  223. package/cjs/list/useScrollPosition.js +74 -0
  224. package/cjs/list/useScrollPosition.js.map +1 -0
  225. package/cjs/measured-container/MeasuredContainer.css.js +6 -0
  226. package/cjs/measured-container/MeasuredContainer.css.js.map +1 -0
  227. package/cjs/measured-container/MeasuredContainer.js +69 -0
  228. package/cjs/measured-container/MeasuredContainer.js.map +1 -0
  229. package/cjs/measured-container/useMeasuredContainer.js +127 -0
  230. package/cjs/measured-container/useMeasuredContainer.js.map +1 -0
  231. package/cjs/measured-container/useResizeObserver.js +130 -0
  232. package/cjs/measured-container/useResizeObserver.js.map +1 -0
  233. package/cjs/overflow-container/OverflowContainer.css.js +6 -0
  234. package/cjs/overflow-container/OverflowContainer.css.js.map +1 -0
  235. package/cjs/overflow-container/OverflowContainer.js +142 -0
  236. package/cjs/overflow-container/OverflowContainer.js.map +1 -0
  237. package/cjs/overflow-container/overflow-utils.js +286 -0
  238. package/cjs/overflow-container/overflow-utils.js.map +1 -0
  239. package/cjs/overflow-container/useOverflowContainer.js +143 -0
  240. package/cjs/overflow-container/useOverflowContainer.js.map +1 -0
  241. package/cjs/price-ticker/PriceTicker.css.js +6 -0
  242. package/cjs/price-ticker/PriceTicker.css.js.map +1 -0
  243. package/cjs/price-ticker/PriceTicker.js +50 -0
  244. package/cjs/price-ticker/PriceTicker.js.map +1 -0
  245. package/cjs/split-button/SplitButton.css.js +6 -0
  246. package/cjs/split-button/SplitButton.css.js.map +1 -0
  247. package/cjs/split-button/SplitButton.js +81 -0
  248. package/cjs/split-button/SplitButton.js.map +1 -0
  249. package/cjs/split-button/SplitStateButton.css.js +6 -0
  250. package/cjs/split-button/SplitStateButton.css.js.map +1 -0
  251. package/cjs/split-button/SplitStateButton.js +31 -0
  252. package/cjs/split-button/SplitStateButton.js.map +1 -0
  253. package/cjs/split-button/useSplitButton.js +84 -0
  254. package/cjs/split-button/useSplitButton.js.map +1 -0
  255. package/cjs/tabstrip/Tab.css.js +6 -0
  256. package/cjs/tabstrip/Tab.css.js.map +1 -0
  257. package/cjs/tabstrip/Tab.js +151 -0
  258. package/cjs/tabstrip/Tab.js.map +1 -0
  259. package/cjs/tabstrip/TabMenu.css.js +6 -0
  260. package/cjs/tabstrip/TabMenu.css.js.map +1 -0
  261. package/cjs/tabstrip/TabMenu.js +72 -0
  262. package/cjs/tabstrip/TabMenu.js.map +1 -0
  263. package/cjs/tabstrip/TabMenuOptions.js +20 -0
  264. package/cjs/tabstrip/TabMenuOptions.js.map +1 -0
  265. package/cjs/tabstrip/Tabstrip.css.js +6 -0
  266. package/cjs/tabstrip/Tabstrip.css.js.map +1 -0
  267. package/cjs/tabstrip/Tabstrip.js +156 -0
  268. package/cjs/tabstrip/Tabstrip.js.map +1 -0
  269. package/cjs/tabstrip/tabstrip-dom-utils.js +19 -0
  270. package/cjs/tabstrip/tabstrip-dom-utils.js.map +1 -0
  271. package/cjs/tabstrip/useAnimatedSelectionThumb.js +85 -0
  272. package/cjs/tabstrip/useAnimatedSelectionThumb.js.map +1 -0
  273. package/cjs/tabstrip/useKeyboardNavigation.js +243 -0
  274. package/cjs/tabstrip/useKeyboardNavigation.js.map +1 -0
  275. package/cjs/tabstrip/useSelection.js +60 -0
  276. package/cjs/tabstrip/useSelection.js.map +1 -0
  277. package/cjs/tabstrip/useTabstrip.js +261 -0
  278. package/cjs/tabstrip/useTabstrip.js.map +1 -0
  279. package/cjs/toolbar/Toolbar.css.js +6 -0
  280. package/cjs/toolbar/Toolbar.css.js.map +1 -0
  281. package/cjs/toolbar/Toolbar.js +90 -0
  282. package/cjs/toolbar/Toolbar.js.map +1 -0
  283. package/cjs/toolbar/toolbar-dom-utils.js +18 -0
  284. package/cjs/toolbar/toolbar-dom-utils.js.map +1 -0
  285. package/cjs/toolbar/useKeyboardNavigation.js +305 -0
  286. package/cjs/toolbar/useKeyboardNavigation.js.map +1 -0
  287. package/cjs/toolbar/useSelection.js +94 -0
  288. package/cjs/toolbar/useSelection.js.map +1 -0
  289. package/cjs/toolbar/useToolbar.js +100 -0
  290. package/cjs/toolbar/useToolbar.js.map +1 -0
  291. package/cjs/tree/Tree.css.js +6 -0
  292. package/cjs/tree/Tree.css.js.map +1 -0
  293. package/cjs/tree/Tree.js +179 -0
  294. package/cjs/tree/Tree.js.map +1 -0
  295. package/cjs/tree/hierarchical-data-utils.js +72 -0
  296. package/cjs/tree/hierarchical-data-utils.js.map +1 -0
  297. package/cjs/tree/key-code.js +62 -0
  298. package/cjs/tree/key-code.js.map +1 -0
  299. package/cjs/tree/list-dom-utils.js +19 -0
  300. package/cjs/tree/list-dom-utils.js.map +1 -0
  301. package/cjs/tree/treeTypeUtils.js +6 -0
  302. package/cjs/tree/treeTypeUtils.js.map +1 -0
  303. package/cjs/tree/use-collapsible-groups.js +85 -0
  304. package/cjs/tree/use-collapsible-groups.js.map +1 -0
  305. package/cjs/tree/use-hierarchical-data.js +51 -0
  306. package/cjs/tree/use-hierarchical-data.js.map +1 -0
  307. package/cjs/tree/use-items-with-ids.js +100 -0
  308. package/cjs/tree/use-items-with-ids.js.map +1 -0
  309. package/cjs/tree/use-keyboard-navigation.js +144 -0
  310. package/cjs/tree/use-keyboard-navigation.js.map +1 -0
  311. package/cjs/tree/use-selection.js +154 -0
  312. package/cjs/tree/use-selection.js.map +1 -0
  313. package/cjs/tree/use-tree-keyboard-navigation.js +41 -0
  314. package/cjs/tree/use-tree-keyboard-navigation.js.map +1 -0
  315. package/cjs/tree/use-viewport-tracking.js +76 -0
  316. package/cjs/tree/use-viewport-tracking.js.map +1 -0
  317. package/cjs/tree/useTree.js +106 -0
  318. package/cjs/tree/useTree.js.map +1 -0
  319. package/cjs/utils/escapeRegExp.js +9 -0
  320. package/cjs/utils/escapeRegExp.js.map +1 -0
  321. package/cjs/utils/forwardCallbackProps.js +22 -0
  322. package/cjs/utils/forwardCallbackProps.js.map +1 -0
  323. package/cjs/utils/isOverflowElement.js +8 -0
  324. package/cjs/utils/isOverflowElement.js.map +1 -0
  325. package/cjs/vuu-input/VuuInput.css.js +6 -0
  326. package/cjs/vuu-input/VuuInput.css.js.map +1 -0
  327. package/cjs/vuu-input/VuuInput.js +105 -0
  328. package/cjs/vuu-input/VuuInput.js.map +1 -0
  329. package/esm/calendar/Calendar.css.js +4 -0
  330. package/esm/calendar/Calendar.css.js.map +1 -0
  331. package/esm/calendar/Calendar.js +72 -0
  332. package/esm/calendar/Calendar.js.map +1 -0
  333. package/esm/calendar/internal/CalendarCarousel.css.js +4 -0
  334. package/esm/calendar/internal/CalendarCarousel.css.js.map +1 -0
  335. package/esm/calendar/internal/CalendarCarousel.js +95 -0
  336. package/esm/calendar/internal/CalendarCarousel.js.map +1 -0
  337. package/esm/calendar/internal/CalendarContext.js +16 -0
  338. package/esm/calendar/internal/CalendarContext.js.map +1 -0
  339. package/esm/calendar/internal/CalendarDay.css.js +4 -0
  340. package/esm/calendar/internal/CalendarDay.css.js.map +1 -0
  341. package/esm/calendar/internal/CalendarDay.js +81 -0
  342. package/esm/calendar/internal/CalendarDay.js.map +1 -0
  343. package/esm/calendar/internal/CalendarMonth.css.js +4 -0
  344. package/esm/calendar/internal/CalendarMonth.css.js.map +1 -0
  345. package/esm/calendar/internal/CalendarMonth.js +71 -0
  346. package/esm/calendar/internal/CalendarMonth.js.map +1 -0
  347. package/esm/calendar/internal/CalendarNavigation.css.js +4 -0
  348. package/esm/calendar/internal/CalendarNavigation.css.js.map +1 -0
  349. package/esm/calendar/internal/CalendarNavigation.js +248 -0
  350. package/esm/calendar/internal/CalendarNavigation.js.map +1 -0
  351. package/esm/calendar/internal/CalendarWeekHeader.css.js +4 -0
  352. package/esm/calendar/internal/CalendarWeekHeader.css.js.map +1 -0
  353. package/esm/calendar/internal/CalendarWeekHeader.js +41 -0
  354. package/esm/calendar/internal/CalendarWeekHeader.js.map +1 -0
  355. package/esm/calendar/internal/useFocusManagement.js +61 -0
  356. package/esm/calendar/internal/useFocusManagement.js.map +1 -0
  357. package/esm/calendar/internal/utils.js +55 -0
  358. package/esm/calendar/internal/utils.js.map +1 -0
  359. package/esm/calendar/useCalendar.js +129 -0
  360. package/esm/calendar/useCalendar.js.map +1 -0
  361. package/esm/calendar/useCalendarDay.js +68 -0
  362. package/esm/calendar/useCalendarDay.js.map +1 -0
  363. package/esm/calendar/useSelection.js +239 -0
  364. package/esm/calendar/useSelection.js.map +1 -0
  365. package/esm/combo-box/ComboBox.js +189 -0
  366. package/esm/combo-box/ComboBox.js.map +1 -0
  367. package/esm/combo-box/useCombobox.js +356 -0
  368. package/esm/combo-box/useCombobox.js.map +1 -0
  369. package/esm/common-hooks/collectionProvider.js +20 -0
  370. package/esm/common-hooks/collectionProvider.js.map +1 -0
  371. package/esm/common-hooks/isPlainObject.js +4 -0
  372. package/esm/common-hooks/isPlainObject.js.map +1 -0
  373. package/esm/common-hooks/itemToString.js +22 -0
  374. package/esm/common-hooks/itemToString.js.map +1 -0
  375. package/esm/common-hooks/selectionTypes.js +10 -0
  376. package/esm/common-hooks/selectionTypes.js.map +1 -0
  377. package/esm/common-hooks/use-resize-observer.js +118 -0
  378. package/esm/common-hooks/use-resize-observer.js.map +1 -0
  379. package/esm/common-hooks/useCollectionItems.js +307 -0
  380. package/esm/common-hooks/useCollectionItems.js.map +1 -0
  381. package/esm/common-hooks/useControlled.js +56 -0
  382. package/esm/common-hooks/useControlled.js.map +1 -0
  383. package/esm/common-hooks/useSelection.js +205 -0
  384. package/esm/common-hooks/useSelection.js.map +1 -0
  385. package/esm/common-hooks/useStateRef.js +21 -0
  386. package/esm/common-hooks/useStateRef.js.map +1 -0
  387. package/esm/cycle-state-button/CycleStateButton.js +52 -0
  388. package/esm/cycle-state-button/CycleStateButton.js.map +1 -0
  389. package/esm/date-input/DateInput.css.js +4 -0
  390. package/esm/date-input/DateInput.css.js.map +1 -0
  391. package/esm/date-input/DateInput.js +88 -0
  392. package/esm/date-input/DateInput.js.map +1 -0
  393. package/esm/date-input/DateRangeInput.js +75 -0
  394. package/esm/date-input/DateRangeInput.js.map +1 -0
  395. package/esm/date-input/useDatePicker.js +18 -0
  396. package/esm/date-input/useDatePicker.js.map +1 -0
  397. package/esm/date-popup/DatePopup.js +88 -0
  398. package/esm/date-popup/DatePopup.js.map +1 -0
  399. package/esm/date-popup/useDatePopup.js +75 -0
  400. package/esm/date-popup/useDatePopup.js.map +1 -0
  401. package/esm/drag-drop/DragDropProvider.js +142 -0
  402. package/esm/drag-drop/DragDropProvider.js.map +1 -0
  403. package/esm/drag-drop/DragDropState.js +27 -0
  404. package/esm/drag-drop/DragDropState.js.map +1 -0
  405. package/esm/drag-drop/Draggable.css.js +4 -0
  406. package/esm/drag-drop/Draggable.css.js.map +1 -0
  407. package/esm/drag-drop/Draggable.js +90 -0
  408. package/esm/drag-drop/Draggable.js.map +1 -0
  409. package/esm/drag-drop/dragDropTypes.js +5 -0
  410. package/esm/drag-drop/dragDropTypes.js.map +1 -0
  411. package/esm/drag-drop/drop-target-utils.js +228 -0
  412. package/esm/drag-drop/drop-target-utils.js.map +1 -0
  413. package/esm/drag-drop/useAutoScroll.js +69 -0
  414. package/esm/drag-drop/useAutoScroll.js.map +1 -0
  415. package/esm/drag-drop/useDragDisplacers.js +158 -0
  416. package/esm/drag-drop/useDragDisplacers.js.map +1 -0
  417. package/esm/drag-drop/useDragDrop.js +497 -0
  418. package/esm/drag-drop/useDragDrop.js.map +1 -0
  419. package/esm/drag-drop/useDragDropCopy.js +31 -0
  420. package/esm/drag-drop/useDragDropCopy.js.map +1 -0
  421. package/esm/drag-drop/useDragDropIndicator.js +249 -0
  422. package/esm/drag-drop/useDragDropIndicator.js.map +1 -0
  423. package/esm/drag-drop/useDragDropNaturalMovement.js +262 -0
  424. package/esm/drag-drop/useDragDropNaturalMovement.js.map +1 -0
  425. package/esm/drag-drop/useDropIndicator.js +25 -0
  426. package/esm/drag-drop/useDropIndicator.js.map +1 -0
  427. package/esm/drag-drop/useGlobalDragDrop.js +87 -0
  428. package/esm/drag-drop/useGlobalDragDrop.js.map +1 -0
  429. package/esm/dropdown/Dropdown.css.js +4 -0
  430. package/esm/dropdown/Dropdown.css.js.map +1 -0
  431. package/esm/dropdown/Dropdown.js +148 -0
  432. package/esm/dropdown/Dropdown.js.map +1 -0
  433. package/esm/dropdown/DropdownBase.js +119 -0
  434. package/esm/dropdown/DropdownBase.js.map +1 -0
  435. package/esm/dropdown/DropdownButton.css.js +4 -0
  436. package/esm/dropdown/DropdownButton.css.js.map +1 -0
  437. package/esm/dropdown/DropdownButton.js +70 -0
  438. package/esm/dropdown/DropdownButton.js.map +1 -0
  439. package/esm/dropdown/useClickAway.js +64 -0
  440. package/esm/dropdown/useClickAway.js.map +1 -0
  441. package/esm/dropdown/useDropdown.js +113 -0
  442. package/esm/dropdown/useDropdown.js.map +1 -0
  443. package/esm/dropdown/useDropdownBase.js +167 -0
  444. package/esm/dropdown/useDropdownBase.js.map +1 -0
  445. package/esm/editable/editable-utils.js +35 -0
  446. package/esm/editable/editable-utils.js.map +1 -0
  447. package/esm/editable/useEditableText.js +103 -0
  448. package/esm/editable/useEditableText.js.map +1 -0
  449. package/esm/editable-label/EditableLabel.css.js +4 -0
  450. package/esm/editable-label/EditableLabel.css.js.map +1 -0
  451. package/esm/editable-label/EditableLabel.js +135 -0
  452. package/esm/editable-label/EditableLabel.js.map +1 -0
  453. package/esm/expando-input/ExpandoInput.css.js +4 -0
  454. package/esm/expando-input/ExpandoInput.css.js.map +1 -0
  455. package/esm/expando-input/ExpandoInput.js +51 -0
  456. package/esm/expando-input/ExpandoInput.js.map +1 -0
  457. package/esm/icon-button/Icon.css.js +4 -0
  458. package/esm/icon-button/Icon.css.js.map +1 -0
  459. package/esm/icon-button/Icon.js +35 -0
  460. package/esm/icon-button/Icon.js.map +1 -0
  461. package/esm/icon-button/IconButton.css.js +4 -0
  462. package/esm/icon-button/IconButton.css.js.map +1 -0
  463. package/esm/icon-button/IconButton.js +24 -0
  464. package/esm/icon-button/IconButton.js.map +1 -0
  465. package/esm/index.js +73 -0
  466. package/esm/index.js.map +1 -0
  467. package/esm/inputs/Checkbox.css.js +4 -0
  468. package/esm/inputs/Checkbox.css.js.map +1 -0
  469. package/esm/inputs/Checkbox.js +30 -0
  470. package/esm/inputs/Checkbox.js.map +1 -0
  471. package/esm/inputs/RadioButton.css.js +4 -0
  472. package/esm/inputs/RadioButton.css.js.map +1 -0
  473. package/esm/inputs/RadioButton.js +37 -0
  474. package/esm/inputs/RadioButton.js.map +1 -0
  475. package/esm/instrument-picker/InstrumentPicker.css.js +4 -0
  476. package/esm/instrument-picker/InstrumentPicker.css.js.map +1 -0
  477. package/esm/instrument-picker/InstrumentPicker.js +111 -0
  478. package/esm/instrument-picker/InstrumentPicker.js.map +1 -0
  479. package/esm/instrument-picker/SearchCell.css.js +4 -0
  480. package/esm/instrument-picker/SearchCell.css.js.map +1 -0
  481. package/esm/instrument-picker/SearchCell.js +31 -0
  482. package/esm/instrument-picker/SearchCell.js.map +1 -0
  483. package/esm/instrument-picker/useInstrumentPicker.js +85 -0
  484. package/esm/instrument-picker/useInstrumentPicker.js.map +1 -0
  485. package/esm/instrument-search/InstrumentSearch.css.js +4 -0
  486. package/esm/instrument-search/InstrumentSearch.css.js.map +1 -0
  487. package/esm/instrument-search/InstrumentSearch.js +94 -0
  488. package/esm/instrument-search/InstrumentSearch.js.map +1 -0
  489. package/esm/instrument-search/SearchCell.css.js +4 -0
  490. package/esm/instrument-search/SearchCell.css.js.map +1 -0
  491. package/esm/instrument-search/SearchCell.js +31 -0
  492. package/esm/instrument-search/SearchCell.js.map +1 -0
  493. package/esm/instrument-search/useInstrumentSearch.js +37 -0
  494. package/esm/instrument-search/useInstrumentSearch.js.map +1 -0
  495. package/esm/list/CheckboxIcon.css.js +4 -0
  496. package/esm/list/CheckboxIcon.css.js.map +1 -0
  497. package/esm/list/CheckboxIcon.js +31 -0
  498. package/esm/list/CheckboxIcon.js.map +1 -0
  499. package/esm/list/ChevronIcon.css.js +4 -0
  500. package/esm/list/ChevronIcon.css.js.map +1 -0
  501. package/esm/list/ChevronIcon.js +20 -0
  502. package/esm/list/ChevronIcon.js.map +1 -0
  503. package/esm/list/Highlighter.css.js +4 -0
  504. package/esm/list/Highlighter.css.js.map +1 -0
  505. package/esm/list/Highlighter.js +34 -0
  506. package/esm/list/Highlighter.js.map +1 -0
  507. package/esm/list/List.css.js +4 -0
  508. package/esm/list/List.css.js.map +1 -0
  509. package/esm/list/List.js +315 -0
  510. package/esm/list/List.js.map +1 -0
  511. package/esm/list/ListItem.css.js +4 -0
  512. package/esm/list/ListItem.css.js.map +1 -0
  513. package/esm/list/ListItem.js +81 -0
  514. package/esm/list/ListItem.js.map +1 -0
  515. package/esm/list/ListItemGroup.js +4 -0
  516. package/esm/list/ListItemGroup.js.map +1 -0
  517. package/esm/list/ListItemHeader.js +4 -0
  518. package/esm/list/ListItemHeader.js.map +1 -0
  519. package/esm/list/RadioIcon.css.js +4 -0
  520. package/esm/list/RadioIcon.css.js.map +1 -0
  521. package/esm/list/RadioIcon.js +25 -0
  522. package/esm/list/RadioIcon.js.map +1 -0
  523. package/esm/list/common-hooks/keyUtils.js +64 -0
  524. package/esm/list/common-hooks/keyUtils.js.map +1 -0
  525. package/esm/list/common-hooks/list-dom-utils.js +19 -0
  526. package/esm/list/common-hooks/list-dom-utils.js.map +1 -0
  527. package/esm/list/common-hooks/useCollapsibleGroups.js +80 -0
  528. package/esm/list/common-hooks/useCollapsibleGroups.js.map +1 -0
  529. package/esm/list/common-hooks/useImperativeScrollingAPI.js +50 -0
  530. package/esm/list/common-hooks/useImperativeScrollingAPI.js.map +1 -0
  531. package/esm/list/common-hooks/useKeyboardNavigation.js +286 -0
  532. package/esm/list/common-hooks/useKeyboardNavigation.js.map +1 -0
  533. package/esm/list/common-hooks/useTypeahead.js +72 -0
  534. package/esm/list/common-hooks/useTypeahead.js.map +1 -0
  535. package/esm/list/common-hooks/useViewportTracking.js +131 -0
  536. package/esm/list/common-hooks/useViewportTracking.js.map +1 -0
  537. package/esm/list/common-hooks/utils/collection-item-utils.js +167 -0
  538. package/esm/list/common-hooks/utils/collection-item-utils.js.map +1 -0
  539. package/esm/list/common-hooks/utils/filter-utils.js +8 -0
  540. package/esm/list/common-hooks/utils/filter-utils.js.map +1 -0
  541. package/esm/list/common-hooks/utils/isSelected.js +7 -0
  542. package/esm/list/common-hooks/utils/isSelected.js.map +1 -0
  543. package/esm/list/useList.js +276 -0
  544. package/esm/list/useList.js.map +1 -0
  545. package/esm/list/useListDrop.js +90 -0
  546. package/esm/list/useListDrop.js.map +1 -0
  547. package/esm/list/useListHeight.js +75 -0
  548. package/esm/list/useListHeight.js.map +1 -0
  549. package/esm/list/useScrollPosition.js +72 -0
  550. package/esm/list/useScrollPosition.js.map +1 -0
  551. package/esm/measured-container/MeasuredContainer.css.js +4 -0
  552. package/esm/measured-container/MeasuredContainer.css.js.map +1 -0
  553. package/esm/measured-container/MeasuredContainer.js +67 -0
  554. package/esm/measured-container/MeasuredContainer.js.map +1 -0
  555. package/esm/measured-container/useMeasuredContainer.js +125 -0
  556. package/esm/measured-container/useMeasuredContainer.js.map +1 -0
  557. package/esm/measured-container/useResizeObserver.js +128 -0
  558. package/esm/measured-container/useResizeObserver.js.map +1 -0
  559. package/esm/overflow-container/OverflowContainer.css.js +4 -0
  560. package/esm/overflow-container/OverflowContainer.css.js.map +1 -0
  561. package/esm/overflow-container/OverflowContainer.js +140 -0
  562. package/esm/overflow-container/OverflowContainer.js.map +1 -0
  563. package/esm/overflow-container/overflow-utils.js +272 -0
  564. package/esm/overflow-container/overflow-utils.js.map +1 -0
  565. package/esm/overflow-container/useOverflowContainer.js +141 -0
  566. package/esm/overflow-container/useOverflowContainer.js.map +1 -0
  567. package/esm/price-ticker/PriceTicker.css.js +4 -0
  568. package/esm/price-ticker/PriceTicker.css.js.map +1 -0
  569. package/esm/price-ticker/PriceTicker.js +48 -0
  570. package/esm/price-ticker/PriceTicker.js.map +1 -0
  571. package/esm/split-button/SplitButton.css.js +4 -0
  572. package/esm/split-button/SplitButton.css.js.map +1 -0
  573. package/esm/split-button/SplitButton.js +79 -0
  574. package/esm/split-button/SplitButton.js.map +1 -0
  575. package/esm/split-button/SplitStateButton.css.js +4 -0
  576. package/esm/split-button/SplitStateButton.css.js.map +1 -0
  577. package/esm/split-button/SplitStateButton.js +29 -0
  578. package/esm/split-button/SplitStateButton.js.map +1 -0
  579. package/esm/split-button/useSplitButton.js +82 -0
  580. package/esm/split-button/useSplitButton.js.map +1 -0
  581. package/esm/tabstrip/Tab.css.js +4 -0
  582. package/esm/tabstrip/Tab.css.js.map +1 -0
  583. package/esm/tabstrip/Tab.js +149 -0
  584. package/esm/tabstrip/Tab.js.map +1 -0
  585. package/esm/tabstrip/TabMenu.css.js +4 -0
  586. package/esm/tabstrip/TabMenu.css.js.map +1 -0
  587. package/esm/tabstrip/TabMenu.js +70 -0
  588. package/esm/tabstrip/TabMenu.js.map +1 -0
  589. package/esm/tabstrip/TabMenuOptions.js +16 -0
  590. package/esm/tabstrip/TabMenuOptions.js.map +1 -0
  591. package/esm/tabstrip/Tabstrip.css.js +4 -0
  592. package/esm/tabstrip/Tabstrip.css.js.map +1 -0
  593. package/esm/tabstrip/Tabstrip.js +154 -0
  594. package/esm/tabstrip/Tabstrip.js.map +1 -0
  595. package/esm/tabstrip/tabstrip-dom-utils.js +16 -0
  596. package/esm/tabstrip/tabstrip-dom-utils.js.map +1 -0
  597. package/esm/tabstrip/useAnimatedSelectionThumb.js +83 -0
  598. package/esm/tabstrip/useAnimatedSelectionThumb.js.map +1 -0
  599. package/esm/tabstrip/useKeyboardNavigation.js +241 -0
  600. package/esm/tabstrip/useKeyboardNavigation.js.map +1 -0
  601. package/esm/tabstrip/useSelection.js +58 -0
  602. package/esm/tabstrip/useSelection.js.map +1 -0
  603. package/esm/tabstrip/useTabstrip.js +259 -0
  604. package/esm/tabstrip/useTabstrip.js.map +1 -0
  605. package/esm/toolbar/Toolbar.css.js +4 -0
  606. package/esm/toolbar/Toolbar.css.js.map +1 -0
  607. package/esm/toolbar/Toolbar.js +88 -0
  608. package/esm/toolbar/Toolbar.js.map +1 -0
  609. package/esm/toolbar/toolbar-dom-utils.js +15 -0
  610. package/esm/toolbar/toolbar-dom-utils.js.map +1 -0
  611. package/esm/toolbar/useKeyboardNavigation.js +303 -0
  612. package/esm/toolbar/useKeyboardNavigation.js.map +1 -0
  613. package/esm/toolbar/useSelection.js +92 -0
  614. package/esm/toolbar/useSelection.js.map +1 -0
  615. package/esm/toolbar/useToolbar.js +98 -0
  616. package/esm/toolbar/useToolbar.js.map +1 -0
  617. package/esm/tree/Tree.css.js +4 -0
  618. package/esm/tree/Tree.css.js.map +1 -0
  619. package/esm/tree/Tree.js +176 -0
  620. package/esm/tree/Tree.js.map +1 -0
  621. package/esm/tree/hierarchical-data-utils.js +65 -0
  622. package/esm/tree/hierarchical-data-utils.js.map +1 -0
  623. package/esm/tree/key-code.js +54 -0
  624. package/esm/tree/key-code.js.map +1 -0
  625. package/esm/tree/list-dom-utils.js +15 -0
  626. package/esm/tree/list-dom-utils.js.map +1 -0
  627. package/esm/tree/treeTypeUtils.js +4 -0
  628. package/esm/tree/treeTypeUtils.js.map +1 -0
  629. package/esm/tree/use-collapsible-groups.js +83 -0
  630. package/esm/tree/use-collapsible-groups.js.map +1 -0
  631. package/esm/tree/use-hierarchical-data.js +49 -0
  632. package/esm/tree/use-hierarchical-data.js.map +1 -0
  633. package/esm/tree/use-items-with-ids.js +98 -0
  634. package/esm/tree/use-items-with-ids.js.map +1 -0
  635. package/esm/tree/use-keyboard-navigation.js +142 -0
  636. package/esm/tree/use-keyboard-navigation.js.map +1 -0
  637. package/esm/tree/use-selection.js +147 -0
  638. package/esm/tree/use-selection.js.map +1 -0
  639. package/esm/tree/use-tree-keyboard-navigation.js +39 -0
  640. package/esm/tree/use-tree-keyboard-navigation.js.map +1 -0
  641. package/esm/tree/use-viewport-tracking.js +74 -0
  642. package/esm/tree/use-viewport-tracking.js.map +1 -0
  643. package/esm/tree/useTree.js +104 -0
  644. package/esm/tree/useTree.js.map +1 -0
  645. package/esm/utils/escapeRegExp.js +7 -0
  646. package/esm/utils/escapeRegExp.js.map +1 -0
  647. package/esm/utils/forwardCallbackProps.js +20 -0
  648. package/esm/utils/forwardCallbackProps.js.map +1 -0
  649. package/esm/utils/isOverflowElement.js +6 -0
  650. package/esm/utils/isOverflowElement.js.map +1 -0
  651. package/esm/vuu-input/VuuInput.css.js +4 -0
  652. package/esm/vuu-input/VuuInput.css.js.map +1 -0
  653. package/esm/vuu-input/VuuInput.js +103 -0
  654. package/esm/vuu-input/VuuInput.js.map +1 -0
  655. package/package.json +45 -0
  656. package/types/calendar/Calendar.d.ts +12 -0
  657. package/types/calendar/index.d.ts +4 -0
  658. package/types/calendar/internal/CalendarCarousel.d.ts +4 -0
  659. package/types/calendar/internal/CalendarContext.d.ts +9 -0
  660. package/types/calendar/internal/CalendarDay.d.ts +14 -0
  661. package/types/calendar/internal/CalendarMonth.d.ts +11 -0
  662. package/types/calendar/internal/CalendarNavigation.d.ts +20 -0
  663. package/types/calendar/internal/CalendarWeekHeader.d.ts +5 -0
  664. package/types/calendar/internal/useFocusManagement.d.ts +9 -0
  665. package/types/calendar/internal/utils.d.ts +14 -0
  666. package/types/calendar/useCalendar.d.ts +57 -0
  667. package/types/calendar/useCalendarDay.d.ts +19 -0
  668. package/types/calendar/useSelection.d.ts +75 -0
  669. package/types/combo-box/ComboBox.d.ts +24 -0
  670. package/types/combo-box/index.d.ts +1 -0
  671. package/types/combo-box/useCombobox.d.ts +20 -0
  672. package/types/common-hooks/collectionProvider.d.ts +13 -0
  673. package/types/common-hooks/collectionTypes.d.ts +58 -0
  674. package/types/common-hooks/index.d.ts +9 -0
  675. package/types/common-hooks/isPlainObject.d.ts +1 -0
  676. package/types/common-hooks/itemToString.d.ts +2 -0
  677. package/types/common-hooks/navigationTypes.d.ts +36 -0
  678. package/types/common-hooks/selectionTypes.d.ts +70 -0
  679. package/types/common-hooks/use-resize-observer.d.ts +16 -0
  680. package/types/common-hooks/useCollectionItems.d.ts +2 -0
  681. package/types/common-hooks/useControlled.d.ts +24 -0
  682. package/types/common-hooks/useSelection.d.ts +8 -0
  683. package/types/common-hooks/useStateRef.d.ts +2 -0
  684. package/types/cycle-state-button/CycleStateButton.d.ts +12 -0
  685. package/types/cycle-state-button/index.d.ts +1 -0
  686. package/types/date-input/DateInput.d.ts +12 -0
  687. package/types/date-input/DateRangeInput.d.ts +11 -0
  688. package/types/date-input/index.d.ts +2 -0
  689. package/types/date-input/types.d.ts +16 -0
  690. package/types/date-input/useBaseDatePickerDropdown.d.ts +15 -0
  691. package/types/date-input/useDatePicker.d.ts +7 -0
  692. package/types/date-popup/DatePopup.d.ts +12 -0
  693. package/types/date-popup/index.d.ts +1 -0
  694. package/types/date-popup/useDatePopup.d.ts +20 -0
  695. package/types/drag-drop/DragDropProvider.d.ts +38 -0
  696. package/types/drag-drop/DragDropState.d.ts +15 -0
  697. package/types/drag-drop/Draggable.d.ts +13 -0
  698. package/types/drag-drop/DropIndicator.d.ts +6 -0
  699. package/types/drag-drop/dragDropTypes.d.ts +100 -0
  700. package/types/drag-drop/drop-target-utils.d.ts +78 -0
  701. package/types/drag-drop/index.d.ts +6 -0
  702. package/types/drag-drop/useAutoScroll.d.ts +11 -0
  703. package/types/drag-drop/useDragDisplacers.d.ts +17 -0
  704. package/types/drag-drop/useDragDrop.d.ts +2 -0
  705. package/types/drag-drop/useDragDropCopy.d.ts +6 -0
  706. package/types/drag-drop/useDragDropIndicator.d.ts +2 -0
  707. package/types/drag-drop/useDragDropNaturalMovement.d.ts +2 -0
  708. package/types/drag-drop/useDropIndicator.d.ts +8 -0
  709. package/types/drag-drop/useGlobalDragDrop.d.ts +12 -0
  710. package/types/drag-drop/useTransition.d.ts +3 -0
  711. package/types/dropdown/Dropdown.d.ts +10 -0
  712. package/types/dropdown/DropdownBase.d.ts +9 -0
  713. package/types/dropdown/DropdownButton.d.ts +41 -0
  714. package/types/dropdown/dropdownTypes.d.ts +51 -0
  715. package/types/dropdown/index.d.ts +5 -0
  716. package/types/dropdown/useClickAway.d.ts +10 -0
  717. package/types/dropdown/useDropdown.d.ts +13 -0
  718. package/types/dropdown/useDropdownBase.d.ts +2 -0
  719. package/types/editable/editable-utils.d.ts +2 -0
  720. package/types/editable/index.d.ts +2 -0
  721. package/types/editable/useEditableText.d.ts +19 -0
  722. package/types/editable-label/EditableLabel.d.ts +19 -0
  723. package/types/editable-label/index.d.ts +1 -0
  724. package/types/expando-input/ExpandoInput.d.ts +6 -0
  725. package/types/expando-input/index.d.ts +1 -0
  726. package/types/icon-button/Icon.d.ts +6 -0
  727. package/types/icon-button/IconButton.d.ts +7 -0
  728. package/types/icon-button/index.d.ts +2 -0
  729. package/types/index.d.ts +27 -0
  730. package/types/inputs/Checkbox.d.ts +9 -0
  731. package/types/inputs/RadioButton.d.ts +9 -0
  732. package/types/inputs/index.d.ts +2 -0
  733. package/types/instrument-picker/InstrumentPicker.d.ts +24 -0
  734. package/types/instrument-picker/SearchCell.d.ts +3 -0
  735. package/types/instrument-picker/index.d.ts +1 -0
  736. package/types/instrument-picker/moving-window.d.ts +14 -0
  737. package/types/instrument-picker/useDataSource.d.ts +6 -0
  738. package/types/instrument-picker/useInstrumentPicker.d.ts +28 -0
  739. package/types/instrument-search/InstrumentSearch.d.ts +11 -0
  740. package/types/instrument-search/SearchCell.d.ts +3 -0
  741. package/types/instrument-search/index.d.ts +1 -0
  742. package/types/instrument-search/moving-window.d.ts +14 -0
  743. package/types/instrument-search/useDataSource.d.ts +6 -0
  744. package/types/instrument-search/useInstrumentSearch.d.ts +13 -0
  745. package/types/list/CheckboxIcon.d.ts +6 -0
  746. package/types/list/ChevronIcon.d.ts +7 -0
  747. package/types/list/Highlighter.d.ts +6 -0
  748. package/types/list/List.d.ts +6 -0
  749. package/types/list/ListItem.d.ts +6 -0
  750. package/types/list/ListItemGroup.d.ts +6 -0
  751. package/types/list/ListItemHeader.d.ts +5 -0
  752. package/types/list/RadioIcon.d.ts +5 -0
  753. package/types/list/common-hooks/index.d.ts +10 -0
  754. package/types/list/common-hooks/keyUtils.d.ts +14 -0
  755. package/types/list/common-hooks/list-dom-utils.d.ts +5 -0
  756. package/types/list/common-hooks/useCollapsibleGroups.d.ts +14 -0
  757. package/types/list/common-hooks/useImperativeScrollingAPI.d.ts +14 -0
  758. package/types/list/common-hooks/useKeyboardNavigation.d.ts +3 -0
  759. package/types/list/common-hooks/useTypeahead.d.ts +15 -0
  760. package/types/list/common-hooks/useViewportTracking.d.ts +14 -0
  761. package/types/list/common-hooks/utils/collection-item-utils.d.ts +21 -0
  762. package/types/list/common-hooks/utils/filter-utils.d.ts +4 -0
  763. package/types/list/common-hooks/utils/index.d.ts +4 -0
  764. package/types/list/common-hooks/utils/isSelected.d.ts +2 -0
  765. package/types/list/index.d.ts +10 -0
  766. package/types/list/keyset.d.ts +9 -0
  767. package/types/list/listTypes.d.ts +200 -0
  768. package/types/list/useList.d.ts +3 -0
  769. package/types/list/useListDrop.d.ts +15 -0
  770. package/types/list/useListHeight.d.ts +19 -0
  771. package/types/list/useScrollPosition.d.ts +19 -0
  772. package/types/measured-container/MeasuredContainer.d.ts +14 -0
  773. package/types/measured-container/index.d.ts +2 -0
  774. package/types/measured-container/useMeasuredContainer.d.ts +22 -0
  775. package/types/measured-container/useResizeObserver.d.ts +15 -0
  776. package/types/overflow-container/OverflowContainer.d.ts +15 -0
  777. package/types/overflow-container/index.d.ts +2 -0
  778. package/types/overflow-container/overflow-utils.d.ts +48 -0
  779. package/types/overflow-container/useOverflowContainer.d.ts +20 -0
  780. package/types/price-ticker/PriceTicker.d.ts +7 -0
  781. package/types/price-ticker/index.d.ts +1 -0
  782. package/types/split-button/SplitButton.d.ts +11 -0
  783. package/types/split-button/SplitStateButton.d.ts +6 -0
  784. package/types/split-button/index.d.ts +2 -0
  785. package/types/split-button/useSplitButton.d.ts +288 -0
  786. package/types/tabstrip/Tab.d.ts +26 -0
  787. package/types/tabstrip/TabMenu.d.ts +19 -0
  788. package/types/tabstrip/TabMenuOptions.d.ts +10 -0
  789. package/types/tabstrip/TabsTypes.d.ts +127 -0
  790. package/types/tabstrip/Tabstrip.d.ts +3 -0
  791. package/types/tabstrip/index.d.ts +4 -0
  792. package/types/tabstrip/tabstrip-dom-utils.d.ts +2 -0
  793. package/types/tabstrip/useAnimatedSelectionThumb.d.ts +7 -0
  794. package/types/tabstrip/useKeyboardNavigation.d.ts +29 -0
  795. package/types/tabstrip/useSelection.d.ts +13 -0
  796. package/types/tabstrip/useTabstrip.d.ts +49 -0
  797. package/types/toolbar/Toolbar.d.ts +20 -0
  798. package/types/toolbar/index.d.ts +1 -0
  799. package/types/toolbar/toolbar-dom-utils.d.ts +3 -0
  800. package/types/toolbar/useKeyboardNavigation.d.ts +32 -0
  801. package/types/toolbar/useSelection.d.ts +22 -0
  802. package/types/toolbar/useToolbar.d.ts +28 -0
  803. package/types/tree/Tree.d.ts +19 -0
  804. package/types/tree/hierarchical-data-utils.d.ts +8 -0
  805. package/types/tree/index.d.ts +4 -0
  806. package/types/tree/key-code.d.ts +11 -0
  807. package/types/tree/list-dom-utils.d.ts +6 -0
  808. package/types/tree/treeTypeUtils.d.ts +2 -0
  809. package/types/tree/treeTypes.d.ts +17 -0
  810. package/types/tree/use-collapsible-groups.d.ts +18 -0
  811. package/types/tree/use-hierarchical-data.d.ts +6 -0
  812. package/types/tree/use-items-with-ids.d.ts +8 -0
  813. package/types/tree/use-keyboard-navigation.d.ts +26 -0
  814. package/types/tree/use-selection.d.ts +31 -0
  815. package/types/tree/use-tree-keyboard-navigation.d.ts +12 -0
  816. package/types/tree/use-viewport-tracking.d.ts +2 -0
  817. package/types/tree/useTree.d.ts +30 -0
  818. package/types/utils/escapeRegExp.d.ts +1 -0
  819. package/types/utils/forwardCallbackProps.d.ts +3 -0
  820. package/types/utils/index.d.ts +3 -0
  821. package/types/utils/isOverflowElement.d.ts +1 -0
  822. package/types/vuu-input/VuuInput.d.ts +16 -0
  823. package/types/vuu-input/index.d.ts +1 -0
@@ -0,0 +1,499 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var vuuUtils = require('@vuu-ui/vuu-utils');
5
+ var React = require('react');
6
+ var DragDropProvider = require('./DragDropProvider.js');
7
+ var DragDropState = require('./DragDropState.js');
8
+ var Draggable = require('./Draggable.js');
9
+ var dropTargetUtils = require('./drop-target-utils.js');
10
+ var useAutoScroll = require('./useAutoScroll.js');
11
+ var useDragDropCopy = require('./useDragDropCopy.js');
12
+ var useDragDropIndicator = require('./useDragDropIndicator.js');
13
+ var useDragDropNaturalMovement = require('./useDragDropNaturalMovement.js');
14
+ var isOverflowElement = require('../utils/isOverflowElement.js');
15
+
16
+ const NULL_DRAG_DROP_RESULT = {
17
+ beginDrag: () => void 0,
18
+ drag: () => void 0,
19
+ draggableRef: { current: null },
20
+ drop: () => useDragDropCopy.NULL_DROP_OPTIONS,
21
+ isDragging: false,
22
+ isScrolling: false,
23
+ handleScrollStart: () => void 0,
24
+ handleScrollStop: () => void 0,
25
+ revealOverflowedItems: false
26
+ };
27
+ const UNBOUNDED = {
28
+ start: 0,
29
+ end: 1e3,
30
+ contraStart: 0,
31
+ contraEnd: 1e3
32
+ };
33
+ const noDragDrop = () => NULL_DRAG_DROP_RESULT;
34
+ const dragThreshold = 3;
35
+ const getDraggableElement = (el, query) => el?.closest(query);
36
+ const getLastElement = (container, itemQuery) => {
37
+ const fullItemQuery = `:is(${itemQuery}${dropTargetUtils.NOT_OVERFLOWED},.vuuOverflowContainer-OverflowIndicator)`;
38
+ const childElements = Array.from(container.querySelectorAll(fullItemQuery));
39
+ const lastElement = childElements.pop();
40
+ return [lastElement, isOverflowElement.isOverflowElement(lastElement)];
41
+ };
42
+ const useDragDrop = ({
43
+ allowDragDrop,
44
+ containerRef,
45
+ draggableClassName,
46
+ getDragPayload,
47
+ id,
48
+ itemQuery = "*",
49
+ onDragStart,
50
+ onDrop,
51
+ onDropSettle,
52
+ orientation,
53
+ scrollingContainerRef,
54
+ ...dragDropProps
55
+ }) => {
56
+ const dragBoundaries = React.useRef({
57
+ start: 0,
58
+ end: 0,
59
+ contraStart: 0,
60
+ contraEnd: 0
61
+ });
62
+ const [draggableStatus, setDraggableStatus] = React.useState({
63
+ draggable: void 0,
64
+ draggedItemIndex: -1,
65
+ isDragging: false
66
+ });
67
+ const dragDropStateRef = React.useRef(null);
68
+ const mouseDownTimer = React.useRef(null);
69
+ const isScrollableRef = React.useRef(false);
70
+ const mousedownElementRef = React.useRef(null);
71
+ const mousePosRef = React.useRef({ x: 0, y: 0 });
72
+ const startPosRef = React.useRef({ x: 0, y: 0 });
73
+ const settlingItemRef = React.useRef(null);
74
+ const scrollableContainerRef = React.useRef(null);
75
+ const dropPosRef = React.useRef(-1);
76
+ const dropIndexRef = React.useRef(-1);
77
+ const handleScrollStopRef = React.useRef();
78
+ const {
79
+ isDragSource,
80
+ isDropTarget,
81
+ onDragOut,
82
+ onEndOfDragOperation,
83
+ register
84
+ } = DragDropProvider.useDragDropProvider(id);
85
+ const dragMouseMoveHandlerRef = React.useRef();
86
+ const dragMouseUpHandlerRef = React.useRef();
87
+ const attachDragHandlers = React.useCallback(() => {
88
+ const { current: dragMove } = dragMouseMoveHandlerRef;
89
+ const { current: dragUp } = dragMouseUpHandlerRef;
90
+ if (dragMove && dragUp) {
91
+ document.addEventListener("mousemove", dragMove, false);
92
+ document.addEventListener("mouseup", dragUp, false);
93
+ }
94
+ }, []);
95
+ const removeDragHandlers = React.useCallback(() => {
96
+ const { current: dragMove } = dragMouseMoveHandlerRef;
97
+ const { current: dragUp } = dragMouseUpHandlerRef;
98
+ if (dragMove && dragUp) {
99
+ document.removeEventListener("mousemove", dragMove, false);
100
+ document.removeEventListener("mouseup", dragUp, false);
101
+ }
102
+ }, []);
103
+ const setDragBoundaries = React.useCallback(
104
+ (containerRect, draggableRect) => {
105
+ const { current: container } = containerRef;
106
+ if (container) {
107
+ const [lastElement, lastItemIsOverflowIndicator] = getLastElement(
108
+ container,
109
+ itemQuery
110
+ );
111
+ const { CONTRA, CONTRA_END, DIMENSION, END, START } = dropTargetUtils.dimensions(orientation);
112
+ const draggableSize = draggableRect[DIMENSION];
113
+ const { [START]: lastItemStart, [END]: lastItemEnd } = lastElement.getBoundingClientRect();
114
+ dragBoundaries.current.start = containerRect[START];
115
+ dragBoundaries.current.end = lastItemIsOverflowIndicator ? Math.max(lastItemStart, containerRect.right - draggableSize) : isScrollableRef.current ? containerRect[START] + containerRect[DIMENSION] - draggableSize : lastItemEnd - draggableSize;
116
+ dragBoundaries.current.contraStart = containerRect[CONTRA];
117
+ dragBoundaries.current.contraEnd = containerRect[CONTRA_END];
118
+ }
119
+ },
120
+ [containerRef, itemQuery, orientation]
121
+ );
122
+ const terminateDrag = React.useCallback(() => {
123
+ const { current: settlingItem2 } = settlingItemRef;
124
+ settlingItemRef.current = null;
125
+ const { current: toIndex } = dropIndexRef;
126
+ const droppedItem = containerRef.current?.querySelector(
127
+ `${itemQuery}[data-index="${toIndex}"]`
128
+ );
129
+ if (droppedItem) {
130
+ droppedItem.classList.remove("vuuDropTarget-settling");
131
+ }
132
+ dropIndexRef.current = -1;
133
+ onDropSettle?.(toIndex);
134
+ setDraggableStatus((status) => ({
135
+ ...status,
136
+ draggable: void 0
137
+ }));
138
+ if (settlingItem2) {
139
+ vuuUtils.dispatchCustomEvent(settlingItem2, "vuu-dropped");
140
+ }
141
+ }, [containerRef, itemQuery, onDropSettle]);
142
+ const getScrollDirection = React.useCallback(
143
+ (mousePos) => {
144
+ if (scrollableContainerRef.current && dragDropStateRef.current) {
145
+ const { mouseOffset } = dragDropStateRef.current;
146
+ const { POS, SCROLL_POS, SCROLL_SIZE, CLIENT_SIZE } = dropTargetUtils.dimensions(orientation);
147
+ const {
148
+ [SCROLL_POS]: scrollPos,
149
+ [SCROLL_SIZE]: scrollSize,
150
+ [CLIENT_SIZE]: clientSize
151
+ } = scrollableContainerRef.current;
152
+ const maxScroll = scrollSize - clientSize;
153
+ const canScrollFwd = scrollPos < maxScroll;
154
+ const viewportEnd = dragBoundaries.current.end;
155
+ const bwd = scrollPos > 0 && mousePos - mouseOffset[POS] <= dragBoundaries.current.start;
156
+ const fwd = canScrollFwd && mousePos - mouseOffset[POS] >= viewportEnd;
157
+ return bwd ? "bwd" : fwd ? "fwd" : "";
158
+ }
159
+ },
160
+ [scrollableContainerRef, orientation]
161
+ );
162
+ const useDragDropHook = allowDragDrop === true || allowDragDrop === "natural-movement" ? useDragDropNaturalMovement.useDragDropNaturalMovement : allowDragDrop === "drop-indicator" ? useDragDropIndicator.useDragDropIndicator : allowDragDrop === "drag-copy" ? useDragDropCopy.useDragDropCopy : noDragDrop;
163
+ const onScrollingStopped = React.useCallback(
164
+ (scrollDirection, scrollPos, atEnd) => {
165
+ handleScrollStopRef.current?.(scrollDirection, scrollPos, atEnd);
166
+ },
167
+ []
168
+ );
169
+ const { isScrolling, startScrolling, stopScrolling } = useAutoScroll.useAutoScroll({
170
+ containerRef: scrollableContainerRef,
171
+ onScrollingStopped,
172
+ orientation
173
+ });
174
+ const handleDrop = React.useCallback(
175
+ (options) => {
176
+ dropPosRef.current = options.toIndex;
177
+ if (options.isExternal) {
178
+ onDrop?.({
179
+ ...options,
180
+ payload: dragDropStateRef.current?.payload
181
+ });
182
+ } else {
183
+ onDrop?.(options);
184
+ }
185
+ dropIndexRef.current = options.toIndex;
186
+ if (id) {
187
+ onEndOfDragOperation?.(id);
188
+ }
189
+ dragDropStateRef.current = null;
190
+ },
191
+ [id, onDrop, onEndOfDragOperation]
192
+ );
193
+ const {
194
+ beginDrag,
195
+ drag,
196
+ drop,
197
+ handleScrollStart,
198
+ handleScrollStop,
199
+ releaseDrag,
200
+ ...dragResult
201
+ } = useDragDropHook({
202
+ ...dragDropProps,
203
+ containerRef,
204
+ isDragSource,
205
+ isDropTarget,
206
+ itemQuery,
207
+ orientation
208
+ });
209
+ handleScrollStopRef.current = handleScrollStop;
210
+ const dragHandedOvertoProvider = React.useCallback(
211
+ (dragDistance, clientContraPos) => {
212
+ const { CONTRA_POS } = dropTargetUtils.dimensions(orientation);
213
+ const lastClientContraPos = mousePosRef.current[CONTRA_POS];
214
+ const dragOutDistance = isDragSource ? Math.abs(lastClientContraPos - clientContraPos) : 0;
215
+ if (allowDragDrop === true && !isDragSource && !isDropTarget) {
216
+ return false;
217
+ }
218
+ const handoverToProvider = isDropTarget === false || dragOutDistance - dragDistance > 5;
219
+ if (dragDropStateRef.current && handoverToProvider) {
220
+ if (onDragOut?.(id, dragDropStateRef.current)) {
221
+ removeDragHandlers();
222
+ releaseDrag?.();
223
+ dragDropStateRef.current = null;
224
+ }
225
+ dragBoundaries.current = UNBOUNDED;
226
+ return true;
227
+ }
228
+ },
229
+ [
230
+ allowDragDrop,
231
+ id,
232
+ isDragSource,
233
+ isDropTarget,
234
+ onDragOut,
235
+ orientation,
236
+ releaseDrag,
237
+ removeDragHandlers
238
+ ]
239
+ );
240
+ const dragMouseMoveHandler = React.useCallback(
241
+ (evt) => {
242
+ const { CLIENT_POS, CONTRA_CLIENT_POS, POS } = dropTargetUtils.dimensions(orientation);
243
+ const { clientX, clientY } = evt;
244
+ const { [CLIENT_POS]: clientPos, [CONTRA_CLIENT_POS]: clientContraPos } = evt;
245
+ const lastClientPos = mousePosRef.current[POS];
246
+ const dragDistance = Math.abs(lastClientPos - clientPos);
247
+ const { current: dragDropState } = dragDropStateRef;
248
+ const { current: boundary } = dragBoundaries;
249
+ if (dragHandedOvertoProvider(dragDistance, clientContraPos)) {
250
+ return;
251
+ }
252
+ mousePosRef.current.x = clientX;
253
+ mousePosRef.current.y = clientY;
254
+ if (dragDropState) {
255
+ const { draggableElement, mouseOffset } = dragDropState;
256
+ if (dragBoundaries.current === UNBOUNDED && draggableElement) {
257
+ const dragPosX = mousePosRef.current.x - mouseOffset.x;
258
+ const dragPosY = mousePosRef.current.y - mouseOffset.y;
259
+ draggableElement.style.top = `${dragPosY}px`;
260
+ draggableElement.style.left = `${dragPosX}px`;
261
+ } else if (dragDistance > 0 && draggableElement) {
262
+ const mouseMoveDirection = lastClientPos < clientPos ? "fwd" : "bwd";
263
+ const scrollDirection = getScrollDirection(clientPos);
264
+ const dragPos = mousePosRef.current[POS] - mouseOffset[POS];
265
+ const START = orientation === "horizontal" ? "left" : "top";
266
+ if (scrollDirection && isScrollableRef.current && !isScrolling.current) {
267
+ handleScrollStart?.(scrollDirection);
268
+ startScrolling(scrollDirection, 1);
269
+ if (scrollDirection === "fwd") {
270
+ draggableElement.style[START] = `${boundary.end}px`;
271
+ } else {
272
+ draggableElement.style[START] = `${boundary.start}px`;
273
+ }
274
+ } else if (!scrollDirection && isScrolling.current) {
275
+ stopScrolling();
276
+ }
277
+ if (!isScrolling.current) {
278
+ const renderDragPos = Math.round(
279
+ Math.max(boundary.start, Math.min(boundary.end, dragPos))
280
+ );
281
+ draggableElement.style[START] = `${renderDragPos}px`;
282
+ drag(renderDragPos, mouseMoveDirection);
283
+ }
284
+ }
285
+ }
286
+ },
287
+ [
288
+ drag,
289
+ dragHandedOvertoProvider,
290
+ getScrollDirection,
291
+ handleScrollStart,
292
+ isScrolling,
293
+ orientation,
294
+ startScrolling,
295
+ stopScrolling
296
+ ]
297
+ );
298
+ const dragMouseUpHandler = React.useCallback(() => {
299
+ removeDragHandlers();
300
+ if (dragDropStateRef.current) {
301
+ settlingItemRef.current = dragDropStateRef.current.draggableElement;
302
+ }
303
+ const dropOptions = drop();
304
+ handleDrop(dropOptions);
305
+ setDraggableStatus((status) => ({
306
+ ...status,
307
+ draggedItemIndex: -1,
308
+ isDragging: false
309
+ }));
310
+ }, [drop, handleDrop, removeDragHandlers]);
311
+ dragMouseMoveHandlerRef.current = dragMouseMoveHandler;
312
+ dragMouseUpHandlerRef.current = dragMouseUpHandler;
313
+ const resumeDrag = React.useCallback(
314
+ (dragDropState) => {
315
+ dragDropStateRef.current = dragDropState;
316
+ const { draggableElement, mouseOffset } = dragDropState;
317
+ const { current: container } = containerRef;
318
+ if (container && draggableElement) {
319
+ const containerRect = container.getBoundingClientRect();
320
+ const draggableRect = draggableElement.getBoundingClientRect();
321
+ setDragBoundaries(containerRect, draggableRect);
322
+ mousePosRef.current.x = draggableRect.left + mouseOffset.x;
323
+ mousePosRef.current.y = draggableRect.top + mouseOffset.y;
324
+ beginDrag(draggableElement);
325
+ attachDragHandlers();
326
+ return true;
327
+ } else {
328
+ return false;
329
+ }
330
+ },
331
+ [attachDragHandlers, beginDrag, containerRef, setDragBoundaries]
332
+ );
333
+ const dragStart = React.useCallback(
334
+ (mousePosition) => {
335
+ const { current: container } = containerRef;
336
+ const { current: target } = mousedownElementRef;
337
+ const dragElement = getDraggableElement(target, itemQuery);
338
+ const scrollableContainer = scrollingContainerRef?.current ?? dropTargetUtils.getScrollableContainer(container, itemQuery);
339
+ if (container && scrollableContainer && dragElement) {
340
+ isScrollableRef.current = dropTargetUtils.isContainerScrollable(
341
+ scrollableContainer,
342
+ orientation
343
+ );
344
+ scrollableContainerRef.current = scrollableContainer;
345
+ const containerRect = scrollableContainer.getBoundingClientRect();
346
+ const draggableRect = dragElement.getBoundingClientRect();
347
+ const dragDropState = dragDropStateRef.current = new DragDropState.DragDropState(
348
+ mousePosition,
349
+ dragElement
350
+ );
351
+ setDragBoundaries(containerRect, draggableRect);
352
+ beginDrag(dragElement);
353
+ const {
354
+ dataset: { index = "-1" }
355
+ } = dragElement;
356
+ setDraggableStatus({
357
+ isDragging: true,
358
+ draggable: /* @__PURE__ */ jsxRuntime.jsx(
359
+ Draggable.Draggable,
360
+ {
361
+ element: dropTargetUtils.cloneElement(dragElement),
362
+ onDropped: terminateDrag,
363
+ onTransitionEnd: terminateDrag,
364
+ ref: dragDropState.setDraggable,
365
+ style: dropTargetUtils.constrainRect(draggableRect, containerRect),
366
+ wrapperClassName: draggableClassName
367
+ }
368
+ ),
369
+ draggedItemIndex: parseInt(index)
370
+ });
371
+ onDragStart?.(dragDropState);
372
+ attachDragHandlers();
373
+ mousedownElementRef.current = null;
374
+ }
375
+ },
376
+ [
377
+ attachDragHandlers,
378
+ beginDrag,
379
+ containerRef,
380
+ draggableClassName,
381
+ itemQuery,
382
+ onDragStart,
383
+ orientation,
384
+ scrollingContainerRef,
385
+ setDragBoundaries,
386
+ terminateDrag
387
+ ]
388
+ );
389
+ const preDragMouseMoveHandler = React.useCallback(
390
+ (evt) => {
391
+ const { current: mouseDownPosition } = startPosRef;
392
+ const { CLIENT_POS, POS } = dropTargetUtils.dimensions(orientation);
393
+ const { [CLIENT_POS]: clientPos } = evt;
394
+ const mouseMoveDistance = Math.abs(clientPos - mouseDownPosition[POS]);
395
+ if (mouseMoveDistance > dragThreshold && containerRef.current) {
396
+ if (mouseDownTimer.current) {
397
+ window.clearTimeout(mouseDownTimer.current);
398
+ mouseDownTimer.current = null;
399
+ }
400
+ document.removeEventListener("mousemove", preDragMouseMoveHandler);
401
+ document.removeEventListener("mouseup", preDragMouseUpHandler, false);
402
+ const mousePosition = {
403
+ clientX: mouseDownPosition.x,
404
+ clientY: mouseDownPosition.y
405
+ };
406
+ dragStart(mousePosition);
407
+ }
408
+ },
409
+ // eslint-disable-next-line react-hooks/exhaustive-deps
410
+ [containerRef, beginDrag, orientation]
411
+ );
412
+ const preDragMouseUpHandler = React.useCallback(() => {
413
+ if (mouseDownTimer.current) {
414
+ window.clearTimeout(mouseDownTimer.current);
415
+ mouseDownTimer.current = null;
416
+ }
417
+ document.removeEventListener("mousemove", preDragMouseMoveHandler, false);
418
+ document.removeEventListener("mouseup", preDragMouseUpHandler, false);
419
+ }, [preDragMouseMoveHandler]);
420
+ const mouseDownHandler = React.useCallback(
421
+ (evt) => {
422
+ if (evt.button !== 0) {
423
+ return;
424
+ }
425
+ const { current: container } = containerRef;
426
+ evt.stopPropagation();
427
+ if (container && !evt.defaultPrevented) {
428
+ const { clientX, clientY } = evt;
429
+ mousePosRef.current.x = startPosRef.current.x = clientX;
430
+ mousePosRef.current.y = startPosRef.current.y = clientY;
431
+ mousedownElementRef.current = evt.target;
432
+ const mousePosition = {
433
+ clientX,
434
+ clientY
435
+ };
436
+ document.addEventListener("mousemove", preDragMouseMoveHandler, false);
437
+ document.addEventListener("mouseup", preDragMouseUpHandler, false);
438
+ evt.persist();
439
+ mouseDownTimer.current = window.setTimeout(() => {
440
+ document.removeEventListener(
441
+ "mousemove",
442
+ preDragMouseMoveHandler,
443
+ false
444
+ );
445
+ document.removeEventListener("mouseup", preDragMouseUpHandler, false);
446
+ dragStart(mousePosition);
447
+ }, 500);
448
+ }
449
+ },
450
+ [containerRef, dragStart, preDragMouseMoveHandler, preDragMouseUpHandler]
451
+ );
452
+ const { current: settlingItem } = settlingItemRef;
453
+ React.useLayoutEffect(() => {
454
+ if (settlingItem && containerRef.current) {
455
+ const dropPos = dropPosRef.current;
456
+ const droppedItem = containerRef.current.querySelector(
457
+ `${itemQuery}[data-index="${dropPos}"]`
458
+ );
459
+ if (droppedItem) {
460
+ droppedItem.classList.add("vuuDropTarget-settling");
461
+ requestAnimationFrame(() => {
462
+ const { top: targetTop, left: targetLeft } = droppedItem.getBoundingClientRect();
463
+ const style = getComputedStyle(settlingItem);
464
+ const currentLeft = parseInt(style.getPropertyValue("left"));
465
+ const currentTop = parseInt(style.getPropertyValue("top"));
466
+ if (currentLeft !== targetLeft || currentTop !== targetTop) {
467
+ settlingItem.classList.add("vuuDraggable-settling");
468
+ settlingItem.style.top = `${targetTop}px`;
469
+ settlingItem.style.left = `${targetLeft}px`;
470
+ } else {
471
+ terminateDrag();
472
+ }
473
+ });
474
+ }
475
+ }
476
+ }, [containerRef, itemQuery, settlingItem, terminateDrag]);
477
+ React.useEffect(() => {
478
+ if (id && (isDragSource || isDropTarget)) {
479
+ register(id, allowDragDrop === "drop-only" ? false : resumeDrag, onDrop);
480
+ }
481
+ }, [
482
+ allowDragDrop,
483
+ id,
484
+ isDragSource,
485
+ isDropTarget,
486
+ onDrop,
487
+ register,
488
+ resumeDrag
489
+ ]);
490
+ return {
491
+ ...dragResult,
492
+ ...draggableStatus,
493
+ isScrolling,
494
+ onMouseDown: allowDragDrop && allowDragDrop !== "drop-only" ? mouseDownHandler : void 0
495
+ };
496
+ };
497
+
498
+ exports.useDragDrop = useDragDrop;
499
+ //# sourceMappingURL=useDragDrop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDragDrop.js","sources":["../../src/drag-drop/useDragDrop.tsx"],"sourcesContent":["import { dispatchCustomEvent } from \"@vuu-ui/vuu-utils\";\nimport {\n MouseEventHandler,\n useCallback,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from \"react\";\nimport { useDragDropProvider } from \"./DragDropProvider\";\nimport { DragDropState } from \"./DragDropState\";\nimport {\n DragDropHook,\n DropHandler,\n InternalDragDropProps,\n InternalDragHookResult,\n MouseOffset,\n MousePosition,\n} from \"./dragDropTypes\";\nimport { Draggable } from \"./Draggable\";\nimport {\n cloneElement,\n constrainRect,\n dimensions,\n getScrollableContainer,\n isContainerScrollable,\n NOT_OVERFLOWED,\n} from \"./drop-target-utils\";\nimport { ScrollStopHandler, useAutoScroll } from \"./useAutoScroll\";\nimport { useDragDropCopy, NULL_DROP_OPTIONS } from \"./useDragDropCopy\";\nimport { useDragDropIndicator } from \"./useDragDropIndicator\";\nimport { useDragDropNaturalMovement } from \"./useDragDropNaturalMovement\";\nimport { ResumeDragHandler } from \"./useGlobalDragDrop\";\nimport { isOverflowElement } from \"../utils\";\n\nconst NULL_DRAG_DROP_RESULT = {\n beginDrag: () => undefined,\n drag: () => undefined,\n draggableRef: { current: null },\n drop: () => NULL_DROP_OPTIONS,\n isDragging: false,\n isScrolling: false,\n handleScrollStart: () => undefined,\n handleScrollStop: () => undefined,\n revealOverflowedItems: false,\n};\n\ntype DraggableStatus = {\n draggable?: JSX.Element;\n draggedItemIndex: number;\n isDragging: boolean;\n};\n\ntype DragBoundary = {\n start: number;\n end: number;\n contraStart: number;\n contraEnd: number;\n};\n\nconst UNBOUNDED: DragBoundary = {\n start: 0,\n end: 1000,\n contraStart: 0,\n contraEnd: 1000,\n};\n\ntype InternalHook = (props: InternalDragDropProps) => InternalDragHookResult;\nconst noDragDrop: InternalHook = () => NULL_DRAG_DROP_RESULT;\nconst dragThreshold = 3;\n\nconst getDraggableElement = (\n el: EventTarget | null,\n query: string\n): HTMLElement => (el as HTMLElement)?.closest(query) as HTMLElement;\n\nconst getLastElement = (\n container: HTMLElement,\n itemQuery: string\n): [HTMLElement, boolean] => {\n const fullItemQuery = `:is(${itemQuery}${NOT_OVERFLOWED},.vuuOverflowContainer-OverflowIndicator)`;\n const childElements = Array.from(container.querySelectorAll(fullItemQuery));\n const lastElement = childElements.pop() as HTMLElement;\n return [lastElement, isOverflowElement(lastElement)];\n};\n\nexport const useDragDrop: DragDropHook = ({\n allowDragDrop,\n containerRef,\n draggableClassName,\n getDragPayload,\n id,\n itemQuery = \"*\",\n onDragStart,\n onDrop,\n onDropSettle,\n orientation,\n scrollingContainerRef,\n ...dragDropProps\n}) => {\n const dragBoundaries = useRef<DragBoundary>({\n start: 0,\n end: 0,\n contraStart: 0,\n contraEnd: 0,\n });\n const [draggableStatus, setDraggableStatus] = useState<DraggableStatus>({\n draggable: undefined,\n draggedItemIndex: -1,\n isDragging: false,\n });\n\n const dragDropStateRef = useRef<DragDropState | null>(null);\n const mouseDownTimer = useRef<number | null>(null);\n /** do we actually have scrollable content */\n const isScrollableRef = useRef(false);\n\n /** save this on mousedown. We cannot rely on the target of mousemove being same element*/\n const mousedownElementRef = useRef<HTMLElement | null>(null);\n\n /** current mouse position */\n const mousePosRef = useRef<MouseOffset>({ x: 0, y: 0 });\n /** mouse position when mousedown initiated drag */\n const startPosRef = useRef<MouseOffset>({ x: 0, y: 0 });\n /** references the dragged Item during its final 'settling' phase post drop */\n const settlingItemRef = useRef<HTMLElement | null>(null);\n /** the container which will scroll if content overflows */\n const scrollableContainerRef = useRef<HTMLElement | null>(null);\n const dropPosRef = useRef(-1);\n const dropIndexRef = useRef(-1);\n\n const handleScrollStopRef = useRef<ScrollStopHandler>();\n\n const {\n isDragSource,\n isDropTarget,\n onDragOut,\n onEndOfDragOperation,\n register,\n } = useDragDropProvider(id);\n\n type NativeMouseHandler = (evt: MouseEvent) => void;\n /** refs for drag handlers to avoid circular dependency issues */\n const dragMouseMoveHandlerRef = useRef<NativeMouseHandler>();\n const dragMouseUpHandlerRef = useRef<NativeMouseHandler>();\n\n const attachDragHandlers = useCallback(() => {\n const { current: dragMove } = dragMouseMoveHandlerRef;\n const { current: dragUp } = dragMouseUpHandlerRef;\n if (dragMove && dragUp) {\n // prettier-ignore\n document.addEventListener(\"mousemove\", dragMove, false);\n document.addEventListener(\"mouseup\", dragUp, false);\n }\n }, []);\n const removeDragHandlers = useCallback(() => {\n const { current: dragMove } = dragMouseMoveHandlerRef;\n const { current: dragUp } = dragMouseUpHandlerRef;\n if (dragMove && dragUp) {\n // prettier-ignore\n document.removeEventListener(\"mousemove\", dragMove, false);\n document.removeEventListener(\"mouseup\", dragUp, false);\n }\n }, []);\n\n /**\n * Establish the boundaries for the current drag operation. When dragging along\n * a single axis (eg list items within a list, tabs within a tabstrip), constrain\n * valid drag positions to the confines of the container. A sharp drag away from\n * the primary drag axis is interpreted as a request to drag an item out of the\n * container. This will be allowed if configured appropriately.\n */\n const setDragBoundaries = useCallback(\n (containerRect: DOMRect, draggableRect: DOMRect) => {\n const { current: container } = containerRef;\n if (container) {\n const [lastElement, lastItemIsOverflowIndicator] = getLastElement(\n container,\n itemQuery\n );\n const { CONTRA, CONTRA_END, DIMENSION, END, START } =\n dimensions(orientation);\n\n const draggableSize = draggableRect[DIMENSION];\n const { [START]: lastItemStart, [END]: lastItemEnd } =\n lastElement.getBoundingClientRect();\n\n dragBoundaries.current.start = containerRect[START];\n dragBoundaries.current.end = lastItemIsOverflowIndicator\n ? Math.max(lastItemStart, containerRect.right - draggableSize)\n : isScrollableRef.current\n ? containerRect[START] + containerRect[DIMENSION] - draggableSize\n : lastItemEnd - draggableSize;\n dragBoundaries.current.contraStart = containerRect[CONTRA];\n dragBoundaries.current.contraEnd = containerRect[CONTRA_END];\n }\n },\n [containerRef, itemQuery, orientation]\n );\n\n const terminateDrag = useCallback(() => {\n const { current: settlingItem } = settlingItemRef;\n settlingItemRef.current = null;\n\n const { current: toIndex } = dropIndexRef;\n const droppedItem = containerRef.current?.querySelector(\n `${itemQuery}[data-index=\"${toIndex}\"]`\n );\n if (droppedItem) {\n droppedItem.classList.remove(\"vuuDropTarget-settling\");\n }\n dropIndexRef.current = -1;\n onDropSettle?.(toIndex);\n setDraggableStatus((status) => ({\n ...status,\n draggable: undefined,\n }));\n\n if (settlingItem) {\n dispatchCustomEvent(settlingItem, \"vuu-dropped\");\n }\n }, [containerRef, itemQuery, onDropSettle]);\n\n const getScrollDirection = useCallback(\n (mousePos: number) => {\n if (scrollableContainerRef.current && dragDropStateRef.current) {\n const { mouseOffset } = dragDropStateRef.current;\n\n const { POS, SCROLL_POS, SCROLL_SIZE, CLIENT_SIZE } =\n dimensions(orientation);\n const {\n [SCROLL_POS]: scrollPos,\n [SCROLL_SIZE]: scrollSize,\n [CLIENT_SIZE]: clientSize,\n } = scrollableContainerRef.current;\n\n const maxScroll = scrollSize - clientSize;\n const canScrollFwd = scrollPos < maxScroll;\n const viewportEnd = dragBoundaries.current.end;\n const bwd =\n scrollPos > 0 &&\n mousePos - mouseOffset[POS] <= dragBoundaries.current.start;\n const fwd = canScrollFwd && mousePos - mouseOffset[POS] >= viewportEnd;\n\n return bwd ? \"bwd\" : fwd ? \"fwd\" : \"\";\n }\n },\n [scrollableContainerRef, orientation]\n );\n\n const useDragDropHook: InternalHook =\n allowDragDrop === true || allowDragDrop === \"natural-movement\"\n ? useDragDropNaturalMovement\n : allowDragDrop === \"drop-indicator\"\n ? useDragDropIndicator\n : allowDragDrop === \"drag-copy\"\n ? useDragDropCopy\n : noDragDrop;\n\n const onScrollingStopped = useCallback(\n (scrollDirection: \"fwd\" | \"bwd\", scrollPos: number, atEnd: boolean) => {\n handleScrollStopRef.current?.(scrollDirection, scrollPos, atEnd);\n },\n []\n );\n\n const { isScrolling, startScrolling, stopScrolling } = useAutoScroll({\n containerRef: scrollableContainerRef,\n onScrollingStopped,\n orientation,\n });\n\n const handleDrop = useCallback<DropHandler>(\n (options) => {\n //TODO why do we need both this and dropIndexRef ?\n dropPosRef.current = options.toIndex;\n if (options.isExternal) {\n onDrop?.({\n ...options,\n payload: dragDropStateRef.current?.payload,\n });\n } else {\n onDrop?.(options);\n }\n dropIndexRef.current = options.toIndex;\n if (id) {\n onEndOfDragOperation?.(id);\n }\n dragDropStateRef.current = null;\n },\n [id, onDrop, onEndOfDragOperation]\n );\n\n const {\n beginDrag,\n drag,\n drop,\n handleScrollStart,\n handleScrollStop,\n releaseDrag,\n ...dragResult\n } = useDragDropHook({\n ...dragDropProps,\n containerRef,\n isDragSource,\n isDropTarget,\n itemQuery,\n orientation,\n });\n // To avoid circular ref between hooks\n handleScrollStopRef.current = handleScrollStop;\n\n const dragHandedOvertoProvider = useCallback(\n (dragDistance: number, clientContraPos: number) => {\n const { CONTRA_POS } = dimensions(orientation);\n const lastClientContraPos = mousePosRef.current[CONTRA_POS];\n\n const dragOutDistance = isDragSource\n ? Math.abs(lastClientContraPos - clientContraPos)\n : 0;\n\n if (allowDragDrop === true && !isDragSource && !isDropTarget) {\n //This is a simple internal drag\n return false;\n }\n\n // If isDropTarget is false, there are configured dropTargets in context\n // but this is not one, so drag will be handed straight over to DragProvider\n // (global drag). If isDropTarget is undefined, we have no DragProvider\n // so we are dealing with a simple local drag drop operation.\n const handoverToProvider =\n isDropTarget === false || dragOutDistance - dragDistance > 5;\n\n if (dragDropStateRef.current && handoverToProvider) {\n if (onDragOut?.(id as string, dragDropStateRef.current)) {\n // TODO create a cleanup function\n removeDragHandlers();\n releaseDrag?.();\n dragDropStateRef.current = null;\n }\n // remove the drag boundaries\n dragBoundaries.current = UNBOUNDED;\n return true;\n }\n },\n [\n allowDragDrop,\n id,\n isDragSource,\n isDropTarget,\n onDragOut,\n orientation,\n releaseDrag,\n removeDragHandlers,\n ]\n );\n\n const dragMouseMoveHandler = useCallback(\n (evt: MouseEvent) => {\n const { CLIENT_POS, CONTRA_CLIENT_POS, POS } = dimensions(orientation);\n const { clientX, clientY } = evt;\n const { [CLIENT_POS]: clientPos, [CONTRA_CLIENT_POS]: clientContraPos } =\n evt;\n const lastClientPos = mousePosRef.current[POS];\n const dragDistance = Math.abs(lastClientPos - clientPos);\n const { current: dragDropState } = dragDropStateRef;\n const { current: boundary } = dragBoundaries;\n\n if (dragHandedOvertoProvider(dragDistance, clientContraPos)) {\n return;\n }\n\n mousePosRef.current.x = clientX;\n mousePosRef.current.y = clientY;\n\n if (dragDropState) {\n const { draggableElement, mouseOffset } = dragDropState;\n\n if (dragBoundaries.current === UNBOUNDED && draggableElement) {\n const dragPosX = mousePosRef.current.x - mouseOffset.x;\n const dragPosY = mousePosRef.current.y - mouseOffset.y;\n draggableElement.style.top = `${dragPosY}px`;\n draggableElement.style.left = `${dragPosX}px`;\n } else if (dragDistance > 0 && draggableElement) {\n const mouseMoveDirection = lastClientPos < clientPos ? \"fwd\" : \"bwd\";\n const scrollDirection = getScrollDirection(clientPos);\n const dragPos = mousePosRef.current[POS] - mouseOffset[POS];\n const START = orientation === \"horizontal\" ? \"left\" : \"top\";\n\n if (\n scrollDirection &&\n isScrollableRef.current &&\n !isScrolling.current\n ) {\n handleScrollStart?.(scrollDirection);\n startScrolling(scrollDirection, 1);\n\n if (scrollDirection === \"fwd\") {\n draggableElement.style[START] = `${boundary.end}px`;\n } else {\n draggableElement.style[START] = `${boundary.start}px`;\n }\n } else if (!scrollDirection && isScrolling.current) {\n stopScrolling();\n }\n\n if (!isScrolling.current) {\n const renderDragPos = Math.round(\n Math.max(boundary.start, Math.min(boundary.end, dragPos))\n );\n draggableElement.style[START] = `${renderDragPos}px`;\n drag(renderDragPos, mouseMoveDirection);\n }\n }\n }\n },\n [\n drag,\n dragHandedOvertoProvider,\n getScrollDirection,\n handleScrollStart,\n isScrolling,\n orientation,\n startScrolling,\n stopScrolling,\n ]\n );\n const dragMouseUpHandler = useCallback(() => {\n removeDragHandlers();\n if (dragDropStateRef.current) {\n settlingItemRef.current = dragDropStateRef.current.draggableElement;\n }\n const dropOptions = drop();\n handleDrop(dropOptions);\n\n setDraggableStatus((status) => ({\n ...status,\n draggedItemIndex: -1,\n isDragging: false,\n }));\n // TODO clear the dragDropState\n }, [drop, handleDrop, removeDragHandlers]);\n\n dragMouseMoveHandlerRef.current = dragMouseMoveHandler;\n dragMouseUpHandlerRef.current = dragMouseUpHandler;\n\n const resumeDrag = useCallback<ResumeDragHandler>(\n (dragDropState: DragDropState) => {\n dragDropStateRef.current = dragDropState;\n // Note this is using the draggable element rather than the original draggedElement\n const { draggableElement, mouseOffset } = dragDropState;\n const { current: container } = containerRef;\n\n if (container && draggableElement) {\n const containerRect = container.getBoundingClientRect();\n const draggableRect = draggableElement.getBoundingClientRect();\n setDragBoundaries(containerRect, draggableRect);\n\n mousePosRef.current.x = draggableRect.left + mouseOffset.x;\n mousePosRef.current.y = draggableRect.top + mouseOffset.y;\n\n // why doesn't this work if we use the initialDragEement\n beginDrag(draggableElement);\n\n attachDragHandlers();\n\n return true;\n } else {\n return false;\n }\n },\n [attachDragHandlers, beginDrag, containerRef, setDragBoundaries]\n );\n\n const dragStart = useCallback(\n (mousePosition: MousePosition) => {\n const { current: container } = containerRef;\n const { current: target } = mousedownElementRef;\n const dragElement = getDraggableElement(target, itemQuery);\n const scrollableContainer =\n scrollingContainerRef?.current ??\n getScrollableContainer(container, itemQuery);\n if (container && scrollableContainer && dragElement) {\n isScrollableRef.current = isContainerScrollable(\n scrollableContainer,\n orientation\n );\n scrollableContainerRef.current = scrollableContainer;\n\n const containerRect = scrollableContainer.getBoundingClientRect();\n const draggableRect = dragElement.getBoundingClientRect();\n\n const dragDropState = (dragDropStateRef.current = new DragDropState(\n mousePosition,\n dragElement\n ));\n\n setDragBoundaries(containerRect, draggableRect);\n\n beginDrag(dragElement);\n\n const {\n dataset: { index = \"-1\" },\n } = dragElement;\n\n setDraggableStatus({\n isDragging: true,\n draggable: (\n <Draggable\n element={cloneElement(dragElement)}\n onDropped={terminateDrag}\n onTransitionEnd={terminateDrag}\n ref={dragDropState.setDraggable}\n style={constrainRect(draggableRect, containerRect)}\n wrapperClassName={draggableClassName}\n />\n ),\n draggedItemIndex: parseInt(index),\n });\n\n onDragStart?.(dragDropState);\n attachDragHandlers();\n\n mousedownElementRef.current = null;\n }\n },\n [\n attachDragHandlers,\n beginDrag,\n containerRef,\n draggableClassName,\n itemQuery,\n onDragStart,\n orientation,\n scrollingContainerRef,\n setDragBoundaries,\n terminateDrag,\n ]\n );\n\n const preDragMouseMoveHandler = useCallback(\n (evt: MouseEvent) => {\n const { current: mouseDownPosition } = startPosRef;\n const { CLIENT_POS, POS } = dimensions(orientation);\n const { [CLIENT_POS]: clientPos } = evt;\n const mouseMoveDistance = Math.abs(clientPos - mouseDownPosition[POS]);\n if (mouseMoveDistance > dragThreshold && containerRef.current) {\n if (mouseDownTimer.current) {\n window.clearTimeout(mouseDownTimer.current);\n mouseDownTimer.current = null;\n }\n document.removeEventListener(\"mousemove\", preDragMouseMoveHandler);\n document.removeEventListener(\"mouseup\", preDragMouseUpHandler, false);\n\n const mousePosition = {\n clientX: mouseDownPosition.x,\n clientY: mouseDownPosition.y,\n };\n dragStart(mousePosition);\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [containerRef, beginDrag, orientation]\n );\n\n const preDragMouseUpHandler = useCallback(() => {\n if (mouseDownTimer.current) {\n window.clearTimeout(mouseDownTimer.current);\n mouseDownTimer.current = null;\n }\n document.removeEventListener(\"mousemove\", preDragMouseMoveHandler, false);\n document.removeEventListener(\"mouseup\", preDragMouseUpHandler, false);\n }, [preDragMouseMoveHandler]);\n\n const mouseDownHandler: MouseEventHandler = useCallback(\n (evt) => {\n if (evt.button !== 0) {\n return;\n }\n // TODO runtime check here for valid drop targets ?\n const { current: container } = containerRef;\n // We don't want to prevent other handlers on this element from working\n // but we do want to stop a drag drop being initiated on a bubbled event.\n evt.stopPropagation();\n if (container && !evt.defaultPrevented) {\n const { clientX, clientY } = evt;\n mousePosRef.current.x = startPosRef.current.x = clientX;\n mousePosRef.current.y = startPosRef.current.y = clientY;\n mousedownElementRef.current = evt.target as HTMLElement;\n\n const mousePosition = {\n clientX,\n clientY,\n };\n\n document.addEventListener(\"mousemove\", preDragMouseMoveHandler, false);\n document.addEventListener(\"mouseup\", preDragMouseUpHandler, false);\n\n evt.persist();\n\n mouseDownTimer.current = window.setTimeout(() => {\n document.removeEventListener(\n \"mousemove\",\n preDragMouseMoveHandler,\n false\n );\n document.removeEventListener(\"mouseup\", preDragMouseUpHandler, false);\n dragStart(mousePosition);\n }, 500);\n }\n },\n [containerRef, dragStart, preDragMouseMoveHandler, preDragMouseUpHandler]\n );\n\n const { current: settlingItem } = settlingItemRef;\n useLayoutEffect(() => {\n if (settlingItem && containerRef.current) {\n const dropPos = dropPosRef.current;\n const droppedItem = containerRef.current.querySelector(\n `${itemQuery}[data-index=\"${dropPos}\"]`\n );\n if (droppedItem) {\n droppedItem.classList.add(\"vuuDropTarget-settling\");\n requestAnimationFrame(() => {\n const { top: targetTop, left: targetLeft } =\n droppedItem.getBoundingClientRect();\n // If the droppedItem is already exactly in the drop position, we can just\n // terminate the drag here and now. Most likely, though, it is out by a few\n // pixels. We animate the dragged item into the final resting place before\n // terminating the drag.\n const style = getComputedStyle(settlingItem);\n const currentLeft = parseInt(style.getPropertyValue(\"left\"));\n const currentTop = parseInt(style.getPropertyValue(\"top\"));\n if (currentLeft !== targetLeft || currentTop !== targetTop) {\n settlingItem.classList.add(\"vuuDraggable-settling\");\n settlingItem.style.top = `${targetTop}px`;\n settlingItem.style.left = `${targetLeft}px`;\n } else {\n terminateDrag();\n }\n });\n }\n // settlingItemRef.current = null;\n }\n }, [containerRef, itemQuery, settlingItem, terminateDrag]);\n\n useEffect(() => {\n if (id && (isDragSource || isDropTarget)) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n //@ts-ignore TODO drah drop WIP\n register(id, allowDragDrop === \"drop-only\" ? false : resumeDrag, onDrop);\n }\n }, [\n allowDragDrop,\n id,\n isDragSource,\n isDropTarget,\n onDrop,\n register,\n resumeDrag,\n ]);\n\n return {\n ...dragResult,\n ...draggableStatus,\n isScrolling,\n onMouseDown:\n allowDragDrop && allowDragDrop !== \"drop-only\"\n ? mouseDownHandler\n : undefined,\n };\n};\n"],"names":["NULL_DROP_OPTIONS","NOT_OVERFLOWED","isOverflowElement","useRef","useState","useDragDropProvider","useCallback","dimensions","settlingItem","dispatchCustomEvent","useDragDropNaturalMovement","useDragDropIndicator","useDragDropCopy","useAutoScroll","getScrollableContainer","isContainerScrollable","DragDropState","jsx","Draggable","cloneElement","constrainRect","useLayoutEffect","useEffect"],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+
5
+ const NULL_DROP_OPTIONS = {
6
+ fromIndex: -1,
7
+ toIndex: -1
8
+ };
9
+ const useDragDropCopy = ({
10
+ selected,
11
+ viewportRange
12
+ }) => {
13
+ const rangeRef = React.useRef();
14
+ rangeRef.current = viewportRange;
15
+ const beginDrag = React.useCallback(
16
+ (dragElement) => {
17
+ if (dragElement.ariaSelected && Array.isArray(selected) && selected.length > 1) {
18
+ console.log("its a selected element, and we have a multi select");
19
+ }
20
+ },
21
+ [selected]
22
+ );
23
+ const drag = React.useCallback(() => void 0, []);
24
+ const drop = React.useCallback(() => NULL_DROP_OPTIONS, []);
25
+ return {
26
+ beginDrag,
27
+ drag,
28
+ drop
29
+ };
30
+ };
31
+
32
+ exports.NULL_DROP_OPTIONS = NULL_DROP_OPTIONS;
33
+ exports.useDragDropCopy = useDragDropCopy;
34
+ //# sourceMappingURL=useDragDropCopy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDragDropCopy.js","sources":["../../src/drag-drop/useDragDropCopy.ts"],"sourcesContent":["import { useCallback, useRef } from \"react\";\n\nimport type {\n InternalDragDropProps,\n InternalDragHookResult,\n ViewportRange,\n} from \"./dragDropTypes\";\n\nexport const NULL_DROP_OPTIONS = {\n fromIndex: -1,\n toIndex: -1,\n} as const;\n\nexport const useDragDropCopy = ({\n selected,\n viewportRange,\n}: InternalDragDropProps): InternalDragHookResult => {\n const rangeRef = useRef<ViewportRange>();\n rangeRef.current = viewportRange;\n\n const beginDrag = useCallback(\n (dragElement: HTMLElement) => {\n if (\n dragElement.ariaSelected &&\n Array.isArray(selected) &&\n selected.length > 1\n ) {\n console.log(\"its a selected element, and we have a multi select\");\n }\n },\n [selected]\n );\n\n const drag = useCallback(() => undefined, []);\n const drop = useCallback(() => NULL_DROP_OPTIONS, []);\n\n return {\n beginDrag,\n drag,\n drop,\n };\n};\n"],"names":["useRef","useCallback"],"mappings":";;;;AAQO,MAAM,iBAAoB,GAAA;AAAA,EAC/B,SAAW,EAAA,CAAA,CAAA;AAAA,EACX,OAAS,EAAA,CAAA,CAAA;AACX,EAAA;AAEO,MAAM,kBAAkB,CAAC;AAAA,EAC9B,QAAA;AAAA,EACA,aAAA;AACF,CAAqD,KAAA;AACnD,EAAA,MAAM,WAAWA,YAAsB,EAAA,CAAA;AACvC,EAAA,QAAA,CAAS,OAAU,GAAA,aAAA,CAAA;AAEnB,EAAA,MAAM,SAAY,GAAAC,iBAAA;AAAA,IAChB,CAAC,WAA6B,KAAA;AAC5B,MACE,IAAA,WAAA,CAAY,gBACZ,KAAM,CAAA,OAAA,CAAQ,QAAQ,CACtB,IAAA,QAAA,CAAS,SAAS,CAClB,EAAA;AACA,QAAA,OAAA,CAAQ,IAAI,oDAAoD,CAAA,CAAA;AAAA,OAClE;AAAA,KACF;AAAA,IACA,CAAC,QAAQ,CAAA;AAAA,GACX,CAAA;AAEA,EAAA,MAAM,IAAO,GAAAA,iBAAA,CAAY,MAAM,KAAA,CAAA,EAAW,EAAE,CAAA,CAAA;AAC5C,EAAA,MAAM,IAAO,GAAAA,iBAAA,CAAY,MAAM,iBAAA,EAAmB,EAAE,CAAA,CAAA;AAEpD,EAAO,OAAA;AAAA,IACL,SAAA;AAAA,IACA,IAAA;AAAA,IACA,IAAA;AAAA,GACF,CAAA;AACF;;;;;"}