@mantine/hooks 7.13.5-alpha.1 → 7.13.5-alpha.2

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 (433) hide show
  1. package/cjs/index.cjs +164 -0
  2. package/cjs/index.cjs.map +1 -0
  3. package/cjs/use-callback-ref/use-callback-ref.cjs +15 -0
  4. package/cjs/use-callback-ref/use-callback-ref.cjs.map +1 -0
  5. package/cjs/use-click-outside/use-click-outside.cjs +29 -0
  6. package/cjs/use-click-outside/use-click-outside.cjs.map +1 -0
  7. package/cjs/use-clipboard/use-clipboard.cjs +31 -0
  8. package/cjs/use-clipboard/use-clipboard.cjs.map +1 -0
  9. package/cjs/use-color-scheme/use-color-scheme.cjs +11 -0
  10. package/cjs/use-color-scheme/use-color-scheme.cjs.map +1 -0
  11. package/cjs/use-counter/use-counter.cjs +22 -0
  12. package/cjs/use-counter/use-counter.cjs.map +1 -0
  13. package/cjs/use-debounced-callback/use-debounced-callback.cjs +21 -0
  14. package/cjs/use-debounced-callback/use-debounced-callback.cjs.map +1 -0
  15. package/cjs/use-debounced-state/use-debounced-state.cjs +31 -0
  16. package/cjs/use-debounced-state/use-debounced-state.cjs.map +1 -0
  17. package/cjs/use-debounced-value/use-debounced-value.cjs +34 -0
  18. package/cjs/use-debounced-value/use-debounced-value.cjs.map +1 -0
  19. package/cjs/use-did-update/use-did-update.cjs +24 -0
  20. package/cjs/use-did-update/use-did-update.cjs.map +1 -0
  21. package/cjs/use-disclosure/use-disclosure.cjs +34 -0
  22. package/cjs/use-disclosure/use-disclosure.cjs.map +1 -0
  23. package/cjs/use-document-title/use-document-title.cjs +15 -0
  24. package/cjs/use-document-title/use-document-title.cjs.map +1 -0
  25. package/cjs/use-document-visibility/use-document-visibility.cjs +17 -0
  26. package/cjs/use-document-visibility/use-document-visibility.cjs.map +1 -0
  27. package/cjs/use-event-listener/use-event-listener.cjs +19 -0
  28. package/cjs/use-event-listener/use-event-listener.cjs.map +1 -0
  29. package/cjs/use-eye-dropper/use-eye-dropper.cjs +29 -0
  30. package/cjs/use-eye-dropper/use-eye-dropper.cjs.map +1 -0
  31. package/cjs/use-favicon/use-favicon.cjs +37 -0
  32. package/cjs/use-favicon/use-favicon.cjs.map +1 -0
  33. package/cjs/use-fetch/use-fetch.cjs +51 -0
  34. package/cjs/use-fetch/use-fetch.cjs.map +1 -0
  35. package/cjs/use-focus-return/use-focus-return.cjs +36 -0
  36. package/cjs/use-focus-return/use-focus-return.cjs.map +1 -0
  37. package/cjs/use-focus-trap/create-aria-hider.cjs +45 -0
  38. package/cjs/use-focus-trap/create-aria-hider.cjs.map +1 -0
  39. package/cjs/use-focus-trap/scope-tab.cjs +34 -0
  40. package/cjs/use-focus-trap/scope-tab.cjs.map +1 -0
  41. package/cjs/use-focus-trap/tabbable.cjs +58 -0
  42. package/cjs/use-focus-trap/tabbable.cjs.map +1 -0
  43. package/cjs/use-focus-trap/use-focus-trap.cjs +83 -0
  44. package/cjs/use-focus-trap/use-focus-trap.cjs.map +1 -0
  45. package/cjs/use-focus-within/use-focus-within.cjs +50 -0
  46. package/cjs/use-focus-within/use-focus-within.cjs.map +1 -0
  47. package/cjs/use-force-update/use-force-update.cjs +13 -0
  48. package/cjs/use-force-update/use-force-update.cjs.map +1 -0
  49. package/cjs/use-fullscreen/use-fullscreen.cjs +99 -0
  50. package/cjs/use-fullscreen/use-fullscreen.cjs.map +1 -0
  51. package/cjs/use-hash/use-hash.cjs +31 -0
  52. package/cjs/use-hash/use-hash.cjs.map +1 -0
  53. package/cjs/use-headroom/use-headroom.cjs +81 -0
  54. package/cjs/use-headroom/use-headroom.cjs.map +1 -0
  55. package/cjs/use-hotkeys/parse-hotkey.cjs +66 -0
  56. package/cjs/use-hotkeys/parse-hotkey.cjs.map +1 -0
  57. package/cjs/use-hotkeys/use-hotkeys.cjs +35 -0
  58. package/cjs/use-hotkeys/use-hotkeys.cjs.map +1 -0
  59. package/cjs/use-hover/use-hover.cjs +26 -0
  60. package/cjs/use-hover/use-hover.cjs.map +1 -0
  61. package/cjs/use-id/use-id.cjs +25 -0
  62. package/cjs/use-id/use-id.cjs.map +1 -0
  63. package/cjs/use-id/use-react-id.cjs +17 -0
  64. package/cjs/use-id/use-react-id.cjs.map +1 -0
  65. package/cjs/use-idle/use-idle.cjs +43 -0
  66. package/cjs/use-idle/use-idle.cjs.map +1 -0
  67. package/cjs/use-in-viewport/use-in-viewport.cjs +29 -0
  68. package/cjs/use-in-viewport/use-in-viewport.cjs.map +1 -0
  69. package/cjs/use-input-state/use-input-state.cjs +31 -0
  70. package/cjs/use-input-state/use-input-state.cjs.map +1 -0
  71. package/cjs/use-intersection/use-intersection.cjs +30 -0
  72. package/cjs/use-intersection/use-intersection.cjs.map +1 -0
  73. package/cjs/use-interval/use-interval.cjs +44 -0
  74. package/cjs/use-interval/use-interval.cjs.map +1 -0
  75. package/cjs/use-is-first-render/use-is-first-render.cjs +16 -0
  76. package/cjs/use-is-first-render/use-is-first-render.cjs.map +1 -0
  77. package/cjs/use-isomorphic-effect/use-isomorphic-effect.cjs +9 -0
  78. package/cjs/use-isomorphic-effect/use-isomorphic-effect.cjs.map +1 -0
  79. package/cjs/use-list-state/use-list-state.cjs +76 -0
  80. package/cjs/use-list-state/use-list-state.cjs.map +1 -0
  81. package/cjs/use-local-storage/create-storage.cjs +143 -0
  82. package/cjs/use-local-storage/create-storage.cjs.map +1 -0
  83. package/cjs/use-local-storage/use-local-storage.cjs +13 -0
  84. package/cjs/use-local-storage/use-local-storage.cjs.map +1 -0
  85. package/cjs/use-logger/use-logger.cjs +19 -0
  86. package/cjs/use-logger/use-logger.cjs.map +1 -0
  87. package/cjs/use-map/use-map.cjs +28 -0
  88. package/cjs/use-map/use-map.cjs.map +1 -0
  89. package/cjs/use-media-query/use-media-query.cjs +40 -0
  90. package/cjs/use-media-query/use-media-query.cjs.map +1 -0
  91. package/cjs/use-merged-ref/use-merged-ref.cjs +25 -0
  92. package/cjs/use-merged-ref/use-merged-ref.cjs.map +1 -0
  93. package/cjs/use-mounted/use-mounted.cjs +13 -0
  94. package/cjs/use-mounted/use-mounted.cjs.map +1 -0
  95. package/cjs/use-mouse/use-mouse.cjs +43 -0
  96. package/cjs/use-mouse/use-mouse.cjs.map +1 -0
  97. package/cjs/use-move/use-move.cjs +102 -0
  98. package/cjs/use-move/use-move.cjs.map +1 -0
  99. package/cjs/use-mutation-observer/use-mutation-observer.cjs +23 -0
  100. package/cjs/use-mutation-observer/use-mutation-observer.cjs.map +1 -0
  101. package/cjs/use-network/use-network.cjs +51 -0
  102. package/cjs/use-network/use-network.cjs.map +1 -0
  103. package/cjs/use-orientation/use-orientation.cjs +21 -0
  104. package/cjs/use-orientation/use-orientation.cjs.map +1 -0
  105. package/cjs/use-os/use-os.cjs +60 -0
  106. package/cjs/use-os/use-os.cjs.map +1 -0
  107. package/cjs/use-page-leave/use-page-leave.cjs +14 -0
  108. package/cjs/use-page-leave/use-page-leave.cjs.map +1 -0
  109. package/cjs/use-pagination/use-pagination.cjs +78 -0
  110. package/cjs/use-pagination/use-pagination.cjs.map +1 -0
  111. package/cjs/use-previous/use-previous.cjs +15 -0
  112. package/cjs/use-previous/use-previous.cjs.map +1 -0
  113. package/cjs/use-queue/use-queue.cjs +36 -0
  114. package/cjs/use-queue/use-queue.cjs.map +1 -0
  115. package/cjs/use-reduced-motion/use-reduced-motion.cjs +11 -0
  116. package/cjs/use-reduced-motion/use-reduced-motion.cjs.map +1 -0
  117. package/cjs/use-resize-observer/use-resize-observer.cjs +54 -0
  118. package/cjs/use-resize-observer/use-resize-observer.cjs.map +1 -0
  119. package/cjs/use-scroll-into-view/use-scroll-into-view.cjs +94 -0
  120. package/cjs/use-scroll-into-view/use-scroll-into-view.cjs.map +1 -0
  121. package/cjs/use-scroll-into-view/utils/ease-in-out-quad.cjs +7 -0
  122. package/cjs/use-scroll-into-view/utils/ease-in-out-quad.cjs.map +1 -0
  123. package/cjs/use-scroll-into-view/utils/get-relative-position.cjs +66 -0
  124. package/cjs/use-scroll-into-view/utils/get-relative-position.cjs.map +1 -0
  125. package/cjs/use-scroll-into-view/utils/get-scroll-start.cjs +17 -0
  126. package/cjs/use-scroll-into-view/utils/get-scroll-start.cjs.map +1 -0
  127. package/cjs/use-scroll-into-view/utils/set-scroll-param.cjs +19 -0
  128. package/cjs/use-scroll-into-view/utils/set-scroll-param.cjs.map +1 -0
  129. package/cjs/use-session-storage/use-session-storage.cjs +13 -0
  130. package/cjs/use-session-storage/use-session-storage.cjs.map +1 -0
  131. package/cjs/use-set/use-set.cjs +28 -0
  132. package/cjs/use-set/use-set.cjs.map +1 -0
  133. package/cjs/use-set-state/use-set-state.cjs +19 -0
  134. package/cjs/use-set-state/use-set-state.cjs.map +1 -0
  135. package/cjs/use-shallow-effect/use-shallow-effect.cjs +38 -0
  136. package/cjs/use-shallow-effect/use-shallow-effect.cjs.map +1 -0
  137. package/cjs/use-state-history/use-state-history.cjs +43 -0
  138. package/cjs/use-state-history/use-state-history.cjs.map +1 -0
  139. package/cjs/use-text-selection/use-text-selection.cjs +23 -0
  140. package/cjs/use-text-selection/use-text-selection.cjs.map +1 -0
  141. package/cjs/use-throttled-callback/use-throttled-callback.cjs +54 -0
  142. package/cjs/use-throttled-callback/use-throttled-callback.cjs.map +1 -0
  143. package/cjs/use-throttled-state/use-throttled-state.cjs +15 -0
  144. package/cjs/use-throttled-state/use-throttled-state.cjs.map +1 -0
  145. package/cjs/use-throttled-value/use-throttled-value.cjs +25 -0
  146. package/cjs/use-throttled-value/use-throttled-value.cjs.map +1 -0
  147. package/cjs/use-timeout/use-timeout.cjs +35 -0
  148. package/cjs/use-timeout/use-timeout.cjs.map +1 -0
  149. package/cjs/use-toggle/use-toggle.cjs +16 -0
  150. package/cjs/use-toggle/use-toggle.cjs.map +1 -0
  151. package/cjs/use-uncontrolled/use-uncontrolled.cjs +27 -0
  152. package/cjs/use-uncontrolled/use-uncontrolled.cjs.map +1 -0
  153. package/cjs/use-validated-state/use-validated-state.cjs +27 -0
  154. package/cjs/use-validated-state/use-validated-state.cjs.map +1 -0
  155. package/cjs/use-viewport-size/use-viewport-size.cjs +25 -0
  156. package/cjs/use-viewport-size/use-viewport-size.cjs.map +1 -0
  157. package/cjs/use-window-event/use-window-event.cjs +14 -0
  158. package/cjs/use-window-event/use-window-event.cjs.map +1 -0
  159. package/cjs/use-window-scroll/use-window-scroll.cjs +33 -0
  160. package/cjs/use-window-scroll/use-window-scroll.cjs.map +1 -0
  161. package/cjs/utils/clamp/clamp.cjs +18 -0
  162. package/cjs/utils/clamp/clamp.cjs.map +1 -0
  163. package/cjs/utils/lower-first/lower-first.cjs +9 -0
  164. package/cjs/utils/lower-first/lower-first.cjs.map +1 -0
  165. package/cjs/utils/random-id/random-id.cjs +9 -0
  166. package/cjs/utils/random-id/random-id.cjs.map +1 -0
  167. package/cjs/utils/range/range.cjs +14 -0
  168. package/cjs/utils/range/range.cjs.map +1 -0
  169. package/cjs/utils/shallow-equal/shallow-equal.cjs +29 -0
  170. package/cjs/utils/shallow-equal/shallow-equal.cjs.map +1 -0
  171. package/cjs/utils/upper-first/upper-first.cjs +9 -0
  172. package/cjs/utils/upper-first/upper-first.cjs.map +1 -0
  173. package/esm/index.mjs +77 -0
  174. package/esm/index.mjs.map +1 -0
  175. package/esm/use-callback-ref/use-callback-ref.mjs +13 -0
  176. package/esm/use-callback-ref/use-callback-ref.mjs.map +1 -0
  177. package/esm/use-click-outside/use-click-outside.mjs +27 -0
  178. package/esm/use-click-outside/use-click-outside.mjs.map +1 -0
  179. package/esm/use-clipboard/use-clipboard.mjs +29 -0
  180. package/esm/use-clipboard/use-clipboard.mjs.map +1 -0
  181. package/esm/use-color-scheme/use-color-scheme.mjs +9 -0
  182. package/esm/use-color-scheme/use-color-scheme.mjs.map +1 -0
  183. package/esm/use-counter/use-counter.mjs +20 -0
  184. package/esm/use-counter/use-counter.mjs.map +1 -0
  185. package/esm/use-debounced-callback/use-debounced-callback.mjs +19 -0
  186. package/esm/use-debounced-callback/use-debounced-callback.mjs.map +1 -0
  187. package/esm/use-debounced-state/use-debounced-state.mjs +29 -0
  188. package/esm/use-debounced-state/use-debounced-state.mjs.map +1 -0
  189. package/esm/use-debounced-value/use-debounced-value.mjs +32 -0
  190. package/esm/use-debounced-value/use-debounced-value.mjs.map +1 -0
  191. package/esm/use-did-update/use-did-update.mjs +22 -0
  192. package/esm/use-did-update/use-did-update.mjs.map +1 -0
  193. package/esm/use-disclosure/use-disclosure.mjs +32 -0
  194. package/esm/use-disclosure/use-disclosure.mjs.map +1 -0
  195. package/esm/use-document-title/use-document-title.mjs +13 -0
  196. package/esm/use-document-title/use-document-title.mjs.map +1 -0
  197. package/esm/use-document-visibility/use-document-visibility.mjs +15 -0
  198. package/esm/use-document-visibility/use-document-visibility.mjs.map +1 -0
  199. package/esm/use-event-listener/use-event-listener.mjs +17 -0
  200. package/esm/use-event-listener/use-event-listener.mjs.map +1 -0
  201. package/esm/use-eye-dropper/use-eye-dropper.mjs +27 -0
  202. package/esm/use-eye-dropper/use-eye-dropper.mjs.map +1 -0
  203. package/esm/use-favicon/use-favicon.mjs +35 -0
  204. package/esm/use-favicon/use-favicon.mjs.map +1 -0
  205. package/esm/use-fetch/use-fetch.mjs +49 -0
  206. package/esm/use-fetch/use-fetch.mjs.map +1 -0
  207. package/esm/use-focus-return/use-focus-return.mjs +34 -0
  208. package/esm/use-focus-return/use-focus-return.mjs.map +1 -0
  209. package/esm/use-focus-trap/create-aria-hider.mjs +43 -0
  210. package/esm/use-focus-trap/create-aria-hider.mjs.map +1 -0
  211. package/esm/use-focus-trap/scope-tab.mjs +32 -0
  212. package/esm/use-focus-trap/scope-tab.mjs.map +1 -0
  213. package/esm/use-focus-trap/tabbable.mjs +53 -0
  214. package/esm/use-focus-trap/tabbable.mjs.map +1 -0
  215. package/esm/use-focus-trap/use-focus-trap.mjs +81 -0
  216. package/esm/use-focus-trap/use-focus-trap.mjs.map +1 -0
  217. package/esm/use-focus-within/use-focus-within.mjs +48 -0
  218. package/esm/use-focus-within/use-focus-within.mjs.map +1 -0
  219. package/esm/use-force-update/use-force-update.mjs +11 -0
  220. package/esm/use-force-update/use-force-update.mjs.map +1 -0
  221. package/esm/use-fullscreen/use-fullscreen.mjs +97 -0
  222. package/esm/use-fullscreen/use-fullscreen.mjs.map +1 -0
  223. package/esm/use-hash/use-hash.mjs +29 -0
  224. package/esm/use-hash/use-hash.mjs.map +1 -0
  225. package/esm/use-headroom/use-headroom.mjs +76 -0
  226. package/esm/use-headroom/use-headroom.mjs.map +1 -0
  227. package/esm/use-hotkeys/parse-hotkey.mjs +62 -0
  228. package/esm/use-hotkeys/parse-hotkey.mjs.map +1 -0
  229. package/esm/use-hotkeys/use-hotkeys.mjs +33 -0
  230. package/esm/use-hotkeys/use-hotkeys.mjs.map +1 -0
  231. package/esm/use-hover/use-hover.mjs +24 -0
  232. package/esm/use-hover/use-hover.mjs.map +1 -0
  233. package/esm/use-id/use-id.mjs +23 -0
  234. package/esm/use-id/use-id.mjs.map +1 -0
  235. package/esm/use-id/use-react-id.mjs +11 -0
  236. package/esm/use-id/use-react-id.mjs.map +1 -0
  237. package/esm/use-idle/use-idle.mjs +41 -0
  238. package/esm/use-idle/use-idle.mjs.map +1 -0
  239. package/esm/use-in-viewport/use-in-viewport.mjs +27 -0
  240. package/esm/use-in-viewport/use-in-viewport.mjs.map +1 -0
  241. package/esm/use-input-state/use-input-state.mjs +28 -0
  242. package/esm/use-input-state/use-input-state.mjs.map +1 -0
  243. package/esm/use-intersection/use-intersection.mjs +28 -0
  244. package/esm/use-intersection/use-intersection.mjs.map +1 -0
  245. package/esm/use-interval/use-interval.mjs +42 -0
  246. package/esm/use-interval/use-interval.mjs.map +1 -0
  247. package/esm/use-is-first-render/use-is-first-render.mjs +14 -0
  248. package/esm/use-is-first-render/use-is-first-render.mjs.map +1 -0
  249. package/esm/use-isomorphic-effect/use-isomorphic-effect.mjs +7 -0
  250. package/esm/use-isomorphic-effect/use-isomorphic-effect.mjs.map +1 -0
  251. package/esm/use-list-state/use-list-state.mjs +74 -0
  252. package/esm/use-list-state/use-list-state.mjs.map +1 -0
  253. package/esm/use-local-storage/create-storage.mjs +140 -0
  254. package/esm/use-local-storage/create-storage.mjs.map +1 -0
  255. package/esm/use-local-storage/use-local-storage.mjs +10 -0
  256. package/esm/use-local-storage/use-local-storage.mjs.map +1 -0
  257. package/esm/use-logger/use-logger.mjs +17 -0
  258. package/esm/use-logger/use-logger.mjs.map +1 -0
  259. package/esm/use-map/use-map.mjs +26 -0
  260. package/esm/use-map/use-map.mjs.map +1 -0
  261. package/esm/use-media-query/use-media-query.mjs +38 -0
  262. package/esm/use-media-query/use-media-query.mjs.map +1 -0
  263. package/esm/use-merged-ref/use-merged-ref.mjs +21 -0
  264. package/esm/use-merged-ref/use-merged-ref.mjs.map +1 -0
  265. package/esm/use-mounted/use-mounted.mjs +11 -0
  266. package/esm/use-mounted/use-mounted.mjs.map +1 -0
  267. package/esm/use-mouse/use-mouse.mjs +41 -0
  268. package/esm/use-mouse/use-mouse.mjs.map +1 -0
  269. package/esm/use-move/use-move.mjs +99 -0
  270. package/esm/use-move/use-move.mjs.map +1 -0
  271. package/esm/use-mutation-observer/use-mutation-observer.mjs +21 -0
  272. package/esm/use-mutation-observer/use-mutation-observer.mjs.map +1 -0
  273. package/esm/use-network/use-network.mjs +49 -0
  274. package/esm/use-network/use-network.mjs.map +1 -0
  275. package/esm/use-orientation/use-orientation.mjs +19 -0
  276. package/esm/use-orientation/use-orientation.mjs.map +1 -0
  277. package/esm/use-os/use-os.mjs +58 -0
  278. package/esm/use-os/use-os.mjs.map +1 -0
  279. package/esm/use-page-leave/use-page-leave.mjs +12 -0
  280. package/esm/use-page-leave/use-page-leave.mjs.map +1 -0
  281. package/esm/use-pagination/use-pagination.mjs +75 -0
  282. package/esm/use-pagination/use-pagination.mjs.map +1 -0
  283. package/esm/use-previous/use-previous.mjs +13 -0
  284. package/esm/use-previous/use-previous.mjs.map +1 -0
  285. package/esm/use-queue/use-queue.mjs +34 -0
  286. package/esm/use-queue/use-queue.mjs.map +1 -0
  287. package/esm/use-reduced-motion/use-reduced-motion.mjs +9 -0
  288. package/esm/use-reduced-motion/use-reduced-motion.mjs.map +1 -0
  289. package/esm/use-resize-observer/use-resize-observer.mjs +51 -0
  290. package/esm/use-resize-observer/use-resize-observer.mjs.map +1 -0
  291. package/esm/use-scroll-into-view/use-scroll-into-view.mjs +92 -0
  292. package/esm/use-scroll-into-view/use-scroll-into-view.mjs.map +1 -0
  293. package/esm/use-scroll-into-view/utils/ease-in-out-quad.mjs +5 -0
  294. package/esm/use-scroll-into-view/utils/ease-in-out-quad.mjs.map +1 -0
  295. package/esm/use-scroll-into-view/utils/get-relative-position.mjs +64 -0
  296. package/esm/use-scroll-into-view/utils/get-relative-position.mjs.map +1 -0
  297. package/esm/use-scroll-into-view/utils/get-scroll-start.mjs +15 -0
  298. package/esm/use-scroll-into-view/utils/get-scroll-start.mjs.map +1 -0
  299. package/esm/use-scroll-into-view/utils/set-scroll-param.mjs +17 -0
  300. package/esm/use-scroll-into-view/utils/set-scroll-param.mjs.map +1 -0
  301. package/esm/use-session-storage/use-session-storage.mjs +10 -0
  302. package/esm/use-session-storage/use-session-storage.mjs.map +1 -0
  303. package/esm/use-set/use-set.mjs +26 -0
  304. package/esm/use-set/use-set.mjs.map +1 -0
  305. package/esm/use-set-state/use-set-state.mjs +17 -0
  306. package/esm/use-set-state/use-set-state.mjs.map +1 -0
  307. package/esm/use-shallow-effect/use-shallow-effect.mjs +36 -0
  308. package/esm/use-shallow-effect/use-shallow-effect.mjs.map +1 -0
  309. package/esm/use-state-history/use-state-history.mjs +41 -0
  310. package/esm/use-state-history/use-state-history.mjs.map +1 -0
  311. package/esm/use-text-selection/use-text-selection.mjs +21 -0
  312. package/esm/use-text-selection/use-text-selection.mjs.map +1 -0
  313. package/esm/use-throttled-callback/use-throttled-callback.mjs +51 -0
  314. package/esm/use-throttled-callback/use-throttled-callback.mjs.map +1 -0
  315. package/esm/use-throttled-state/use-throttled-state.mjs +13 -0
  316. package/esm/use-throttled-state/use-throttled-state.mjs.map +1 -0
  317. package/esm/use-throttled-value/use-throttled-value.mjs +23 -0
  318. package/esm/use-throttled-value/use-throttled-value.mjs.map +1 -0
  319. package/esm/use-timeout/use-timeout.mjs +33 -0
  320. package/esm/use-timeout/use-timeout.mjs.map +1 -0
  321. package/esm/use-toggle/use-toggle.mjs +14 -0
  322. package/esm/use-toggle/use-toggle.mjs.map +1 -0
  323. package/esm/use-uncontrolled/use-uncontrolled.mjs +25 -0
  324. package/esm/use-uncontrolled/use-uncontrolled.mjs.map +1 -0
  325. package/esm/use-validated-state/use-validated-state.mjs +25 -0
  326. package/esm/use-validated-state/use-validated-state.mjs.map +1 -0
  327. package/esm/use-viewport-size/use-viewport-size.mjs +23 -0
  328. package/esm/use-viewport-size/use-viewport-size.mjs.map +1 -0
  329. package/esm/use-window-event/use-window-event.mjs +12 -0
  330. package/esm/use-window-event/use-window-event.mjs.map +1 -0
  331. package/esm/use-window-scroll/use-window-scroll.mjs +31 -0
  332. package/esm/use-window-scroll/use-window-scroll.mjs.map +1 -0
  333. package/esm/utils/clamp/clamp.mjs +16 -0
  334. package/esm/utils/clamp/clamp.mjs.map +1 -0
  335. package/esm/utils/lower-first/lower-first.mjs +7 -0
  336. package/esm/utils/lower-first/lower-first.mjs.map +1 -0
  337. package/esm/utils/random-id/random-id.mjs +7 -0
  338. package/esm/utils/random-id/random-id.mjs.map +1 -0
  339. package/esm/utils/range/range.mjs +12 -0
  340. package/esm/utils/range/range.mjs.map +1 -0
  341. package/esm/utils/shallow-equal/shallow-equal.mjs +27 -0
  342. package/esm/utils/shallow-equal/shallow-equal.mjs.map +1 -0
  343. package/esm/utils/upper-first/upper-first.mjs +7 -0
  344. package/esm/utils/upper-first/upper-first.mjs.map +1 -0
  345. package/lib/index.d.mts +78 -0
  346. package/lib/index.d.ts +78 -0
  347. package/lib/use-callback-ref/use-callback-ref.d.ts +1 -0
  348. package/lib/use-click-outside/use-click-outside.d.ts +1 -0
  349. package/lib/use-clipboard/use-clipboard.d.ts +8 -0
  350. package/lib/use-color-scheme/use-color-scheme.d.ts +2 -0
  351. package/lib/use-counter/use-counter.d.ts +9 -0
  352. package/lib/use-debounced-callback/use-debounced-callback.d.ts +1 -0
  353. package/lib/use-debounced-state/use-debounced-state.d.ts +4 -0
  354. package/lib/use-debounced-value/use-debounced-value.d.ts +3 -0
  355. package/lib/use-did-update/use-did-update.d.ts +2 -0
  356. package/lib/use-disclosure/use-disclosure.d.ts +8 -0
  357. package/lib/use-document-title/use-document-title.d.ts +1 -0
  358. package/lib/use-document-visibility/use-document-visibility.d.ts +1 -0
  359. package/lib/use-event-listener/use-event-listener.d.ts +1 -0
  360. package/lib/use-eye-dropper/use-eye-dropper.d.ts +11 -0
  361. package/lib/use-favicon/use-favicon.d.ts +1 -0
  362. package/lib/use-fetch/use-fetch.d.ts +10 -0
  363. package/lib/use-focus-return/use-focus-return.d.ts +7 -0
  364. package/lib/use-focus-trap/create-aria-hider.d.ts +1 -0
  365. package/lib/use-focus-trap/scope-tab.d.ts +1 -0
  366. package/lib/use-focus-trap/tabbable.d.ts +4 -0
  367. package/lib/use-focus-trap/use-focus-trap.d.ts +1 -0
  368. package/lib/use-focus-within/use-focus-within.d.ts +8 -0
  369. package/lib/use-force-update/use-force-update.d.ts +1 -0
  370. package/lib/use-fullscreen/use-fullscreen.d.ts +5 -0
  371. package/lib/use-hash/use-hash.d.ts +5 -0
  372. package/lib/use-headroom/use-headroom.d.ts +17 -0
  373. package/lib/use-hotkeys/parse-hotkey.d.ts +19 -0
  374. package/lib/use-hotkeys/use-hotkeys.d.ts +5 -0
  375. package/lib/use-hover/use-hover.d.ts +4 -0
  376. package/lib/use-id/use-id.d.ts +1 -0
  377. package/lib/use-id/use-react-id.d.ts +1 -0
  378. package/lib/use-idle/use-idle.d.ts +4 -0
  379. package/lib/use-in-viewport/use-in-viewport.d.ts +4 -0
  380. package/lib/use-input-state/use-input-state.d.ts +2 -0
  381. package/lib/use-intersection/use-intersection.d.ts +4 -0
  382. package/lib/use-interval/use-interval.d.ts +11 -0
  383. package/lib/use-is-first-render/use-is-first-render.d.ts +1 -0
  384. package/lib/use-isomorphic-effect/use-isomorphic-effect.d.ts +2 -0
  385. package/lib/use-list-state/use-list-state.d.ts +24 -0
  386. package/lib/use-local-storage/create-storage.d.ts +15 -0
  387. package/lib/use-local-storage/use-local-storage.d.ts +3 -0
  388. package/lib/use-logger/use-logger.d.ts +1 -0
  389. package/lib/use-map/use-map.d.ts +1 -0
  390. package/lib/use-media-query/use-media-query.d.ts +4 -0
  391. package/lib/use-merged-ref/use-merged-ref.d.ts +6 -0
  392. package/lib/use-mounted/use-mounted.d.ts +1 -0
  393. package/lib/use-mouse/use-mouse.d.ts +7 -0
  394. package/lib/use-move/use-move.d.ts +17 -0
  395. package/lib/use-mutation-observer/use-mutation-observer.d.ts +2 -0
  396. package/lib/use-network/use-network.d.ts +12 -0
  397. package/lib/use-orientation/use-orientation.d.ts +4 -0
  398. package/lib/use-os/use-os.d.ts +6 -0
  399. package/lib/use-page-leave/use-page-leave.d.ts +1 -0
  400. package/lib/use-pagination/use-pagination.d.ts +24 -0
  401. package/lib/use-previous/use-previous.d.ts +1 -0
  402. package/lib/use-queue/use-queue.d.ts +10 -0
  403. package/lib/use-reduced-motion/use-reduced-motion.d.ts +2 -0
  404. package/lib/use-resize-observer/use-resize-observer.d.ts +8 -0
  405. package/lib/use-scroll-into-view/use-scroll-into-view.d.ts +28 -0
  406. package/lib/use-scroll-into-view/utils/ease-in-out-quad.d.ts +1 -0
  407. package/lib/use-scroll-into-view/utils/get-relative-position.d.ts +1 -0
  408. package/lib/use-scroll-into-view/utils/get-scroll-start.d.ts +1 -0
  409. package/lib/use-scroll-into-view/utils/set-scroll-param.d.ts +1 -0
  410. package/lib/use-session-storage/use-session-storage.d.ts +3 -0
  411. package/lib/use-set/use-set.d.ts +1 -0
  412. package/lib/use-set-state/use-set-state.d.ts +1 -0
  413. package/lib/use-shallow-effect/use-shallow-effect.d.ts +1 -0
  414. package/lib/use-state-history/use-state-history.d.ts +11 -0
  415. package/lib/use-text-selection/use-text-selection.d.ts +1 -0
  416. package/lib/use-throttled-callback/use-throttled-callback.d.ts +2 -0
  417. package/lib/use-throttled-state/use-throttled-state.d.ts +1 -0
  418. package/lib/use-throttled-value/use-throttled-value.d.ts +1 -0
  419. package/lib/use-timeout/use-timeout.d.ts +6 -0
  420. package/lib/use-toggle/use-toggle.d.ts +1 -0
  421. package/lib/use-uncontrolled/use-uncontrolled.d.ts +12 -0
  422. package/lib/use-validated-state/use-validated-state.d.ts +5 -0
  423. package/lib/use-viewport-size/use-viewport-size.d.ts +4 -0
  424. package/lib/use-window-event/use-window-event.d.ts +1 -0
  425. package/lib/use-window-scroll/use-window-scroll.d.ts +7 -0
  426. package/lib/utils/clamp/clamp.d.ts +1 -0
  427. package/lib/utils/index.d.ts +6 -0
  428. package/lib/utils/lower-first/lower-first.d.ts +1 -0
  429. package/lib/utils/random-id/random-id.d.ts +1 -0
  430. package/lib/utils/range/range.d.ts +1 -0
  431. package/lib/utils/shallow-equal/shallow-equal.d.ts +1 -0
  432. package/lib/utils/upper-first/upper-first.d.ts +1 -0
  433. package/package.json +1 -1
package/esm/index.mjs ADDED
@@ -0,0 +1,77 @@
1
+ export { clamp } from './utils/clamp/clamp.mjs';
2
+ export { lowerFirst } from './utils/lower-first/lower-first.mjs';
3
+ export { randomId } from './utils/random-id/random-id.mjs';
4
+ export { range } from './utils/range/range.mjs';
5
+ export { shallowEqual } from './utils/shallow-equal/shallow-equal.mjs';
6
+ export { upperFirst } from './utils/upper-first/upper-first.mjs';
7
+ export { useCallbackRef } from './use-callback-ref/use-callback-ref.mjs';
8
+ export { useDebouncedCallback } from './use-debounced-callback/use-debounced-callback.mjs';
9
+ export { useClickOutside } from './use-click-outside/use-click-outside.mjs';
10
+ export { useClipboard } from './use-clipboard/use-clipboard.mjs';
11
+ export { useColorScheme } from './use-color-scheme/use-color-scheme.mjs';
12
+ export { useCounter } from './use-counter/use-counter.mjs';
13
+ export { useDebouncedState } from './use-debounced-state/use-debounced-state.mjs';
14
+ export { useDebouncedValue } from './use-debounced-value/use-debounced-value.mjs';
15
+ export { useDocumentTitle } from './use-document-title/use-document-title.mjs';
16
+ export { useDocumentVisibility } from './use-document-visibility/use-document-visibility.mjs';
17
+ export { useFocusReturn } from './use-focus-return/use-focus-return.mjs';
18
+ export { useDidUpdate } from './use-did-update/use-did-update.mjs';
19
+ export { useFocusTrap } from './use-focus-trap/use-focus-trap.mjs';
20
+ export { useForceUpdate } from './use-force-update/use-force-update.mjs';
21
+ export { useId } from './use-id/use-id.mjs';
22
+ export { useIdle } from './use-idle/use-idle.mjs';
23
+ export { useInterval } from './use-interval/use-interval.mjs';
24
+ export { useIsomorphicEffect } from './use-isomorphic-effect/use-isomorphic-effect.mjs';
25
+ export { useListState } from './use-list-state/use-list-state.mjs';
26
+ export { readLocalStorageValue, useLocalStorage } from './use-local-storage/use-local-storage.mjs';
27
+ export { readSessionStorageValue, useSessionStorage } from './use-session-storage/use-session-storage.mjs';
28
+ export { useMediaQuery } from './use-media-query/use-media-query.mjs';
29
+ export { assignRef, mergeRefs, useMergedRef } from './use-merged-ref/use-merged-ref.mjs';
30
+ export { useMouse } from './use-mouse/use-mouse.mjs';
31
+ export { clampUseMovePosition, useMove } from './use-move/use-move.mjs';
32
+ export { usePagination } from './use-pagination/use-pagination.mjs';
33
+ export { useQueue } from './use-queue/use-queue.mjs';
34
+ export { usePageLeave } from './use-page-leave/use-page-leave.mjs';
35
+ export { useReducedMotion } from './use-reduced-motion/use-reduced-motion.mjs';
36
+ export { useScrollIntoView } from './use-scroll-into-view/use-scroll-into-view.mjs';
37
+ export { useElementSize, useResizeObserver } from './use-resize-observer/use-resize-observer.mjs';
38
+ export { useShallowEffect } from './use-shallow-effect/use-shallow-effect.mjs';
39
+ export { useToggle } from './use-toggle/use-toggle.mjs';
40
+ export { useUncontrolled } from './use-uncontrolled/use-uncontrolled.mjs';
41
+ export { useViewportSize } from './use-viewport-size/use-viewport-size.mjs';
42
+ export { useWindowEvent } from './use-window-event/use-window-event.mjs';
43
+ export { useWindowScroll } from './use-window-scroll/use-window-scroll.mjs';
44
+ export { useIntersection } from './use-intersection/use-intersection.mjs';
45
+ export { useHash } from './use-hash/use-hash.mjs';
46
+ export { useHotkeys } from './use-hotkeys/use-hotkeys.mjs';
47
+ export { useFullscreen } from './use-fullscreen/use-fullscreen.mjs';
48
+ export { useLogger } from './use-logger/use-logger.mjs';
49
+ export { useHover } from './use-hover/use-hover.mjs';
50
+ export { useValidatedState } from './use-validated-state/use-validated-state.mjs';
51
+ export { useOs } from './use-os/use-os.mjs';
52
+ export { useSetState } from './use-set-state/use-set-state.mjs';
53
+ export { useInputState } from './use-input-state/use-input-state.mjs';
54
+ export { useEventListener } from './use-event-listener/use-event-listener.mjs';
55
+ export { useDisclosure } from './use-disclosure/use-disclosure.mjs';
56
+ export { useFocusWithin } from './use-focus-within/use-focus-within.mjs';
57
+ export { useNetwork } from './use-network/use-network.mjs';
58
+ export { useTimeout } from './use-timeout/use-timeout.mjs';
59
+ export { useTextSelection } from './use-text-selection/use-text-selection.mjs';
60
+ export { usePrevious } from './use-previous/use-previous.mjs';
61
+ export { useFavicon } from './use-favicon/use-favicon.mjs';
62
+ export { useHeadroom } from './use-headroom/use-headroom.mjs';
63
+ export { useEyeDropper } from './use-eye-dropper/use-eye-dropper.mjs';
64
+ export { useInViewport } from './use-in-viewport/use-in-viewport.mjs';
65
+ export { useMutationObserver } from './use-mutation-observer/use-mutation-observer.mjs';
66
+ export { useMounted } from './use-mounted/use-mounted.mjs';
67
+ export { useStateHistory } from './use-state-history/use-state-history.mjs';
68
+ export { useMap } from './use-map/use-map.mjs';
69
+ export { useSet } from './use-set/use-set.mjs';
70
+ export { useThrottledCallback } from './use-throttled-callback/use-throttled-callback.mjs';
71
+ export { useThrottledState } from './use-throttled-state/use-throttled-state.mjs';
72
+ export { useThrottledValue } from './use-throttled-value/use-throttled-value.mjs';
73
+ export { useIsFirstRender } from './use-is-first-render/use-is-first-render.mjs';
74
+ export { useOrientation } from './use-orientation/use-orientation.mjs';
75
+ export { useFetch } from './use-fetch/use-fetch.mjs';
76
+ export { getHotkeyHandler } from './use-hotkeys/parse-hotkey.mjs';
77
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,13 @@
1
+ 'use client';
2
+ import { useRef, useEffect, useMemo } from 'react';
3
+
4
+ function useCallbackRef(callback) {
5
+ const callbackRef = useRef(callback);
6
+ useEffect(() => {
7
+ callbackRef.current = callback;
8
+ });
9
+ return useMemo(() => (...args) => callbackRef.current?.(...args), []);
10
+ }
11
+
12
+ export { useCallbackRef };
13
+ //# sourceMappingURL=use-callback-ref.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-callback-ref.mjs","sources":["../../src/use-callback-ref/use-callback-ref.ts"],"sourcesContent":["import { useEffect, useMemo, useRef } from 'react';\n\nexport function useCallbackRef<T extends (...args: any[]) => any>(callback: T | undefined): T {\n const callbackRef = useRef(callback);\n\n useEffect(() => {\n callbackRef.current = callback;\n });\n\n return useMemo(() => ((...args) => callbackRef.current?.(...args)) as T, []);\n}\n"],"names":[],"mappings":";;;AAEO,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAc,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAE,CAAA,CAAA;AACzC,CAAA,CAAE,MAAM,CAAW,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,QAAQ,CAAC,CAAA;AACtC,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAClB,CAAA,CAAA,CAAA,CAAI,CAAW,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAClC,CAAA,CAAA,CAAG,CAAC,CAAA;AACJ,CAAA,CAAE,OAAO,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,GAAG,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAK,CAAW,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,OAAO,CAAG,CAAA,CAAA,CAAA,CAAA,CAAG,IAAI,CAAC,CAAA,CAAE,EAAE,CAAC,CAAA;AACvE,CAAA;;"}
@@ -0,0 +1,27 @@
1
+ 'use client';
2
+ import { useRef, useEffect } from 'react';
3
+
4
+ const DEFAULT_EVENTS = ["mousedown", "touchstart"];
5
+ function useClickOutside(handler, events, nodes) {
6
+ const ref = useRef();
7
+ useEffect(() => {
8
+ const listener = (event) => {
9
+ const { target } = event ?? {};
10
+ if (Array.isArray(nodes)) {
11
+ const shouldIgnore = target?.hasAttribute("data-ignore-outside-clicks") || !document.body.contains(target) && target.tagName !== "HTML";
12
+ const shouldTrigger = nodes.every((node) => !!node && !event.composedPath().includes(node));
13
+ shouldTrigger && !shouldIgnore && handler();
14
+ } else if (ref.current && !ref.current.contains(target)) {
15
+ handler();
16
+ }
17
+ };
18
+ (events || DEFAULT_EVENTS).forEach((fn) => document.addEventListener(fn, listener));
19
+ return () => {
20
+ (events || DEFAULT_EVENTS).forEach((fn) => document.removeEventListener(fn, listener));
21
+ };
22
+ }, [ref, handler, nodes]);
23
+ return ref;
24
+ }
25
+
26
+ export { useClickOutside };
27
+ //# sourceMappingURL=use-click-outside.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-click-outside.mjs","sources":["../../src/use-click-outside/use-click-outside.ts"],"sourcesContent":["import { useEffect, useRef } from 'react';\n\nconst DEFAULT_EVENTS = ['mousedown', 'touchstart'];\n\nexport function useClickOutside<T extends HTMLElement = any>(\n handler: () => void,\n events?: string[] | null,\n nodes?: (HTMLElement | null)[]\n) {\n const ref = useRef<T>();\n\n useEffect(() => {\n const listener = (event: any) => {\n const { target } = event ?? {};\n if (Array.isArray(nodes)) {\n const shouldIgnore =\n target?.hasAttribute('data-ignore-outside-clicks') ||\n (!document.body.contains(target) && target.tagName !== 'HTML');\n const shouldTrigger = nodes.every((node) => !!node && !event.composedPath().includes(node));\n shouldTrigger && !shouldIgnore && handler();\n } else if (ref.current && !ref.current.contains(target)) {\n handler();\n }\n };\n\n (events || DEFAULT_EVENTS).forEach((fn) => document.addEventListener(fn, listener));\n\n return () => {\n (events || DEFAULT_EVENTS).forEach((fn) => document.removeEventListener(fn, listener));\n };\n }, [ref, handler, nodes]);\n\n return ref;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ 'use client';
2
+ import { useState } from 'react';
3
+
4
+ function useClipboard({ timeout = 2e3 } = {}) {
5
+ const [error, setError] = useState(null);
6
+ const [copied, setCopied] = useState(false);
7
+ const [copyTimeout, setCopyTimeout] = useState(null);
8
+ const handleCopyResult = (value) => {
9
+ window.clearTimeout(copyTimeout);
10
+ setCopyTimeout(window.setTimeout(() => setCopied(false), timeout));
11
+ setCopied(value);
12
+ };
13
+ const copy = (valueToCopy) => {
14
+ if ("clipboard" in navigator) {
15
+ navigator.clipboard.writeText(valueToCopy).then(() => handleCopyResult(true)).catch((err) => setError(err));
16
+ } else {
17
+ setError(new Error("useClipboard: navigator.clipboard is not supported"));
18
+ }
19
+ };
20
+ const reset = () => {
21
+ setCopied(false);
22
+ setError(null);
23
+ window.clearTimeout(copyTimeout);
24
+ };
25
+ return { copy, reset, error, copied };
26
+ }
27
+
28
+ export { useClipboard };
29
+ //# sourceMappingURL=use-clipboard.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-clipboard.mjs","sources":["../../src/use-clipboard/use-clipboard.ts"],"sourcesContent":["import { useState } from 'react';\n\nexport function useClipboard({ timeout = 2000 } = {}) {\n const [error, setError] = useState<Error | null>(null);\n const [copied, setCopied] = useState(false);\n const [copyTimeout, setCopyTimeout] = useState<number | null>(null);\n\n const handleCopyResult = (value: boolean) => {\n window.clearTimeout(copyTimeout!);\n setCopyTimeout(window.setTimeout(() => setCopied(false), timeout));\n setCopied(value);\n };\n\n const copy = (valueToCopy: any) => {\n if ('clipboard' in navigator) {\n navigator.clipboard\n .writeText(valueToCopy)\n .then(() => handleCopyResult(true))\n .catch((err) => setError(err));\n } else {\n setError(new Error('useClipboard: navigator.clipboard is not supported'));\n }\n };\n\n const reset = () => {\n setCopied(false);\n setError(null);\n window.clearTimeout(copyTimeout!);\n };\n\n return { copy, reset, error, copied };\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ 'use client';
2
+ import { useMediaQuery } from '../use-media-query/use-media-query.mjs';
3
+
4
+ function useColorScheme(initialValue, options) {
5
+ return useMediaQuery("(prefers-color-scheme: dark)", initialValue === "dark", options) ? "dark" : "light";
6
+ }
7
+
8
+ export { useColorScheme };
9
+ //# sourceMappingURL=use-color-scheme.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-color-scheme.mjs","sources":["../../src/use-color-scheme/use-color-scheme.ts"],"sourcesContent":["import { useMediaQuery, UseMediaQueryOptions } from '../use-media-query/use-media-query';\n\nexport function useColorScheme(initialValue?: 'dark' | 'light', options?: UseMediaQueryOptions) {\n return useMediaQuery('(prefers-color-scheme: dark)', initialValue === 'dark', options)\n ? 'dark'\n : 'light';\n}\n"],"names":[],"mappings":";;;AAEO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAc,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,OAAO,CAAE,CAAA,CAAA;AACtD,CAAA,CAAE,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAa,CAAC,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,CAAA,CAAA,CAAA,CAAA,CAA8B,EAAE,CAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAK,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,GAAG,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAC3G,CAAA;;"}
@@ -0,0 +1,20 @@
1
+ 'use client';
2
+ import { useState } from 'react';
3
+ import { clamp } from '../utils/clamp/clamp.mjs';
4
+
5
+ const DEFAULT_OPTIONS = {
6
+ min: -Infinity,
7
+ max: Infinity
8
+ };
9
+ function useCounter(initialValue = 0, options) {
10
+ const { min, max } = { ...DEFAULT_OPTIONS, ...options };
11
+ const [count, setCount] = useState(clamp(initialValue, min, max));
12
+ const increment = () => setCount((current) => clamp(current + 1, min, max));
13
+ const decrement = () => setCount((current) => clamp(current - 1, min, max));
14
+ const set = (value) => setCount(clamp(value, min, max));
15
+ const reset = () => setCount(clamp(initialValue, min, max));
16
+ return [count, { increment, decrement, set, reset }];
17
+ }
18
+
19
+ export { useCounter };
20
+ //# sourceMappingURL=use-counter.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-counter.mjs","sources":["../../src/use-counter/use-counter.ts"],"sourcesContent":["import { useState } from 'react';\nimport { clamp } from '../utils';\n\nconst DEFAULT_OPTIONS = {\n min: -Infinity,\n max: Infinity,\n};\n\nexport function useCounter(initialValue = 0, options?: Partial<{ min: number; max: number }>) {\n const { min, max } = { ...DEFAULT_OPTIONS, ...options };\n const [count, setCount] = useState<number>(clamp(initialValue, min, max));\n\n const increment = () => setCount((current) => clamp(current + 1, min, max));\n const decrement = () => setCount((current) => clamp(current - 1, min, max));\n const set = (value: number) => setCount(clamp(value, min, max));\n const reset = () => setCount(clamp(initialValue, min, max));\n\n return [count, { increment, decrement, set, reset }] as const;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ import { useRef, useEffect, useCallback } from 'react';
3
+ import { useCallbackRef } from '../use-callback-ref/use-callback-ref.mjs';
4
+
5
+ function useDebouncedCallback(callback, delay) {
6
+ const handleCallback = useCallbackRef(callback);
7
+ const debounceTimerRef = useRef(0);
8
+ useEffect(() => () => window.clearTimeout(debounceTimerRef.current), []);
9
+ return useCallback(
10
+ (...args) => {
11
+ window.clearTimeout(debounceTimerRef.current);
12
+ debounceTimerRef.current = window.setTimeout(() => handleCallback(...args), delay);
13
+ },
14
+ [handleCallback, delay]
15
+ );
16
+ }
17
+
18
+ export { useDebouncedCallback };
19
+ //# sourceMappingURL=use-debounced-callback.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-debounced-callback.mjs","sources":["../../src/use-debounced-callback/use-debounced-callback.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from 'react';\nimport { useCallbackRef } from '../use-callback-ref/use-callback-ref';\n\nexport function useDebouncedCallback<T extends (...args: any[]) => any>(\n callback: T,\n delay: number\n) {\n const handleCallback = useCallbackRef(callback);\n const debounceTimerRef = useRef(0);\n useEffect(() => () => window.clearTimeout(debounceTimerRef.current), []);\n\n return useCallback(\n (...args: Parameters<T>) => {\n window.clearTimeout(debounceTimerRef.current);\n debounceTimerRef.current = window.setTimeout(() => handleCallback(...args), delay);\n },\n [handleCallback, delay]\n );\n}\n"],"names":[],"mappings":";;;;AAGO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAoB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,KAAK,CAAE,CAAA,CAAA;AACtD,CAAA,CAAE,MAAM,CAAc,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAc,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,QAAQ,CAAC,CAAA;AACjD,CAAA,CAAE,MAAM,CAAgB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAC,CAAC,CAAA;AACpC,CAAA,CAAE,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,MAAM,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAY,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAC,CAAA,CAAE,EAAE,CAAC,CAAA;AAC1E,CAAA,CAAE,OAAO,CAAW,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACpB,CAAI,CAAA,CAAA,CAAA,CAAC,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAI,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA;AACjB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,MAAM,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAY,CAAC,CAAgB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,OAAO,CAAC,CAAA;AACnD,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,gBAAgB,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAC,CAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAc,CAAC,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAI,CAAC,CAAA,CAAE,KAAK,CAAC,CAAA;AACxF,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA;AACL,CAAI,CAAA,CAAA,CAAA,CAAC,CAAc,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA;AAC1B,CAAG,CAAA,CAAA,CAAA;AACH,CAAA;;"}
@@ -0,0 +1,29 @@
1
+ 'use client';
2
+ import { useState, useRef, useEffect, useCallback } from 'react';
3
+
4
+ function useDebouncedState(defaultValue, wait, options = { leading: false }) {
5
+ const [value, setValue] = useState(defaultValue);
6
+ const timeoutRef = useRef(null);
7
+ const leadingRef = useRef(true);
8
+ const clearTimeout = () => window.clearTimeout(timeoutRef.current);
9
+ useEffect(() => clearTimeout, []);
10
+ const debouncedSetValue = useCallback(
11
+ (newValue) => {
12
+ clearTimeout();
13
+ if (leadingRef.current && options.leading) {
14
+ setValue(newValue);
15
+ } else {
16
+ timeoutRef.current = window.setTimeout(() => {
17
+ leadingRef.current = true;
18
+ setValue(newValue);
19
+ }, wait);
20
+ }
21
+ leadingRef.current = false;
22
+ },
23
+ [options.leading]
24
+ );
25
+ return [value, debouncedSetValue];
26
+ }
27
+
28
+ export { useDebouncedState };
29
+ //# sourceMappingURL=use-debounced-state.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-debounced-state.mjs","sources":["../../src/use-debounced-state/use-debounced-state.ts"],"sourcesContent":["import { SetStateAction, useCallback, useEffect, useRef, useState } from 'react';\n\nexport function useDebouncedState<T = any>(\n defaultValue: T,\n wait: number,\n options = { leading: false }\n) {\n const [value, setValue] = useState(defaultValue);\n const timeoutRef = useRef<number | null>(null);\n const leadingRef = useRef(true);\n\n const clearTimeout = () => window.clearTimeout(timeoutRef.current!);\n useEffect(() => clearTimeout, []);\n\n const debouncedSetValue = useCallback(\n (newValue: SetStateAction<T>) => {\n clearTimeout();\n if (leadingRef.current && options.leading) {\n setValue(newValue);\n } else {\n timeoutRef.current = window.setTimeout(() => {\n leadingRef.current = true;\n setValue(newValue);\n }, wait);\n }\n leadingRef.current = false;\n },\n [options.leading]\n );\n\n return [value, debouncedSetValue] as const;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ 'use client';
2
+ import { useState, useRef, useEffect } from 'react';
3
+
4
+ function useDebouncedValue(value, wait, options = { leading: false }) {
5
+ const [_value, setValue] = useState(value);
6
+ const mountedRef = useRef(false);
7
+ const timeoutRef = useRef(null);
8
+ const cooldownRef = useRef(false);
9
+ const cancel = () => window.clearTimeout(timeoutRef.current);
10
+ useEffect(() => {
11
+ if (mountedRef.current) {
12
+ if (!cooldownRef.current && options.leading) {
13
+ cooldownRef.current = true;
14
+ setValue(value);
15
+ } else {
16
+ cancel();
17
+ timeoutRef.current = window.setTimeout(() => {
18
+ cooldownRef.current = false;
19
+ setValue(value);
20
+ }, wait);
21
+ }
22
+ }
23
+ }, [value, options.leading, wait]);
24
+ useEffect(() => {
25
+ mountedRef.current = true;
26
+ return cancel;
27
+ }, []);
28
+ return [_value, cancel];
29
+ }
30
+
31
+ export { useDebouncedValue };
32
+ //# sourceMappingURL=use-debounced-value.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-debounced-value.mjs","sources":["../../src/use-debounced-value/use-debounced-value.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nexport function useDebouncedValue<T = any>(value: T, wait: number, options = { leading: false }) {\n const [_value, setValue] = useState(value);\n const mountedRef = useRef(false);\n const timeoutRef = useRef<number | null>(null);\n const cooldownRef = useRef(false);\n\n const cancel = () => window.clearTimeout(timeoutRef.current!);\n\n useEffect(() => {\n if (mountedRef.current) {\n if (!cooldownRef.current && options.leading) {\n cooldownRef.current = true;\n setValue(value);\n } else {\n cancel();\n timeoutRef.current = window.setTimeout(() => {\n cooldownRef.current = false;\n setValue(value);\n }, wait);\n }\n }\n }, [value, options.leading, wait]);\n\n useEffect(() => {\n mountedRef.current = true;\n return cancel;\n }, []);\n\n return [_value, cancel] as const;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ 'use client';
2
+ import { useRef, useEffect } from 'react';
3
+
4
+ function useDidUpdate(fn, dependencies) {
5
+ const mounted = useRef(false);
6
+ useEffect(
7
+ () => () => {
8
+ mounted.current = false;
9
+ },
10
+ []
11
+ );
12
+ useEffect(() => {
13
+ if (mounted.current) {
14
+ return fn();
15
+ }
16
+ mounted.current = true;
17
+ return void 0;
18
+ }, dependencies);
19
+ }
20
+
21
+ export { useDidUpdate };
22
+ //# sourceMappingURL=use-did-update.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-did-update.mjs","sources":["../../src/use-did-update/use-did-update.ts"],"sourcesContent":["import { DependencyList, EffectCallback, useEffect, useRef } from 'react';\n\nexport function useDidUpdate(fn: EffectCallback, dependencies?: DependencyList) {\n const mounted = useRef(false);\n\n useEffect(\n () => () => {\n mounted.current = false;\n },\n []\n );\n\n useEffect(() => {\n if (mounted.current) {\n return fn();\n }\n\n mounted.current = true;\n return undefined;\n }, dependencies);\n}\n"],"names":[],"mappings":";;;AAEO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAE,CAAA,CAAA,CAAE,YAAY,CAAE,CAAA,CAAA;AAC/C,CAAA,CAAE,MAAM,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,KAAK,CAAC,CAAA;AAC/B,CAAA,CAAE,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACX,CAAA,CAAA,CAAA,CAAI,MAAM,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAChB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA;AAC7B,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA;AACL,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA;AACJ,CAAG,CAAA,CAAA,CAAA;AACH,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAClB,CAAA,CAAA,CAAA,CAAI,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAE,CAAA,CAAA;AACzB,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,EAAE,CAAE,CAAA,CAAA;AACjB,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAA,CAAI,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAI,CAAA,CAAA,CAAA,CAAA;AAC1B,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,KAAK,CAAC,CAAA;AACjB,CAAG,CAAA,CAAA,CAAA,CAAE,YAAY,CAAC,CAAA;AAClB,CAAA;;"}
@@ -0,0 +1,32 @@
1
+ 'use client';
2
+ import { useState, useCallback } from 'react';
3
+
4
+ function useDisclosure(initialState = false, callbacks) {
5
+ const { onOpen, onClose } = callbacks || {};
6
+ const [opened, setOpened] = useState(initialState);
7
+ const open = useCallback(() => {
8
+ setOpened((isOpened) => {
9
+ if (!isOpened) {
10
+ onOpen?.();
11
+ return true;
12
+ }
13
+ return isOpened;
14
+ });
15
+ }, [onOpen]);
16
+ const close = useCallback(() => {
17
+ setOpened((isOpened) => {
18
+ if (isOpened) {
19
+ onClose?.();
20
+ return false;
21
+ }
22
+ return isOpened;
23
+ });
24
+ }, [onClose]);
25
+ const toggle = useCallback(() => {
26
+ opened ? close() : open();
27
+ }, [close, open, opened]);
28
+ return [opened, { open, close, toggle }];
29
+ }
30
+
31
+ export { useDisclosure };
32
+ //# sourceMappingURL=use-disclosure.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-disclosure.mjs","sources":["../../src/use-disclosure/use-disclosure.ts"],"sourcesContent":["import { useCallback, useState } from 'react';\n\nexport function useDisclosure(\n initialState = false,\n callbacks?: { onOpen?: () => void; onClose?: () => void }\n) {\n const { onOpen, onClose } = callbacks || {};\n const [opened, setOpened] = useState(initialState);\n\n const open = useCallback(() => {\n setOpened((isOpened) => {\n if (!isOpened) {\n onOpen?.();\n return true;\n }\n return isOpened;\n });\n }, [onOpen]);\n\n const close = useCallback(() => {\n setOpened((isOpened) => {\n if (isOpened) {\n onClose?.();\n return false;\n }\n return isOpened;\n });\n }, [onClose]);\n\n const toggle = useCallback(() => {\n opened ? close() : open();\n }, [close, open, opened]);\n\n return [opened, { open, close, toggle }] as const;\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ 'use client';
2
+ import { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect.mjs';
3
+
4
+ function useDocumentTitle(title) {
5
+ useIsomorphicEffect(() => {
6
+ if (typeof title === "string" && title.trim().length > 0) {
7
+ document.title = title.trim();
8
+ }
9
+ }, [title]);
10
+ }
11
+
12
+ export { useDocumentTitle };
13
+ //# sourceMappingURL=use-document-title.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-document-title.mjs","sources":["../../src/use-document-title/use-document-title.ts"],"sourcesContent":["import { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect';\n\nexport function useDocumentTitle(title: string) {\n useIsomorphicEffect(() => {\n if (typeof title === 'string' && title.trim().length > 0) {\n document.title = title.trim();\n }\n }, [title]);\n}\n"],"names":[],"mappings":";;;AAEO,CAAS,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAC,CAAA,CAAA,CAAA,CAAA,CAAK,CAAE,CAAA,CAAA;AACxC,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAmB,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAC5B,CAAA,CAAA,CAAA,CAAI,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAK,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAK,QAAQ,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAK,CAAC,CAAA,CAAA,CAAA,CAAI,CAAE,CAAA,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAC,CAAE,CAAA,CAAA;AAC9D,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,QAAQ,CAAC,CAAA,CAAA,CAAA,CAAA,CAAK,GAAG,CAAK,CAAA,CAAA,CAAA,CAAA,CAAC,IAAI,CAAE,CAAA,CAAA;AACnC,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAA,CAAA,CAAG,CAAE,CAAA,CAAC,CAAK,CAAA,CAAA,CAAA,CAAA,CAAC,CAAC,CAAA;AACb,CAAA;;"}
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { useState, useEffect } from 'react';
3
+
4
+ function useDocumentVisibility() {
5
+ const [documentVisibility, setDocumentVisibility] = useState("visible");
6
+ useEffect(() => {
7
+ const listener = () => setDocumentVisibility(document.visibilityState);
8
+ document.addEventListener("visibilitychange", listener);
9
+ return () => document.removeEventListener("visibilitychange", listener);
10
+ }, []);
11
+ return documentVisibility;
12
+ }
13
+
14
+ export { useDocumentVisibility };
15
+ //# sourceMappingURL=use-document-visibility.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-document-visibility.mjs","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 const listener = () => setDocumentVisibility(document.visibilityState);\n document.addEventListener('visibilitychange', listener);\n return () => document.removeEventListener('visibilitychange', listener);\n }, []);\n\n return documentVisibility;\n}\n"],"names":[],"mappings":";;;AAEO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,qBAAqB,CAAG,CAAA,CAAA,CAAA;AACxC,CAAE,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,CAAkB,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAqB,CAAC,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAC,CAAA;AACzE,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAClB,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,QAAQ,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,qBAAqB,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAe,CAAC,CAAA;AAC1E,CAAA,CAAA,CAAA,CAAI,QAAQ,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAC,CAAkB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,QAAQ,CAAC,CAAA;AAC3D,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,MAAM,CAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,mBAAmB,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAkB,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAC,CAAA;AAC3E,CAAG,CAAA,CAAA,CAAA,CAAE,EAAE,CAAC,CAAA;AACR,CAAA,CAAE,OAAO,CAAkB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAC3B,CAAA;;"}
@@ -0,0 +1,17 @@
1
+ 'use client';
2
+ import { useRef, useEffect } from 'react';
3
+
4
+ function useEventListener(type, listener, options) {
5
+ const ref = useRef();
6
+ useEffect(() => {
7
+ if (ref.current) {
8
+ ref.current.addEventListener(type, listener, options);
9
+ return () => ref.current?.removeEventListener(type, listener, options);
10
+ }
11
+ return void 0;
12
+ }, [listener, options]);
13
+ return ref;
14
+ }
15
+
16
+ export { useEventListener };
17
+ //# sourceMappingURL=use-event-listener.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-event-listener.mjs","sources":["../../src/use-event-listener/use-event-listener.ts"],"sourcesContent":["import { useEffect, useRef } from 'react';\n\nexport function useEventListener<K extends keyof HTMLElementEventMap, T extends HTMLElement = any>(\n type: K,\n listener: (this: HTMLDivElement, ev: HTMLElementEventMap[K]) => any,\n options?: boolean | AddEventListenerOptions\n) {\n const ref = useRef<T>();\n\n useEffect(() => {\n if (ref.current) {\n ref.current.addEventListener(type, listener as any, options);\n return () => ref.current?.removeEventListener(type, listener as any, options);\n }\n return undefined;\n }, [listener, options]);\n\n return ref;\n}\n"],"names":[],"mappings":";;;AAEO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,gBAAgB,CAAC,CAAA,CAAA,CAAA,CAAI,EAAE,CAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,OAAO,CAAE,CAAA,CAAA;AAC1D,CAAA,CAAE,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAE,CAAA,CAAA;AACtB,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAC,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AAClB,CAAA,CAAA,CAAA,CAAI,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAE,CAAA,CAAA;AACrB,CAAM,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAG,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAC,CAAA,CAAA,CAAA,CAAI,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAC,CAAA;AAC3D,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAG,CAAA,CAAA,CAAC,CAAO,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,CAAmB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAI,CAAA,CAAA,CAAA,CAAA,CAAE,CAAQ,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAE,OAAO,CAAC,CAAA;AAC5E,CAAA,CAAA,CAAA,CAAA,CAAA;AACA,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,KAAK,CAAC,CAAA;AACjB,CAAA,CAAA,CAAG,EAAE,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAQ,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAO,CAAC,CAAC,CAAA;AACzB,CAAA,CAAE,OAAO,CAAG,CAAA,CAAA,CAAA;AACZ,CAAA;;"}
@@ -0,0 +1,27 @@
1
+ 'use client';
2
+ import { useState, useCallback } from 'react';
3
+ import { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect.mjs';
4
+
5
+ function isOpera() {
6
+ return navigator.userAgent.includes("OPR");
7
+ }
8
+ function useEyeDropper() {
9
+ const [supported, setSupported] = useState(false);
10
+ useIsomorphicEffect(() => {
11
+ setSupported(typeof window !== "undefined" && !isOpera() && "EyeDropper" in window);
12
+ }, []);
13
+ const open = useCallback(
14
+ (options = {}) => {
15
+ if (supported) {
16
+ const eyeDropper = new window.EyeDropper();
17
+ return eyeDropper.open(options);
18
+ }
19
+ return Promise.resolve(void 0);
20
+ },
21
+ [supported]
22
+ );
23
+ return { supported, open };
24
+ }
25
+
26
+ export { useEyeDropper };
27
+ //# sourceMappingURL=use-eye-dropper.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-eye-dropper.mjs","sources":["../../src/use-eye-dropper/use-eye-dropper.ts"],"sourcesContent":["import { useCallback, useState } from 'react';\nimport { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect';\n\ninterface EyeDropperOpenOptions {\n signal?: AbortSignal;\n}\n\nexport interface EyeDropperOpenReturnType {\n sRGBHex: string;\n}\n\nfunction isOpera() {\n return navigator.userAgent.includes('OPR');\n}\n\nexport function useEyeDropper() {\n const [supported, setSupported] = useState(false);\n\n useIsomorphicEffect(() => {\n setSupported(typeof window !== 'undefined' && !isOpera() && 'EyeDropper' in window);\n }, []);\n\n const open = useCallback(\n (options: EyeDropperOpenOptions = {}): Promise<EyeDropperOpenReturnType | undefined> => {\n if (supported) {\n const eyeDropper = new (window as any).EyeDropper();\n return eyeDropper.open(options);\n }\n\n return Promise.resolve(undefined);\n },\n [supported]\n );\n\n return { supported, open };\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ 'use client';
2
+ import { useRef } from 'react';
3
+ import { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect.mjs';
4
+
5
+ const MIME_TYPES = {
6
+ ico: "image/x-icon",
7
+ png: "image/png",
8
+ svg: "image/svg+xml",
9
+ gif: "image/gif"
10
+ };
11
+ function useFavicon(url) {
12
+ const link = useRef();
13
+ useIsomorphicEffect(() => {
14
+ if (!url) {
15
+ return;
16
+ }
17
+ if (!link.current) {
18
+ const existingElements = document.querySelectorAll('link[rel*="icon"]');
19
+ existingElements.forEach((element2) => document.head.removeChild(element2));
20
+ const element = document.createElement("link");
21
+ element.rel = "shortcut icon";
22
+ link.current = element;
23
+ document.querySelector("head").appendChild(element);
24
+ }
25
+ const splittedUrl = url.split(".");
26
+ link.current.setAttribute(
27
+ "type",
28
+ MIME_TYPES[splittedUrl[splittedUrl.length - 1].toLowerCase()]
29
+ );
30
+ link.current.setAttribute("href", url);
31
+ }, [url]);
32
+ }
33
+
34
+ export { useFavicon };
35
+ //# sourceMappingURL=use-favicon.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-favicon.mjs","sources":["../../src/use-favicon/use-favicon.ts"],"sourcesContent":["import { useRef } from 'react';\nimport { useIsomorphicEffect } from '../use-isomorphic-effect/use-isomorphic-effect';\n\nconst MIME_TYPES: Record<string, string> = {\n ico: 'image/x-icon',\n png: 'image/png',\n svg: 'image/svg+xml',\n gif: 'image/gif',\n};\n\nexport function useFavicon(url: string) {\n const link = useRef<HTMLLinkElement>();\n\n useIsomorphicEffect(() => {\n if (!url) {\n return;\n }\n\n if (!link.current) {\n const existingElements = document.querySelectorAll<HTMLLinkElement>('link[rel*=\"icon\"]');\n existingElements.forEach((element) => document.head.removeChild(element));\n\n const element = document.createElement('link');\n element.rel = 'shortcut icon';\n link.current = element;\n document.querySelector('head')!.appendChild(element);\n }\n\n const splittedUrl = url.split('.');\n link.current.setAttribute(\n 'type',\n MIME_TYPES[splittedUrl[splittedUrl.length - 1].toLowerCase()]\n );\n link.current.setAttribute('href', url);\n }, [url]);\n}\n"],"names":[],"mappings":"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"}