@mantine/hooks 9.0.0-alpha.5 → 9.0.0-alpha.6

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 (378) hide show
  1. package/cjs/index.cjs +183 -188
  2. package/cjs/use-click-outside/use-click-outside.cjs +22 -26
  3. package/cjs/use-click-outside/use-click-outside.cjs.map +1 -1
  4. package/cjs/use-clipboard/use-clipboard.cjs +29 -28
  5. package/cjs/use-clipboard/use-clipboard.cjs.map +1 -1
  6. package/cjs/use-collapse/use-collapse.cjs +95 -98
  7. package/cjs/use-collapse/use-collapse.cjs.map +1 -1
  8. package/cjs/use-collapse/use-horizontal-collapse.cjs +94 -97
  9. package/cjs/use-collapse/use-horizontal-collapse.cjs.map +1 -1
  10. package/cjs/use-color-scheme/use-color-scheme.cjs +7 -8
  11. package/cjs/use-color-scheme/use-color-scheme.cjs.map +1 -1
  12. package/cjs/use-counter/use-counter.cjs +24 -26
  13. package/cjs/use-counter/use-counter.cjs.map +1 -1
  14. package/cjs/use-debounced-callback/use-debounced-callback.cjs +89 -93
  15. package/cjs/use-debounced-callback/use-debounced-callback.cjs.map +1 -1
  16. package/cjs/use-debounced-state/use-debounced-state.cjs +20 -28
  17. package/cjs/use-debounced-state/use-debounced-state.cjs.map +1 -1
  18. package/cjs/use-debounced-value/use-debounced-value.cjs +32 -31
  19. package/cjs/use-debounced-value/use-debounced-value.cjs.map +1 -1
  20. package/cjs/use-did-update/use-did-update.cjs +14 -21
  21. package/cjs/use-did-update/use-did-update.cjs.map +1 -1
  22. package/cjs/use-disclosure/use-disclosure.cjs +37 -30
  23. package/cjs/use-disclosure/use-disclosure.cjs.map +1 -1
  24. package/cjs/use-document-title/use-document-title.cjs +9 -12
  25. package/cjs/use-document-title/use-document-title.cjs.map +1 -1
  26. package/cjs/use-document-visibility/use-document-visibility.cjs +14 -15
  27. package/cjs/use-document-visibility/use-document-visibility.cjs.map +1 -1
  28. package/cjs/use-drag/use-drag.cjs +256 -294
  29. package/cjs/use-drag/use-drag.cjs.map +1 -1
  30. package/cjs/use-event-listener/use-event-listener.cjs +23 -32
  31. package/cjs/use-event-listener/use-event-listener.cjs.map +1 -1
  32. package/cjs/use-eye-dropper/use-eye-dropper.cjs +19 -24
  33. package/cjs/use-eye-dropper/use-eye-dropper.cjs.map +1 -1
  34. package/cjs/use-favicon/use-favicon.cjs +25 -32
  35. package/cjs/use-favicon/use-favicon.cjs.map +1 -1
  36. package/cjs/use-fetch/use-fetch.cjs +43 -45
  37. package/cjs/use-fetch/use-fetch.cjs.map +1 -1
  38. package/cjs/use-file-dialog/use-file-dialog.cjs +65 -77
  39. package/cjs/use-file-dialog/use-file-dialog.cjs.map +1 -1
  40. package/cjs/use-floating-window/use-floating-window.cjs +244 -255
  41. package/cjs/use-floating-window/use-floating-window.cjs.map +1 -1
  42. package/cjs/use-focus-return/use-focus-return.cjs +26 -37
  43. package/cjs/use-focus-return/use-focus-return.cjs.map +1 -1
  44. package/cjs/use-focus-trap/scope-tab.cjs +20 -31
  45. package/cjs/use-focus-trap/scope-tab.cjs.map +1 -1
  46. package/cjs/use-focus-trap/tabbable.cjs +24 -40
  47. package/cjs/use-focus-trap/tabbable.cjs.map +1 -1
  48. package/cjs/use-focus-trap/use-focus-trap.cjs +41 -68
  49. package/cjs/use-focus-trap/use-focus-trap.cjs.map +1 -1
  50. package/cjs/use-focus-within/use-focus-within.cjs +51 -62
  51. package/cjs/use-focus-within/use-focus-within.cjs.map +1 -1
  52. package/cjs/use-force-update/use-force-update.cjs +8 -9
  53. package/cjs/use-force-update/use-force-update.cjs.map +1 -1
  54. package/cjs/use-fullscreen/use-fullscreen.cjs +80 -89
  55. package/cjs/use-fullscreen/use-fullscreen.cjs.map +1 -1
  56. package/cjs/use-hash/use-hash.cjs +21 -28
  57. package/cjs/use-hash/use-hash.cjs.map +1 -1
  58. package/cjs/use-headroom/use-headroom.cjs +71 -94
  59. package/cjs/use-headroom/use-headroom.cjs.map +1 -1
  60. package/cjs/use-hotkeys/parse-hotkey.cjs +74 -82
  61. package/cjs/use-hotkeys/parse-hotkey.cjs.map +1 -1
  62. package/cjs/use-hotkeys/use-hotkeys.cjs +32 -33
  63. package/cjs/use-hotkeys/use-hotkeys.cjs.map +1 -1
  64. package/cjs/use-hover/use-hover.cjs +31 -33
  65. package/cjs/use-hover/use-hover.cjs.map +1 -1
  66. package/cjs/use-id/use-id.cjs +14 -18
  67. package/cjs/use-id/use-id.cjs.map +1 -1
  68. package/cjs/use-idle/use-idle.cjs +40 -33
  69. package/cjs/use-idle/use-idle.cjs.map +1 -1
  70. package/cjs/use-in-viewport/use-in-viewport.cjs +22 -27
  71. package/cjs/use-in-viewport/use-in-viewport.cjs.map +1 -1
  72. package/cjs/use-input-state/use-input-state.cjs +17 -26
  73. package/cjs/use-input-state/use-input-state.cjs.map +1 -1
  74. package/cjs/use-intersection/use-intersection.cjs +29 -27
  75. package/cjs/use-intersection/use-intersection.cjs.map +1 -1
  76. package/cjs/use-interval/use-interval.cjs +42 -41
  77. package/cjs/use-interval/use-interval.cjs.map +1 -1
  78. package/cjs/use-is-first-render/use-is-first-render.cjs +12 -13
  79. package/cjs/use-is-first-render/use-is-first-render.cjs.map +1 -1
  80. package/cjs/use-isomorphic-effect/use-isomorphic-effect.cjs +6 -7
  81. package/cjs/use-isomorphic-effect/use-isomorphic-effect.cjs.map +1 -1
  82. package/cjs/use-list-state/use-list-state.cjs +74 -73
  83. package/cjs/use-list-state/use-list-state.cjs.map +1 -1
  84. package/cjs/use-local-storage/create-storage.cjs +127 -139
  85. package/cjs/use-local-storage/create-storage.cjs.map +1 -1
  86. package/cjs/use-local-storage/use-local-storage.cjs +8 -9
  87. package/cjs/use-local-storage/use-local-storage.cjs.map +1 -1
  88. package/cjs/use-logger/use-logger.cjs +15 -16
  89. package/cjs/use-logger/use-logger.cjs.map +1 -1
  90. package/cjs/use-long-press/use-long-press.cjs +49 -58
  91. package/cjs/use-long-press/use-long-press.cjs.map +1 -1
  92. package/cjs/use-map/use-map.cjs +24 -25
  93. package/cjs/use-map/use-map.cjs.map +1 -1
  94. package/cjs/use-mask/use-mask.cjs +418 -544
  95. package/cjs/use-mask/use-mask.cjs.map +1 -1
  96. package/cjs/use-media-query/use-media-query.cjs +27 -33
  97. package/cjs/use-media-query/use-media-query.cjs.map +1 -1
  98. package/cjs/use-merged-ref/use-merged-ref.cjs +24 -35
  99. package/cjs/use-merged-ref/use-merged-ref.cjs.map +1 -1
  100. package/cjs/use-mounted/use-mounted.cjs +9 -10
  101. package/cjs/use-mounted/use-mounted.cjs.map +1 -1
  102. package/cjs/use-mouse/use-mouse.cjs +55 -53
  103. package/cjs/use-mouse/use-mouse.cjs.map +1 -1
  104. package/cjs/use-move/use-move.cjs +98 -98
  105. package/cjs/use-move/use-move.cjs.map +1 -1
  106. package/cjs/use-mutation-observer/use-mutation-observer.cjs +45 -46
  107. package/cjs/use-mutation-observer/use-mutation-observer.cjs.map +1 -1
  108. package/cjs/use-network/use-network.cjs +48 -44
  109. package/cjs/use-network/use-network.cjs.map +1 -1
  110. package/cjs/use-orientation/use-orientation.cjs +30 -41
  111. package/cjs/use-orientation/use-orientation.cjs.map +1 -1
  112. package/cjs/use-os/use-os.cjs +27 -52
  113. package/cjs/use-os/use-os.cjs.map +1 -1
  114. package/cjs/use-page-leave/use-page-leave.cjs +11 -12
  115. package/cjs/use-page-leave/use-page-leave.cjs.map +1 -1
  116. package/cjs/use-pagination/use-pagination.cjs +75 -88
  117. package/cjs/use-pagination/use-pagination.cjs.map +1 -1
  118. package/cjs/use-previous/use-previous.cjs +11 -12
  119. package/cjs/use-previous/use-previous.cjs.map +1 -1
  120. package/cjs/use-queue/use-queue.cjs +40 -37
  121. package/cjs/use-queue/use-queue.cjs.map +1 -1
  122. package/cjs/use-radial-move/use-radial-move.cjs +87 -94
  123. package/cjs/use-radial-move/use-radial-move.cjs.map +1 -1
  124. package/cjs/use-reduced-motion/use-reduced-motion.cjs +7 -8
  125. package/cjs/use-reduced-motion/use-reduced-motion.cjs.map +1 -1
  126. package/cjs/use-resize-observer/use-resize-observer.cjs +55 -62
  127. package/cjs/use-resize-observer/use-resize-observer.cjs.map +1 -1
  128. package/cjs/use-roving-index/use-roving-index.cjs +188 -258
  129. package/cjs/use-roving-index/use-roving-index.cjs.map +1 -1
  130. package/cjs/use-scroll-direction/use-scroll-direction.cjs +33 -36
  131. package/cjs/use-scroll-direction/use-scroll-direction.cjs.map +1 -1
  132. package/cjs/use-scroll-into-view/use-scroll-into-view.cjs +128 -160
  133. package/cjs/use-scroll-into-view/use-scroll-into-view.cjs.map +1 -1
  134. package/cjs/use-scroll-spy/use-scroll-spy.cjs +58 -84
  135. package/cjs/use-scroll-spy/use-scroll-spy.cjs.map +1 -1
  136. package/cjs/use-scroller/use-scroller.cjs +128 -151
  137. package/cjs/use-scroller/use-scroller.cjs.map +1 -1
  138. package/cjs/use-selection/use-selection.cjs +61 -72
  139. package/cjs/use-selection/use-selection.cjs.map +1 -1
  140. package/cjs/use-session-storage/use-session-storage.cjs +8 -9
  141. package/cjs/use-session-storage/use-session-storage.cjs.map +1 -1
  142. package/cjs/use-set/use-set.cjs +60 -74
  143. package/cjs/use-set/use-set.cjs.map +1 -1
  144. package/cjs/use-set-state/use-set-state.cjs +11 -16
  145. package/cjs/use-set-state/use-set-state.cjs.map +1 -1
  146. package/cjs/use-shallow-effect/use-shallow-effect.cjs +20 -31
  147. package/cjs/use-shallow-effect/use-shallow-effect.cjs.map +1 -1
  148. package/cjs/use-splitter/use-splitter.cjs +433 -0
  149. package/cjs/use-splitter/use-splitter.cjs.map +1 -0
  150. package/cjs/use-state-history/use-state-history.cjs +47 -40
  151. package/cjs/use-state-history/use-state-history.cjs.map +1 -1
  152. package/cjs/use-text-selection/use-text-selection.cjs +19 -20
  153. package/cjs/use-text-selection/use-text-selection.cjs.map +1 -1
  154. package/cjs/use-throttled-callback/use-throttled-callback.cjs +37 -48
  155. package/cjs/use-throttled-callback/use-throttled-callback.cjs.map +1 -1
  156. package/cjs/use-throttled-state/use-throttled-state.cjs +11 -12
  157. package/cjs/use-throttled-state/use-throttled-state.cjs.map +1 -1
  158. package/cjs/use-throttled-value/use-throttled-value.cjs +18 -22
  159. package/cjs/use-throttled-value/use-throttled-value.cjs.map +1 -1
  160. package/cjs/use-timeout/use-timeout.cjs +27 -32
  161. package/cjs/use-timeout/use-timeout.cjs.map +1 -1
  162. package/cjs/use-toggle/use-toggle.cjs +12 -13
  163. package/cjs/use-toggle/use-toggle.cjs.map +1 -1
  164. package/cjs/use-uncontrolled/use-uncontrolled.cjs +22 -25
  165. package/cjs/use-uncontrolled/use-uncontrolled.cjs.map +1 -1
  166. package/cjs/use-validated-state/use-validated-state.cjs +21 -24
  167. package/cjs/use-validated-state/use-validated-state.cjs.map +1 -1
  168. package/cjs/use-viewport-size/use-viewport-size.cjs +22 -22
  169. package/cjs/use-viewport-size/use-viewport-size.cjs.map +1 -1
  170. package/cjs/use-window-event/use-window-event.cjs +11 -12
  171. package/cjs/use-window-event/use-window-event.cjs.map +1 -1
  172. package/cjs/use-window-scroll/use-window-scroll.cjs +30 -26
  173. package/cjs/use-window-scroll/use-window-scroll.cjs.map +1 -1
  174. package/cjs/utils/clamp/clamp.cjs +9 -15
  175. package/cjs/utils/clamp/clamp.cjs.map +1 -1
  176. package/cjs/utils/lower-first/lower-first.cjs +6 -6
  177. package/cjs/utils/lower-first/lower-first.cjs.map +1 -1
  178. package/cjs/utils/random-id/random-id.cjs +6 -6
  179. package/cjs/utils/random-id/random-id.cjs.map +1 -1
  180. package/cjs/utils/range/range.cjs +8 -11
  181. package/cjs/utils/range/range.cjs.map +1 -1
  182. package/cjs/utils/shallow-equal/shallow-equal.cjs +17 -29
  183. package/cjs/utils/shallow-equal/shallow-equal.cjs.map +1 -1
  184. package/cjs/utils/upper-first/upper-first.cjs +6 -6
  185. package/cjs/utils/upper-first/upper-first.cjs.map +1 -1
  186. package/cjs/utils/use-callback-ref/use-callback-ref.cjs +11 -12
  187. package/cjs/utils/use-callback-ref/use-callback-ref.cjs.map +1 -1
  188. package/esm/index.mjs +87 -87
  189. package/esm/use-click-outside/use-click-outside.mjs +22 -24
  190. package/esm/use-click-outside/use-click-outside.mjs.map +1 -1
  191. package/esm/use-clipboard/use-clipboard.mjs +29 -26
  192. package/esm/use-clipboard/use-clipboard.mjs.map +1 -1
  193. package/esm/use-collapse/use-collapse.mjs +95 -95
  194. package/esm/use-collapse/use-collapse.mjs.map +1 -1
  195. package/esm/use-collapse/use-horizontal-collapse.mjs +94 -94
  196. package/esm/use-collapse/use-horizontal-collapse.mjs.map +1 -1
  197. package/esm/use-color-scheme/use-color-scheme.mjs +7 -6
  198. package/esm/use-color-scheme/use-color-scheme.mjs.map +1 -1
  199. package/esm/use-counter/use-counter.mjs +24 -24
  200. package/esm/use-counter/use-counter.mjs.map +1 -1
  201. package/esm/use-debounced-callback/use-debounced-callback.mjs +89 -91
  202. package/esm/use-debounced-callback/use-debounced-callback.mjs.map +1 -1
  203. package/esm/use-debounced-state/use-debounced-state.mjs +20 -26
  204. package/esm/use-debounced-state/use-debounced-state.mjs.map +1 -1
  205. package/esm/use-debounced-value/use-debounced-value.mjs +32 -29
  206. package/esm/use-debounced-value/use-debounced-value.mjs.map +1 -1
  207. package/esm/use-did-update/use-did-update.mjs +14 -19
  208. package/esm/use-did-update/use-did-update.mjs.map +1 -1
  209. package/esm/use-disclosure/use-disclosure.mjs +37 -28
  210. package/esm/use-disclosure/use-disclosure.mjs.map +1 -1
  211. package/esm/use-document-title/use-document-title.mjs +9 -10
  212. package/esm/use-document-title/use-document-title.mjs.map +1 -1
  213. package/esm/use-document-visibility/use-document-visibility.mjs +14 -13
  214. package/esm/use-document-visibility/use-document-visibility.mjs.map +1 -1
  215. package/esm/use-drag/use-drag.mjs +256 -292
  216. package/esm/use-drag/use-drag.mjs.map +1 -1
  217. package/esm/use-event-listener/use-event-listener.mjs +23 -30
  218. package/esm/use-event-listener/use-event-listener.mjs.map +1 -1
  219. package/esm/use-eye-dropper/use-eye-dropper.mjs +19 -22
  220. package/esm/use-eye-dropper/use-eye-dropper.mjs.map +1 -1
  221. package/esm/use-favicon/use-favicon.mjs +25 -30
  222. package/esm/use-favicon/use-favicon.mjs.map +1 -1
  223. package/esm/use-fetch/use-fetch.mjs +43 -43
  224. package/esm/use-fetch/use-fetch.mjs.map +1 -1
  225. package/esm/use-file-dialog/use-file-dialog.mjs +65 -75
  226. package/esm/use-file-dialog/use-file-dialog.mjs.map +1 -1
  227. package/esm/use-floating-window/use-floating-window.mjs +244 -253
  228. package/esm/use-floating-window/use-floating-window.mjs.map +1 -1
  229. package/esm/use-focus-return/use-focus-return.mjs +26 -35
  230. package/esm/use-focus-return/use-focus-return.mjs.map +1 -1
  231. package/esm/use-focus-trap/scope-tab.mjs +20 -29
  232. package/esm/use-focus-trap/scope-tab.mjs.map +1 -1
  233. package/esm/use-focus-trap/tabbable.mjs +23 -38
  234. package/esm/use-focus-trap/tabbable.mjs.map +1 -1
  235. package/esm/use-focus-trap/use-focus-trap.mjs +39 -66
  236. package/esm/use-focus-trap/use-focus-trap.mjs.map +1 -1
  237. package/esm/use-focus-within/use-focus-within.mjs +51 -60
  238. package/esm/use-focus-within/use-focus-within.mjs.map +1 -1
  239. package/esm/use-force-update/use-force-update.mjs +8 -7
  240. package/esm/use-force-update/use-force-update.mjs.map +1 -1
  241. package/esm/use-fullscreen/use-fullscreen.mjs +80 -87
  242. package/esm/use-fullscreen/use-fullscreen.mjs.map +1 -1
  243. package/esm/use-hash/use-hash.mjs +21 -26
  244. package/esm/use-hash/use-hash.mjs.map +1 -1
  245. package/esm/use-headroom/use-headroom.mjs +71 -89
  246. package/esm/use-headroom/use-headroom.mjs.map +1 -1
  247. package/esm/use-hotkeys/parse-hotkey.mjs +74 -79
  248. package/esm/use-hotkeys/parse-hotkey.mjs.map +1 -1
  249. package/esm/use-hotkeys/use-hotkeys.mjs +32 -31
  250. package/esm/use-hotkeys/use-hotkeys.mjs.map +1 -1
  251. package/esm/use-hover/use-hover.mjs +31 -31
  252. package/esm/use-hover/use-hover.mjs.map +1 -1
  253. package/esm/use-id/use-id.mjs +15 -17
  254. package/esm/use-id/use-id.mjs.map +1 -1
  255. package/esm/use-idle/use-idle.mjs +40 -31
  256. package/esm/use-idle/use-idle.mjs.map +1 -1
  257. package/esm/use-in-viewport/use-in-viewport.mjs +22 -25
  258. package/esm/use-in-viewport/use-in-viewport.mjs.map +1 -1
  259. package/esm/use-input-state/use-input-state.mjs +17 -23
  260. package/esm/use-input-state/use-input-state.mjs.map +1 -1
  261. package/esm/use-intersection/use-intersection.mjs +29 -25
  262. package/esm/use-intersection/use-intersection.mjs.map +1 -1
  263. package/esm/use-interval/use-interval.mjs +42 -39
  264. package/esm/use-interval/use-interval.mjs.map +1 -1
  265. package/esm/use-is-first-render/use-is-first-render.mjs +12 -11
  266. package/esm/use-is-first-render/use-is-first-render.mjs.map +1 -1
  267. package/esm/use-isomorphic-effect/use-isomorphic-effect.mjs +6 -5
  268. package/esm/use-isomorphic-effect/use-isomorphic-effect.mjs.map +1 -1
  269. package/esm/use-list-state/use-list-state.mjs +74 -71
  270. package/esm/use-list-state/use-list-state.mjs.map +1 -1
  271. package/esm/use-local-storage/create-storage.mjs +127 -137
  272. package/esm/use-local-storage/create-storage.mjs.map +1 -1
  273. package/esm/use-local-storage/use-local-storage.mjs +7 -6
  274. package/esm/use-local-storage/use-local-storage.mjs.map +1 -1
  275. package/esm/use-logger/use-logger.mjs +15 -14
  276. package/esm/use-logger/use-logger.mjs.map +1 -1
  277. package/esm/use-long-press/use-long-press.mjs +49 -56
  278. package/esm/use-long-press/use-long-press.mjs.map +1 -1
  279. package/esm/use-map/use-map.mjs +24 -23
  280. package/esm/use-map/use-map.mjs.map +1 -1
  281. package/esm/use-mask/use-mask.mjs +418 -542
  282. package/esm/use-mask/use-mask.mjs.map +1 -1
  283. package/esm/use-media-query/use-media-query.mjs +27 -31
  284. package/esm/use-media-query/use-media-query.mjs.map +1 -1
  285. package/esm/use-merged-ref/use-merged-ref.mjs +24 -33
  286. package/esm/use-merged-ref/use-merged-ref.mjs.map +1 -1
  287. package/esm/use-mounted/use-mounted.mjs +9 -8
  288. package/esm/use-mounted/use-mounted.mjs.map +1 -1
  289. package/esm/use-mouse/use-mouse.mjs +55 -51
  290. package/esm/use-mouse/use-mouse.mjs.map +1 -1
  291. package/esm/use-move/use-move.mjs +98 -96
  292. package/esm/use-move/use-move.mjs.map +1 -1
  293. package/esm/use-mutation-observer/use-mutation-observer.mjs +45 -44
  294. package/esm/use-mutation-observer/use-mutation-observer.mjs.map +1 -1
  295. package/esm/use-network/use-network.mjs +48 -42
  296. package/esm/use-network/use-network.mjs.map +1 -1
  297. package/esm/use-orientation/use-orientation.mjs +30 -39
  298. package/esm/use-orientation/use-orientation.mjs.map +1 -1
  299. package/esm/use-os/use-os.mjs +27 -50
  300. package/esm/use-os/use-os.mjs.map +1 -1
  301. package/esm/use-page-leave/use-page-leave.mjs +11 -10
  302. package/esm/use-page-leave/use-page-leave.mjs.map +1 -1
  303. package/esm/use-pagination/use-pagination.mjs +75 -85
  304. package/esm/use-pagination/use-pagination.mjs.map +1 -1
  305. package/esm/use-previous/use-previous.mjs +11 -10
  306. package/esm/use-previous/use-previous.mjs.map +1 -1
  307. package/esm/use-queue/use-queue.mjs +40 -35
  308. package/esm/use-queue/use-queue.mjs.map +1 -1
  309. package/esm/use-radial-move/use-radial-move.mjs +87 -92
  310. package/esm/use-radial-move/use-radial-move.mjs.map +1 -1
  311. package/esm/use-reduced-motion/use-reduced-motion.mjs +7 -6
  312. package/esm/use-reduced-motion/use-reduced-motion.mjs.map +1 -1
  313. package/esm/use-resize-observer/use-resize-observer.mjs +55 -60
  314. package/esm/use-resize-observer/use-resize-observer.mjs.map +1 -1
  315. package/esm/use-roving-index/use-roving-index.mjs +188 -256
  316. package/esm/use-roving-index/use-roving-index.mjs.map +1 -1
  317. package/esm/use-scroll-direction/use-scroll-direction.mjs +33 -34
  318. package/esm/use-scroll-direction/use-scroll-direction.mjs.map +1 -1
  319. package/esm/use-scroll-into-view/use-scroll-into-view.mjs +128 -158
  320. package/esm/use-scroll-into-view/use-scroll-into-view.mjs.map +1 -1
  321. package/esm/use-scroll-spy/use-scroll-spy.mjs +58 -82
  322. package/esm/use-scroll-spy/use-scroll-spy.mjs.map +1 -1
  323. package/esm/use-scroller/use-scroller.mjs +128 -149
  324. package/esm/use-scroller/use-scroller.mjs.map +1 -1
  325. package/esm/use-selection/use-selection.mjs +61 -70
  326. package/esm/use-selection/use-selection.mjs.map +1 -1
  327. package/esm/use-session-storage/use-session-storage.mjs +7 -6
  328. package/esm/use-session-storage/use-session-storage.mjs.map +1 -1
  329. package/esm/use-set/use-set.mjs +60 -71
  330. package/esm/use-set/use-set.mjs.map +1 -1
  331. package/esm/use-set-state/use-set-state.mjs +11 -14
  332. package/esm/use-set-state/use-set-state.mjs.map +1 -1
  333. package/esm/use-shallow-effect/use-shallow-effect.mjs +20 -29
  334. package/esm/use-shallow-effect/use-shallow-effect.mjs.map +1 -1
  335. package/esm/use-splitter/use-splitter.mjs +433 -0
  336. package/esm/use-splitter/use-splitter.mjs.map +1 -0
  337. package/esm/use-state-history/use-state-history.mjs +47 -38
  338. package/esm/use-state-history/use-state-history.mjs.map +1 -1
  339. package/esm/use-text-selection/use-text-selection.mjs +19 -18
  340. package/esm/use-text-selection/use-text-selection.mjs.map +1 -1
  341. package/esm/use-throttled-callback/use-throttled-callback.mjs +37 -46
  342. package/esm/use-throttled-callback/use-throttled-callback.mjs.map +1 -1
  343. package/esm/use-throttled-state/use-throttled-state.mjs +11 -10
  344. package/esm/use-throttled-state/use-throttled-state.mjs.map +1 -1
  345. package/esm/use-throttled-value/use-throttled-value.mjs +18 -20
  346. package/esm/use-throttled-value/use-throttled-value.mjs.map +1 -1
  347. package/esm/use-timeout/use-timeout.mjs +27 -30
  348. package/esm/use-timeout/use-timeout.mjs.map +1 -1
  349. package/esm/use-toggle/use-toggle.mjs +12 -11
  350. package/esm/use-toggle/use-toggle.mjs.map +1 -1
  351. package/esm/use-uncontrolled/use-uncontrolled.mjs +22 -23
  352. package/esm/use-uncontrolled/use-uncontrolled.mjs.map +1 -1
  353. package/esm/use-validated-state/use-validated-state.mjs +21 -22
  354. package/esm/use-validated-state/use-validated-state.mjs.map +1 -1
  355. package/esm/use-viewport-size/use-viewport-size.mjs +22 -20
  356. package/esm/use-viewport-size/use-viewport-size.mjs.map +1 -1
  357. package/esm/use-window-event/use-window-event.mjs +11 -10
  358. package/esm/use-window-event/use-window-event.mjs.map +1 -1
  359. package/esm/use-window-scroll/use-window-scroll.mjs +30 -24
  360. package/esm/use-window-scroll/use-window-scroll.mjs.map +1 -1
  361. package/esm/utils/clamp/clamp.mjs +9 -13
  362. package/esm/utils/clamp/clamp.mjs.map +1 -1
  363. package/esm/utils/lower-first/lower-first.mjs +6 -4
  364. package/esm/utils/lower-first/lower-first.mjs.map +1 -1
  365. package/esm/utils/random-id/random-id.mjs +6 -4
  366. package/esm/utils/random-id/random-id.mjs.map +1 -1
  367. package/esm/utils/range/range.mjs +8 -9
  368. package/esm/utils/range/range.mjs.map +1 -1
  369. package/esm/utils/shallow-equal/shallow-equal.mjs +17 -27
  370. package/esm/utils/shallow-equal/shallow-equal.mjs.map +1 -1
  371. package/esm/utils/upper-first/upper-first.mjs +6 -4
  372. package/esm/utils/upper-first/upper-first.mjs.map +1 -1
  373. package/esm/utils/use-callback-ref/use-callback-ref.mjs +11 -10
  374. package/esm/utils/use-callback-ref/use-callback-ref.mjs.map +1 -1
  375. package/lib/use-splitter/use-splitter.d.ts +94 -0
  376. package/package.json +1 -1
  377. package/cjs/index.cjs.map +0 -1
  378. package/esm/index.mjs.map +0 -1
@@ -1,18 +1,17 @@
1
- 'use client';
2
- 'use strict';
3
-
4
- var react = require('react');
5
-
1
+ "use client";
2
+ let react = require("react");
3
+ //#region packages/@mantine/hooks/src/use-document-visibility/use-document-visibility.ts
6
4
  function useDocumentVisibility() {
7
- const [documentVisibility, setDocumentVisibility] = react.useState("visible");
8
- react.useEffect(() => {
9
- setDocumentVisibility(document.visibilityState);
10
- const listener = () => setDocumentVisibility(document.visibilityState);
11
- document.addEventListener("visibilitychange", listener);
12
- return () => document.removeEventListener("visibilitychange", listener);
13
- }, []);
14
- return documentVisibility;
5
+ const [documentVisibility, setDocumentVisibility] = (0, react.useState)("visible");
6
+ (0, react.useEffect)(() => {
7
+ setDocumentVisibility(document.visibilityState);
8
+ const listener = () => setDocumentVisibility(document.visibilityState);
9
+ document.addEventListener("visibilitychange", listener);
10
+ return () => document.removeEventListener("visibilitychange", listener);
11
+ }, []);
12
+ return documentVisibility;
15
13
  }
16
-
14
+ //#endregion
17
15
  exports.useDocumentVisibility = useDocumentVisibility;
18
- //# sourceMappingURL=use-document-visibility.cjs.map
16
+
17
+ //# sourceMappingURL=use-document-visibility.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"use-document-visibility.cjs","sources":["../../src/use-document-visibility/use-document-visibility.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nexport function useDocumentVisibility(): DocumentVisibilityState {\n const [documentVisibility, setDocumentVisibility] = useState<DocumentVisibilityState>('visible');\n\n useEffect(() => {\n setDocumentVisibility(document.visibilityState);\n const listener = () => setDocumentVisibility(document.visibilityState);\n document.addEventListener('visibilitychange', listener);\n return () => document.removeEventListener('visibilitychange', listener);\n }, []);\n\n return documentVisibility;\n}\n"],"names":["useState","useEffect"],"mappings":";;;;;AAEO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,qBAAA,CAAA,CAAA,CAAiD,CAAA;AAC/D,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAoB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAqB,CAAA,CAAA,CAAA,CAAIA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,EAAkC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAA,CAAA;AAE/F,CAAA,CAAAC,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAA,CAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAA;AACd,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAsB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAS,eAAe,CAAA,CAAA;AAC9C,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,QAAA,CAAA,CAAA,CAAW,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,qBAAA,CAAsB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAe,CAAA,CAAA;AACrE,CAAA,CAAA,CAAA,CAAA,QAAA,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAiB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAoB,QAAQ,CAAA,CAAA;AACtD,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,MAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,mBAAA,CAAoB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAoB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAA,CAAA;AAAA,CAAA,CACxE,CAAA,CAAA,CAAG,CAAA,CAAE,CAAA,CAAA;AAEL,CAAA,CAAA,OAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACT,CAAA;;"}
1
+ {"version":3,"file":"use-document-visibility.cjs","names":[],"sources":["../../src/use-document-visibility/use-document-visibility.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nexport function useDocumentVisibility(): DocumentVisibilityState {\n const [documentVisibility, setDocumentVisibility] = useState<DocumentVisibilityState>('visible');\n\n useEffect(() => {\n setDocumentVisibility(document.visibilityState);\n const listener = () => setDocumentVisibility(document.visibilityState);\n document.addEventListener('visibilitychange', listener);\n return () => document.removeEventListener('visibilitychange', listener);\n }, []);\n\n return documentVisibility;\n}\n"],"mappings":";;;AAEA,SAAgB,wBAAiD;CAC/D,MAAM,CAAC,oBAAoB,0BAAA,GAAA,MAAA,UAA2D,UAAU;AAEhG,EAAA,GAAA,MAAA,iBAAgB;AACd,wBAAsB,SAAS,gBAAgB;EAC/C,MAAM,iBAAiB,sBAAsB,SAAS,gBAAgB;AACtE,WAAS,iBAAiB,oBAAoB,SAAS;AACvD,eAAa,SAAS,oBAAoB,oBAAoB,SAAS;IACtE,EAAE,CAAC;AAEN,QAAO"}
@@ -1,304 +1,266 @@
1
- 'use client';
2
- 'use strict';
3
-
4
- var react = require('react');
5
-
1
+ "use client";
2
+ let react = require("react");
3
+ //#region packages/@mantine/hooks/src/use-drag/use-drag.ts
6
4
  const VELOCITY_DECAY_MS = 100;
7
5
  function sign(n) {
8
- if (n > 0) {
9
- return 1;
10
- }
11
- if (n < 0) {
12
- return -1;
13
- }
14
- return 0;
6
+ if (n > 0) return 1;
7
+ if (n < 0) return -1;
8
+ return 0;
15
9
  }
16
10
  function getThresholdVector(threshold) {
17
- const t = threshold ?? 0;
18
- if (typeof t === "number") {
19
- return [t, t];
20
- }
21
- return t;
11
+ const t = threshold ?? 0;
12
+ if (typeof t === "number") return [t, t];
13
+ return t;
22
14
  }
23
15
  function createInitialState() {
24
- return {
25
- isActive: false,
26
- pointerId: -1,
27
- startXY: [0, 0],
28
- prevXY: [0, 0],
29
- startTimestamp: 0,
30
- prevTimestamp: 0,
31
- thresholdMet: false,
32
- firstFired: false,
33
- lockedAxis: null,
34
- canceled: false,
35
- lastVelocity: [0, 0]
36
- };
16
+ return {
17
+ isActive: false,
18
+ pointerId: -1,
19
+ startXY: [0, 0],
20
+ prevXY: [0, 0],
21
+ startTimestamp: 0,
22
+ prevTimestamp: 0,
23
+ thresholdMet: false,
24
+ firstFired: false,
25
+ lockedAxis: null,
26
+ canceled: false,
27
+ lastVelocity: [0, 0]
28
+ };
37
29
  }
38
30
  function useDrag(handler, options = {}) {
39
- const [active, setActive] = react.useState(false);
40
- const handlerRef = react.useRef(handler);
41
- handlerRef.current = handler;
42
- const optionsRef = react.useRef(options);
43
- optionsRef.current = options;
44
- const stateRef = react.useRef(createInitialState());
45
- const documentControllerRef = react.useRef(null);
46
- const refCallback = react.useCallback((node) => {
47
- if (!node) {
48
- return void 0;
49
- }
50
- const elementController = new AbortController();
51
- const applyAxisConstraint = (v) => {
52
- const opts = optionsRef.current;
53
- const s = stateRef.current;
54
- if (opts.axis === "x") {
55
- return [v[0], 0];
56
- }
57
- if (opts.axis === "y") {
58
- return [0, v[1]];
59
- }
60
- if (opts.axis === "lock") {
61
- if (s.lockedAxis === null) {
62
- const t = opts.axisThreshold ?? 1;
63
- if (Math.abs(v[0]) > t || Math.abs(v[1]) > t) {
64
- s.lockedAxis = Math.abs(v[0]) >= Math.abs(v[1]) ? "x" : "y";
65
- }
66
- }
67
- if (s.lockedAxis === "x") {
68
- return [v[0], 0];
69
- }
70
- if (s.lockedAxis === "y") {
71
- return [0, v[1]];
72
- }
73
- }
74
- return v;
75
- };
76
- const resetDrag = () => {
77
- const s = stateRef.current;
78
- s.isActive = false;
79
- s.pointerId = -1;
80
- s.thresholdMet = false;
81
- s.firstFired = false;
82
- s.lockedAxis = null;
83
- s.canceled = false;
84
- setActive(false);
85
- document.body.style.userSelect = "";
86
- document.body.style.webkitUserSelect = "";
87
- documentControllerRef.current?.abort();
88
- documentControllerRef.current = null;
89
- };
90
- const cancel = () => {
91
- if (stateRef.current.isActive) {
92
- stateRef.current.canceled = true;
93
- resetDrag();
94
- }
95
- };
96
- const activateDrag = () => {
97
- setActive(true);
98
- document.body.style.userSelect = "none";
99
- document.body.style.webkitUserSelect = "none";
100
- };
101
- const onPointerDown = (event) => {
102
- if (optionsRef.current.enabled === false) {
103
- return;
104
- }
105
- if (event.button !== 0) {
106
- return;
107
- }
108
- if (stateRef.current.isActive) {
109
- return;
110
- }
111
- const s = stateRef.current;
112
- s.isActive = true;
113
- s.pointerId = event.pointerId;
114
- s.startXY = [event.clientX, event.clientY];
115
- s.prevXY = [event.clientX, event.clientY];
116
- s.startTimestamp = event.timeStamp;
117
- s.prevTimestamp = event.timeStamp;
118
- s.thresholdMet = false;
119
- s.firstFired = false;
120
- s.lockedAxis = null;
121
- s.canceled = false;
122
- s.lastVelocity = [0, 0];
123
- const [tx, ty] = getThresholdVector(optionsRef.current.threshold);
124
- if (tx === 0 && ty === 0) {
125
- s.thresholdMet = true;
126
- s.firstFired = true;
127
- activateDrag();
128
- handlerRef.current({
129
- xy: [event.clientX, event.clientY],
130
- initial: [event.clientX, event.clientY],
131
- movement: [0, 0],
132
- delta: [0, 0],
133
- distance: [0, 0],
134
- direction: [0, 0],
135
- velocity: [0, 0],
136
- elapsedTime: 0,
137
- first: true,
138
- last: false,
139
- active: true,
140
- tap: false,
141
- canceled: false,
142
- cancel,
143
- event
144
- });
145
- }
146
- documentControllerRef.current?.abort();
147
- documentControllerRef.current = new AbortController();
148
- const sig = documentControllerRef.current.signal;
149
- document.addEventListener("pointermove", onPointerMove, { signal: sig });
150
- document.addEventListener("pointerup", onPointerUp, { signal: sig });
151
- document.addEventListener("pointercancel", onPointerCancel, { signal: sig });
152
- };
153
- const onPointerMove = (event) => {
154
- const s = stateRef.current;
155
- if (!s.isActive || event.pointerId !== s.pointerId) {
156
- return;
157
- }
158
- const rawMovement = [event.clientX - s.startXY[0], event.clientY - s.startXY[1]];
159
- if (!s.thresholdMet) {
160
- const [tx, ty] = getThresholdVector(optionsRef.current.threshold);
161
- if (Math.abs(rawMovement[0]) < tx && Math.abs(rawMovement[1]) < ty) {
162
- s.prevXY = [event.clientX, event.clientY];
163
- s.prevTimestamp = event.timeStamp;
164
- return;
165
- }
166
- s.thresholdMet = true;
167
- activateDrag();
168
- }
169
- const movement = applyAxisConstraint(rawMovement);
170
- const rawDelta = [event.clientX - s.prevXY[0], event.clientY - s.prevXY[1]];
171
- const delta = applyAxisConstraint(rawDelta);
172
- const timeDelta = event.timeStamp - s.prevTimestamp;
173
- const velocity = timeDelta > 0 ? [Math.abs(delta[0]) / timeDelta, Math.abs(delta[1]) / timeDelta] : s.lastVelocity;
174
- s.lastVelocity = velocity;
175
- const isFirst = !s.firstFired;
176
- s.firstFired = true;
177
- s.prevXY = [event.clientX, event.clientY];
178
- s.prevTimestamp = event.timeStamp;
179
- handlerRef.current({
180
- xy: [event.clientX, event.clientY],
181
- initial: [...s.startXY],
182
- movement,
183
- delta,
184
- distance: [Math.abs(movement[0]), Math.abs(movement[1])],
185
- direction: [sign(delta[0]), sign(delta[1])],
186
- velocity,
187
- elapsedTime: event.timeStamp - s.startTimestamp,
188
- first: isFirst,
189
- last: false,
190
- active: true,
191
- tap: false,
192
- canceled: false,
193
- cancel,
194
- event
195
- });
196
- };
197
- const onPointerUp = (event) => {
198
- const s = stateRef.current;
199
- if (!s.isActive || event.pointerId !== s.pointerId) {
200
- return;
201
- }
202
- const opts = optionsRef.current;
203
- if (!s.thresholdMet) {
204
- if (opts.filterTaps) {
205
- const rawMov = [event.clientX - s.startXY[0], event.clientY - s.startXY[1]];
206
- const mov = applyAxisConstraint(rawMov);
207
- const dist = [Math.abs(mov[0]), Math.abs(mov[1])];
208
- const maxDist = Math.max(dist[0], dist[1]);
209
- const isTap = maxDist < (opts.tapThreshold ?? 3);
210
- handlerRef.current({
211
- xy: [event.clientX, event.clientY],
212
- initial: [...s.startXY],
213
- movement: mov,
214
- delta: mov,
215
- distance: dist,
216
- direction: [sign(mov[0]), sign(mov[1])],
217
- velocity: [0, 0],
218
- elapsedTime: event.timeStamp - s.startTimestamp,
219
- first: true,
220
- last: true,
221
- active: false,
222
- tap: isTap,
223
- canceled: false,
224
- cancel,
225
- event
226
- });
227
- }
228
- resetDrag();
229
- return;
230
- }
231
- const rawMovement = [event.clientX - s.startXY[0], event.clientY - s.startXY[1]];
232
- const movement = applyAxisConstraint(rawMovement);
233
- const distance = [Math.abs(movement[0]), Math.abs(movement[1])];
234
- const rawDelta = [event.clientX - s.prevXY[0], event.clientY - s.prevXY[1]];
235
- const delta = applyAxisConstraint(rawDelta);
236
- const timeSinceLastMove = event.timeStamp - s.prevTimestamp;
237
- const velocity = timeSinceLastMove > VELOCITY_DECAY_MS ? [0, 0] : s.lastVelocity;
238
- const maxDistance = Math.max(distance[0], distance[1]);
239
- const tap = opts.filterTaps === true && maxDistance < (opts.tapThreshold ?? 3);
240
- handlerRef.current({
241
- xy: [event.clientX, event.clientY],
242
- initial: [...s.startXY],
243
- movement,
244
- delta,
245
- distance,
246
- direction: [sign(delta[0]), sign(delta[1])],
247
- velocity,
248
- elapsedTime: event.timeStamp - s.startTimestamp,
249
- first: !s.firstFired,
250
- last: true,
251
- active: false,
252
- tap,
253
- canceled: false,
254
- cancel,
255
- event
256
- });
257
- resetDrag();
258
- };
259
- const onPointerCancel = (event) => {
260
- const s = stateRef.current;
261
- if (!s.isActive || event.pointerId !== s.pointerId) {
262
- return;
263
- }
264
- const rawMovement = [event.clientX - s.startXY[0], event.clientY - s.startXY[1]];
265
- const movement = applyAxisConstraint(rawMovement);
266
- handlerRef.current({
267
- xy: [event.clientX, event.clientY],
268
- initial: [...s.startXY],
269
- movement,
270
- delta: [0, 0],
271
- distance: [Math.abs(movement[0]), Math.abs(movement[1])],
272
- direction: [0, 0],
273
- velocity: [0, 0],
274
- elapsedTime: event.timeStamp - s.startTimestamp,
275
- first: !s.firstFired,
276
- last: true,
277
- active: false,
278
- tap: false,
279
- canceled: true,
280
- cancel,
281
- event
282
- });
283
- resetDrag();
284
- };
285
- node.addEventListener("pointerdown", onPointerDown, {
286
- signal: elementController.signal
287
- });
288
- return () => {
289
- elementController.abort();
290
- documentControllerRef.current?.abort();
291
- documentControllerRef.current = null;
292
- if (stateRef.current.isActive) {
293
- stateRef.current.isActive = false;
294
- setActive(false);
295
- document.body.style.userSelect = "";
296
- document.body.style.webkitUserSelect = "";
297
- }
298
- };
299
- }, []);
300
- return { ref: refCallback, active };
31
+ const [active, setActive] = (0, react.useState)(false);
32
+ const handlerRef = (0, react.useRef)(handler);
33
+ handlerRef.current = handler;
34
+ const optionsRef = (0, react.useRef)(options);
35
+ optionsRef.current = options;
36
+ const stateRef = (0, react.useRef)(createInitialState());
37
+ const documentControllerRef = (0, react.useRef)(null);
38
+ return {
39
+ ref: (0, react.useCallback)((node) => {
40
+ if (!node) return;
41
+ const elementController = new AbortController();
42
+ const applyAxisConstraint = (v) => {
43
+ const opts = optionsRef.current;
44
+ const s = stateRef.current;
45
+ if (opts.axis === "x") return [v[0], 0];
46
+ if (opts.axis === "y") return [0, v[1]];
47
+ if (opts.axis === "lock") {
48
+ if (s.lockedAxis === null) {
49
+ const t = opts.axisThreshold ?? 1;
50
+ if (Math.abs(v[0]) > t || Math.abs(v[1]) > t) s.lockedAxis = Math.abs(v[0]) >= Math.abs(v[1]) ? "x" : "y";
51
+ }
52
+ if (s.lockedAxis === "x") return [v[0], 0];
53
+ if (s.lockedAxis === "y") return [0, v[1]];
54
+ }
55
+ return v;
56
+ };
57
+ const resetDrag = () => {
58
+ const s = stateRef.current;
59
+ s.isActive = false;
60
+ s.pointerId = -1;
61
+ s.thresholdMet = false;
62
+ s.firstFired = false;
63
+ s.lockedAxis = null;
64
+ s.canceled = false;
65
+ setActive(false);
66
+ document.body.style.userSelect = "";
67
+ document.body.style.webkitUserSelect = "";
68
+ documentControllerRef.current?.abort();
69
+ documentControllerRef.current = null;
70
+ };
71
+ const cancel = () => {
72
+ if (stateRef.current.isActive) {
73
+ stateRef.current.canceled = true;
74
+ resetDrag();
75
+ }
76
+ };
77
+ const activateDrag = () => {
78
+ setActive(true);
79
+ document.body.style.userSelect = "none";
80
+ document.body.style.webkitUserSelect = "none";
81
+ };
82
+ const onPointerDown = (event) => {
83
+ if (optionsRef.current.enabled === false) return;
84
+ if (event.button !== 0) return;
85
+ if (stateRef.current.isActive) return;
86
+ const s = stateRef.current;
87
+ s.isActive = true;
88
+ s.pointerId = event.pointerId;
89
+ s.startXY = [event.clientX, event.clientY];
90
+ s.prevXY = [event.clientX, event.clientY];
91
+ s.startTimestamp = event.timeStamp;
92
+ s.prevTimestamp = event.timeStamp;
93
+ s.thresholdMet = false;
94
+ s.firstFired = false;
95
+ s.lockedAxis = null;
96
+ s.canceled = false;
97
+ s.lastVelocity = [0, 0];
98
+ const [tx, ty] = getThresholdVector(optionsRef.current.threshold);
99
+ if (tx === 0 && ty === 0) {
100
+ s.thresholdMet = true;
101
+ s.firstFired = true;
102
+ activateDrag();
103
+ handlerRef.current({
104
+ xy: [event.clientX, event.clientY],
105
+ initial: [event.clientX, event.clientY],
106
+ movement: [0, 0],
107
+ delta: [0, 0],
108
+ distance: [0, 0],
109
+ direction: [0, 0],
110
+ velocity: [0, 0],
111
+ elapsedTime: 0,
112
+ first: true,
113
+ last: false,
114
+ active: true,
115
+ tap: false,
116
+ canceled: false,
117
+ cancel,
118
+ event
119
+ });
120
+ }
121
+ documentControllerRef.current?.abort();
122
+ documentControllerRef.current = new AbortController();
123
+ const sig = documentControllerRef.current.signal;
124
+ document.addEventListener("pointermove", onPointerMove, { signal: sig });
125
+ document.addEventListener("pointerup", onPointerUp, { signal: sig });
126
+ document.addEventListener("pointercancel", onPointerCancel, { signal: sig });
127
+ };
128
+ const onPointerMove = (event) => {
129
+ const s = stateRef.current;
130
+ if (!s.isActive || event.pointerId !== s.pointerId) return;
131
+ const rawMovement = [event.clientX - s.startXY[0], event.clientY - s.startXY[1]];
132
+ if (!s.thresholdMet) {
133
+ const [tx, ty] = getThresholdVector(optionsRef.current.threshold);
134
+ if (Math.abs(rawMovement[0]) < tx && Math.abs(rawMovement[1]) < ty) {
135
+ s.prevXY = [event.clientX, event.clientY];
136
+ s.prevTimestamp = event.timeStamp;
137
+ return;
138
+ }
139
+ s.thresholdMet = true;
140
+ activateDrag();
141
+ }
142
+ const movement = applyAxisConstraint(rawMovement);
143
+ const delta = applyAxisConstraint([event.clientX - s.prevXY[0], event.clientY - s.prevXY[1]]);
144
+ const timeDelta = event.timeStamp - s.prevTimestamp;
145
+ const velocity = timeDelta > 0 ? [Math.abs(delta[0]) / timeDelta, Math.abs(delta[1]) / timeDelta] : s.lastVelocity;
146
+ s.lastVelocity = velocity;
147
+ const isFirst = !s.firstFired;
148
+ s.firstFired = true;
149
+ s.prevXY = [event.clientX, event.clientY];
150
+ s.prevTimestamp = event.timeStamp;
151
+ handlerRef.current({
152
+ xy: [event.clientX, event.clientY],
153
+ initial: [...s.startXY],
154
+ movement,
155
+ delta,
156
+ distance: [Math.abs(movement[0]), Math.abs(movement[1])],
157
+ direction: [sign(delta[0]), sign(delta[1])],
158
+ velocity,
159
+ elapsedTime: event.timeStamp - s.startTimestamp,
160
+ first: isFirst,
161
+ last: false,
162
+ active: true,
163
+ tap: false,
164
+ canceled: false,
165
+ cancel,
166
+ event
167
+ });
168
+ };
169
+ const onPointerUp = (event) => {
170
+ const s = stateRef.current;
171
+ if (!s.isActive || event.pointerId !== s.pointerId) return;
172
+ const opts = optionsRef.current;
173
+ if (!s.thresholdMet) {
174
+ if (opts.filterTaps) {
175
+ const mov = applyAxisConstraint([event.clientX - s.startXY[0], event.clientY - s.startXY[1]]);
176
+ const dist = [Math.abs(mov[0]), Math.abs(mov[1])];
177
+ const isTap = Math.max(dist[0], dist[1]) < (opts.tapThreshold ?? 3);
178
+ handlerRef.current({
179
+ xy: [event.clientX, event.clientY],
180
+ initial: [...s.startXY],
181
+ movement: mov,
182
+ delta: mov,
183
+ distance: dist,
184
+ direction: [sign(mov[0]), sign(mov[1])],
185
+ velocity: [0, 0],
186
+ elapsedTime: event.timeStamp - s.startTimestamp,
187
+ first: true,
188
+ last: true,
189
+ active: false,
190
+ tap: isTap,
191
+ canceled: false,
192
+ cancel,
193
+ event
194
+ });
195
+ }
196
+ resetDrag();
197
+ return;
198
+ }
199
+ const movement = applyAxisConstraint([event.clientX - s.startXY[0], event.clientY - s.startXY[1]]);
200
+ const distance = [Math.abs(movement[0]), Math.abs(movement[1])];
201
+ const delta = applyAxisConstraint([event.clientX - s.prevXY[0], event.clientY - s.prevXY[1]]);
202
+ const velocity = event.timeStamp - s.prevTimestamp > VELOCITY_DECAY_MS ? [0, 0] : s.lastVelocity;
203
+ const maxDistance = Math.max(distance[0], distance[1]);
204
+ const tap = opts.filterTaps === true && maxDistance < (opts.tapThreshold ?? 3);
205
+ handlerRef.current({
206
+ xy: [event.clientX, event.clientY],
207
+ initial: [...s.startXY],
208
+ movement,
209
+ delta,
210
+ distance,
211
+ direction: [sign(delta[0]), sign(delta[1])],
212
+ velocity,
213
+ elapsedTime: event.timeStamp - s.startTimestamp,
214
+ first: !s.firstFired,
215
+ last: true,
216
+ active: false,
217
+ tap,
218
+ canceled: false,
219
+ cancel,
220
+ event
221
+ });
222
+ resetDrag();
223
+ };
224
+ const onPointerCancel = (event) => {
225
+ const s = stateRef.current;
226
+ if (!s.isActive || event.pointerId !== s.pointerId) return;
227
+ const movement = applyAxisConstraint([event.clientX - s.startXY[0], event.clientY - s.startXY[1]]);
228
+ handlerRef.current({
229
+ xy: [event.clientX, event.clientY],
230
+ initial: [...s.startXY],
231
+ movement,
232
+ delta: [0, 0],
233
+ distance: [Math.abs(movement[0]), Math.abs(movement[1])],
234
+ direction: [0, 0],
235
+ velocity: [0, 0],
236
+ elapsedTime: event.timeStamp - s.startTimestamp,
237
+ first: !s.firstFired,
238
+ last: true,
239
+ active: false,
240
+ tap: false,
241
+ canceled: true,
242
+ cancel,
243
+ event
244
+ });
245
+ resetDrag();
246
+ };
247
+ node.addEventListener("pointerdown", onPointerDown, { signal: elementController.signal });
248
+ return () => {
249
+ elementController.abort();
250
+ documentControllerRef.current?.abort();
251
+ documentControllerRef.current = null;
252
+ if (stateRef.current.isActive) {
253
+ stateRef.current.isActive = false;
254
+ setActive(false);
255
+ document.body.style.userSelect = "";
256
+ document.body.style.webkitUserSelect = "";
257
+ }
258
+ };
259
+ }, []),
260
+ active
261
+ };
301
262
  }
302
-
263
+ //#endregion
303
264
  exports.useDrag = useDrag;
304
- //# sourceMappingURL=use-drag.cjs.map
265
+
266
+ //# sourceMappingURL=use-drag.cjs.map