@siberiacancode/reactuse 0.2.12 → 0.2.13

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 (412) hide show
  1. package/dist/cjs/helpers/createContext/createContext.cjs.map +1 -1
  2. package/dist/cjs/helpers/createReactiveContext/createReactiveContext.cjs.map +1 -1
  3. package/dist/cjs/helpers/createStore/createStore.cjs.map +1 -1
  4. package/dist/cjs/hooks/useActiveElement/useActiveElement.cjs +1 -1
  5. package/dist/cjs/hooks/useActiveElement/useActiveElement.cjs.map +1 -1
  6. package/dist/cjs/hooks/useAsync/useAsync.cjs.map +1 -1
  7. package/dist/cjs/hooks/useBattery/useBattery.cjs +1 -1
  8. package/dist/cjs/hooks/useBattery/useBattery.cjs.map +1 -1
  9. package/dist/cjs/hooks/useBluetooth/useBluetooth.cjs +1 -1
  10. package/dist/cjs/hooks/useBluetooth/useBluetooth.cjs.map +1 -1
  11. package/dist/cjs/hooks/useBoolean/useBoolean.cjs.map +1 -1
  12. package/dist/cjs/hooks/useBreakpoints/useBreakpoints.cjs.map +1 -1
  13. package/dist/cjs/hooks/useBrowserLanguage/useBrowserLanguage.cjs.map +1 -1
  14. package/dist/cjs/hooks/useClickOutside/useClickOutside.cjs.map +1 -1
  15. package/dist/cjs/hooks/useClipboard/useClipboard.cjs +1 -1
  16. package/dist/cjs/hooks/useClipboard/useClipboard.cjs.map +1 -1
  17. package/dist/cjs/hooks/useCookie/useCookie.cjs +1 -1
  18. package/dist/cjs/hooks/useCookie/useCookie.cjs.map +1 -1
  19. package/dist/cjs/hooks/useCookies/useCookies.cjs +1 -1
  20. package/dist/cjs/hooks/useCookies/useCookies.cjs.map +1 -1
  21. package/dist/cjs/hooks/useCopy/useCopy.cjs.map +1 -1
  22. package/dist/cjs/hooks/useCounter/useCounter.cjs +1 -1
  23. package/dist/cjs/hooks/useCounter/useCounter.cjs.map +1 -1
  24. package/dist/cjs/hooks/useCssVar/useCssVar.cjs +1 -1
  25. package/dist/cjs/hooks/useCssVar/useCssVar.cjs.map +1 -1
  26. package/dist/cjs/hooks/useDebounceCallback/useDebounceCallback.cjs.map +1 -1
  27. package/dist/cjs/hooks/useDebounceValue/useDebounceValue.cjs.map +1 -1
  28. package/dist/cjs/hooks/useDeviceMotion/useDeviceMotion.cjs +1 -1
  29. package/dist/cjs/hooks/useDeviceMotion/useDeviceMotion.cjs.map +1 -1
  30. package/dist/cjs/hooks/useDeviceOrientation/useDeviceOrientation.cjs.map +1 -1
  31. package/dist/cjs/hooks/useDevicePixelRatio/useDevicePixelRatio.cjs.map +1 -1
  32. package/dist/cjs/hooks/useDidUpdate/useDidUpdate.cjs.map +1 -1
  33. package/dist/cjs/hooks/useDisclosure/useDisclosure.cjs +1 -1
  34. package/dist/cjs/hooks/useDisclosure/useDisclosure.cjs.map +1 -1
  35. package/dist/cjs/hooks/useDisplayMedia/useDisplayMedia.cjs +1 -1
  36. package/dist/cjs/hooks/useDisplayMedia/useDisplayMedia.cjs.map +1 -1
  37. package/dist/cjs/hooks/useDocumentEvent/useDocumentEvent.cjs.map +1 -1
  38. package/dist/cjs/hooks/useDocumentTitle/useDocumentTitle.cjs +1 -1
  39. package/dist/cjs/hooks/useDocumentTitle/useDocumentTitle.cjs.map +1 -1
  40. package/dist/cjs/hooks/useDocumentVisibility/useDocumentVisibility.cjs.map +1 -1
  41. package/dist/cjs/hooks/useDoubleClick/useDoubleClick.cjs +1 -1
  42. package/dist/cjs/hooks/useDoubleClick/useDoubleClick.cjs.map +1 -1
  43. package/dist/cjs/hooks/useDropZone/useDropZone.cjs +1 -1
  44. package/dist/cjs/hooks/useDropZone/useDropZone.cjs.map +1 -1
  45. package/dist/cjs/hooks/useElementSize/useElementSize.cjs.map +1 -1
  46. package/dist/cjs/hooks/useEvent/useEvent.cjs.map +1 -1
  47. package/dist/cjs/hooks/useEventListener/useEventListener.cjs.map +1 -1
  48. package/dist/cjs/hooks/useEventSource/useEventSource.cjs +1 -1
  49. package/dist/cjs/hooks/useEventSource/useEventSource.cjs.map +1 -1
  50. package/dist/cjs/hooks/useEyeDropper/useEyeDropper.cjs.map +1 -1
  51. package/dist/cjs/hooks/useFavicon/useFavicon.cjs +1 -1
  52. package/dist/cjs/hooks/useFavicon/useFavicon.cjs.map +1 -1
  53. package/dist/cjs/hooks/useField/useField.cjs +1 -1
  54. package/dist/cjs/hooks/useField/useField.cjs.map +1 -1
  55. package/dist/cjs/hooks/useFileDialog/useFileDialog.cjs +1 -1
  56. package/dist/cjs/hooks/useFileDialog/useFileDialog.cjs.map +1 -1
  57. package/dist/cjs/hooks/useFocus/useFocus.cjs +1 -1
  58. package/dist/cjs/hooks/useFocus/useFocus.cjs.map +1 -1
  59. package/dist/cjs/hooks/useFps/useFps.cjs.map +1 -1
  60. package/dist/cjs/hooks/useFul/useFul.cjs.map +1 -1
  61. package/dist/cjs/hooks/useFullscreen/useFullscreen.cjs +1 -1
  62. package/dist/cjs/hooks/useFullscreen/useFullscreen.cjs.map +1 -1
  63. package/dist/cjs/hooks/useGamepad/useGamepad.cjs.map +1 -1
  64. package/dist/cjs/hooks/useGeolocation/useGeolocation.cjs +1 -1
  65. package/dist/cjs/hooks/useGeolocation/useGeolocation.cjs.map +1 -1
  66. package/dist/cjs/hooks/useHash/useHash.cjs.map +1 -1
  67. package/dist/cjs/hooks/useHotkeys/useHotkeys.cjs +1 -1
  68. package/dist/cjs/hooks/useHotkeys/useHotkeys.cjs.map +1 -1
  69. package/dist/cjs/hooks/useHover/useHover.cjs +1 -1
  70. package/dist/cjs/hooks/useHover/useHover.cjs.map +1 -1
  71. package/dist/cjs/hooks/useIdle/useIdle.cjs.map +1 -1
  72. package/dist/cjs/hooks/useImage/useImage.cjs.map +1 -1
  73. package/dist/cjs/hooks/useInfiniteScroll/useInfiniteScroll.cjs +1 -1
  74. package/dist/cjs/hooks/useInfiniteScroll/useInfiniteScroll.cjs.map +1 -1
  75. package/dist/cjs/hooks/useIntersectionObserver/useIntersectionObserver.cjs +1 -1
  76. package/dist/cjs/hooks/useIntersectionObserver/useIntersectionObserver.cjs.map +1 -1
  77. package/dist/cjs/hooks/useInterval/useInterval.cjs +1 -1
  78. package/dist/cjs/hooks/useInterval/useInterval.cjs.map +1 -1
  79. package/dist/cjs/hooks/useIsFirstRender/useIsFirstRender.cjs.map +1 -1
  80. package/dist/cjs/hooks/useKeyPress/useKeyPress.cjs +1 -1
  81. package/dist/cjs/hooks/useKeyPress/useKeyPress.cjs.map +1 -1
  82. package/dist/cjs/hooks/useKeyPressEvent/useKeyPressEvent.cjs +1 -1
  83. package/dist/cjs/hooks/useKeyPressEvent/useKeyPressEvent.cjs.map +1 -1
  84. package/dist/cjs/hooks/useKeyboard/useKeyboard.cjs +1 -1
  85. package/dist/cjs/hooks/useKeyboard/useKeyboard.cjs.map +1 -1
  86. package/dist/cjs/hooks/useKeysPressed/useKeysPressed.cjs +1 -1
  87. package/dist/cjs/hooks/useKeysPressed/useKeysPressed.cjs.map +1 -1
  88. package/dist/cjs/hooks/useLastChanged/useLastChanged.cjs +1 -1
  89. package/dist/cjs/hooks/useLastChanged/useLastChanged.cjs.map +1 -1
  90. package/dist/cjs/hooks/useLatest/useLatest.cjs +1 -1
  91. package/dist/cjs/hooks/useLatest/useLatest.cjs.map +1 -1
  92. package/dist/cjs/hooks/useLess/useLess.cjs.map +1 -1
  93. package/dist/cjs/hooks/useList/useList.cjs.map +1 -1
  94. package/dist/cjs/hooks/useLockCallback/useLockCallback.cjs.map +1 -1
  95. package/dist/cjs/hooks/useLogger/useLogger.cjs.map +1 -1
  96. package/dist/cjs/hooks/useLongPress/useLongPress.cjs +1 -1
  97. package/dist/cjs/hooks/useLongPress/useLongPress.cjs.map +1 -1
  98. package/dist/cjs/hooks/useMap/useMap.cjs.map +1 -1
  99. package/dist/cjs/hooks/useMeasure/useMeasure.cjs.map +1 -1
  100. package/dist/cjs/hooks/useMediaQuery/useMediaQuery.cjs.map +1 -1
  101. package/dist/cjs/hooks/useMemory/useMemory.cjs +1 -1
  102. package/dist/cjs/hooks/useMemory/useMemory.cjs.map +1 -1
  103. package/dist/cjs/hooks/useMount/useMount.cjs.map +1 -1
  104. package/dist/cjs/hooks/useMouse/useMouse.cjs.map +1 -1
  105. package/dist/cjs/hooks/useMutation/useMutation.cjs +1 -1
  106. package/dist/cjs/hooks/useMutation/useMutation.cjs.map +1 -1
  107. package/dist/cjs/hooks/useMutationObserver/useMutationObserver.cjs +1 -1
  108. package/dist/cjs/hooks/useMutationObserver/useMutationObserver.cjs.map +1 -1
  109. package/dist/cjs/hooks/useNetwork/useNetwork.cjs +1 -1
  110. package/dist/cjs/hooks/useNetwork/useNetwork.cjs.map +1 -1
  111. package/dist/cjs/hooks/useOffsetPagination/useOffsetPagination.cjs.map +1 -1
  112. package/dist/cjs/hooks/useOnce/useOnce.cjs.map +1 -1
  113. package/dist/cjs/hooks/useOnline/useOnline.cjs.map +1 -1
  114. package/dist/cjs/hooks/useOperatingSystem/useOperatingSystem.cjs.map +1 -1
  115. package/dist/cjs/hooks/useOptimistic/useOptimistic.cjs.map +1 -1
  116. package/dist/cjs/hooks/useOrientation/useOrientation.cjs.map +1 -1
  117. package/dist/cjs/hooks/useOtpCredential/useOtpCredential.cjs +1 -1
  118. package/dist/cjs/hooks/useOtpCredential/useOtpCredential.cjs.map +1 -1
  119. package/dist/cjs/hooks/usePageLeave/usePageLeave.cjs +1 -1
  120. package/dist/cjs/hooks/usePageLeave/usePageLeave.cjs.map +1 -1
  121. package/dist/cjs/hooks/usePaint/usePaint.cjs +1 -1
  122. package/dist/cjs/hooks/usePaint/usePaint.cjs.map +1 -1
  123. package/dist/cjs/hooks/useParallax/useParallax.cjs.map +1 -1
  124. package/dist/cjs/hooks/usePerformanceObserver/usePerformanceObserver.cjs +1 -1
  125. package/dist/cjs/hooks/usePerformanceObserver/usePerformanceObserver.cjs.map +1 -1
  126. package/dist/cjs/hooks/usePermission/usePermission.cjs +1 -1
  127. package/dist/cjs/hooks/usePermission/usePermission.cjs.map +1 -1
  128. package/dist/cjs/hooks/usePointerLock/usePointerLock.cjs.map +1 -1
  129. package/dist/cjs/hooks/usePostMessage/usePostMessage.cjs.map +1 -1
  130. package/dist/cjs/hooks/usePreferredColorScheme/usePreferredColorScheme.cjs.map +1 -1
  131. package/dist/cjs/hooks/usePreferredContrast/usePreferredContrast.cjs.map +1 -1
  132. package/dist/cjs/hooks/usePreferredLanguages/usePreferredLanguages.cjs.map +1 -1
  133. package/dist/cjs/hooks/usePreferredReducedMotion/usePreferredReducedMotion.cjs.map +1 -1
  134. package/dist/cjs/hooks/usePrevious/usePrevious.cjs +1 -1
  135. package/dist/cjs/hooks/usePrevious/usePrevious.cjs.map +1 -1
  136. package/dist/cjs/hooks/useQuery/useQuery.cjs +1 -1
  137. package/dist/cjs/hooks/useQuery/useQuery.cjs.map +1 -1
  138. package/dist/cjs/hooks/useQueue/useQueue.cjs.map +1 -1
  139. package/dist/cjs/hooks/useRaf/useRaf.cjs +1 -1
  140. package/dist/cjs/hooks/useRaf/useRaf.cjs.map +1 -1
  141. package/dist/cjs/hooks/useRafValue/useRafValue.cjs.map +1 -1
  142. package/dist/cjs/hooks/useRefState/useRefState.cjs.map +1 -1
  143. package/dist/cjs/hooks/useRenderCount/useRenderCount.cjs.map +1 -1
  144. package/dist/cjs/hooks/useRenderInfo/useRenderInfo.cjs.map +1 -1
  145. package/dist/cjs/hooks/useRerender/useRerender.cjs.map +1 -1
  146. package/dist/cjs/hooks/useResizeObserver/useResizeObserver.cjs +1 -1
  147. package/dist/cjs/hooks/useResizeObserver/useResizeObserver.cjs.map +1 -1
  148. package/dist/cjs/hooks/useScreenOrientation/useScreenOrientation.cjs +1 -1
  149. package/dist/cjs/hooks/useScreenOrientation/useScreenOrientation.cjs.map +1 -1
  150. package/dist/cjs/hooks/useScript/useScript.cjs +1 -1
  151. package/dist/cjs/hooks/useScript/useScript.cjs.map +1 -1
  152. package/dist/cjs/hooks/useScroll/useScroll.cjs +1 -1
  153. package/dist/cjs/hooks/useScroll/useScroll.cjs.map +1 -1
  154. package/dist/cjs/hooks/useScrollIntoView/useScrollIntoView.cjs.map +1 -1
  155. package/dist/cjs/hooks/useScrollTo/useScrollTo.cjs.map +1 -1
  156. package/dist/cjs/hooks/useSet/useSet.cjs.map +1 -1
  157. package/dist/cjs/hooks/useShare/useShare.cjs.map +1 -1
  158. package/dist/cjs/hooks/useSpeechRecognition/useSpeechRecognition.cjs +1 -1
  159. package/dist/cjs/hooks/useSpeechRecognition/useSpeechRecognition.cjs.map +1 -1
  160. package/dist/cjs/hooks/useSpeechSynthesis/useSpeechSynthesis.cjs +1 -1
  161. package/dist/cjs/hooks/useSpeechSynthesis/useSpeechSynthesis.cjs.map +1 -1
  162. package/dist/cjs/hooks/useStateHistory/useStateHistory.cjs.map +1 -1
  163. package/dist/cjs/hooks/useStep/useStep.cjs.map +1 -1
  164. package/dist/cjs/hooks/useSticky/useSticky.cjs +1 -1
  165. package/dist/cjs/hooks/useSticky/useSticky.cjs.map +1 -1
  166. package/dist/cjs/hooks/useStopwatch/useStopwatch.cjs +1 -1
  167. package/dist/cjs/hooks/useStopwatch/useStopwatch.cjs.map +1 -1
  168. package/dist/cjs/hooks/useStorage/useStorage.cjs +1 -1
  169. package/dist/cjs/hooks/useStorage/useStorage.cjs.map +1 -1
  170. package/dist/cjs/hooks/useTextDirection/useTextDirection.cjs +1 -1
  171. package/dist/cjs/hooks/useTextDirection/useTextDirection.cjs.map +1 -1
  172. package/dist/cjs/hooks/useTextSelection/useTextSelection.cjs +1 -1
  173. package/dist/cjs/hooks/useTextSelection/useTextSelection.cjs.map +1 -1
  174. package/dist/cjs/hooks/useThrottleCallback/useThrottleCallback.cjs.map +1 -1
  175. package/dist/cjs/hooks/useThrottleValue/useThrottleValue.cjs.map +1 -1
  176. package/dist/cjs/hooks/useTime/useTime.cjs.map +1 -1
  177. package/dist/cjs/hooks/useTimeout/useTimeout.cjs.map +1 -1
  178. package/dist/cjs/hooks/useTimer/useTimer.cjs +1 -1
  179. package/dist/cjs/hooks/useTimer/useTimer.cjs.map +1 -1
  180. package/dist/cjs/hooks/useToggle/useToggle.cjs.map +1 -1
  181. package/dist/cjs/hooks/useUnmount/useUnmount.cjs.map +1 -1
  182. package/dist/cjs/hooks/useUrlSearchParam/useUrlSearchParam.cjs +1 -1
  183. package/dist/cjs/hooks/useUrlSearchParam/useUrlSearchParam.cjs.map +1 -1
  184. package/dist/cjs/hooks/useUrlSearchParams/useUrlSearchParams.cjs +1 -1
  185. package/dist/cjs/hooks/useUrlSearchParams/useUrlSearchParams.cjs.map +1 -1
  186. package/dist/cjs/hooks/useVibrate/useVibrate.cjs.map +1 -1
  187. package/dist/cjs/hooks/useWakeLock/useWakeLock.cjs +1 -1
  188. package/dist/cjs/hooks/useWakeLock/useWakeLock.cjs.map +1 -1
  189. package/dist/cjs/hooks/useWebSocket/useWebSocket.cjs +1 -1
  190. package/dist/cjs/hooks/useWebSocket/useWebSocket.cjs.map +1 -1
  191. package/dist/cjs/hooks/useWindowEvent/useWindowEvent.cjs.map +1 -1
  192. package/dist/cjs/hooks/useWindowFocus/useWindowFocus.cjs.map +1 -1
  193. package/dist/cjs/hooks/useWindowScroll/useWindowScroll.cjs.map +1 -1
  194. package/dist/cjs/hooks/useWindowSize/useWindowSize.cjs +1 -1
  195. package/dist/cjs/hooks/useWindowSize/useWindowSize.cjs.map +1 -1
  196. package/dist/cjs/hooks/useWizard/useWizard.cjs +1 -1
  197. package/dist/cjs/hooks/useWizard/useWizard.cjs.map +1 -1
  198. package/dist/cjs/utils/helpers/copy.cjs.map +1 -1
  199. package/dist/cjs/utils/helpers/debounce.cjs.map +1 -1
  200. package/dist/cjs/utils/helpers/getDate.cjs.map +1 -1
  201. package/dist/cjs/utils/helpers/getElement.cjs.map +1 -1
  202. package/dist/cjs/utils/helpers/getRetry.cjs.map +1 -1
  203. package/dist/cjs/utils/helpers/isTarget.cjs.map +1 -1
  204. package/dist/cjs/utils/helpers/throttle.cjs.map +1 -1
  205. package/dist/esm/helpers/createContext/createContext.mjs.map +1 -1
  206. package/dist/esm/helpers/createReactiveContext/createReactiveContext.mjs.map +1 -1
  207. package/dist/esm/helpers/createStore/createStore.mjs.map +1 -1
  208. package/dist/esm/hooks/useActiveElement/useActiveElement.mjs +1 -1
  209. package/dist/esm/hooks/useActiveElement/useActiveElement.mjs.map +1 -1
  210. package/dist/esm/hooks/useAsync/useAsync.mjs.map +1 -1
  211. package/dist/esm/hooks/useBattery/useBattery.mjs +10 -10
  212. package/dist/esm/hooks/useBattery/useBattery.mjs.map +1 -1
  213. package/dist/esm/hooks/useBluetooth/useBluetooth.mjs +14 -15
  214. package/dist/esm/hooks/useBluetooth/useBluetooth.mjs.map +1 -1
  215. package/dist/esm/hooks/useBoolean/useBoolean.mjs.map +1 -1
  216. package/dist/esm/hooks/useBreakpoints/useBreakpoints.mjs.map +1 -1
  217. package/dist/esm/hooks/useBrowserLanguage/useBrowserLanguage.mjs.map +1 -1
  218. package/dist/esm/hooks/useClickOutside/useClickOutside.mjs.map +1 -1
  219. package/dist/esm/hooks/useClipboard/useClipboard.mjs +13 -14
  220. package/dist/esm/hooks/useClipboard/useClipboard.mjs.map +1 -1
  221. package/dist/esm/hooks/useConst/useConst.mjs.map +1 -1
  222. package/dist/esm/hooks/useCookie/useCookie.mjs +27 -27
  223. package/dist/esm/hooks/useCookie/useCookie.mjs.map +1 -1
  224. package/dist/esm/hooks/useCookies/useCookies.mjs +19 -19
  225. package/dist/esm/hooks/useCookies/useCookies.mjs.map +1 -1
  226. package/dist/esm/hooks/useCopy/useCopy.mjs.map +1 -1
  227. package/dist/esm/hooks/useCounter/useCounter.mjs +5 -6
  228. package/dist/esm/hooks/useCounter/useCounter.mjs.map +1 -1
  229. package/dist/esm/hooks/useCssVar/useCssVar.mjs +13 -14
  230. package/dist/esm/hooks/useCssVar/useCssVar.mjs.map +1 -1
  231. package/dist/esm/hooks/useDebounceCallback/useDebounceCallback.mjs.map +1 -1
  232. package/dist/esm/hooks/useDebounceValue/useDebounceValue.mjs.map +1 -1
  233. package/dist/esm/hooks/useDefault/useDefault.mjs.map +1 -1
  234. package/dist/esm/hooks/useDeviceMotion/useDeviceMotion.mjs +18 -19
  235. package/dist/esm/hooks/useDeviceMotion/useDeviceMotion.mjs.map +1 -1
  236. package/dist/esm/hooks/useDeviceOrientation/useDeviceOrientation.mjs.map +1 -1
  237. package/dist/esm/hooks/useDevicePixelRatio/useDevicePixelRatio.mjs.map +1 -1
  238. package/dist/esm/hooks/useDidUpdate/useDidUpdate.mjs.map +1 -1
  239. package/dist/esm/hooks/useDisclosure/useDisclosure.mjs +5 -11
  240. package/dist/esm/hooks/useDisclosure/useDisclosure.mjs.map +1 -1
  241. package/dist/esm/hooks/useDisplayMedia/useDisplayMedia.mjs +28 -28
  242. package/dist/esm/hooks/useDisplayMedia/useDisplayMedia.mjs.map +1 -1
  243. package/dist/esm/hooks/useDocumentEvent/useDocumentEvent.mjs.map +1 -1
  244. package/dist/esm/hooks/useDocumentTitle/useDocumentTitle.mjs +15 -15
  245. package/dist/esm/hooks/useDocumentTitle/useDocumentTitle.mjs.map +1 -1
  246. package/dist/esm/hooks/useDocumentVisibility/useDocumentVisibility.mjs.map +1 -1
  247. package/dist/esm/hooks/useDoubleClick/useDoubleClick.mjs +11 -13
  248. package/dist/esm/hooks/useDoubleClick/useDoubleClick.mjs.map +1 -1
  249. package/dist/esm/hooks/useDropZone/useDropZone.mjs +27 -28
  250. package/dist/esm/hooks/useDropZone/useDropZone.mjs.map +1 -1
  251. package/dist/esm/hooks/useElementSize/useElementSize.mjs.map +1 -1
  252. package/dist/esm/hooks/useEvent/useEvent.mjs.map +1 -1
  253. package/dist/esm/hooks/useEventListener/useEventListener.mjs.map +1 -1
  254. package/dist/esm/hooks/useEventSource/useEventSource.mjs +37 -40
  255. package/dist/esm/hooks/useEventSource/useEventSource.mjs.map +1 -1
  256. package/dist/esm/hooks/useEyeDropper/useEyeDropper.mjs.map +1 -1
  257. package/dist/esm/hooks/useFavicon/useFavicon.mjs +11 -12
  258. package/dist/esm/hooks/useFavicon/useFavicon.mjs.map +1 -1
  259. package/dist/esm/hooks/useField/useField.mjs +45 -49
  260. package/dist/esm/hooks/useField/useField.mjs.map +1 -1
  261. package/dist/esm/hooks/useFileDialog/useFileDialog.mjs +22 -25
  262. package/dist/esm/hooks/useFileDialog/useFileDialog.mjs.map +1 -1
  263. package/dist/esm/hooks/useFocus/useFocus.mjs +24 -32
  264. package/dist/esm/hooks/useFocus/useFocus.mjs.map +1 -1
  265. package/dist/esm/hooks/useFps/useFps.mjs.map +1 -1
  266. package/dist/esm/hooks/useFul/useFul.mjs.map +1 -1
  267. package/dist/esm/hooks/useFullscreen/useFullscreen.mjs +23 -24
  268. package/dist/esm/hooks/useFullscreen/useFullscreen.mjs.map +1 -1
  269. package/dist/esm/hooks/useGamepad/useGamepad.mjs.map +1 -1
  270. package/dist/esm/hooks/useGeolocation/useGeolocation.mjs +24 -24
  271. package/dist/esm/hooks/useGeolocation/useGeolocation.mjs.map +1 -1
  272. package/dist/esm/hooks/useHash/useHash.mjs.map +1 -1
  273. package/dist/esm/hooks/useHotkeys/useHotkeys.mjs +24 -25
  274. package/dist/esm/hooks/useHotkeys/useHotkeys.mjs.map +1 -1
  275. package/dist/esm/hooks/useHover/useHover.mjs +20 -22
  276. package/dist/esm/hooks/useHover/useHover.mjs.map +1 -1
  277. package/dist/esm/hooks/useIdle/useIdle.mjs.map +1 -1
  278. package/dist/esm/hooks/useImage/useImage.mjs.map +1 -1
  279. package/dist/esm/hooks/useInfiniteScroll/useInfiniteScroll.mjs +14 -14
  280. package/dist/esm/hooks/useInfiniteScroll/useInfiniteScroll.mjs.map +1 -1
  281. package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.mjs +19 -20
  282. package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.mjs.map +1 -1
  283. package/dist/esm/hooks/useInterval/useInterval.mjs +8 -8
  284. package/dist/esm/hooks/useInterval/useInterval.mjs.map +1 -1
  285. package/dist/esm/hooks/useIsFirstRender/useIsFirstRender.mjs.map +1 -1
  286. package/dist/esm/hooks/useKeyPress/useKeyPress.mjs +22 -24
  287. package/dist/esm/hooks/useKeyPress/useKeyPress.mjs.map +1 -1
  288. package/dist/esm/hooks/useKeyPressEvent/useKeyPressEvent.mjs +23 -23
  289. package/dist/esm/hooks/useKeyPressEvent/useKeyPressEvent.mjs.map +1 -1
  290. package/dist/esm/hooks/useKeyboard/useKeyboard.mjs +16 -22
  291. package/dist/esm/hooks/useKeyboard/useKeyboard.mjs.map +1 -1
  292. package/dist/esm/hooks/useKeysPressed/useKeysPressed.mjs +20 -20
  293. package/dist/esm/hooks/useKeysPressed/useKeysPressed.mjs.map +1 -1
  294. package/dist/esm/hooks/useLastChanged/useLastChanged.mjs +6 -6
  295. package/dist/esm/hooks/useLastChanged/useLastChanged.mjs.map +1 -1
  296. package/dist/esm/hooks/useLatest/useLatest.mjs +12 -4
  297. package/dist/esm/hooks/useLatest/useLatest.mjs.map +1 -1
  298. package/dist/esm/hooks/useLess/useLess.mjs.map +1 -1
  299. package/dist/esm/hooks/useList/useList.mjs.map +1 -1
  300. package/dist/esm/hooks/useLockCallback/useLockCallback.mjs.map +1 -1
  301. package/dist/esm/hooks/useLogger/useLogger.mjs.map +1 -1
  302. package/dist/esm/hooks/useLongPress/useLongPress.mjs +23 -27
  303. package/dist/esm/hooks/useLongPress/useLongPress.mjs.map +1 -1
  304. package/dist/esm/hooks/useMap/useMap.mjs.map +1 -1
  305. package/dist/esm/hooks/useMeasure/useMeasure.mjs.map +1 -1
  306. package/dist/esm/hooks/useMediaQuery/useMediaQuery.mjs.map +1 -1
  307. package/dist/esm/hooks/useMemory/useMemory.mjs +1 -1
  308. package/dist/esm/hooks/useMemory/useMemory.mjs.map +1 -1
  309. package/dist/esm/hooks/useMount/useMount.mjs.map +1 -1
  310. package/dist/esm/hooks/useMouse/useMouse.mjs.map +1 -1
  311. package/dist/esm/hooks/useMutation/useMutation.mjs +38 -42
  312. package/dist/esm/hooks/useMutation/useMutation.mjs.map +1 -1
  313. package/dist/esm/hooks/useMutationObserver/useMutationObserver.mjs +12 -12
  314. package/dist/esm/hooks/useMutationObserver/useMutationObserver.mjs.map +1 -1
  315. package/dist/esm/hooks/useNetwork/useNetwork.mjs +28 -28
  316. package/dist/esm/hooks/useNetwork/useNetwork.mjs.map +1 -1
  317. package/dist/esm/hooks/useOffsetPagination/useOffsetPagination.mjs.map +1 -1
  318. package/dist/esm/hooks/useOnce/useOnce.mjs.map +1 -1
  319. package/dist/esm/hooks/useOnline/useOnline.mjs.map +1 -1
  320. package/dist/esm/hooks/useOperatingSystem/useOperatingSystem.mjs.map +1 -1
  321. package/dist/esm/hooks/useOptimistic/useOptimistic.mjs.map +1 -1
  322. package/dist/esm/hooks/useOrientation/useOrientation.mjs.map +1 -1
  323. package/dist/esm/hooks/useOtpCredential/useOtpCredential.mjs +12 -13
  324. package/dist/esm/hooks/useOtpCredential/useOtpCredential.mjs.map +1 -1
  325. package/dist/esm/hooks/usePageLeave/usePageLeave.mjs +6 -6
  326. package/dist/esm/hooks/usePageLeave/usePageLeave.mjs.map +1 -1
  327. package/dist/esm/hooks/usePaint/usePaint.mjs +87 -93
  328. package/dist/esm/hooks/usePaint/usePaint.mjs.map +1 -1
  329. package/dist/esm/hooks/useParallax/useParallax.mjs.map +1 -1
  330. package/dist/esm/hooks/usePerformanceObserver/usePerformanceObserver.mjs +17 -19
  331. package/dist/esm/hooks/usePerformanceObserver/usePerformanceObserver.mjs.map +1 -1
  332. package/dist/esm/hooks/usePermission/usePermission.mjs +13 -13
  333. package/dist/esm/hooks/usePermission/usePermission.mjs.map +1 -1
  334. package/dist/esm/hooks/usePointerLock/usePointerLock.mjs.map +1 -1
  335. package/dist/esm/hooks/usePostMessage/usePostMessage.mjs.map +1 -1
  336. package/dist/esm/hooks/usePreferredColorScheme/usePreferredColorScheme.mjs.map +1 -1
  337. package/dist/esm/hooks/usePreferredContrast/usePreferredContrast.mjs.map +1 -1
  338. package/dist/esm/hooks/usePreferredDark/usePreferredDark.mjs.map +1 -1
  339. package/dist/esm/hooks/usePreferredLanguages/usePreferredLanguages.mjs.map +1 -1
  340. package/dist/esm/hooks/usePrevious/usePrevious.mjs +4 -4
  341. package/dist/esm/hooks/usePrevious/usePrevious.mjs.map +1 -1
  342. package/dist/esm/hooks/useQuery/useQuery.mjs +39 -41
  343. package/dist/esm/hooks/useQuery/useQuery.mjs.map +1 -1
  344. package/dist/esm/hooks/useQueue/useQueue.mjs.map +1 -1
  345. package/dist/esm/hooks/useRaf/useRaf.mjs +21 -21
  346. package/dist/esm/hooks/useRaf/useRaf.mjs.map +1 -1
  347. package/dist/esm/hooks/useRafValue/useRafValue.mjs.map +1 -1
  348. package/dist/esm/hooks/useRefState/useRefState.mjs.map +1 -1
  349. package/dist/esm/hooks/useRenderCount/useRenderCount.mjs.map +1 -1
  350. package/dist/esm/hooks/useRenderInfo/useRenderInfo.mjs.map +1 -1
  351. package/dist/esm/hooks/useRerender/useRerender.mjs.map +1 -1
  352. package/dist/esm/hooks/useResizeObserver/useResizeObserver.mjs +16 -17
  353. package/dist/esm/hooks/useResizeObserver/useResizeObserver.mjs.map +1 -1
  354. package/dist/esm/hooks/useScreenOrientation/useScreenOrientation.mjs +11 -11
  355. package/dist/esm/hooks/useScreenOrientation/useScreenOrientation.mjs.map +1 -1
  356. package/dist/esm/hooks/useScript/useScript.mjs +16 -16
  357. package/dist/esm/hooks/useScript/useScript.mjs.map +1 -1
  358. package/dist/esm/hooks/useScroll/useScroll.mjs +37 -39
  359. package/dist/esm/hooks/useScroll/useScroll.mjs.map +1 -1
  360. package/dist/esm/hooks/useScrollIntoView/useScrollIntoView.mjs.map +1 -1
  361. package/dist/esm/hooks/useScrollTo/useScrollTo.mjs.map +1 -1
  362. package/dist/esm/hooks/useSet/useSet.mjs.map +1 -1
  363. package/dist/esm/hooks/useShare/useShare.mjs.map +1 -1
  364. package/dist/esm/hooks/useSpeechRecognition/useSpeechRecognition.mjs +35 -35
  365. package/dist/esm/hooks/useSpeechRecognition/useSpeechRecognition.mjs.map +1 -1
  366. package/dist/esm/hooks/useSpeechSynthesis/useSpeechSynthesis.mjs +36 -42
  367. package/dist/esm/hooks/useSpeechSynthesis/useSpeechSynthesis.mjs.map +1 -1
  368. package/dist/esm/hooks/useStateHistory/useStateHistory.mjs.map +1 -1
  369. package/dist/esm/hooks/useStep/useStep.mjs.map +1 -1
  370. package/dist/esm/hooks/useSticky/useSticky.mjs +12 -12
  371. package/dist/esm/hooks/useSticky/useSticky.mjs.map +1 -1
  372. package/dist/esm/hooks/useStopwatch/useStopwatch.mjs +10 -11
  373. package/dist/esm/hooks/useStopwatch/useStopwatch.mjs.map +1 -1
  374. package/dist/esm/hooks/useStorage/useStorage.mjs +27 -27
  375. package/dist/esm/hooks/useStorage/useStorage.mjs.map +1 -1
  376. package/dist/esm/hooks/useTextDirection/useTextDirection.mjs +21 -24
  377. package/dist/esm/hooks/useTextDirection/useTextDirection.mjs.map +1 -1
  378. package/dist/esm/hooks/useTextSelection/useTextSelection.mjs +7 -7
  379. package/dist/esm/hooks/useTextSelection/useTextSelection.mjs.map +1 -1
  380. package/dist/esm/hooks/useThrottleCallback/useThrottleCallback.mjs.map +1 -1
  381. package/dist/esm/hooks/useThrottleValue/useThrottleValue.mjs.map +1 -1
  382. package/dist/esm/hooks/useTime/useTime.mjs.map +1 -1
  383. package/dist/esm/hooks/useTimeout/useTimeout.mjs.map +1 -1
  384. package/dist/esm/hooks/useTimer/useTimer.mjs +51 -54
  385. package/dist/esm/hooks/useTimer/useTimer.mjs.map +1 -1
  386. package/dist/esm/hooks/useToggle/useToggle.mjs.map +1 -1
  387. package/dist/esm/hooks/useUnmount/useUnmount.mjs.map +1 -1
  388. package/dist/esm/hooks/useUrlSearchParam/useUrlSearchParam.mjs +38 -38
  389. package/dist/esm/hooks/useUrlSearchParam/useUrlSearchParam.mjs.map +1 -1
  390. package/dist/esm/hooks/useUrlSearchParams/useUrlSearchParams.mjs +29 -29
  391. package/dist/esm/hooks/useUrlSearchParams/useUrlSearchParams.mjs.map +1 -1
  392. package/dist/esm/hooks/useVibrate/useVibrate.mjs.map +1 -1
  393. package/dist/esm/hooks/useWakeLock/useWakeLock.mjs +16 -16
  394. package/dist/esm/hooks/useWakeLock/useWakeLock.mjs.map +1 -1
  395. package/dist/esm/hooks/useWebSocket/useWebSocket.mjs +28 -38
  396. package/dist/esm/hooks/useWebSocket/useWebSocket.mjs.map +1 -1
  397. package/dist/esm/hooks/useWindowEvent/useWindowEvent.mjs.map +1 -1
  398. package/dist/esm/hooks/useWindowFocus/useWindowFocus.mjs.map +1 -1
  399. package/dist/esm/hooks/useWindowScroll/useWindowScroll.mjs.map +1 -1
  400. package/dist/esm/hooks/useWindowSize/useWindowSize.mjs +9 -9
  401. package/dist/esm/hooks/useWindowSize/useWindowSize.mjs.map +1 -1
  402. package/dist/esm/hooks/useWizard/useWizard.mjs +9 -11
  403. package/dist/esm/hooks/useWizard/useWizard.mjs.map +1 -1
  404. package/dist/esm/utils/helpers/copy.mjs.map +1 -1
  405. package/dist/esm/utils/helpers/debounce.mjs.map +1 -1
  406. package/dist/esm/utils/helpers/getDate.mjs.map +1 -1
  407. package/dist/esm/utils/helpers/getElement.mjs.map +1 -1
  408. package/dist/esm/utils/helpers/getRetry.mjs.map +1 -1
  409. package/dist/esm/utils/helpers/isTarget.mjs.map +1 -1
  410. package/dist/esm/utils/helpers/throttle.mjs.map +1 -1
  411. package/dist/types/hooks/useLatest/useLatest.d.ts +7 -2
  412. package/package.json +5 -5
@@ -1,25 +1,24 @@
1
- import { useState as i, useEffect as s } from "react";
2
- import { copy as a } from "../../utils/helpers/copy.mjs";
3
- const v = (o) => {
4
- const [d, n] = i(null), c = (o == null ? void 0 : o.enabled) ?? !1, t = async () => {
5
- var e, r;
1
+ import { useState as a, useEffect as s } from "react";
2
+ import { copy as d } from "../../utils/helpers/copy.mjs";
3
+ const l = (c) => {
4
+ const [r, o] = a(null), n = c?.enabled ?? !1, e = async () => {
6
5
  try {
7
- const u = await navigator.clipboard.readText();
8
- n(u);
6
+ const t = await navigator.clipboard.readText();
7
+ o(t);
9
8
  } catch {
10
- n(((r = (e = document.getSelection) == null ? void 0 : e.call(document)) == null ? void 0 : r.toString()) ?? "");
9
+ o(document.getSelection?.()?.toString() ?? "");
11
10
  }
12
11
  };
13
12
  return s(() => {
14
- if (c)
15
- return document.addEventListener("copy", t), document.addEventListener("cut", t), () => {
16
- document.removeEventListener("copy", t), document.removeEventListener("cut", t);
13
+ if (n)
14
+ return document.addEventListener("copy", e), document.addEventListener("cut", e), () => {
15
+ document.removeEventListener("copy", e), document.removeEventListener("cut", e);
17
16
  };
18
- }, [c]), { value: d, copy: async (e) => {
19
- a(e), n(e);
17
+ }, [n]), { value: r, copy: async (t) => {
18
+ d(t), o(t);
20
19
  } };
21
20
  };
22
21
  export {
23
- v as useClipboard
22
+ l as useClipboard
24
23
  };
25
24
  //# sourceMappingURL=useClipboard.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useClipboard.mjs","sources":["../../../../src/hooks/useClipboard/useClipboard.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport { copy } from '@/utils/helpers';\n\n/** The use copy to clipboard return type */\nexport interface UseCopyToClipboardReturn {\n /** The copied value */\n value: string | null;\n /** Function to copy to clipboard */\n copy: (value: string) => Promise<void>;\n}\n\n/** The use copy to clipboard params type */\nexport interface UseCopyToClipboardParams {\n /** Whether the copy to clipboard is enabled */\n enabled: boolean;\n}\n\n/**\n * @name useClipboard\n * @description - Hook that manages a copy to clipboard\n * @category Browser\n *\n * @browserapi navigator.clipboard https://developer.mozilla.org/en-US/docs/Web/API/Navigator/clipboard\n *\n * @param {boolean} [params.enabled=false] Whether the copy to clipboard is enabled\n * @returns {UseCopyToClipboardReturn} An object containing the boolean state value and utility functions to manipulate the state\n *\n * @example\n * const { value, copy } = useClipboard();\n */\nexport const useClipboard = (params?: UseCopyToClipboardParams): UseCopyToClipboardReturn => {\n const [value, setValue] = useState<string | null>(null);\n const enabled = params?.enabled ?? false;\n\n const set = async () => {\n try {\n const value = await navigator.clipboard.readText();\n setValue(value);\n } catch {\n setValue(document.getSelection?.()?.toString() ?? '');\n }\n };\n\n useEffect(() => {\n if (!enabled) return;\n\n document.addEventListener('copy', set);\n document.addEventListener('cut', set);\n return () => {\n document.removeEventListener('copy', set);\n document.removeEventListener('cut', set);\n };\n }, [enabled]);\n\n const copyToClipboard = async (value: string) => {\n copy(value);\n setValue(value);\n };\n\n return { value, copy: copyToClipboard };\n};\n"],"names":["useClipboard","params","value","setValue","useState","enabled","set","_b","_a","useEffect","copy"],"mappings":";;AA+Ba,MAAAA,IAAe,CAACC,MAAgE;AAC3F,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAwB,IAAI,GAChDC,KAAUJ,KAAA,gBAAAA,EAAQ,YAAW,IAE7BK,IAAM,YAAY;;AAClB,QAAA;AACF,YAAMJ,IAAQ,MAAM,UAAU,UAAU,SAAS;AACjD,MAAAC,EAASD,CAAK;AAAA,IAAA,QACR;AACN,MAAAC,IAASI,KAAAC,IAAA,SAAS,iBAAT,gBAAAA,EAAA,mCAAAD,EAA2B,eAAc,EAAE;AAAA,IAAA;AAAA,EAExD;AAEA,SAAAE,EAAU,MAAM;AACd,QAAKJ;AAEI,sBAAA,iBAAiB,QAAQC,CAAG,GAC5B,SAAA,iBAAiB,OAAOA,CAAG,GAC7B,MAAM;AACF,iBAAA,oBAAoB,QAAQA,CAAG,GAC/B,SAAA,oBAAoB,OAAOA,CAAG;AAAA,MACzC;AAAA,EAAA,GACC,CAACD,CAAO,CAAC,GAOL,EAAE,OAAAH,GAAO,MALQ,OAAOA,MAAkB;AAC/C,IAAAQ,EAAKR,CAAK,GACVC,EAASD,CAAK;AAAA,EAChB,EAEsC;AACxC;"}
1
+ {"version":3,"file":"useClipboard.mjs","sources":["../../../../src/hooks/useClipboard/useClipboard.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport { copy } from '@/utils/helpers';\n\n/** The use copy to clipboard return type */\nexport interface UseCopyToClipboardReturn {\n /** The copied value */\n value: string | null;\n /** Function to copy to clipboard */\n copy: (value: string) => Promise<void>;\n}\n\n/** The use copy to clipboard params type */\nexport interface UseCopyToClipboardParams {\n /** Whether the copy to clipboard is enabled */\n enabled: boolean;\n}\n\n/**\n * @name useClipboard\n * @description - Hook that manages a copy to clipboard\n * @category Browser\n *\n * @browserapi navigator.clipboard https://developer.mozilla.org/en-US/docs/Web/API/Navigator/clipboard\n *\n * @param {boolean} [params.enabled=false] Whether the copy to clipboard is enabled\n * @returns {UseCopyToClipboardReturn} An object containing the boolean state value and utility functions to manipulate the state\n *\n * @example\n * const { value, copy } = useClipboard();\n */\nexport const useClipboard = (params?: UseCopyToClipboardParams): UseCopyToClipboardReturn => {\n const [value, setValue] = useState<string | null>(null);\n const enabled = params?.enabled ?? false;\n\n const set = async () => {\n try {\n const value = await navigator.clipboard.readText();\n setValue(value);\n } catch {\n setValue(document.getSelection?.()?.toString() ?? '');\n }\n };\n\n useEffect(() => {\n if (!enabled) return;\n\n document.addEventListener('copy', set);\n document.addEventListener('cut', set);\n return () => {\n document.removeEventListener('copy', set);\n document.removeEventListener('cut', set);\n };\n }, [enabled]);\n\n const copyToClipboard = async (value: string) => {\n copy(value);\n setValue(value);\n };\n\n return { value, copy: copyToClipboard };\n};\n"],"names":["useClipboard","params","value","setValue","useState","enabled","set","useEffect","copy"],"mappings":";;AA+BO,MAAMA,IAAe,CAACC,MAAgE;AAC3F,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAwB,IAAI,GAChDC,IAAUJ,GAAQ,WAAW,IAE7BK,IAAM,YAAY;AACtB,QAAI;AACF,YAAMJ,IAAQ,MAAM,UAAU,UAAU,SAAA;AACxC,MAAAC,EAASD,CAAK;AAAA,IAAA,QACR;AACN,MAAAC,EAAS,SAAS,eAAA,GAAkB,SAAA,KAAc,EAAE;AAAA,IAAA;AAAA,EACtD;AAGF,SAAAI,EAAU,MAAM;AACd,QAAKF;AAEL,sBAAS,iBAAiB,QAAQC,CAAG,GACrC,SAAS,iBAAiB,OAAOA,CAAG,GAC7B,MAAM;AACX,iBAAS,oBAAoB,QAAQA,CAAG,GACxC,SAAS,oBAAoB,OAAOA,CAAG;AAAA,MAAA;AAAA,EACzC,GACC,CAACD,CAAO,CAAC,GAOL,EAAE,OAAAH,GAAO,MALQ,OAAOA,MAAkB;AAC/C,IAAAM,EAAKN,CAAK,GACVC,EAASD,CAAK;AAAA,EAAA,EAGM;AACxB;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useConst.mjs","sources":["../../../../src/hooks/useConst/useConst.ts"],"sourcesContent":["import { useRef } from 'react';\n\n/**\n * @name useConst\n * @description - Hook that returns the constant value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {(() => Value) | Value} initialValue The initial value of the constant\n * @returns {Value} The constant value\n *\n * @example\n * const value = useConst('value');\n */\nexport const useConst = <Value>(initialValue: (() => Value) | Value) =>\n useRef<Value>(typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue)\n .current;\n"],"names":["useConst","initialValue","useRef"],"mappings":";AAca,MAAAA,IAAW,CAAQC,MAC9BC,EAAc,OAAOD,KAAiB,aAAcA,MAAiCA,CAAY,EAC9F;"}
1
+ {"version":3,"file":"useConst.mjs","sources":["../../../../src/hooks/useConst/useConst.ts"],"sourcesContent":["import { useRef } from 'react';\n\n/**\n * @name useConst\n * @description - Hook that returns the constant value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {(() => Value) | Value} initialValue The initial value of the constant\n * @returns {Value} The constant value\n *\n * @example\n * const value = useConst('value');\n */\nexport const useConst = <Value>(initialValue: (() => Value) | Value) =>\n useRef<Value>(typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue)\n .current;\n"],"names":["useConst","initialValue","useRef"],"mappings":";AAcO,MAAMA,IAAW,CAAQC,MAC9BC,EAAc,OAAOD,KAAiB,aAAcA,MAAiCA,CAAY,EAC9F;"}
@@ -1,26 +1,26 @@
1
1
  import { useState as l, useEffect as $ } from "react";
2
- const C = () => Object.fromEntries(
2
+ const p = () => Object.fromEntries(
3
3
  document.cookie.split("; ").map((n) => {
4
- const [t, ...e] = n.split("="), r = decodeURIComponent(e.join("="));
5
- return [t, r];
4
+ const [e, ...t] = n.split("="), o = decodeURIComponent(t.join("="));
5
+ return [e, o];
6
6
  })
7
- ), v = (n, t = {}) => {
8
- document.cookie = `${encodeURIComponent(n)}=; expires=Thu, 01 Jan 1970 00:00:00 GMT${t.path ? `; path=${t.path}` : ""}${t.domain ? `; domain=${t.domain}` : ""}${t.maxAge ? "; max-age=0" : ""}${t.expires ? "; expires=Thu, 01 Jan 1970 00:00:00 GMT" : ""}${t.secure ? "; secure" : ""}${t.sameSite ? `; samesite=${t.sameSite}` : ""}`;
9
- }, k = (n, t, e = {}) => {
10
- const r = [`${encodeURIComponent(n)}=${encodeURIComponent(t)}`];
11
- e.path && r.push(`path=${e.path}`), e.domain && r.push(`domain=${e.domain}`), typeof e.maxAge == "number" && r.push(`max-age=${e.maxAge}`), e.expires && r.push(`expires=${e.expires.toUTCString()}`), e.secure && r.push("secure"), e.httpOnly && r.push("httpOnly"), e.sameSite && r.push(`samesite=${e.sameSite}`), document.cookie = r.join("; ");
12
- }, c = "reactuse-cookie", m = () => window.dispatchEvent(new Event(c)), a = (n, t, e) => {
13
- k(n, t, e), m();
14
- }, x = (n, t) => {
15
- v(n, t), m();
16
- }, d = (n) => C()[n], z = (n, t) => {
17
- const e = typeof t == "object" && t && ("serializer" in t || "deserializer" in t || "initialValue" in t) ? t : void 0, r = e ? e == null ? void 0 : e.initialValue : t;
7
+ ), C = (n, e = {}) => {
8
+ document.cookie = `${encodeURIComponent(n)}=; expires=Thu, 01 Jan 1970 00:00:00 GMT${e.path ? `; path=${e.path}` : ""}${e.domain ? `; domain=${e.domain}` : ""}${e.maxAge ? "; max-age=0" : ""}${e.expires ? "; expires=Thu, 01 Jan 1970 00:00:00 GMT" : ""}${e.secure ? "; secure" : ""}${e.sameSite ? `; samesite=${e.sameSite}` : ""}`;
9
+ }, v = (n, e, t = {}) => {
10
+ const o = [`${encodeURIComponent(n)}=${encodeURIComponent(e)}`];
11
+ t.path && o.push(`path=${t.path}`), t.domain && o.push(`domain=${t.domain}`), typeof t.maxAge == "number" && o.push(`max-age=${t.maxAge}`), t.expires && o.push(`expires=${t.expires.toUTCString()}`), t.secure && o.push("secure"), t.httpOnly && o.push("httpOnly"), t.sameSite && o.push(`samesite=${t.sameSite}`), document.cookie = o.join("; ");
12
+ }, c = "reactuse-cookie", m = () => window.dispatchEvent(new Event(c)), a = (n, e, t) => {
13
+ v(n, e, t), m();
14
+ }, k = (n, e) => {
15
+ C(n, e), m();
16
+ }, d = (n) => p()[n], z = (n, e) => {
17
+ const t = typeof e == "object" && e && ("serializer" in e || "deserializer" in e || "initialValue" in e) ? e : void 0, o = t ? t?.initialValue : e;
18
18
  if (typeof document > "u")
19
19
  return {
20
- value: typeof r == "function" ? r() : r
20
+ value: typeof o == "function" ? o() : o
21
21
  };
22
- const s = (i) => e != null && e.serializer ? e.serializer(i) : typeof i == "string" ? i : JSON.stringify(i), u = (i) => {
23
- if (e != null && e.deserializer) return e.deserializer(i);
22
+ const s = (i) => t?.serializer ? t.serializer(i) : typeof i == "string" ? i : JSON.stringify(i), u = (i) => {
23
+ if (t?.deserializer) return t.deserializer(i);
24
24
  if (i !== "undefined")
25
25
  try {
26
26
  return JSON.parse(i);
@@ -29,28 +29,28 @@ const C = () => Object.fromEntries(
29
29
  }
30
30
  }, [f, h] = l(() => {
31
31
  const i = d(n);
32
- if (i === void 0 && r !== void 0) {
33
- const o = typeof r == "function" ? r() : r;
34
- return a(n, s(o), e), o;
32
+ if (i === void 0 && o !== void 0) {
33
+ const r = typeof o == "function" ? o() : o;
34
+ return a(n, s(r), t), r;
35
35
  }
36
36
  return i ? u(i) : void 0;
37
37
  });
38
38
  return $(() => {
39
39
  const i = () => {
40
- const o = d(n);
41
- h(o ? u(o) : void 0);
40
+ const r = d(n);
41
+ h(r ? u(r) : void 0);
42
42
  };
43
43
  return window.addEventListener(c, i), () => window.removeEventListener(c, i);
44
- }, [n]), { value: f, set: (i, o) => a(n, s(i), { ...e, ...o }), remove: (i) => x(n, { ...e, ...i }) };
44
+ }, [n]), { value: f, set: (i, r) => a(n, s(i), { ...t, ...r }), remove: (i) => k(n, { ...t, ...i }) };
45
45
  };
46
46
  export {
47
47
  c as COOKIE_EVENT,
48
48
  m as dispatchCookieEvent,
49
49
  d as getCookie,
50
- C as getCookies,
51
- v as removeCookie,
52
- x as removeCookieItem,
53
- k as setCookie,
50
+ p as getCookies,
51
+ C as removeCookie,
52
+ k as removeCookieItem,
53
+ v as setCookie,
54
54
  a as setCookieItem,
55
55
  z as useCookie
56
56
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useCookie.mjs","sources":["../../../../src/hooks/useCookie/useCookie.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nexport const getCookies = () =>\n Object.fromEntries(\n document.cookie.split('; ').map((cookie) => {\n const [key, ...value] = cookie.split('=');\n const decodedValue = decodeURIComponent(value.join('='));\n return [key, decodedValue];\n })\n );\n\nexport interface RemoveCookieParams {\n domain?: string;\n expires?: Date;\n maxAge?: number;\n path?: string;\n sameSite?: 'Lax' | 'None' | 'Strict';\n secure?: boolean;\n}\n\nexport const removeCookie = (key: string, options: RemoveCookieParams = {}) => {\n document.cookie = `${encodeURIComponent(key)}=; expires=Thu, 01 Jan 1970 00:00:00 GMT${\n options.path ? `; path=${options.path}` : ''\n }${options.domain ? `; domain=${options.domain}` : ''}${\n options.maxAge ? `; max-age=0` : ''\n }${options.expires ? `; expires=Thu, 01 Jan 1970 00:00:00 GMT` : ''}${\n options.secure ? `; secure` : ''\n }${options.sameSite ? `; samesite=${options.sameSite}` : ''}`;\n};\n\nexport interface SetCookieParams {\n domain?: string;\n expires?: Date;\n httpOnly?: boolean;\n maxAge?: number;\n path?: string;\n sameSite?: 'Lax' | 'None' | 'Strict';\n secure?: boolean;\n}\n\nexport const setCookie = (key: string, value: string, options: SetCookieParams = {}) => {\n const cookie = [`${encodeURIComponent(key)}=${encodeURIComponent(value)}`];\n\n if (options.path) cookie.push(`path=${options.path}`);\n if (options.domain) cookie.push(`domain=${options.domain}`);\n if (typeof options.maxAge === 'number') cookie.push(`max-age=${options.maxAge}`);\n if (options.expires) cookie.push(`expires=${options.expires.toUTCString()}`);\n if (options.secure) cookie.push(`secure`);\n if (options.httpOnly) cookie.push(`httpOnly`);\n if (options.sameSite) cookie.push(`samesite=${options.sameSite}`);\n\n document.cookie = cookie.join('; ');\n};\n\n/* The use cookie initial value type */\nexport type UseCookieInitialValue<Value> = (() => Value) | Value;\n\n/* The use cookie options type */\nexport interface UseCookieOptions<Value> {\n /* The domain of the cookie */\n domain?: string;\n /* The expiration date of the cookie */\n expires?: Date;\n /* Whether the cookie is httpOnly */\n httpOnly?: boolean;\n /* The initial value of the storage */\n initialValue?: UseCookieInitialValue<Value>;\n /* The maximum age of the cookie */\n maxAge?: number;\n /* The path of the cookie */\n path?: string;\n /* The sameSite of the cookie */\n sameSite?: 'Lax' | 'None' | 'Strict';\n /* Whether the cookie is secure */\n secure?: boolean;\n /* The deserializer function to be invoked */\n deserializer?: (value: string) => Value;\n /* The serializer function to be invoked */\n serializer?: (value: Value) => string;\n}\n\n/* The use cookie return type */\nexport interface UseCookieReturn<Value> {\n /* The value of the cookie */\n value: Value;\n /* The remove function */\n remove: (options?: RemoveCookieParams) => void;\n /* The set function */\n set: (value: Value, options?: SetCookieParams) => void;\n}\n\nexport const COOKIE_EVENT = 'reactuse-cookie';\n\nexport const dispatchCookieEvent = () => window.dispatchEvent(new Event(COOKIE_EVENT));\n\nexport const setCookieItem = (key: string, value: string, options?: SetCookieParams) => {\n setCookie(key, value, options);\n dispatchCookieEvent();\n};\n\nexport const removeCookieItem = (key: string, options?: RemoveCookieParams) => {\n removeCookie(key, options);\n dispatchCookieEvent();\n};\n\nexport const getCookie = (key: string): string | undefined => {\n const cookies = getCookies();\n return cookies[key];\n};\n\nexport interface UseCookie {\n <Value>(\n key: string,\n options: UseCookieOptions<Value> & {\n initialValue: UseCookieInitialValue<Value>;\n }\n ): UseCookieReturn<Value>;\n\n <Value>(key: string, options?: UseCookieOptions<Value>): UseCookieReturn<Value | undefined>;\n\n <Value>(key: string, initialValue: UseCookieInitialValue<Value>): UseCookieReturn<Value>;\n\n <Value>(key: string): UseCookieReturn<Value | undefined>;\n}\n\n/**\n * @name useCookie\n * @description - Hook that manages cookie value\n * @category Browser\n *\n * @overload\n * @template Value The type of the cookie value\n * @param {string} key The key of the cookie\n * @param {UseCookieInitialValue<Value>} [initialValue] The initial value of the cookie\n * @returns {UseCookieReturn<Value>} The value and the set function\n *\n * @overload\n * @template Value The type of the cookie value\n * @param {string} key The key of the cookie\n * @param {UseCookieOptions<Value>} options The options object\n * @param {UseCookieInitialValue<Value>} [options.initialValue] The initial value of the cookie\n * @param {(value: string) => Value} [options.deserializer] The deserializer function to be invoked\n * @param {(value: Value) => string} [options.serializer] The serializer function to be invoked\n * @returns {UseCookieReturn<Value | undefined>} The value and the set function\n *\n * @example\n * const { value, set, remove } = useCookie('key', 'value');\n */\nexport const useCookie = (<Value>(key: string, params?: any) => {\n const options = (\n typeof params === 'object' &&\n params &&\n ('serializer' in params || 'deserializer' in params || 'initialValue' in params)\n ? params\n : undefined\n ) as UseCookieOptions<Value>;\n const initialValue = (options ? options?.initialValue : params) as UseCookieInitialValue<Value>;\n\n if (typeof document === 'undefined')\n return {\n value: typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue\n } as UseCookieReturn<Value>;\n\n const serializer = (value: Value) => {\n if (options?.serializer) return options.serializer(value);\n if (typeof value === 'string') return value;\n return JSON.stringify(value);\n };\n\n const deserializer = (value: string) => {\n if (options?.deserializer) return options.deserializer(value);\n if (value === 'undefined') return undefined as unknown as Value;\n\n try {\n return JSON.parse(value) as Value;\n } catch {\n return value as Value;\n }\n };\n\n const [value, setValue] = useState<Value | undefined>(() => {\n const cookieValue = getCookie(key);\n if (cookieValue === undefined && initialValue !== undefined) {\n const value =\n typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue;\n setCookieItem(key, serializer(value), options);\n return value;\n }\n return cookieValue ? deserializer(cookieValue) : undefined;\n });\n\n useEffect(() => {\n const onChange = () => {\n const cookieValue = getCookie(key);\n setValue(cookieValue ? deserializer(cookieValue) : undefined);\n };\n window.addEventListener(COOKIE_EVENT, onChange);\n return () => window.removeEventListener(COOKIE_EVENT, onChange);\n }, [key]);\n\n const set = (value: Value, params?: SetCookieParams) =>\n setCookieItem(key, serializer(value), { ...options, ...params });\n const remove = (params?: RemoveCookieParams) => removeCookieItem(key, { ...options, ...params });\n\n return { value, set, remove };\n}) as UseCookie;\n"],"names":["getCookies","cookie","key","value","decodedValue","removeCookie","options","setCookie","COOKIE_EVENT","dispatchCookieEvent","setCookieItem","removeCookieItem","getCookie","useCookie","params","initialValue","serializer","deserializer","setValue","useState","cookieValue","useEffect","onChange"],"mappings":";AAEa,MAAAA,IAAa,MACxB,OAAO;AAAA,EACL,SAAS,OAAO,MAAM,IAAI,EAAE,IAAI,CAACC,MAAW;AAC1C,UAAM,CAACC,GAAK,GAAGC,CAAK,IAAIF,EAAO,MAAM,GAAG,GAClCG,IAAe,mBAAmBD,EAAM,KAAK,GAAG,CAAC;AAChD,WAAA,CAACD,GAAKE,CAAY;AAAA,EAC1B,CAAA;AACH,GAWWC,IAAe,CAACH,GAAaI,IAA8B,OAAO;AAC7E,WAAS,SAAS,GAAG,mBAAmBJ,CAAG,CAAC,2CAC1CI,EAAQ,OAAO,UAAUA,EAAQ,IAAI,KAAK,EAC5C,GAAGA,EAAQ,SAAS,YAAYA,EAAQ,MAAM,KAAK,EAAE,GACnDA,EAAQ,SAAS,gBAAgB,EACnC,GAAGA,EAAQ,UAAU,4CAA4C,EAAE,GACjEA,EAAQ,SAAS,aAAa,EAChC,GAAGA,EAAQ,WAAW,cAAcA,EAAQ,QAAQ,KAAK,EAAE;AAC7D,GAYaC,IAAY,CAACL,GAAaC,GAAeG,IAA2B,CAAA,MAAO;AAChF,QAAAL,IAAS,CAAC,GAAG,mBAAmBC,CAAG,CAAC,IAAI,mBAAmBC,CAAK,CAAC,EAAE;AAEzE,EAAIG,EAAQ,QAAML,EAAO,KAAK,QAAQK,EAAQ,IAAI,EAAE,GAChDA,EAAQ,UAAQL,EAAO,KAAK,UAAUK,EAAQ,MAAM,EAAE,GACtD,OAAOA,EAAQ,UAAW,cAAiB,KAAK,WAAWA,EAAQ,MAAM,EAAE,GAC3EA,EAAQ,WAAgBL,EAAA,KAAK,WAAWK,EAAQ,QAAQ,YAAa,CAAA,EAAE,GACvEA,EAAQ,UAAeL,EAAA,KAAK,QAAQ,GACpCK,EAAQ,YAAiBL,EAAA,KAAK,UAAU,GACxCK,EAAQ,YAAUL,EAAO,KAAK,YAAYK,EAAQ,QAAQ,EAAE,GAEvD,SAAA,SAASL,EAAO,KAAK,IAAI;AACpC,GAuCaO,IAAe,mBAEfC,IAAsB,MAAM,OAAO,cAAc,IAAI,MAAMD,CAAY,CAAC,GAExEE,IAAgB,CAACR,GAAaC,GAAeG,MAA8B;AAC5E,EAAAC,EAAAL,GAAKC,GAAOG,CAAO,GACTG,EAAA;AACtB,GAEaE,IAAmB,CAACT,GAAaI,MAAiC;AAC7E,EAAAD,EAAaH,GAAKI,CAAO,GACLG,EAAA;AACtB,GAEaG,IAAY,CAACV,MACRF,EAAW,EACZE,CAAG,GAyCPW,IAAa,CAAQX,GAAaY,MAAiB;AACxD,QAAAR,IACJ,OAAOQ,KAAW,YAClBA,MACC,gBAAgBA,KAAU,kBAAkBA,KAAU,kBAAkBA,KACrEA,IACA,QAEAC,IAAgBT,IAAUA,KAAA,gBAAAA,EAAS,eAAeQ;AAExD,MAAI,OAAO,WAAa;AACf,WAAA;AAAA,MACL,OAAO,OAAOC,KAAiB,aAAcA,MAAiCA;AAAA,IAChF;AAEI,QAAAC,IAAa,CAACb,MACdG,KAAA,QAAAA,EAAS,aAAmBA,EAAQ,WAAWH,CAAK,IACpD,OAAOA,KAAU,WAAiBA,IAC/B,KAAK,UAAUA,CAAK,GAGvBc,IAAe,CAACd,MAAkB;AACtC,QAAIG,KAAA,QAAAA,EAAS,aAAqB,QAAAA,EAAQ,aAAaH,CAAK;AACxDA,QAAAA,MAAU;AAEV,UAAA;AACK,eAAA,KAAK,MAAMA,CAAK;AAAA,MAAA,QACjB;AACCA,eAAAA;AAAAA,MAAA;AAAA,EAEX,GAEM,CAACA,GAAOe,CAAQ,IAAIC,EAA4B,MAAM;AACpD,UAAAC,IAAcR,EAAUV,CAAG;AAC7B,QAAAkB,MAAgB,UAAaL,MAAiB,QAAW;AAC3D,YAAMZ,IACJ,OAAOY,KAAiB,aAAcA,EAAiC,IAAAA;AACzE,aAAAL,EAAcR,GAAKc,EAAWb,CAAK,GAAGG,CAAO,GACtCH;AAAAA,IAAA;AAEF,WAAAiB,IAAcH,EAAaG,CAAW,IAAI;AAAA,EAAA,CAClD;AAED,SAAAC,EAAU,MAAM;AACd,UAAMC,IAAW,MAAM;AACf,YAAAF,IAAcR,EAAUV,CAAG;AACjC,MAAAgB,EAASE,IAAcH,EAAaG,CAAW,IAAI,MAAS;AAAA,IAC9D;AACO,kBAAA,iBAAiBZ,GAAcc,CAAQ,GACvC,MAAM,OAAO,oBAAoBd,GAAcc,CAAQ;AAAA,EAAA,GAC7D,CAACpB,CAAG,CAAC,GAMD,EAAE,OAAAC,GAAO,KAJJ,CAACA,GAAcW,MACzBJ,EAAcR,GAAKc,EAAWb,CAAK,GAAG,EAAE,GAAGG,GAAS,GAAGQ,GAAQ,GAG5C,QAFN,CAACA,MAAgCH,EAAiBT,GAAK,EAAE,GAAGI,GAAS,GAAGQ,GAAQ,EAEnE;AAC9B;"}
1
+ {"version":3,"file":"useCookie.mjs","sources":["../../../../src/hooks/useCookie/useCookie.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nexport const getCookies = () =>\n Object.fromEntries(\n document.cookie.split('; ').map((cookie) => {\n const [key, ...value] = cookie.split('=');\n const decodedValue = decodeURIComponent(value.join('='));\n return [key, decodedValue];\n })\n );\n\nexport interface RemoveCookieParams {\n domain?: string;\n expires?: Date;\n maxAge?: number;\n path?: string;\n sameSite?: 'Lax' | 'None' | 'Strict';\n secure?: boolean;\n}\n\nexport const removeCookie = (key: string, options: RemoveCookieParams = {}) => {\n document.cookie = `${encodeURIComponent(key)}=; expires=Thu, 01 Jan 1970 00:00:00 GMT${\n options.path ? `; path=${options.path}` : ''\n }${options.domain ? `; domain=${options.domain}` : ''}${\n options.maxAge ? `; max-age=0` : ''\n }${options.expires ? `; expires=Thu, 01 Jan 1970 00:00:00 GMT` : ''}${\n options.secure ? `; secure` : ''\n }${options.sameSite ? `; samesite=${options.sameSite}` : ''}`;\n};\n\nexport interface SetCookieParams {\n domain?: string;\n expires?: Date;\n httpOnly?: boolean;\n maxAge?: number;\n path?: string;\n sameSite?: 'Lax' | 'None' | 'Strict';\n secure?: boolean;\n}\n\nexport const setCookie = (key: string, value: string, options: SetCookieParams = {}) => {\n const cookie = [`${encodeURIComponent(key)}=${encodeURIComponent(value)}`];\n\n if (options.path) cookie.push(`path=${options.path}`);\n if (options.domain) cookie.push(`domain=${options.domain}`);\n if (typeof options.maxAge === 'number') cookie.push(`max-age=${options.maxAge}`);\n if (options.expires) cookie.push(`expires=${options.expires.toUTCString()}`);\n if (options.secure) cookie.push(`secure`);\n if (options.httpOnly) cookie.push(`httpOnly`);\n if (options.sameSite) cookie.push(`samesite=${options.sameSite}`);\n\n document.cookie = cookie.join('; ');\n};\n\n/* The use cookie initial value type */\nexport type UseCookieInitialValue<Value> = (() => Value) | Value;\n\n/* The use cookie options type */\nexport interface UseCookieOptions<Value> {\n /* The domain of the cookie */\n domain?: string;\n /* The expiration date of the cookie */\n expires?: Date;\n /* Whether the cookie is httpOnly */\n httpOnly?: boolean;\n /* The initial value of the storage */\n initialValue?: UseCookieInitialValue<Value>;\n /* The maximum age of the cookie */\n maxAge?: number;\n /* The path of the cookie */\n path?: string;\n /* The sameSite of the cookie */\n sameSite?: 'Lax' | 'None' | 'Strict';\n /* Whether the cookie is secure */\n secure?: boolean;\n /* The deserializer function to be invoked */\n deserializer?: (value: string) => Value;\n /* The serializer function to be invoked */\n serializer?: (value: Value) => string;\n}\n\n/* The use cookie return type */\nexport interface UseCookieReturn<Value> {\n /* The value of the cookie */\n value: Value;\n /* The remove function */\n remove: (options?: RemoveCookieParams) => void;\n /* The set function */\n set: (value: Value, options?: SetCookieParams) => void;\n}\n\nexport const COOKIE_EVENT = 'reactuse-cookie';\n\nexport const dispatchCookieEvent = () => window.dispatchEvent(new Event(COOKIE_EVENT));\n\nexport const setCookieItem = (key: string, value: string, options?: SetCookieParams) => {\n setCookie(key, value, options);\n dispatchCookieEvent();\n};\n\nexport const removeCookieItem = (key: string, options?: RemoveCookieParams) => {\n removeCookie(key, options);\n dispatchCookieEvent();\n};\n\nexport const getCookie = (key: string): string | undefined => {\n const cookies = getCookies();\n return cookies[key];\n};\n\nexport interface UseCookie {\n <Value>(\n key: string,\n options: UseCookieOptions<Value> & {\n initialValue: UseCookieInitialValue<Value>;\n }\n ): UseCookieReturn<Value>;\n\n <Value>(key: string, options?: UseCookieOptions<Value>): UseCookieReturn<Value | undefined>;\n\n <Value>(key: string, initialValue: UseCookieInitialValue<Value>): UseCookieReturn<Value>;\n\n <Value>(key: string): UseCookieReturn<Value | undefined>;\n}\n\n/**\n * @name useCookie\n * @description - Hook that manages cookie value\n * @category Browser\n *\n * @overload\n * @template Value The type of the cookie value\n * @param {string} key The key of the cookie\n * @param {UseCookieInitialValue<Value>} [initialValue] The initial value of the cookie\n * @returns {UseCookieReturn<Value>} The value and the set function\n *\n * @overload\n * @template Value The type of the cookie value\n * @param {string} key The key of the cookie\n * @param {UseCookieOptions<Value>} options The options object\n * @param {UseCookieInitialValue<Value>} [options.initialValue] The initial value of the cookie\n * @param {(value: string) => Value} [options.deserializer] The deserializer function to be invoked\n * @param {(value: Value) => string} [options.serializer] The serializer function to be invoked\n * @returns {UseCookieReturn<Value | undefined>} The value and the set function\n *\n * @example\n * const { value, set, remove } = useCookie('key', 'value');\n */\nexport const useCookie = (<Value>(key: string, params?: any) => {\n const options = (\n typeof params === 'object' &&\n params &&\n ('serializer' in params || 'deserializer' in params || 'initialValue' in params)\n ? params\n : undefined\n ) as UseCookieOptions<Value>;\n const initialValue = (options ? options?.initialValue : params) as UseCookieInitialValue<Value>;\n\n if (typeof document === 'undefined')\n return {\n value: typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue\n } as UseCookieReturn<Value>;\n\n const serializer = (value: Value) => {\n if (options?.serializer) return options.serializer(value);\n if (typeof value === 'string') return value;\n return JSON.stringify(value);\n };\n\n const deserializer = (value: string) => {\n if (options?.deserializer) return options.deserializer(value);\n if (value === 'undefined') return undefined as unknown as Value;\n\n try {\n return JSON.parse(value) as Value;\n } catch {\n return value as Value;\n }\n };\n\n const [value, setValue] = useState<Value | undefined>(() => {\n const cookieValue = getCookie(key);\n if (cookieValue === undefined && initialValue !== undefined) {\n const value =\n typeof initialValue === 'function' ? (initialValue as () => Value)() : initialValue;\n setCookieItem(key, serializer(value), options);\n return value;\n }\n return cookieValue ? deserializer(cookieValue) : undefined;\n });\n\n useEffect(() => {\n const onChange = () => {\n const cookieValue = getCookie(key);\n setValue(cookieValue ? deserializer(cookieValue) : undefined);\n };\n window.addEventListener(COOKIE_EVENT, onChange);\n return () => window.removeEventListener(COOKIE_EVENT, onChange);\n }, [key]);\n\n const set = (value: Value, params?: SetCookieParams) =>\n setCookieItem(key, serializer(value), { ...options, ...params });\n const remove = (params?: RemoveCookieParams) => removeCookieItem(key, { ...options, ...params });\n\n return { value, set, remove };\n}) as UseCookie;\n"],"names":["getCookies","cookie","key","value","decodedValue","removeCookie","options","setCookie","COOKIE_EVENT","dispatchCookieEvent","setCookieItem","removeCookieItem","getCookie","useCookie","params","initialValue","serializer","deserializer","setValue","useState","cookieValue","useEffect","onChange"],"mappings":";AAEO,MAAMA,IAAa,MACxB,OAAO;AAAA,EACL,SAAS,OAAO,MAAM,IAAI,EAAE,IAAI,CAACC,MAAW;AAC1C,UAAM,CAACC,GAAK,GAAGC,CAAK,IAAIF,EAAO,MAAM,GAAG,GAClCG,IAAe,mBAAmBD,EAAM,KAAK,GAAG,CAAC;AACvD,WAAO,CAACD,GAAKE,CAAY;AAAA,EAAA,CAC1B;AACH,GAWWC,IAAe,CAACH,GAAaI,IAA8B,OAAO;AAC7E,WAAS,SAAS,GAAG,mBAAmBJ,CAAG,CAAC,2CAC1CI,EAAQ,OAAO,UAAUA,EAAQ,IAAI,KAAK,EAC5C,GAAGA,EAAQ,SAAS,YAAYA,EAAQ,MAAM,KAAK,EAAE,GACnDA,EAAQ,SAAS,gBAAgB,EACnC,GAAGA,EAAQ,UAAU,4CAA4C,EAAE,GACjEA,EAAQ,SAAS,aAAa,EAChC,GAAGA,EAAQ,WAAW,cAAcA,EAAQ,QAAQ,KAAK,EAAE;AAC7D,GAYaC,IAAY,CAACL,GAAaC,GAAeG,IAA2B,CAAA,MAAO;AACtF,QAAML,IAAS,CAAC,GAAG,mBAAmBC,CAAG,CAAC,IAAI,mBAAmBC,CAAK,CAAC,EAAE;AAEzE,EAAIG,EAAQ,QAAML,EAAO,KAAK,QAAQK,EAAQ,IAAI,EAAE,GAChDA,EAAQ,UAAQL,EAAO,KAAK,UAAUK,EAAQ,MAAM,EAAE,GACtD,OAAOA,EAAQ,UAAW,cAAiB,KAAK,WAAWA,EAAQ,MAAM,EAAE,GAC3EA,EAAQ,WAASL,EAAO,KAAK,WAAWK,EAAQ,QAAQ,YAAA,CAAa,EAAE,GACvEA,EAAQ,UAAQL,EAAO,KAAK,QAAQ,GACpCK,EAAQ,YAAUL,EAAO,KAAK,UAAU,GACxCK,EAAQ,YAAUL,EAAO,KAAK,YAAYK,EAAQ,QAAQ,EAAE,GAEhE,SAAS,SAASL,EAAO,KAAK,IAAI;AACpC,GAuCaO,IAAe,mBAEfC,IAAsB,MAAM,OAAO,cAAc,IAAI,MAAMD,CAAY,CAAC,GAExEE,IAAgB,CAACR,GAAaC,GAAeG,MAA8B;AACtF,EAAAC,EAAUL,GAAKC,GAAOG,CAAO,GAC7BG,EAAA;AACF,GAEaE,IAAmB,CAACT,GAAaI,MAAiC;AAC7E,EAAAD,EAAaH,GAAKI,CAAO,GACzBG,EAAA;AACF,GAEaG,IAAY,CAACV,MACRF,EAAA,EACDE,CAAG,GAyCPW,IAAa,CAAQX,GAAaY,MAAiB;AAC9D,QAAMR,IACJ,OAAOQ,KAAW,YAClBA,MACC,gBAAgBA,KAAU,kBAAkBA,KAAU,kBAAkBA,KACrEA,IACA,QAEAC,IAAgBT,IAAUA,GAAS,eAAeQ;AAExD,MAAI,OAAO,WAAa;AACtB,WAAO;AAAA,MACL,OAAO,OAAOC,KAAiB,aAAcA,MAAiCA;AAAA,IAAA;AAGlF,QAAMC,IAAa,CAACb,MACdG,GAAS,aAAmBA,EAAQ,WAAWH,CAAK,IACpD,OAAOA,KAAU,WAAiBA,IAC/B,KAAK,UAAUA,CAAK,GAGvBc,IAAe,CAACd,MAAkB;AACtC,QAAIG,GAAS,aAAc,QAAOA,EAAQ,aAAaH,CAAK;AAC5D,QAAIA,MAAU;AAEd,UAAI;AACF,eAAO,KAAK,MAAMA,CAAK;AAAA,MAAA,QACjB;AACN,eAAOA;AAAAA,MAAA;AAAA,EACT,GAGI,CAACA,GAAOe,CAAQ,IAAIC,EAA4B,MAAM;AAC1D,UAAMC,IAAcR,EAAUV,CAAG;AACjC,QAAIkB,MAAgB,UAAaL,MAAiB,QAAW;AAC3D,YAAMZ,IACJ,OAAOY,KAAiB,aAAcA,MAAiCA;AACzE,aAAAL,EAAcR,GAAKc,EAAWb,CAAK,GAAGG,CAAO,GACtCH;AAAAA,IAAA;AAET,WAAOiB,IAAcH,EAAaG,CAAW,IAAI;AAAA,EAAA,CAClD;AAED,SAAAC,EAAU,MAAM;AACd,UAAMC,IAAW,MAAM;AACrB,YAAMF,IAAcR,EAAUV,CAAG;AACjC,MAAAgB,EAASE,IAAcH,EAAaG,CAAW,IAAI,MAAS;AAAA,IAAA;AAE9D,kBAAO,iBAAiBZ,GAAcc,CAAQ,GACvC,MAAM,OAAO,oBAAoBd,GAAcc,CAAQ;AAAA,EAAA,GAC7D,CAACpB,CAAG,CAAC,GAMD,EAAE,OAAAC,GAAO,KAJJ,CAACA,GAAcW,MACzBJ,EAAcR,GAAKc,EAAWb,CAAK,GAAG,EAAE,GAAGG,GAAS,GAAGQ,GAAQ,GAG5C,QAFN,CAACA,MAAgCH,EAAiBT,GAAK,EAAE,GAAGI,GAAS,GAAGQ,GAAQ,EAE1E;AACvB;"}
@@ -1,15 +1,15 @@
1
1
  import { useState as l, useEffect as m } from "react";
2
- import { removeCookie as a, COOKIE_EVENT as c, removeCookieItem as k, setCookieItem as C, dispatchCookieEvent as E } from "../useCookie/useCookie.mjs";
3
- const g = () => {
4
- document.cookie.split("; ").forEach((r) => {
5
- const [o] = r.split("=");
6
- a(o);
2
+ import { removeCookie as a, COOKIE_EVENT as s, removeCookieItem as k, setCookieItem as C, dispatchCookieEvent as p } from "../useCookie/useCookie.mjs";
3
+ const E = () => {
4
+ document.cookie.split("; ").forEach((t) => {
5
+ const [n] = t.split("=");
6
+ a(n);
7
7
  });
8
- }, h = () => {
9
- g(), E();
10
- }, N = (r) => {
11
- const o = (e) => r != null && r.serializer ? r.serializer(e) : typeof e == "string" ? e : JSON.stringify(e), s = (e) => {
12
- if (r != null && r.deserializer) return r.deserializer(e);
8
+ }, g = () => {
9
+ E(), p();
10
+ }, O = (t) => {
11
+ const n = (e) => t?.serializer ? t.serializer(e) : typeof e == "string" ? e : JSON.stringify(e), c = (e) => {
12
+ if (t?.deserializer) return t.deserializer(e);
13
13
  if (e !== "undefined")
14
14
  try {
15
15
  return JSON.parse(e);
@@ -18,21 +18,21 @@ const g = () => {
18
18
  }
19
19
  }, i = () => document.cookie ? Object.fromEntries(
20
20
  document.cookie.split("; ").map((e) => {
21
- const [t, ...n] = e.split("=");
22
- if (!t || !n.length) return [];
23
- const f = decodeURIComponent(n.join("="));
24
- return [t, s(f)];
21
+ const [r, ...o] = e.split("=");
22
+ if (!r || !o.length) return [];
23
+ const f = decodeURIComponent(o.join("="));
24
+ return [r, c(f)];
25
25
  }).filter((e) => e.length)
26
26
  ) : {}, [d, u] = l(() => typeof window > "u" ? {} : i());
27
27
  return m(() => {
28
28
  const e = () => u(i());
29
- return window.addEventListener(c, e), () => {
30
- window.removeEventListener(c, e);
29
+ return window.addEventListener(s, e), () => {
30
+ window.removeEventListener(s, e);
31
31
  };
32
- }, []), { value: d, set: (e, t, n) => C(e, o(t), n), remove: (e, t) => k(e, t), getAll: () => i(), clear: () => h() };
32
+ }, []), { value: d, set: (e, r, o) => C(e, n(r), o), remove: (e, r) => k(e, r), getAll: () => i(), clear: () => g() };
33
33
  };
34
34
  export {
35
- g as clearCookies,
36
- N as useCookies
35
+ E as clearCookies,
36
+ O as useCookies
37
37
  };
38
38
  //# sourceMappingURL=useCookies.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useCookies.mjs","sources":["../../../../src/hooks/useCookies/useCookies.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { RemoveCookieParams, SetCookieParams } from '../useCookie/useCookie';\n\nimport {\n COOKIE_EVENT,\n dispatchCookieEvent,\n removeCookie,\n removeCookieItem,\n setCookieItem\n} from '../useCookie/useCookie';\n\n/** The cookies params type */\nexport type CookieParams = Record<string, any>;\n\n/* The use cookies options type */\nexport interface UseCookiesOptions<Value> {\n /* The deserializer function to be invoked */\n deserializer?: (value: string) => Value[keyof Value];\n /* The serializer function to be invoked */\n serializer?: (value: Value[keyof Value]) => string;\n}\n\nexport const clearCookies = () => {\n document.cookie.split('; ').forEach((cookie) => {\n const [name] = cookie.split('=');\n removeCookie(name);\n });\n};\n\nconst clearCookieItems = () => {\n clearCookies();\n dispatchCookieEvent();\n};\n\n/**\n * @name useCookies\n * @description - Hook that manages cookie values\n * @category Browser\n *\n * @overload\n * @template {object} Value The type of the cookie values\n * @returns {UseCookieReturn<Value>} The value and the set function\n *\n * @example\n * const { value, set, remove, getAll, clear } = useCookies();\n */\nexport const useCookies = <Value extends CookieParams>(options?: UseCookiesOptions<Value>) => {\n const serializer = (value: Value[keyof Value]) => {\n if (options?.serializer) return options.serializer(value);\n if (typeof value === 'string') return value;\n return JSON.stringify(value);\n };\n\n const deserializer = (value: string) => {\n if (options?.deserializer) return options.deserializer(value);\n if (value === 'undefined') return undefined as unknown as Value[keyof Value];\n\n try {\n return JSON.parse(value) as Value;\n } catch {\n return value as Value[keyof Value];\n }\n };\n\n const getParsedCookies = () => {\n if (!document.cookie) return {};\n\n return Object.fromEntries(\n document.cookie\n .split('; ')\n .map((cookie) => {\n const [key, ...value] = cookie.split('=');\n if (!key || !value.length) return [];\n const decodedValue = decodeURIComponent(value.join('='));\n return [key, deserializer(decodedValue)];\n })\n .filter((entry) => entry.length)\n );\n };\n\n const [value, setValue] = useState(() => {\n if (typeof window === 'undefined') return {} as Value;\n return getParsedCookies() as Value;\n });\n\n useEffect(() => {\n const onChange = () => setValue(getParsedCookies() as Value);\n\n window.addEventListener(COOKIE_EVENT, onChange);\n return () => {\n window.removeEventListener(COOKIE_EVENT, onChange);\n };\n }, []);\n\n const set = <Key extends keyof Value>(key: Key, value: Value[Key], options?: SetCookieParams) =>\n setCookieItem(key as string, serializer(value), options);\n\n const remove = <Key extends keyof Value>(key: Key, options?: RemoveCookieParams) =>\n removeCookieItem(key as string, options);\n const getAll = () => getParsedCookies();\n const clear = () => clearCookieItems();\n\n return { value, set, remove, getAll, clear };\n};\n"],"names":["clearCookies","cookie","name","removeCookie","clearCookieItems","dispatchCookieEvent","useCookies","options","serializer","value","deserializer","getParsedCookies","key","decodedValue","entry","setValue","useState","useEffect","onChange","COOKIE_EVENT","setCookieItem","removeCookieItem"],"mappings":";;AAuBO,MAAMA,IAAe,MAAM;AAChC,WAAS,OAAO,MAAM,IAAI,EAAE,QAAQ,CAACC,MAAW;AAC9C,UAAM,CAACC,CAAI,IAAID,EAAO,MAAM,GAAG;AAC/B,IAAAE,EAAaD,CAAI;AAAA,EAAA,CAClB;AACH,GAEME,IAAmB,MAAM;AAChB,EAAAJ,EAAA,GACOK,EAAA;AACtB,GAcaC,IAAa,CAA6BC,MAAuC;AACtF,QAAAC,IAAa,CAACC,MACdF,KAAA,QAAAA,EAAS,aAAmBA,EAAQ,WAAWE,CAAK,IACpD,OAAOA,KAAU,WAAiBA,IAC/B,KAAK,UAAUA,CAAK,GAGvBC,IAAe,CAACD,MAAkB;AACtC,QAAIF,KAAA,QAAAA,EAAS,aAAqB,QAAAA,EAAQ,aAAaE,CAAK;AACxDA,QAAAA,MAAU;AAEV,UAAA;AACK,eAAA,KAAK,MAAMA,CAAK;AAAA,MAAA,QACjB;AACCA,eAAAA;AAAAA,MAAA;AAAA,EAEX,GAEME,IAAmB,MAClB,SAAS,SAEP,OAAO;AAAA,IACZ,SAAS,OACN,MAAM,IAAI,EACV,IAAI,CAACV,MAAW;AACf,YAAM,CAACW,GAAK,GAAGH,CAAK,IAAIR,EAAO,MAAM,GAAG;AACxC,UAAI,CAACW,KAAO,CAACH,EAAM,eAAe,CAAC;AACnC,YAAMI,IAAe,mBAAmBJ,EAAM,KAAK,GAAG,CAAC;AACvD,aAAO,CAACG,GAAKF,EAAaG,CAAY,CAAC;AAAA,IACxC,CAAA,EACA,OAAO,CAACC,MAAUA,EAAM,MAAM;AAAA,EACnC,IAZ6B,CAAC,GAe1B,CAACL,GAAOM,CAAQ,IAAIC,EAAS,MAC7B,OAAO,SAAW,MAAoB,CAAC,IACpCL,EAAiB,CACzB;AAED,SAAAM,EAAU,MAAM;AACd,UAAMC,IAAW,MAAMH,EAASJ,GAA2B;AAEpD,kBAAA,iBAAiBQ,GAAcD,CAAQ,GACvC,MAAM;AACJ,aAAA,oBAAoBC,GAAcD,CAAQ;AAAA,IACnD;AAAA,EACF,GAAG,EAAE,GAUE,EAAE,OAAAT,GAAO,KARJ,CAA0BG,GAAUH,GAAmBF,MACjEa,EAAcR,GAAeJ,EAAWC,CAAK,GAAGF,CAAO,GAOpC,QALN,CAA0BK,GAAUL,MACjDc,EAAiBT,GAAeL,CAAO,GAIZ,QAHd,MAAMI,EAAiB,GAGD,OAFvB,MAAMP,EAAiB,EAEM;AAC7C;"}
1
+ {"version":3,"file":"useCookies.mjs","sources":["../../../../src/hooks/useCookies/useCookies.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { RemoveCookieParams, SetCookieParams } from '../useCookie/useCookie';\n\nimport {\n COOKIE_EVENT,\n dispatchCookieEvent,\n removeCookie,\n removeCookieItem,\n setCookieItem\n} from '../useCookie/useCookie';\n\n/** The cookies params type */\nexport type CookieParams = Record<string, any>;\n\n/* The use cookies options type */\nexport interface UseCookiesOptions<Value> {\n /* The deserializer function to be invoked */\n deserializer?: (value: string) => Value[keyof Value];\n /* The serializer function to be invoked */\n serializer?: (value: Value[keyof Value]) => string;\n}\n\nexport const clearCookies = () => {\n document.cookie.split('; ').forEach((cookie) => {\n const [name] = cookie.split('=');\n removeCookie(name);\n });\n};\n\nconst clearCookieItems = () => {\n clearCookies();\n dispatchCookieEvent();\n};\n\n/**\n * @name useCookies\n * @description - Hook that manages cookie values\n * @category Browser\n *\n * @overload\n * @template {object} Value The type of the cookie values\n * @returns {UseCookieReturn<Value>} The value and the set function\n *\n * @example\n * const { value, set, remove, getAll, clear } = useCookies();\n */\nexport const useCookies = <Value extends CookieParams>(options?: UseCookiesOptions<Value>) => {\n const serializer = (value: Value[keyof Value]) => {\n if (options?.serializer) return options.serializer(value);\n if (typeof value === 'string') return value;\n return JSON.stringify(value);\n };\n\n const deserializer = (value: string) => {\n if (options?.deserializer) return options.deserializer(value);\n if (value === 'undefined') return undefined as unknown as Value[keyof Value];\n\n try {\n return JSON.parse(value) as Value;\n } catch {\n return value as Value[keyof Value];\n }\n };\n\n const getParsedCookies = () => {\n if (!document.cookie) return {};\n\n return Object.fromEntries(\n document.cookie\n .split('; ')\n .map((cookie) => {\n const [key, ...value] = cookie.split('=');\n if (!key || !value.length) return [];\n const decodedValue = decodeURIComponent(value.join('='));\n return [key, deserializer(decodedValue)];\n })\n .filter((entry) => entry.length)\n );\n };\n\n const [value, setValue] = useState(() => {\n if (typeof window === 'undefined') return {} as Value;\n return getParsedCookies() as Value;\n });\n\n useEffect(() => {\n const onChange = () => setValue(getParsedCookies() as Value);\n\n window.addEventListener(COOKIE_EVENT, onChange);\n return () => {\n window.removeEventListener(COOKIE_EVENT, onChange);\n };\n }, []);\n\n const set = <Key extends keyof Value>(key: Key, value: Value[Key], options?: SetCookieParams) =>\n setCookieItem(key as string, serializer(value), options);\n\n const remove = <Key extends keyof Value>(key: Key, options?: RemoveCookieParams) =>\n removeCookieItem(key as string, options);\n const getAll = () => getParsedCookies();\n const clear = () => clearCookieItems();\n\n return { value, set, remove, getAll, clear };\n};\n"],"names":["clearCookies","cookie","name","removeCookie","clearCookieItems","dispatchCookieEvent","useCookies","options","serializer","value","deserializer","getParsedCookies","key","decodedValue","entry","setValue","useState","useEffect","onChange","COOKIE_EVENT","setCookieItem","removeCookieItem"],"mappings":";;AAuBO,MAAMA,IAAe,MAAM;AAChC,WAAS,OAAO,MAAM,IAAI,EAAE,QAAQ,CAACC,MAAW;AAC9C,UAAM,CAACC,CAAI,IAAID,EAAO,MAAM,GAAG;AAC/B,IAAAE,EAAaD,CAAI;AAAA,EAAA,CAClB;AACH,GAEME,IAAmB,MAAM;AAC7B,EAAAJ,EAAA,GACAK,EAAA;AACF,GAcaC,IAAa,CAA6BC,MAAuC;AAC5F,QAAMC,IAAa,CAACC,MACdF,GAAS,aAAmBA,EAAQ,WAAWE,CAAK,IACpD,OAAOA,KAAU,WAAiBA,IAC/B,KAAK,UAAUA,CAAK,GAGvBC,IAAe,CAACD,MAAkB;AACtC,QAAIF,GAAS,aAAc,QAAOA,EAAQ,aAAaE,CAAK;AAC5D,QAAIA,MAAU;AAEd,UAAI;AACF,eAAO,KAAK,MAAMA,CAAK;AAAA,MAAA,QACjB;AACN,eAAOA;AAAAA,MAAA;AAAA,EACT,GAGIE,IAAmB,MAClB,SAAS,SAEP,OAAO;AAAA,IACZ,SAAS,OACN,MAAM,IAAI,EACV,IAAI,CAACV,MAAW;AACf,YAAM,CAACW,GAAK,GAAGH,CAAK,IAAIR,EAAO,MAAM,GAAG;AACxC,UAAI,CAACW,KAAO,CAACH,EAAM,eAAe,CAAA;AAClC,YAAMI,IAAe,mBAAmBJ,EAAM,KAAK,GAAG,CAAC;AACvD,aAAO,CAACG,GAAKF,EAAaG,CAAY,CAAC;AAAA,IAAA,CACxC,EACA,OAAO,CAACC,MAAUA,EAAM,MAAM;AAAA,EAAA,IAXN,CAAA,GAezB,CAACL,GAAOM,CAAQ,IAAIC,EAAS,MAC7B,OAAO,SAAW,MAAoB,CAAA,IACnCL,EAAA,CACR;AAED,SAAAM,EAAU,MAAM;AACd,UAAMC,IAAW,MAAMH,EAASJ,GAA2B;AAE3D,kBAAO,iBAAiBQ,GAAcD,CAAQ,GACvC,MAAM;AACX,aAAO,oBAAoBC,GAAcD,CAAQ;AAAA,IAAA;AAAA,EACnD,GACC,EAAE,GAUE,EAAE,OAAAT,GAAO,KARJ,CAA0BG,GAAUH,GAAmBF,MACjEa,EAAcR,GAAeJ,EAAWC,CAAK,GAAGF,CAAO,GAOpC,QALN,CAA0BK,GAAUL,MACjDc,EAAiBT,GAAeL,CAAO,GAIZ,QAHd,MAAMI,EAAA,GAGgB,OAFvB,MAAMP,EAAA,EAEiB;AACvC;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useCopy.mjs","sources":["../../../../src/hooks/useCopy/useCopy.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport { copy } from '@/utils/helpers';\n\n/** The use copy return type */\nexport interface UseCopyReturn {\n /** Whether copy is in progress */\n copied: boolean;\n /** The copied value */\n value: string | null;\n /** Function to copy text */\n copy: (value: string) => Promise<void>;\n}\n\n/** The use copy params type */\nexport interface UseCopyParams {\n /** Reset delay in milliseconds */\n resetDelay?: number;\n}\n\n/**\n * @name useCopy\n * @description - Hook that manages copying text with status reset\n * @category Browser\n *\n * @browserapi navigator.clipboard https://developer.mozilla.org/en-US/docs/Web/API/Navigator/clipboard\n *\n * @param {number} [delay=1000] Delay in ms before resetting copied status\n * @returns {UseCopyReturn} An object containing the copied value, status and copy function\n *\n * @example\n * const { copied, value, copy } = useCopy();\n */\nexport const useCopy = (delay: number = 1000): UseCopyReturn => {\n const [value, setValue] = useState<string | null>(null);\n const [copied, setCopied] = useState(false);\n\n const copyToClipboard = async (text: string) => {\n await copy(text);\n setValue(text);\n setCopied(true);\n setTimeout(() => setCopied(false), delay);\n };\n\n return { value, copied, copy: copyToClipboard };\n};\n"],"names":["useCopy","delay","value","setValue","useState","copied","setCopied","text","copy"],"mappings":";;AAiCa,MAAAA,IAAU,CAACC,IAAgB,QAAwB;AAC9D,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAwB,IAAI,GAChD,CAACC,GAAQC,CAAS,IAAIF,EAAS,EAAK;AAS1C,SAAO,EAAE,OAAAF,GAAO,QAAAG,GAAQ,MAPA,OAAOE,MAAiB;AAC9C,UAAMC,EAAKD,CAAI,GACfJ,EAASI,CAAI,GACbD,EAAU,EAAI,GACd,WAAW,MAAMA,EAAU,EAAK,GAAGL,CAAK;AAAA,EAC1C,EAE8C;AAChD;"}
1
+ {"version":3,"file":"useCopy.mjs","sources":["../../../../src/hooks/useCopy/useCopy.ts"],"sourcesContent":["import { useState } from 'react';\n\nimport { copy } from '@/utils/helpers';\n\n/** The use copy return type */\nexport interface UseCopyReturn {\n /** Whether copy is in progress */\n copied: boolean;\n /** The copied value */\n value: string | null;\n /** Function to copy text */\n copy: (value: string) => Promise<void>;\n}\n\n/** The use copy params type */\nexport interface UseCopyParams {\n /** Reset delay in milliseconds */\n resetDelay?: number;\n}\n\n/**\n * @name useCopy\n * @description - Hook that manages copying text with status reset\n * @category Browser\n *\n * @browserapi navigator.clipboard https://developer.mozilla.org/en-US/docs/Web/API/Navigator/clipboard\n *\n * @param {number} [delay=1000] Delay in ms before resetting copied status\n * @returns {UseCopyReturn} An object containing the copied value, status and copy function\n *\n * @example\n * const { copied, value, copy } = useCopy();\n */\nexport const useCopy = (delay: number = 1000): UseCopyReturn => {\n const [value, setValue] = useState<string | null>(null);\n const [copied, setCopied] = useState(false);\n\n const copyToClipboard = async (text: string) => {\n await copy(text);\n setValue(text);\n setCopied(true);\n setTimeout(() => setCopied(false), delay);\n };\n\n return { value, copied, copy: copyToClipboard };\n};\n"],"names":["useCopy","delay","value","setValue","useState","copied","setCopied","text","copy"],"mappings":";;AAiCO,MAAMA,IAAU,CAACC,IAAgB,QAAwB;AAC9D,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAwB,IAAI,GAChD,CAACC,GAAQC,CAAS,IAAIF,EAAS,EAAK;AAS1C,SAAO,EAAE,OAAAF,GAAO,QAAAG,GAAQ,MAPA,OAAOE,MAAiB;AAC9C,UAAMC,EAAKD,CAAI,GACfJ,EAASI,CAAI,GACbD,EAAU,EAAI,GACd,WAAW,MAAMA,EAAU,EAAK,GAAGL,CAAK;AAAA,EAAA,EAGZ;AAChC;"}
@@ -1,8 +1,7 @@
1
- import { useState as f } from "react";
2
- const h = (...u) => {
3
- var c;
4
- const i = typeof u[0] == "number" ? u[0] : (c = u[0]) == null ? void 0 : c.initialValue, { max: e = Number.POSITIVE_INFINITY, min: o = Number.NEGATIVE_INFINITY } = typeof u[0] == "number" ? u[1] ?? {} : u[0] ?? {}, [m, r] = f(i ?? 0);
5
- return { value: m, set: (t) => {
1
+ import { useState as m } from "react";
2
+ const d = (...u) => {
3
+ const i = typeof u[0] == "number" ? u[0] : u[0]?.initialValue, { max: e = Number.POSITIVE_INFINITY, min: o = Number.NEGATIVE_INFINITY } = typeof u[0] == "number" ? u[1] ?? {} : u[0] ?? {}, [c, r] = m(i ?? 0);
4
+ return { value: c, set: (t) => {
6
5
  r((n) => Math.max(
7
6
  o,
8
7
  Math.min(e, typeof t == "number" ? t : t(n))
@@ -19,6 +18,6 @@ const h = (...u) => {
19
18
  } };
20
19
  };
21
20
  export {
22
- h as useCounter
21
+ d as useCounter
23
22
  };
24
23
  //# sourceMappingURL=useCounter.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useCounter.mjs","sources":["../../../../src/hooks/useCounter/useCounter.ts"],"sourcesContent":["import type { Dispatch, SetStateAction } from 'react';\n\nimport { useState } from 'react';\n\n/** The use counter options */\nexport interface UseCounterOptions {\n /** The max of count value */\n max?: number;\n /** The min of count value */\n min?: number;\n}\n\n/** The use counter return type */\nexport interface UseCounterReturn {\n /** Function to set a specific value to the counter */\n set: Dispatch<SetStateAction<number>>;\n /** The current count value */\n value: number;\n /** Function to decrement the counter */\n dec: (value?: number) => void;\n /** Function to increment the counter */\n inc: (value?: number) => void;\n /** Function to reset the counter to its initial value. */\n reset: () => void;\n}\n\nexport interface UseCounter {\n (initialValue?: number, options?: UseCounterOptions): UseCounterReturn;\n\n (options: UseCounterOptions & { initialValue?: number }, initialValue?: never): UseCounterReturn;\n}\n\n/**\n * @name useCounter\n * @description - Hook that manages a counter\n * @category Utilities\n *\n * @overload\n * @param {number} [initialValue=0] The initial number value\n * @param {number} [options.min=Number.NEGATIVE_INFINITY] The min of count value\n * @param {number} [options.max=Number.POSITIVE_INFINITY] The max of count value\n * @returns {UseCounterReturn} An object containing the current count and functions to interact with the counter\n\n * @overload\n * @param {number} [params.initialValue=0] The initial number value\n * @param {number} [params.min=Number.NEGATIVE_INFINITY] The min of count value\n * @param {number} [params.max=Number.POSITIVE_INFINITY] The max of count value\n * @returns {UseCounterReturn} An object containing the current count and functions to interact with the counter\n *\n * @example\n * const { count, dec, inc, reset, set } = useCounter(5);\n *\n * @example\n * const { count, dec, inc, reset, set } = useCounter({ initialValue: 5, min: 0, max: 10 });\n */\nexport const useCounter = ((...params: any[]) => {\n const initialValue =\n typeof params[0] === 'number'\n ? params[0]\n : (params[0] as UseCounterOptions & { initialValue?: number })?.initialValue;\n const { max = Number.POSITIVE_INFINITY, min = Number.NEGATIVE_INFINITY } =\n typeof params[0] === 'number'\n ? ((params[1] ?? {}) as UseCounterOptions)\n : ((params[0] ?? {}) as UseCounterOptions & { initialValue?: number });\n\n const [value, setValue] = useState(initialValue ?? 0);\n\n const inc = (value: number = 1) => {\n setValue((prevValue) => {\n if (typeof max === 'number' && prevValue === max) return prevValue;\n return Math.max(Math.min(max, prevValue + value), min);\n });\n };\n\n const dec = (value: number = 1) => {\n setValue((prevValue) => {\n if (typeof min === 'number' && prevValue === min) return prevValue;\n return Math.min(Math.max(min, prevValue - value), max);\n });\n };\n\n const reset = () => {\n const value = initialValue ?? 0;\n if (typeof max === 'number' && value > max) return setValue(max);\n if (typeof min === 'number' && value < min) return setValue(min);\n setValue(value);\n };\n\n const set = (value: SetStateAction<number>) => {\n setValue((prevValue) => {\n const updatedCount = Math.max(\n min,\n Math.min(max, typeof value === 'number' ? value : value(prevValue))\n );\n\n return updatedCount;\n });\n };\n\n return { value, set, inc, dec, reset };\n}) as UseCounter;\n"],"names":["useCounter","params","initialValue","_a","max","min","value","setValue","useState","prevValue"],"mappings":";AAuDa,MAAAA,IAAc,IAAIC,MAAkB;;AACzC,QAAAC,IACJ,OAAOD,EAAO,CAAC,KAAM,WACjBA,EAAO,CAAC,KACPE,IAAAF,EAAO,CAAC,MAAR,gBAAAE,EAA6D,cAC9D,EAAE,KAAAC,IAAM,OAAO,mBAAmB,KAAAC,IAAM,OAAO,kBAAA,IACnD,OAAOJ,EAAO,CAAC,KAAM,WACfA,EAAO,CAAC,KAAK,CAAA,IACbA,EAAO,CAAC,KAAK,CAAC,GAEhB,CAACK,GAAOC,CAAQ,IAAIC,EAASN,KAAgB,CAAC;AAkCpD,SAAO,EAAE,OAAAI,GAAO,KAXJ,CAACA,MAAkC;AAC7C,IAAAC,EAAS,CAACE,MACa,KAAK;AAAA,MACxBJ;AAAA,MACA,KAAK,IAAID,GAAK,OAAOE,KAAU,WAAWA,IAAQA,EAAMG,CAAS,CAAC;AAAA,IACpE,CAGD;AAAA,EACH,GAEqB,KAhCT,CAACH,IAAgB,MAAM;AACjC,IAAAC,EAAS,CAACE,MACJ,OAAOL,KAAQ,YAAYK,MAAcL,IAAYK,IAClD,KAAK,IAAI,KAAK,IAAIL,GAAKK,IAAYH,CAAK,GAAGD,CAAG,CACtD;AAAA,EACH,GA2B0B,KAzBd,CAACC,IAAgB,MAAM;AACjC,IAAAC,EAAS,CAACE,MACJ,OAAOJ,KAAQ,YAAYI,MAAcJ,IAAYI,IAClD,KAAK,IAAI,KAAK,IAAIJ,GAAKI,IAAYH,CAAK,GAAGF,CAAG,CACtD;AAAA,EACH,GAoB+B,OAlBjB,MAAM;AAClB,UAAME,IAAQJ,KAAgB;AAC9B,QAAI,OAAOE,KAAQ,YAAYE,IAAQF,EAAK,QAAOG,EAASH,CAAG;AAC/D,QAAI,OAAOC,KAAQ,YAAYC,IAAQD,EAAK,QAAOE,EAASF,CAAG;AAC/D,IAAAE,EAASD,CAAK;AAAA,EAChB,EAaqC;AACvC;"}
1
+ {"version":3,"file":"useCounter.mjs","sources":["../../../../src/hooks/useCounter/useCounter.ts"],"sourcesContent":["import type { Dispatch, SetStateAction } from 'react';\n\nimport { useState } from 'react';\n\n/** The use counter options */\nexport interface UseCounterOptions {\n /** The max of count value */\n max?: number;\n /** The min of count value */\n min?: number;\n}\n\n/** The use counter return type */\nexport interface UseCounterReturn {\n /** Function to set a specific value to the counter */\n set: Dispatch<SetStateAction<number>>;\n /** The current count value */\n value: number;\n /** Function to decrement the counter */\n dec: (value?: number) => void;\n /** Function to increment the counter */\n inc: (value?: number) => void;\n /** Function to reset the counter to its initial value. */\n reset: () => void;\n}\n\nexport interface UseCounter {\n (initialValue?: number, options?: UseCounterOptions): UseCounterReturn;\n\n (options: UseCounterOptions & { initialValue?: number }, initialValue?: never): UseCounterReturn;\n}\n\n/**\n * @name useCounter\n * @description - Hook that manages a counter\n * @category Utilities\n *\n * @overload\n * @param {number} [initialValue=0] The initial number value\n * @param {number} [options.min=Number.NEGATIVE_INFINITY] The min of count value\n * @param {number} [options.max=Number.POSITIVE_INFINITY] The max of count value\n * @returns {UseCounterReturn} An object containing the current count and functions to interact with the counter\n\n * @overload\n * @param {number} [params.initialValue=0] The initial number value\n * @param {number} [params.min=Number.NEGATIVE_INFINITY] The min of count value\n * @param {number} [params.max=Number.POSITIVE_INFINITY] The max of count value\n * @returns {UseCounterReturn} An object containing the current count and functions to interact with the counter\n *\n * @example\n * const { count, dec, inc, reset, set } = useCounter(5);\n *\n * @example\n * const { count, dec, inc, reset, set } = useCounter({ initialValue: 5, min: 0, max: 10 });\n */\nexport const useCounter = ((...params: any[]) => {\n const initialValue =\n typeof params[0] === 'number'\n ? params[0]\n : (params[0] as UseCounterOptions & { initialValue?: number })?.initialValue;\n const { max = Number.POSITIVE_INFINITY, min = Number.NEGATIVE_INFINITY } =\n typeof params[0] === 'number'\n ? ((params[1] ?? {}) as UseCounterOptions)\n : ((params[0] ?? {}) as UseCounterOptions & { initialValue?: number });\n\n const [value, setValue] = useState(initialValue ?? 0);\n\n const inc = (value: number = 1) => {\n setValue((prevValue) => {\n if (typeof max === 'number' && prevValue === max) return prevValue;\n return Math.max(Math.min(max, prevValue + value), min);\n });\n };\n\n const dec = (value: number = 1) => {\n setValue((prevValue) => {\n if (typeof min === 'number' && prevValue === min) return prevValue;\n return Math.min(Math.max(min, prevValue - value), max);\n });\n };\n\n const reset = () => {\n const value = initialValue ?? 0;\n if (typeof max === 'number' && value > max) return setValue(max);\n if (typeof min === 'number' && value < min) return setValue(min);\n setValue(value);\n };\n\n const set = (value: SetStateAction<number>) => {\n setValue((prevValue) => {\n const updatedCount = Math.max(\n min,\n Math.min(max, typeof value === 'number' ? value : value(prevValue))\n );\n\n return updatedCount;\n });\n };\n\n return { value, set, inc, dec, reset };\n}) as UseCounter;\n"],"names":["useCounter","params","initialValue","max","min","value","setValue","useState","prevValue"],"mappings":";AAuDO,MAAMA,IAAc,IAAIC,MAAkB;AAC/C,QAAMC,IACJ,OAAOD,EAAO,CAAC,KAAM,WACjBA,EAAO,CAAC,IACPA,EAAO,CAAC,GAAqD,cAC9D,EAAE,KAAAE,IAAM,OAAO,mBAAmB,KAAAC,IAAM,OAAO,kBAAA,IACnD,OAAOH,EAAO,CAAC,KAAM,WACfA,EAAO,CAAC,KAAK,CAAA,IACbA,EAAO,CAAC,KAAK,CAAA,GAEf,CAACI,GAAOC,CAAQ,IAAIC,EAASL,KAAgB,CAAC;AAkCpD,SAAO,EAAE,OAAAG,GAAO,KAXJ,CAACA,MAAkC;AAC7C,IAAAC,EAAS,CAACE,MACa,KAAK;AAAA,MACxBJ;AAAA,MACA,KAAK,IAAID,GAAK,OAAOE,KAAU,WAAWA,IAAQA,EAAMG,CAAS,CAAC;AAAA,IAAA,CAIrE;AAAA,EAAA,GAGkB,KAhCT,CAACH,IAAgB,MAAM;AACjC,IAAAC,EAAS,CAACE,MACJ,OAAOL,KAAQ,YAAYK,MAAcL,IAAYK,IAClD,KAAK,IAAI,KAAK,IAAIL,GAAKK,IAAYH,CAAK,GAAGD,CAAG,CACtD;AAAA,EAAA,GA4BuB,KAzBd,CAACC,IAAgB,MAAM;AACjC,IAAAC,EAAS,CAACE,MACJ,OAAOJ,KAAQ,YAAYI,MAAcJ,IAAYI,IAClD,KAAK,IAAI,KAAK,IAAIJ,GAAKI,IAAYH,CAAK,GAAGF,CAAG,CACtD;AAAA,EAAA,GAqB4B,OAlBjB,MAAM;AAClB,UAAME,IAAQH,KAAgB;AAC9B,QAAI,OAAOC,KAAQ,YAAYE,IAAQF,EAAK,QAAOG,EAASH,CAAG;AAC/D,QAAI,OAAOC,KAAQ,YAAYC,IAAQD,EAAK,QAAOE,EAASF,CAAG;AAC/D,IAAAE,EAASD,CAAK;AAAA,EAAA,EAce;AACjC;"}
@@ -1,10 +1,10 @@
1
- import { useState as a, useEffect as y } from "react";
2
- import { useRefState as w } from "../useRefState/useRefState.mjs";
3
- import { isTarget as b } from "../../utils/helpers/isTarget.mjs";
4
- import { getElement as d } from "../../utils/helpers/getElement.mjs";
5
- const E = (...r) => {
6
- const t = b(r[0]) ? r[0] : void 0, i = t ? r[1] : r[0], s = t ? r[2] : r[1], [f, c] = a(s ?? ""), o = w(window.document.documentElement), u = (e) => {
7
- const n = t ? d(t) : o.current;
1
+ import { useState as g, useEffect as m } from "react";
2
+ import { useRefState as a } from "../useRefState/useRefState.mjs";
3
+ import { isTarget as w } from "../../utils/helpers/isTarget.mjs";
4
+ import { getElement as y } from "../../utils/helpers/getElement.mjs";
5
+ const C = (...r) => {
6
+ const t = w(r[0]) ? r[0] : void 0, i = t ? r[1] : r[0], s = t ? r[2] : r[1], [f, c] = g(s ?? ""), o = a(window.document.documentElement), u = (e) => {
7
+ const n = t ? y(t) : o.current;
8
8
  if (n && n.style) {
9
9
  if (!e) {
10
10
  n.style.removeProperty(i), c(e);
@@ -13,16 +13,15 @@ const E = (...r) => {
13
13
  n.style.setProperty(i, e), c(e);
14
14
  }
15
15
  };
16
- return y(() => {
16
+ return m(() => {
17
17
  s && u(s);
18
- }, []), y(() => {
18
+ }, []), m(() => {
19
19
  if (!t && !o.state) return;
20
- const e = t ? d(t) : o.current;
20
+ const e = t ? y(t) : o.current;
21
21
  if (!e) return;
22
22
  const n = () => {
23
- var m;
24
- const g = (m = window.getComputedStyle(e).getPropertyValue(i)) == null ? void 0 : m.trim();
25
- c(g ?? s);
23
+ const d = window.getComputedStyle(e).getPropertyValue(i)?.trim();
24
+ c(d ?? s);
26
25
  }, l = new MutationObserver(n);
27
26
  return l.observe(e, { attributeFilter: ["style", "class"] }), () => {
28
27
  l.disconnect();
@@ -30,6 +29,6 @@ const E = (...r) => {
30
29
  }, [t, o.state]), t ? { value: f, set: u } : { ref: o, value: f, set: u };
31
30
  };
32
31
  export {
33
- E as useCssVar
32
+ C as useCssVar
34
33
  };
35
34
  //# sourceMappingURL=useCssVar.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useCssVar.mjs","sources":["../../../../src/hooks/useCssVar/useCssVar.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { getElement, isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The css variable return type */\nexport interface UseCssVarReturn {\n /** The value of the CSS variable */\n value: string;\n /** Set the value of the CSS variable */\n set: (value: string) => void;\n}\n\nexport interface UseCssVar {\n (key: string, initialValue?: string): UseCssVarReturn & { ref: StateRef<Element> };\n\n (target: HookTarget, key: string, initialValue?: string): UseCssVarReturn;\n}\n\n/**\n * @name useCssVar\n * @description - Hook that returns the value of a css variable\n * @category Utilities\n *\n * @overload\n * @param {string} key The CSS variable key\n * @param {string} initialValue The initial value of the CSS variable\n * @returns {UseCssVarReturn & { ref: StateRef<Element> }} The object containing the value of the CSS variable and ref\n *\n * @example\n * const { ref, value, set } = useCssVar('--color', 'red');\n *\n * @overload\n * @param {HookTarget} target The target element\n * @param {string} key The CSS variable key\n * @param {string} initialValue The initial value of the CSS variable\n * @returns {UseCssVarReturn} The object containing the value of the CSS variable\n *\n * @example\n * const { value, set } = useCssVar(ref, '--color', 'red');\n */\nexport const useCssVar = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n const key = (target ? params[1] : params[0]) as string;\n const initialValue = (target ? params[2] : params[1]) as string | undefined;\n\n const [value, setValue] = useState(initialValue ?? '');\n const internalRef = useRefState<Element>(window.document.documentElement);\n\n const set = (value: string) => {\n const element = (target ? getElement(target) : internalRef.current) as HTMLElement;\n if (!element) return;\n\n if (element.style) {\n if (!value) {\n element.style.removeProperty(key);\n setValue(value);\n return;\n }\n\n element.style.setProperty(key, value);\n setValue(value);\n }\n };\n\n useEffect(() => {\n if (initialValue) set(initialValue);\n }, []);\n\n useEffect(() => {\n if (!target && !internalRef.state) return;\n\n const element = (target ? getElement(target) : internalRef.current) as Element;\n if (!element) return;\n\n const onChange = () => {\n const value = window\n .getComputedStyle(element as Element)\n .getPropertyValue(key)\n ?.trim();\n\n setValue(value ?? initialValue);\n };\n\n const observer = new MutationObserver(onChange);\n\n observer.observe(element, { attributeFilter: ['style', 'class'] });\n\n return () => {\n observer.disconnect();\n };\n }, [target, internalRef.state]);\n\n if (target) return { value, set };\n return { ref: internalRef, value, set };\n}) as UseCssVar;\n"],"names":["useCssVar","params","target","isTarget","key","initialValue","value","setValue","useState","internalRef","useRefState","set","element","getElement","useEffect","onChange","_a","observer"],"mappings":";;;;AA8Ca,MAAAA,IAAa,IAAIC,MAAkB;AACxC,QAAAC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAC5CG,IAAOF,IAASD,EAAO,CAAC,IAAIA,EAAO,CAAC,GACpCI,IAAgBH,IAASD,EAAO,CAAC,IAAIA,EAAO,CAAC,GAE7C,CAACK,GAAOC,CAAQ,IAAIC,EAASH,KAAgB,EAAE,GAC/CI,IAAcC,EAAqB,OAAO,SAAS,eAAe,GAElEC,IAAM,CAACL,MAAkB;AAC7B,UAAMM,IAAWV,IAASW,EAAWX,CAAM,IAAIO,EAAY;AAC3D,QAAKG,KAEDA,EAAQ,OAAO;AACjB,UAAI,CAACN,GAAO;AACF,QAAAM,EAAA,MAAM,eAAeR,CAAG,GAChCG,EAASD,CAAK;AACd;AAAA,MAAA;AAGM,MAAAM,EAAA,MAAM,YAAYR,GAAKE,CAAK,GACpCC,EAASD,CAAK;AAAA,IAAA;AAAA,EAElB;AA8BA,SA5BAQ,EAAU,MAAM;AACV,IAAAT,OAAkBA,CAAY;AAAA,EACpC,GAAG,EAAE,GAELS,EAAU,MAAM;AACd,QAAI,CAACZ,KAAU,CAACO,EAAY,MAAO;AAEnC,UAAMG,IAAWV,IAASW,EAAWX,CAAM,IAAIO,EAAY;AAC3D,QAAI,CAACG,EAAS;AAEd,UAAMG,IAAW,MAAM;;AACfT,YAAAA,KAAQU,IAAA,OACX,iBAAiBJ,CAAkB,EACnC,iBAAiBR,CAAG,MAFT,gBAAAY,EAGV;AAEJ,MAAAT,EAASD,KAASD,CAAY;AAAA,IAChC,GAEMY,IAAW,IAAI,iBAAiBF,CAAQ;AAErC,WAAAE,EAAA,QAAQL,GAAS,EAAE,iBAAiB,CAAC,SAAS,OAAO,GAAG,GAE1D,MAAM;AACX,MAAAK,EAAS,WAAW;AAAA,IACtB;AAAA,EACC,GAAA,CAACf,GAAQO,EAAY,KAAK,CAAC,GAE1BP,IAAe,EAAE,OAAAI,GAAO,KAAAK,EAAI,IACzB,EAAE,KAAKF,GAAa,OAAAH,GAAO,KAAAK,EAAI;AACxC;"}
1
+ {"version":3,"file":"useCssVar.mjs","sources":["../../../../src/hooks/useCssVar/useCssVar.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { getElement, isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The css variable return type */\nexport interface UseCssVarReturn {\n /** The value of the CSS variable */\n value: string;\n /** Set the value of the CSS variable */\n set: (value: string) => void;\n}\n\nexport interface UseCssVar {\n (key: string, initialValue?: string): UseCssVarReturn & { ref: StateRef<Element> };\n\n (target: HookTarget, key: string, initialValue?: string): UseCssVarReturn;\n}\n\n/**\n * @name useCssVar\n * @description - Hook that returns the value of a css variable\n * @category Utilities\n *\n * @overload\n * @param {string} key The CSS variable key\n * @param {string} initialValue The initial value of the CSS variable\n * @returns {UseCssVarReturn & { ref: StateRef<Element> }} The object containing the value of the CSS variable and ref\n *\n * @example\n * const { ref, value, set } = useCssVar('--color', 'red');\n *\n * @overload\n * @param {HookTarget} target The target element\n * @param {string} key The CSS variable key\n * @param {string} initialValue The initial value of the CSS variable\n * @returns {UseCssVarReturn} The object containing the value of the CSS variable\n *\n * @example\n * const { value, set } = useCssVar(ref, '--color', 'red');\n */\nexport const useCssVar = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n const key = (target ? params[1] : params[0]) as string;\n const initialValue = (target ? params[2] : params[1]) as string | undefined;\n\n const [value, setValue] = useState(initialValue ?? '');\n const internalRef = useRefState<Element>(window.document.documentElement);\n\n const set = (value: string) => {\n const element = (target ? getElement(target) : internalRef.current) as HTMLElement;\n if (!element) return;\n\n if (element.style) {\n if (!value) {\n element.style.removeProperty(key);\n setValue(value);\n return;\n }\n\n element.style.setProperty(key, value);\n setValue(value);\n }\n };\n\n useEffect(() => {\n if (initialValue) set(initialValue);\n }, []);\n\n useEffect(() => {\n if (!target && !internalRef.state) return;\n\n const element = (target ? getElement(target) : internalRef.current) as Element;\n if (!element) return;\n\n const onChange = () => {\n const value = window\n .getComputedStyle(element as Element)\n .getPropertyValue(key)\n ?.trim();\n\n setValue(value ?? initialValue);\n };\n\n const observer = new MutationObserver(onChange);\n\n observer.observe(element, { attributeFilter: ['style', 'class'] });\n\n return () => {\n observer.disconnect();\n };\n }, [target, internalRef.state]);\n\n if (target) return { value, set };\n return { ref: internalRef, value, set };\n}) as UseCssVar;\n"],"names":["useCssVar","params","target","isTarget","key","initialValue","value","setValue","useState","internalRef","useRefState","set","element","getElement","useEffect","onChange","observer"],"mappings":";;;;AA8CO,MAAMA,IAAa,IAAIC,MAAkB;AAC9C,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAC5CG,IAAOF,IAASD,EAAO,CAAC,IAAIA,EAAO,CAAC,GACpCI,IAAgBH,IAASD,EAAO,CAAC,IAAIA,EAAO,CAAC,GAE7C,CAACK,GAAOC,CAAQ,IAAIC,EAASH,KAAgB,EAAE,GAC/CI,IAAcC,EAAqB,OAAO,SAAS,eAAe,GAElEC,IAAM,CAACL,MAAkB;AAC7B,UAAMM,IAAWV,IAASW,EAAWX,CAAM,IAAIO,EAAY;AAC3D,QAAKG,KAEDA,EAAQ,OAAO;AACjB,UAAI,CAACN,GAAO;AACV,QAAAM,EAAQ,MAAM,eAAeR,CAAG,GAChCG,EAASD,CAAK;AACd;AAAA,MAAA;AAGF,MAAAM,EAAQ,MAAM,YAAYR,GAAKE,CAAK,GACpCC,EAASD,CAAK;AAAA,IAAA;AAAA,EAChB;AA+BF,SA5BAQ,EAAU,MAAM;AACd,IAAIT,OAAkBA,CAAY;AAAA,EAAA,GACjC,EAAE,GAELS,EAAU,MAAM;AACd,QAAI,CAACZ,KAAU,CAACO,EAAY,MAAO;AAEnC,UAAMG,IAAWV,IAASW,EAAWX,CAAM,IAAIO,EAAY;AAC3D,QAAI,CAACG,EAAS;AAEd,UAAMG,IAAW,MAAM;AACrB,YAAMT,IAAQ,OACX,iBAAiBM,CAAkB,EACnC,iBAAiBR,CAAG,GACnB,KAAA;AAEJ,MAAAG,EAASD,KAASD,CAAY;AAAA,IAAA,GAG1BW,IAAW,IAAI,iBAAiBD,CAAQ;AAE9C,WAAAC,EAAS,QAAQJ,GAAS,EAAE,iBAAiB,CAAC,SAAS,OAAO,GAAG,GAE1D,MAAM;AACX,MAAAI,EAAS,WAAA;AAAA,IAAW;AAAA,EACtB,GACC,CAACd,GAAQO,EAAY,KAAK,CAAC,GAE1BP,IAAe,EAAE,OAAAI,GAAO,KAAAK,EAAA,IACrB,EAAE,KAAKF,GAAa,OAAAH,GAAO,KAAAK,EAAA;AACpC;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDebounceCallback.mjs","sources":["../../../../src/hooks/useDebounceCallback/useDebounceCallback.ts"],"sourcesContent":["import { useMemo } from 'react';\n\nimport { debounce } from '@/utils/helpers';\n\nimport { useEvent } from '../useEvent/useEvent';\n\n/**\n * @name useDebounceCallback\n * @description - Hook that creates a debounced callback\n * @category Utilities\n *\n * @template Params The type of the params\n * @template Return The type of the return\n * @param {(...args: Params) => Return} callback The callback function\n * @param {number} delay The delay in milliseconds\n * @returns {(...args: Params) => Return} The callback with debounce\n *\n * @example\n * const debouncedCallback = useDebounceCallback(() => console.log('callback'), 500);\n */\nexport const useDebounceCallback = <Params extends unknown[], Return>(\n callback: (...args: Params) => Return,\n delay: number\n) => {\n const internalCallback = useEvent(callback);\n const debounced = useMemo(() => debounce(internalCallback, delay), [delay]);\n\n return debounced;\n};\n"],"names":["useDebounceCallback","callback","delay","internalCallback","useEvent","useMemo","debounce"],"mappings":";;;AAoBa,MAAAA,IAAsB,CACjCC,GACAC,MACG;AACG,QAAAC,IAAmBC,EAASH,CAAQ;AAGnC,SAFWI,EAAQ,MAAMC,EAASH,GAAkBD,CAAK,GAAG,CAACA,CAAK,CAAC;AAG5E;"}
1
+ {"version":3,"file":"useDebounceCallback.mjs","sources":["../../../../src/hooks/useDebounceCallback/useDebounceCallback.ts"],"sourcesContent":["import { useMemo } from 'react';\n\nimport { debounce } from '@/utils/helpers';\n\nimport { useEvent } from '../useEvent/useEvent';\n\n/**\n * @name useDebounceCallback\n * @description - Hook that creates a debounced callback\n * @category Utilities\n *\n * @template Params The type of the params\n * @template Return The type of the return\n * @param {(...args: Params) => Return} callback The callback function\n * @param {number} delay The delay in milliseconds\n * @returns {(...args: Params) => Return} The callback with debounce\n *\n * @example\n * const debouncedCallback = useDebounceCallback(() => console.log('callback'), 500);\n */\nexport const useDebounceCallback = <Params extends unknown[], Return>(\n callback: (...args: Params) => Return,\n delay: number\n) => {\n const internalCallback = useEvent(callback);\n const debounced = useMemo(() => debounce(internalCallback, delay), [delay]);\n\n return debounced;\n};\n"],"names":["useDebounceCallback","callback","delay","internalCallback","useEvent","useMemo","debounce"],"mappings":";;;AAoBO,MAAMA,IAAsB,CACjCC,GACAC,MACG;AACH,QAAMC,IAAmBC,EAASH,CAAQ;AAG1C,SAFkBI,EAAQ,MAAMC,EAASH,GAAkBD,CAAK,GAAG,CAACA,CAAK,CAAC;AAG5E;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDebounceValue.mjs","sources":["../../../../src/hooks/useDebounceValue/useDebounceValue.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport { useDebounceCallback } from '../useDebounceCallback/useDebounceCallback';\n\n/**\n * @name useDebounceValue\n * @description - Hook that creates a debounced value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {Value} value The value to be debounced\n * @param {number} delay The delay in milliseconds\n * @returns {Value} The debounced value\n *\n * @example\n * const debouncedValue = useDebounceValue(value, 500);\n */\nexport const useDebounceValue = <Value>(value: Value, delay: number) => {\n const previousValueRef = useRef(value);\n const [debouncedValue, setDebounceValue] = useState(value);\n\n const debouncedSetState = useDebounceCallback(setDebounceValue, delay);\n\n useEffect(() => {\n if (previousValueRef.current === value) return;\n debouncedSetState(value);\n previousValueRef.current = value;\n }, [value]);\n\n return debouncedValue;\n};\n"],"names":["useDebounceValue","value","delay","previousValueRef","useRef","debouncedValue","setDebounceValue","useState","debouncedSetState","useDebounceCallback","useEffect"],"mappings":";;AAiBa,MAAAA,IAAmB,CAAQC,GAAcC,MAAkB;AAChE,QAAAC,IAAmBC,EAAOH,CAAK,GAC/B,CAACI,GAAgBC,CAAgB,IAAIC,EAASN,CAAK,GAEnDO,IAAoBC,EAAoBH,GAAkBJ,CAAK;AAErE,SAAAQ,EAAU,MAAM;AACV,IAAAP,EAAiB,YAAYF,MACjCO,EAAkBP,CAAK,GACvBE,EAAiB,UAAUF;AAAA,EAAA,GAC1B,CAACA,CAAK,CAAC,GAEHI;AACT;"}
1
+ {"version":3,"file":"useDebounceValue.mjs","sources":["../../../../src/hooks/useDebounceValue/useDebounceValue.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport { useDebounceCallback } from '../useDebounceCallback/useDebounceCallback';\n\n/**\n * @name useDebounceValue\n * @description - Hook that creates a debounced value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {Value} value The value to be debounced\n * @param {number} delay The delay in milliseconds\n * @returns {Value} The debounced value\n *\n * @example\n * const debouncedValue = useDebounceValue(value, 500);\n */\nexport const useDebounceValue = <Value>(value: Value, delay: number) => {\n const previousValueRef = useRef(value);\n const [debouncedValue, setDebounceValue] = useState(value);\n\n const debouncedSetState = useDebounceCallback(setDebounceValue, delay);\n\n useEffect(() => {\n if (previousValueRef.current === value) return;\n debouncedSetState(value);\n previousValueRef.current = value;\n }, [value]);\n\n return debouncedValue;\n};\n"],"names":["useDebounceValue","value","delay","previousValueRef","useRef","debouncedValue","setDebounceValue","useState","debouncedSetState","useDebounceCallback","useEffect"],"mappings":";;AAiBO,MAAMA,IAAmB,CAAQC,GAAcC,MAAkB;AACtE,QAAMC,IAAmBC,EAAOH,CAAK,GAC/B,CAACI,GAAgBC,CAAgB,IAAIC,EAASN,CAAK,GAEnDO,IAAoBC,EAAoBH,GAAkBJ,CAAK;AAErE,SAAAQ,EAAU,MAAM;AACd,IAAIP,EAAiB,YAAYF,MACjCO,EAAkBP,CAAK,GACvBE,EAAiB,UAAUF;AAAA,EAAA,GAC1B,CAACA,CAAK,CAAC,GAEHI;AACT;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDefault.mjs","sources":["../../../../src/hooks/useDefault/useDefault.ts"],"sourcesContent":["import { useState } from 'react';\n\n/**\n * @name useDefault\n * @description - Hook that returns the default value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {Value} initialValue The initial value\n * @param {Value} defaultValue The default value\n * @returns {[Value, (value: Value) => void]} An array containing the current value and a function to set the value\n *\n * @example\n * const [value, setValue] = useDefault(initialValue, defaultValue);\n */\nexport const useDefault = <Value>(initialValue: (() => Value) | Value, defaultValue: Value) => {\n const [value, setValue] = useState<Value | null | undefined>(initialValue);\n return [value === undefined || value === null ? defaultValue : value, setValue] as const;\n};\n"],"names":["useDefault","initialValue","defaultValue","value","setValue","useState"],"mappings":";AAea,MAAAA,IAAa,CAAQC,GAAqCC,MAAwB;AAC7F,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAmCJ,CAAY;AACzE,SAAO,CAAwBE,KAAiBD,GAAsBE,CAAQ;AAChF;"}
1
+ {"version":3,"file":"useDefault.mjs","sources":["../../../../src/hooks/useDefault/useDefault.ts"],"sourcesContent":["import { useState } from 'react';\n\n/**\n * @name useDefault\n * @description - Hook that returns the default value\n * @category Utilities\n *\n * @template Value The type of the value\n * @param {Value} initialValue The initial value\n * @param {Value} defaultValue The default value\n * @returns {[Value, (value: Value) => void]} An array containing the current value and a function to set the value\n *\n * @example\n * const [value, setValue] = useDefault(initialValue, defaultValue);\n */\nexport const useDefault = <Value>(initialValue: (() => Value) | Value, defaultValue: Value) => {\n const [value, setValue] = useState<Value | null | undefined>(initialValue);\n return [value === undefined || value === null ? defaultValue : value, setValue] as const;\n};\n"],"names":["useDefault","initialValue","defaultValue","value","setValue","useState"],"mappings":";AAeO,MAAMA,IAAa,CAAQC,GAAqCC,MAAwB;AAC7F,QAAM,CAACC,GAAOC,CAAQ,IAAIC,EAAmCJ,CAAY;AACzE,SAAO,CAAwBE,KAAiBD,GAAsBE,CAAQ;AAChF;"}
@@ -1,38 +1,37 @@
1
- import { useState as d, useRef as v, useEffect as y } from "react";
2
- import { throttle as a } from "../../utils/helpers/throttle.mjs";
3
- const b = (e) => {
4
- const o = (e == null ? void 0 : e.enabled) ?? !0, i = (e == null ? void 0 : e.delay) ?? 1e3, [n, r] = d({
1
+ import { useState as r, useRef as u, useEffect as d } from "react";
2
+ import { throttle as v } from "../../utils/helpers/throttle.mjs";
3
+ const f = (t) => {
4
+ const l = t?.enabled ?? !0, a = t?.delay ?? 1e3, [n, c] = r({
5
5
  interval: 0,
6
6
  rotationRate: { alpha: null, beta: null, gamma: null },
7
7
  acceleration: { x: null, y: null, z: null },
8
8
  accelerationIncludingGravity: { x: null, y: null, z: null }
9
- }), l = v(e == null ? void 0 : e.callback);
10
- return l.current = e == null ? void 0 : e.callback, y(() => {
11
- if (!o) return;
12
- const c = a((t) => {
13
- var u;
14
- (u = l.current) == null || u.call(l, t), r({
15
- interval: t.interval,
9
+ }), o = u(t?.callback);
10
+ return o.current = t?.callback, d(() => {
11
+ if (!l) return;
12
+ const i = v((e) => {
13
+ o.current?.(e), c({
14
+ interval: e.interval,
16
15
  rotationRate: {
17
16
  ...n.rotationRate,
18
- ...t.rotationRate
17
+ ...e.rotationRate
19
18
  },
20
19
  acceleration: {
21
20
  ...n.acceleration,
22
- ...t.acceleration
21
+ ...e.acceleration
23
22
  },
24
23
  accelerationIncludingGravity: {
25
24
  ...n.accelerationIncludingGravity,
26
- ...t.accelerationIncludingGravity
25
+ ...e.accelerationIncludingGravity
27
26
  }
28
27
  });
29
- }, i);
30
- return window.addEventListener("devicemotion", c), () => {
31
- window.removeEventListener("devicemotion", c);
28
+ }, a);
29
+ return window.addEventListener("devicemotion", i), () => {
30
+ window.removeEventListener("devicemotion", i);
32
31
  };
33
- }, [i, o]), n;
32
+ }, [a, l]), n;
34
33
  };
35
34
  export {
36
- b as useDeviceMotion
35
+ f as useDeviceMotion
37
36
  };
38
37
  //# sourceMappingURL=useDeviceMotion.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useDeviceMotion.mjs","sources":["../../../../src/hooks/useDeviceMotion/useDeviceMotion.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport { throttle } from '@/utils/helpers';\n\nexport interface UseDeviceMotionReturn {\n acceleration: DeviceMotionEventAcceleration;\n accelerationIncludingGravity: DeviceMotionEventAcceleration;\n interval: DeviceMotionEvent['interval'];\n rotationRate: DeviceMotionEventRotationRate;\n}\n\nexport interface UseDeviceMotionParams {\n /** The delay in milliseconds */\n delay?: number;\n /** Whether to enable the hook */\n enabled?: boolean;\n /** The callback function to be invoked */\n callback?: (event: DeviceMotionEvent) => void;\n}\n\n/**\n * @name useDeviceMotion\n * @description - Hook that work with device motion\n * @category Utilities\n *\n * @browserapi DeviceMotionEvent https://developer.mozilla.org/en-US/docs/Web/API/Window/DeviceMotionEvent\n *\n * @param {number} [delay=1000] The delay in milliseconds\n * @param {(event: DeviceMotionEvent) => void} [callback] The callback function to be invoked\n * @param {boolean} [enabled=true] Whether to enable the hook\n * @returns {UseDeviceMotionReturn} The device motion data and interval\n *\n * @example\n * const { interval, rotationRate, acceleration, accelerationIncludingGravity } = useDeviceMotion();\n */\nexport const useDeviceMotion = (params?: UseDeviceMotionParams) => {\n const enabled = params?.enabled ?? true;\n const delay = params?.delay ?? 1000;\n const [value, setValue] = useState<UseDeviceMotionReturn>({\n interval: 0,\n rotationRate: { alpha: null, beta: null, gamma: null },\n acceleration: { x: null, y: null, z: null },\n accelerationIncludingGravity: { x: null, y: null, z: null }\n });\n const internalCallbackRef = useRef(params?.callback);\n internalCallbackRef.current = params?.callback;\n\n useEffect(() => {\n if (!enabled) return;\n\n const onDeviceMotion = throttle<[DeviceMotionEvent]>((event) => {\n internalCallbackRef.current?.(event);\n setValue({\n interval: event.interval,\n rotationRate: {\n ...value.rotationRate,\n ...event.rotationRate\n },\n acceleration: {\n ...value.acceleration,\n ...event.acceleration\n },\n accelerationIncludingGravity: {\n ...value.accelerationIncludingGravity,\n ...event.accelerationIncludingGravity\n }\n });\n }, delay);\n\n window.addEventListener('devicemotion', onDeviceMotion);\n\n return () => {\n window.removeEventListener('devicemotion', onDeviceMotion);\n };\n }, [delay, enabled]);\n\n return value;\n};\n"],"names":["useDeviceMotion","params","enabled","delay","value","setValue","useState","internalCallbackRef","useRef","useEffect","onDeviceMotion","throttle","event","_a"],"mappings":";;AAmCa,MAAAA,IAAkB,CAACC,MAAmC;AAC3D,QAAAC,KAAUD,KAAA,gBAAAA,EAAQ,YAAW,IAC7BE,KAAQF,KAAA,gBAAAA,EAAQ,UAAS,KACzB,CAACG,GAAOC,CAAQ,IAAIC,EAAgC;AAAA,IACxD,UAAU;AAAA,IACV,cAAc,EAAE,OAAO,MAAM,MAAM,MAAM,OAAO,KAAK;AAAA,IACrD,cAAc,EAAE,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK;AAAA,IAC1C,8BAA8B,EAAE,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK;AAAA,EAAA,CAC3D,GACKC,IAAsBC,EAAOP,KAAA,gBAAAA,EAAQ,QAAQ;AACnD,SAAAM,EAAoB,UAAUN,KAAA,gBAAAA,EAAQ,UAEtCQ,EAAU,MAAM;AACd,QAAI,CAACP,EAAS;AAER,UAAAQ,IAAiBC,EAA8B,CAACC,MAAU;;AAC9D,OAAAC,IAAAN,EAAoB,YAApB,QAAAM,EAAA,KAAAN,GAA8BK,IACrBP,EAAA;AAAA,QACP,UAAUO,EAAM;AAAA,QAChB,cAAc;AAAA,UACZ,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QACX;AAAA,QACA,cAAc;AAAA,UACZ,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QACX;AAAA,QACA,8BAA8B;AAAA,UAC5B,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QAAA;AAAA,MACX,CACD;AAAA,OACAT,CAAK;AAED,kBAAA,iBAAiB,gBAAgBO,CAAc,GAE/C,MAAM;AACJ,aAAA,oBAAoB,gBAAgBA,CAAc;AAAA,IAC3D;AAAA,EAAA,GACC,CAACP,GAAOD,CAAO,CAAC,GAEZE;AACT;"}
1
+ {"version":3,"file":"useDeviceMotion.mjs","sources":["../../../../src/hooks/useDeviceMotion/useDeviceMotion.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport { throttle } from '@/utils/helpers';\n\nexport interface UseDeviceMotionReturn {\n acceleration: DeviceMotionEventAcceleration;\n accelerationIncludingGravity: DeviceMotionEventAcceleration;\n interval: DeviceMotionEvent['interval'];\n rotationRate: DeviceMotionEventRotationRate;\n}\n\nexport interface UseDeviceMotionParams {\n /** The delay in milliseconds */\n delay?: number;\n /** Whether to enable the hook */\n enabled?: boolean;\n /** The callback function to be invoked */\n callback?: (event: DeviceMotionEvent) => void;\n}\n\n/**\n * @name useDeviceMotion\n * @description - Hook that work with device motion\n * @category Utilities\n *\n * @browserapi DeviceMotionEvent https://developer.mozilla.org/en-US/docs/Web/API/Window/DeviceMotionEvent\n *\n * @param {number} [delay=1000] The delay in milliseconds\n * @param {(event: DeviceMotionEvent) => void} [callback] The callback function to be invoked\n * @param {boolean} [enabled=true] Whether to enable the hook\n * @returns {UseDeviceMotionReturn} The device motion data and interval\n *\n * @example\n * const { interval, rotationRate, acceleration, accelerationIncludingGravity } = useDeviceMotion();\n */\nexport const useDeviceMotion = (params?: UseDeviceMotionParams) => {\n const enabled = params?.enabled ?? true;\n const delay = params?.delay ?? 1000;\n const [value, setValue] = useState<UseDeviceMotionReturn>({\n interval: 0,\n rotationRate: { alpha: null, beta: null, gamma: null },\n acceleration: { x: null, y: null, z: null },\n accelerationIncludingGravity: { x: null, y: null, z: null }\n });\n const internalCallbackRef = useRef(params?.callback);\n internalCallbackRef.current = params?.callback;\n\n useEffect(() => {\n if (!enabled) return;\n\n const onDeviceMotion = throttle<[DeviceMotionEvent]>((event) => {\n internalCallbackRef.current?.(event);\n setValue({\n interval: event.interval,\n rotationRate: {\n ...value.rotationRate,\n ...event.rotationRate\n },\n acceleration: {\n ...value.acceleration,\n ...event.acceleration\n },\n accelerationIncludingGravity: {\n ...value.accelerationIncludingGravity,\n ...event.accelerationIncludingGravity\n }\n });\n }, delay);\n\n window.addEventListener('devicemotion', onDeviceMotion);\n\n return () => {\n window.removeEventListener('devicemotion', onDeviceMotion);\n };\n }, [delay, enabled]);\n\n return value;\n};\n"],"names":["useDeviceMotion","params","enabled","delay","value","setValue","useState","internalCallbackRef","useRef","useEffect","onDeviceMotion","throttle","event"],"mappings":";;AAmCO,MAAMA,IAAkB,CAACC,MAAmC;AACjE,QAAMC,IAAUD,GAAQ,WAAW,IAC7BE,IAAQF,GAAQ,SAAS,KACzB,CAACG,GAAOC,CAAQ,IAAIC,EAAgC;AAAA,IACxD,UAAU;AAAA,IACV,cAAc,EAAE,OAAO,MAAM,MAAM,MAAM,OAAO,KAAA;AAAA,IAChD,cAAc,EAAE,GAAG,MAAM,GAAG,MAAM,GAAG,KAAA;AAAA,IACrC,8BAA8B,EAAE,GAAG,MAAM,GAAG,MAAM,GAAG,KAAA;AAAA,EAAK,CAC3D,GACKC,IAAsBC,EAAOP,GAAQ,QAAQ;AACnD,SAAAM,EAAoB,UAAUN,GAAQ,UAEtCQ,EAAU,MAAM;AACd,QAAI,CAACP,EAAS;AAEd,UAAMQ,IAAiBC,EAA8B,CAACC,MAAU;AAC9D,MAAAL,EAAoB,UAAUK,CAAK,GACnCP,EAAS;AAAA,QACP,UAAUO,EAAM;AAAA,QAChB,cAAc;AAAA,UACZ,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QAAA;AAAA,QAEX,cAAc;AAAA,UACZ,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QAAA;AAAA,QAEX,8BAA8B;AAAA,UAC5B,GAAGR,EAAM;AAAA,UACT,GAAGQ,EAAM;AAAA,QAAA;AAAA,MACX,CACD;AAAA,IAAA,GACAT,CAAK;AAER,kBAAO,iBAAiB,gBAAgBO,CAAc,GAE/C,MAAM;AACX,aAAO,oBAAoB,gBAAgBA,CAAc;AAAA,IAAA;AAAA,EAC3D,GACC,CAACP,GAAOD,CAAO,CAAC,GAEZE;AACT;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDeviceOrientation.mjs","sources":["../../../../src/hooks/useDeviceOrientation/useDeviceOrientation.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\n/* The use device orientation value type */\nexport interface UseDeviceOrientationValue {\n /** The current absolute value */\n absolute: boolean;\n /** A number representing the motion of the device around the z axis, express in degrees with values ranging from 0 to 360 */\n alpha: number | null;\n /** A number representing the motion of the device around the x axis, express in degrees with values ranging from -180 to 180 */\n beta: number | null;\n /** A number representing the motion of the device around the y axis, express in degrees with values ranging from -90 to 90 */\n gamma: number | null;\n}\n\n/* The use device orientation return type */\nexport interface UseDeviceOrientationReturn {\n /** Whether the device orientation is supported */\n supported: boolean;\n /** The current device orientation value */\n value: UseDeviceOrientationValue;\n}\n\n/**\n * @name useDeviceOrientation\n * @description - Hook that provides the current device orientation\n * @category Sensors\n *\n * @browserapi DeviceOrientationEvent https://developer.mozilla.org/en-US/docs/Web/API/Window/DeviceOrientationEvent\n *\n * @returns {UseDeviceOrientationReturn} The current device orientation\n *\n * @example\n * const { supported, value } = useDeviceOrientation();\n */\nexport const useDeviceOrientation = (): UseDeviceOrientationReturn => {\n const supported = typeof window !== 'undefined' && 'DeviceOrientationEvent' in window;\n\n const [value, setValue] = useState<UseDeviceOrientationValue>({\n alpha: null,\n beta: null,\n gamma: null,\n absolute: false\n });\n\n useEffect(() => {\n if (!supported) return;\n\n const onDeviceOrientation = (event: DeviceOrientationEvent) =>\n setValue({\n alpha: event.alpha,\n beta: event.beta,\n gamma: event.gamma,\n absolute: event.absolute\n });\n\n window.addEventListener('deviceorientation', onDeviceOrientation);\n return () => {\n window.removeEventListener('deviceorientation', onDeviceOrientation);\n };\n }, []);\n\n return {\n supported,\n value\n };\n};\n"],"names":["useDeviceOrientation","supported","value","setValue","useState","useEffect","onDeviceOrientation","event"],"mappings":";AAkCO,MAAMA,IAAuB,MAAkC;AACpE,QAAMC,IAAY,OAAO,SAAW,OAAe,4BAA4B,QAEzE,CAACC,GAAOC,CAAQ,IAAIC,EAAoC;AAAA,IAC5D,OAAO;AAAA,IACP,MAAM;AAAA,IACN,OAAO;AAAA,IACP,UAAU;AAAA,EAAA,CACX;AAED,SAAAC,EAAU,MAAM;AACd,QAAI,CAACJ,EAAW;AAEV,UAAAK,IAAsB,CAACC,MAC3BJ,EAAS;AAAA,MACP,OAAOI,EAAM;AAAA,MACb,MAAMA,EAAM;AAAA,MACZ,OAAOA,EAAM;AAAA,MACb,UAAUA,EAAM;AAAA,IAAA,CACjB;AAEI,kBAAA,iBAAiB,qBAAqBD,CAAmB,GACzD,MAAM;AACJ,aAAA,oBAAoB,qBAAqBA,CAAmB;AAAA,IACrE;AAAA,EACF,GAAG,EAAE,GAEE;AAAA,IACL,WAAAL;AAAA,IACA,OAAAC;AAAA,EACF;AACF;"}
1
+ {"version":3,"file":"useDeviceOrientation.mjs","sources":["../../../../src/hooks/useDeviceOrientation/useDeviceOrientation.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\n/* The use device orientation value type */\nexport interface UseDeviceOrientationValue {\n /** The current absolute value */\n absolute: boolean;\n /** A number representing the motion of the device around the z axis, express in degrees with values ranging from 0 to 360 */\n alpha: number | null;\n /** A number representing the motion of the device around the x axis, express in degrees with values ranging from -180 to 180 */\n beta: number | null;\n /** A number representing the motion of the device around the y axis, express in degrees with values ranging from -90 to 90 */\n gamma: number | null;\n}\n\n/* The use device orientation return type */\nexport interface UseDeviceOrientationReturn {\n /** Whether the device orientation is supported */\n supported: boolean;\n /** The current device orientation value */\n value: UseDeviceOrientationValue;\n}\n\n/**\n * @name useDeviceOrientation\n * @description - Hook that provides the current device orientation\n * @category Sensors\n *\n * @browserapi DeviceOrientationEvent https://developer.mozilla.org/en-US/docs/Web/API/Window/DeviceOrientationEvent\n *\n * @returns {UseDeviceOrientationReturn} The current device orientation\n *\n * @example\n * const { supported, value } = useDeviceOrientation();\n */\nexport const useDeviceOrientation = (): UseDeviceOrientationReturn => {\n const supported = typeof window !== 'undefined' && 'DeviceOrientationEvent' in window;\n\n const [value, setValue] = useState<UseDeviceOrientationValue>({\n alpha: null,\n beta: null,\n gamma: null,\n absolute: false\n });\n\n useEffect(() => {\n if (!supported) return;\n\n const onDeviceOrientation = (event: DeviceOrientationEvent) =>\n setValue({\n alpha: event.alpha,\n beta: event.beta,\n gamma: event.gamma,\n absolute: event.absolute\n });\n\n window.addEventListener('deviceorientation', onDeviceOrientation);\n return () => {\n window.removeEventListener('deviceorientation', onDeviceOrientation);\n };\n }, []);\n\n return {\n supported,\n value\n };\n};\n"],"names":["useDeviceOrientation","supported","value","setValue","useState","useEffect","onDeviceOrientation","event"],"mappings":";AAkCO,MAAMA,IAAuB,MAAkC;AACpE,QAAMC,IAAY,OAAO,SAAW,OAAe,4BAA4B,QAEzE,CAACC,GAAOC,CAAQ,IAAIC,EAAoC;AAAA,IAC5D,OAAO;AAAA,IACP,MAAM;AAAA,IACN,OAAO;AAAA,IACP,UAAU;AAAA,EAAA,CACX;AAED,SAAAC,EAAU,MAAM;AACd,QAAI,CAACJ,EAAW;AAEhB,UAAMK,IAAsB,CAACC,MAC3BJ,EAAS;AAAA,MACP,OAAOI,EAAM;AAAA,MACb,MAAMA,EAAM;AAAA,MACZ,OAAOA,EAAM;AAAA,MACb,UAAUA,EAAM;AAAA,IAAA,CACjB;AAEH,kBAAO,iBAAiB,qBAAqBD,CAAmB,GACzD,MAAM;AACX,aAAO,oBAAoB,qBAAqBA,CAAmB;AAAA,IAAA;AAAA,EACrE,GACC,EAAE,GAEE;AAAA,IACL,WAAAL;AAAA,IACA,OAAAC;AAAA,EAAA;AAEJ;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDevicePixelRatio.mjs","sources":["../../../../src/hooks/useDevicePixelRatio/useDevicePixelRatio.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\n/** The use device pixel ratio return type */\nexport interface UseDevicePixelRatioReturn {\n /** The ratio of the resolution in physical pixels to the resolution in CSS pixels */\n ratio: number;\n /** Whether the device pixel ratio is supported*/\n supported: boolean;\n}\n\n/**\n * @name useDevicePixelRatio\n * @description - Hook that returns the device's pixel ratio\n * @category Utilities\n *\n * @browserapi window.devicePixelRatio https://developer.mozilla.org/en-US/docs/Web/API/Window/devicePixelRatio\n *\n * @returns {UseDevicePixelRatioReturn} The ratio and supported flag\n *\n * @example\n * const { supported, ratio } = useDevicePixelRatio();\n */\nexport const useDevicePixelRatio = (): UseDevicePixelRatioReturn => {\n const supported =\n typeof window !== 'undefined' &&\n typeof window.matchMedia === 'function' &&\n typeof window.devicePixelRatio === 'number';\n\n const [ratio, setRatio] = useState<number>(window.devicePixelRatio ?? 1);\n\n useEffect(() => {\n if (!supported) return;\n\n const onChange = () => setRatio(window.devicePixelRatio);\n\n const media = window.matchMedia(`(resolution: ${window.devicePixelRatio}dppx)`);\n media.addEventListener('change', onChange);\n return () => {\n media.removeEventListener('change', onChange);\n };\n }, [ratio]);\n\n return { supported, ratio };\n};\n"],"names":["useDevicePixelRatio","supported","ratio","setRatio","useState","useEffect","onChange","media"],"mappings":";AAsBO,MAAMA,IAAsB,MAAiC;AAC5D,QAAAC,IACJ,OAAO,SAAW,OAClB,OAAO,OAAO,cAAe,cAC7B,OAAO,OAAO,oBAAqB,UAE/B,CAACC,GAAOC,CAAQ,IAAIC,EAAiB,OAAO,oBAAoB,CAAC;AAEvE,SAAAC,EAAU,MAAM;AACd,QAAI,CAACJ,EAAW;AAEhB,UAAMK,IAAW,MAAMH,EAAS,OAAO,gBAAgB,GAEjDI,IAAQ,OAAO,WAAW,gBAAgB,OAAO,gBAAgB,OAAO;AACxE,WAAAA,EAAA,iBAAiB,UAAUD,CAAQ,GAClC,MAAM;AACL,MAAAC,EAAA,oBAAoB,UAAUD,CAAQ;AAAA,IAC9C;AAAA,EAAA,GACC,CAACJ,CAAK,CAAC,GAEH,EAAE,WAAAD,GAAW,OAAAC,EAAM;AAC5B;"}
1
+ {"version":3,"file":"useDevicePixelRatio.mjs","sources":["../../../../src/hooks/useDevicePixelRatio/useDevicePixelRatio.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\n/** The use device pixel ratio return type */\nexport interface UseDevicePixelRatioReturn {\n /** The ratio of the resolution in physical pixels to the resolution in CSS pixels */\n ratio: number;\n /** Whether the device pixel ratio is supported*/\n supported: boolean;\n}\n\n/**\n * @name useDevicePixelRatio\n * @description - Hook that returns the device's pixel ratio\n * @category Utilities\n *\n * @browserapi window.devicePixelRatio https://developer.mozilla.org/en-US/docs/Web/API/Window/devicePixelRatio\n *\n * @returns {UseDevicePixelRatioReturn} The ratio and supported flag\n *\n * @example\n * const { supported, ratio } = useDevicePixelRatio();\n */\nexport const useDevicePixelRatio = (): UseDevicePixelRatioReturn => {\n const supported =\n typeof window !== 'undefined' &&\n typeof window.matchMedia === 'function' &&\n typeof window.devicePixelRatio === 'number';\n\n const [ratio, setRatio] = useState<number>(window.devicePixelRatio ?? 1);\n\n useEffect(() => {\n if (!supported) return;\n\n const onChange = () => setRatio(window.devicePixelRatio);\n\n const media = window.matchMedia(`(resolution: ${window.devicePixelRatio}dppx)`);\n media.addEventListener('change', onChange);\n return () => {\n media.removeEventListener('change', onChange);\n };\n }, [ratio]);\n\n return { supported, ratio };\n};\n"],"names":["useDevicePixelRatio","supported","ratio","setRatio","useState","useEffect","onChange","media"],"mappings":";AAsBO,MAAMA,IAAsB,MAAiC;AAClE,QAAMC,IACJ,OAAO,SAAW,OAClB,OAAO,OAAO,cAAe,cAC7B,OAAO,OAAO,oBAAqB,UAE/B,CAACC,GAAOC,CAAQ,IAAIC,EAAiB,OAAO,oBAAoB,CAAC;AAEvE,SAAAC,EAAU,MAAM;AACd,QAAI,CAACJ,EAAW;AAEhB,UAAMK,IAAW,MAAMH,EAAS,OAAO,gBAAgB,GAEjDI,IAAQ,OAAO,WAAW,gBAAgB,OAAO,gBAAgB,OAAO;AAC9E,WAAAA,EAAM,iBAAiB,UAAUD,CAAQ,GAClC,MAAM;AACX,MAAAC,EAAM,oBAAoB,UAAUD,CAAQ;AAAA,IAAA;AAAA,EAC9C,GACC,CAACJ,CAAK,CAAC,GAEH,EAAE,WAAAD,GAAW,OAAAC,EAAA;AACtB;"}
@@ -1 +1 @@
1
- {"version":3,"file":"useDidUpdate.mjs","sources":["../../../../src/hooks/useDidUpdate/useDidUpdate.ts"],"sourcesContent":["import type { DependencyList, EffectCallback } from 'react';\n\nimport { useRef } from 'react';\n\nimport { useIsomorphicLayoutEffect } from '../useIsomorphicLayoutEffect/useIsomorphicLayoutEffect';\n\n/**\n * @name useDidUpdate\n * @description – Hook that triggers the effect callback on updates\n * @category Lifecycle\n *\n * @param {EffectCallback} effect The effect callback\n * @param {DependencyList} [deps] The dependencies list for the effect\n *\n * @example\n * useDidUpdate(() => console.log(\"effect runs on updates\"), deps);\n */\nexport const useDidUpdate = (effect: EffectCallback, deps?: DependencyList) => {\n const mounted = useRef(false);\n\n useIsomorphicLayoutEffect(\n () => () => {\n mounted.current = false;\n },\n []\n );\n\n useIsomorphicLayoutEffect(() => {\n if (mounted.current) {\n return effect();\n }\n\n mounted.current = true;\n return undefined;\n }, deps);\n};\n"],"names":["useDidUpdate","effect","deps","mounted","useRef","useIsomorphicLayoutEffect"],"mappings":";;AAiBa,MAAAA,IAAe,CAACC,GAAwBC,MAA0B;AACvE,QAAAC,IAAUC,EAAO,EAAK;AAE5B,EAAAC;AAAA,IACE,MAAM,MAAM;AACV,MAAAF,EAAQ,UAAU;AAAA,IACpB;AAAA,IACA,CAAA;AAAA,EACF,GAEAE,EAA0B,MAAM;AAC9B,QAAIF,EAAQ;AACV,aAAOF,EAAO;AAGhB,IAAAE,EAAQ,UAAU;AAAA,KAEjBD,CAAI;AACT;"}
1
+ {"version":3,"file":"useDidUpdate.mjs","sources":["../../../../src/hooks/useDidUpdate/useDidUpdate.ts"],"sourcesContent":["import type { DependencyList, EffectCallback } from 'react';\n\nimport { useRef } from 'react';\n\nimport { useIsomorphicLayoutEffect } from '../useIsomorphicLayoutEffect/useIsomorphicLayoutEffect';\n\n/**\n * @name useDidUpdate\n * @description – Hook that triggers the effect callback on updates\n * @category Lifecycle\n *\n * @param {EffectCallback} effect The effect callback\n * @param {DependencyList} [deps] The dependencies list for the effect\n *\n * @example\n * useDidUpdate(() => console.log(\"effect runs on updates\"), deps);\n */\nexport const useDidUpdate = (effect: EffectCallback, deps?: DependencyList) => {\n const mounted = useRef(false);\n\n useIsomorphicLayoutEffect(\n () => () => {\n mounted.current = false;\n },\n []\n );\n\n useIsomorphicLayoutEffect(() => {\n if (mounted.current) {\n return effect();\n }\n\n mounted.current = true;\n return undefined;\n }, deps);\n};\n"],"names":["useDidUpdate","effect","deps","mounted","useRef","useIsomorphicLayoutEffect"],"mappings":";;AAiBO,MAAMA,IAAe,CAACC,GAAwBC,MAA0B;AAC7E,QAAMC,IAAUC,EAAO,EAAK;AAE5B,EAAAC;AAAA,IACE,MAAM,MAAM;AACV,MAAAF,EAAQ,UAAU;AAAA,IAAA;AAAA,IAEpB,CAAA;AAAA,EAAC,GAGHE,EAA0B,MAAM;AAC9B,QAAIF,EAAQ;AACV,aAAOF,EAAA;AAGT,IAAAE,EAAQ,UAAU;AAAA,EACX,GACND,CAAI;AACT;"}