@siberiacancode/reactuse 0.3.2 → 0.3.4

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 (227) hide show
  1. package/dist/cjs/hooks/useActiveElement/useActiveElement.cjs +1 -1
  2. package/dist/cjs/hooks/useActiveElement/useActiveElement.cjs.map +1 -1
  3. package/dist/cjs/hooks/useAudio/useAudio.cjs +1 -1
  4. package/dist/cjs/hooks/useAudio/useAudio.cjs.map +1 -1
  5. package/dist/cjs/hooks/useAutoScroll/useAutoScroll.cjs +1 -1
  6. package/dist/cjs/hooks/useAutoScroll/useAutoScroll.cjs.map +1 -1
  7. package/dist/cjs/hooks/useBreakpoints/useBreakpoints.cjs +1 -1
  8. package/dist/cjs/hooks/useBreakpoints/useBreakpoints.cjs.map +1 -1
  9. package/dist/cjs/hooks/useClickOutside/useClickOutside.cjs +1 -1
  10. package/dist/cjs/hooks/useClickOutside/useClickOutside.cjs.map +1 -1
  11. package/dist/cjs/hooks/useCookie/useCookie.cjs +1 -1
  12. package/dist/cjs/hooks/useCookie/useCookie.cjs.map +1 -1
  13. package/dist/cjs/hooks/useCounter/useCounter.cjs +1 -1
  14. package/dist/cjs/hooks/useCounter/useCounter.cjs.map +1 -1
  15. package/dist/cjs/hooks/useCssVar/useCssVar.cjs +1 -1
  16. package/dist/cjs/hooks/useCssVar/useCssVar.cjs.map +1 -1
  17. package/dist/cjs/hooks/useDeviceMotion/useDeviceMotion.cjs +1 -1
  18. package/dist/cjs/hooks/useDeviceMotion/useDeviceMotion.cjs.map +1 -1
  19. package/dist/cjs/hooks/useDisplayMedia/useDisplayMedia.cjs +1 -1
  20. package/dist/cjs/hooks/useDisplayMedia/useDisplayMedia.cjs.map +1 -1
  21. package/dist/cjs/hooks/useDoubleClick/useDoubleClick.cjs +1 -1
  22. package/dist/cjs/hooks/useDoubleClick/useDoubleClick.cjs.map +1 -1
  23. package/dist/cjs/hooks/useDropZone/useDropZone.cjs +1 -1
  24. package/dist/cjs/hooks/useDropZone/useDropZone.cjs.map +1 -1
  25. package/dist/cjs/hooks/useElementSize/useElementSize.cjs +1 -1
  26. package/dist/cjs/hooks/useElementSize/useElementSize.cjs.map +1 -1
  27. package/dist/cjs/hooks/useEventListener/useEventListener.cjs +1 -1
  28. package/dist/cjs/hooks/useEventListener/useEventListener.cjs.map +1 -1
  29. package/dist/cjs/hooks/useFileDialog/useFileDialog.cjs +1 -1
  30. package/dist/cjs/hooks/useFileDialog/useFileDialog.cjs.map +1 -1
  31. package/dist/cjs/hooks/useFocus/useFocus.cjs +1 -1
  32. package/dist/cjs/hooks/useFocus/useFocus.cjs.map +1 -1
  33. package/dist/cjs/hooks/useFocusTrap/useFocusTrap.cjs +1 -1
  34. package/dist/cjs/hooks/useFocusTrap/useFocusTrap.cjs.map +1 -1
  35. package/dist/cjs/hooks/useFullscreen/useFullscreen.cjs +1 -1
  36. package/dist/cjs/hooks/useFullscreen/useFullscreen.cjs.map +1 -1
  37. package/dist/cjs/hooks/useHash/useHash.cjs +1 -1
  38. package/dist/cjs/hooks/useHash/useHash.cjs.map +1 -1
  39. package/dist/cjs/hooks/useHotkeys/useHotkeys.cjs +1 -1
  40. package/dist/cjs/hooks/useHotkeys/useHotkeys.cjs.map +1 -1
  41. package/dist/cjs/hooks/useHover/useHover.cjs +1 -1
  42. package/dist/cjs/hooks/useHover/useHover.cjs.map +1 -1
  43. package/dist/cjs/hooks/useInfiniteScroll/useInfiniteScroll.cjs +1 -1
  44. package/dist/cjs/hooks/useInfiniteScroll/useInfiniteScroll.cjs.map +1 -1
  45. package/dist/cjs/hooks/useIntersectionObserver/useIntersectionObserver.cjs +1 -1
  46. package/dist/cjs/hooks/useIntersectionObserver/useIntersectionObserver.cjs.map +1 -1
  47. package/dist/cjs/hooks/useInterval/useInterval.cjs +1 -1
  48. package/dist/cjs/hooks/useInterval/useInterval.cjs.map +1 -1
  49. package/dist/cjs/hooks/useKeyPress/useKeyPress.cjs +1 -1
  50. package/dist/cjs/hooks/useKeyPress/useKeyPress.cjs.map +1 -1
  51. package/dist/cjs/hooks/useKeyPressEvent/useKeyPressEvent.cjs +1 -1
  52. package/dist/cjs/hooks/useKeyPressEvent/useKeyPressEvent.cjs.map +1 -1
  53. package/dist/cjs/hooks/useKeyboard/useKeyboard.cjs +1 -1
  54. package/dist/cjs/hooks/useKeyboard/useKeyboard.cjs.map +1 -1
  55. package/dist/cjs/hooks/useKeysPressed/useKeysPressed.cjs +1 -1
  56. package/dist/cjs/hooks/useKeysPressed/useKeysPressed.cjs.map +1 -1
  57. package/dist/cjs/hooks/useLockScroll/useLockScroll.cjs +1 -1
  58. package/dist/cjs/hooks/useLockScroll/useLockScroll.cjs.map +1 -1
  59. package/dist/cjs/hooks/useLongPress/useLongPress.cjs +1 -1
  60. package/dist/cjs/hooks/useLongPress/useLongPress.cjs.map +1 -1
  61. package/dist/cjs/hooks/useMeasure/useMeasure.cjs +1 -1
  62. package/dist/cjs/hooks/useMeasure/useMeasure.cjs.map +1 -1
  63. package/dist/cjs/hooks/useMediaControls/useMediaControls.cjs +1 -1
  64. package/dist/cjs/hooks/useMediaControls/useMediaControls.cjs.map +1 -1
  65. package/dist/cjs/hooks/useMouse/useMouse.cjs +1 -1
  66. package/dist/cjs/hooks/useMouse/useMouse.cjs.map +1 -1
  67. package/dist/cjs/hooks/useMutationObserver/useMutationObserver.cjs +1 -1
  68. package/dist/cjs/hooks/useMutationObserver/useMutationObserver.cjs.map +1 -1
  69. package/dist/cjs/hooks/useOtpCredential/useOtpCredential.cjs +1 -1
  70. package/dist/cjs/hooks/useOtpCredential/useOtpCredential.cjs.map +1 -1
  71. package/dist/cjs/hooks/usePaint/usePaint.cjs +1 -1
  72. package/dist/cjs/hooks/usePaint/usePaint.cjs.map +1 -1
  73. package/dist/cjs/hooks/useParallax/useParallax.cjs +1 -1
  74. package/dist/cjs/hooks/useParallax/useParallax.cjs.map +1 -1
  75. package/dist/cjs/hooks/usePictureInPicture/usePictureInPicture.cjs +1 -1
  76. package/dist/cjs/hooks/usePictureInPicture/usePictureInPicture.cjs.map +1 -1
  77. package/dist/cjs/hooks/useRefState/useRefState.cjs +1 -1
  78. package/dist/cjs/hooks/useRefState/useRefState.cjs.map +1 -1
  79. package/dist/cjs/hooks/useResizeObserver/useResizeObserver.cjs +1 -1
  80. package/dist/cjs/hooks/useResizeObserver/useResizeObserver.cjs.map +1 -1
  81. package/dist/cjs/hooks/useRightClick/useRightClick.cjs +1 -1
  82. package/dist/cjs/hooks/useRightClick/useRightClick.cjs.map +1 -1
  83. package/dist/cjs/hooks/useScroll/useScroll.cjs +1 -1
  84. package/dist/cjs/hooks/useScroll/useScroll.cjs.map +1 -1
  85. package/dist/cjs/hooks/useScrollIntoView/useScrollIntoView.cjs +1 -1
  86. package/dist/cjs/hooks/useScrollIntoView/useScrollIntoView.cjs.map +1 -1
  87. package/dist/cjs/hooks/useScrollTo/useScrollTo.cjs +1 -1
  88. package/dist/cjs/hooks/useScrollTo/useScrollTo.cjs.map +1 -1
  89. package/dist/cjs/hooks/useSticky/useSticky.cjs +1 -1
  90. package/dist/cjs/hooks/useSticky/useSticky.cjs.map +1 -1
  91. package/dist/cjs/hooks/useStopwatch/useStopwatch.cjs +1 -1
  92. package/dist/cjs/hooks/useStopwatch/useStopwatch.cjs.map +1 -1
  93. package/dist/cjs/hooks/useStorage/useStorage.cjs +1 -1
  94. package/dist/cjs/hooks/useStorage/useStorage.cjs.map +1 -1
  95. package/dist/cjs/hooks/useTextDirection/useTextDirection.cjs +1 -1
  96. package/dist/cjs/hooks/useTextDirection/useTextDirection.cjs.map +1 -1
  97. package/dist/cjs/hooks/useTextareaAutosize/useTextareaAutosize.cjs +2 -0
  98. package/dist/cjs/hooks/useTextareaAutosize/useTextareaAutosize.cjs.map +1 -0
  99. package/dist/cjs/hooks/useTimer/useTimer.cjs +1 -1
  100. package/dist/cjs/hooks/useTimer/useTimer.cjs.map +1 -1
  101. package/dist/cjs/hooks/useUrlSearchParam/useUrlSearchParam.cjs +1 -1
  102. package/dist/cjs/hooks/useUrlSearchParam/useUrlSearchParam.cjs.map +1 -1
  103. package/dist/cjs/hooks/useUrlSearchParams/useUrlSearchParams.cjs +1 -1
  104. package/dist/cjs/hooks/useUrlSearchParams/useUrlSearchParams.cjs.map +1 -1
  105. package/dist/cjs/hooks/useVisibility/useVisibility.cjs +1 -1
  106. package/dist/cjs/hooks/useVisibility/useVisibility.cjs.map +1 -1
  107. package/dist/cjs/index.cjs +1 -1
  108. package/dist/cjs/utils/helpers/isTarget.cjs +1 -1
  109. package/dist/cjs/utils/helpers/isTarget.cjs.map +1 -1
  110. package/dist/esm/hooks/useActiveElement/useActiveElement.mjs +13 -13
  111. package/dist/esm/hooks/useActiveElement/useActiveElement.mjs.map +1 -1
  112. package/dist/esm/hooks/useAudio/useAudio.mjs +29 -23
  113. package/dist/esm/hooks/useAudio/useAudio.mjs.map +1 -1
  114. package/dist/esm/hooks/useAutoScroll/useAutoScroll.mjs +24 -24
  115. package/dist/esm/hooks/useAutoScroll/useAutoScroll.mjs.map +1 -1
  116. package/dist/esm/hooks/useBreakpoints/useBreakpoints.mjs +30 -35
  117. package/dist/esm/hooks/useBreakpoints/useBreakpoints.mjs.map +1 -1
  118. package/dist/esm/hooks/useClickOutside/useClickOutside.mjs +15 -14
  119. package/dist/esm/hooks/useClickOutside/useClickOutside.mjs.map +1 -1
  120. package/dist/esm/hooks/useCookie/useCookie.mjs +2 -2
  121. package/dist/esm/hooks/useCookie/useCookie.mjs.map +1 -1
  122. package/dist/esm/hooks/useCounter/useCounter.mjs +2 -2
  123. package/dist/esm/hooks/useCounter/useCounter.mjs.map +1 -1
  124. package/dist/esm/hooks/useCssVar/useCssVar.mjs +8 -8
  125. package/dist/esm/hooks/useCssVar/useCssVar.mjs.map +1 -1
  126. package/dist/esm/hooks/useDeviceMotion/useDeviceMotion.mjs +2 -2
  127. package/dist/esm/hooks/useDeviceMotion/useDeviceMotion.mjs.map +1 -1
  128. package/dist/esm/hooks/useDisplayMedia/useDisplayMedia.mjs +17 -17
  129. package/dist/esm/hooks/useDisplayMedia/useDisplayMedia.mjs.map +1 -1
  130. package/dist/esm/hooks/useDoubleClick/useDoubleClick.mjs +14 -14
  131. package/dist/esm/hooks/useDoubleClick/useDoubleClick.mjs.map +1 -1
  132. package/dist/esm/hooks/useDropZone/useDropZone.mjs +23 -23
  133. package/dist/esm/hooks/useDropZone/useDropZone.mjs.map +1 -1
  134. package/dist/esm/hooks/useElementSize/useElementSize.mjs +14 -14
  135. package/dist/esm/hooks/useElementSize/useElementSize.mjs.map +1 -1
  136. package/dist/esm/hooks/useEventListener/useEventListener.mjs +14 -14
  137. package/dist/esm/hooks/useEventListener/useEventListener.mjs.map +1 -1
  138. package/dist/esm/hooks/useFileDialog/useFileDialog.mjs +2 -2
  139. package/dist/esm/hooks/useFileDialog/useFileDialog.mjs.map +1 -1
  140. package/dist/esm/hooks/useFocus/useFocus.mjs +20 -20
  141. package/dist/esm/hooks/useFocus/useFocus.mjs.map +1 -1
  142. package/dist/esm/hooks/useFocusTrap/useFocusTrap.mjs +21 -21
  143. package/dist/esm/hooks/useFocusTrap/useFocusTrap.mjs.map +1 -1
  144. package/dist/esm/hooks/useFullscreen/useFullscreen.mjs +2 -2
  145. package/dist/esm/hooks/useFullscreen/useFullscreen.mjs.map +1 -1
  146. package/dist/esm/hooks/useHash/useHash.mjs +2 -2
  147. package/dist/esm/hooks/useHash/useHash.mjs.map +1 -1
  148. package/dist/esm/hooks/useHotkeys/useHotkeys.mjs +24 -16
  149. package/dist/esm/hooks/useHotkeys/useHotkeys.mjs.map +1 -1
  150. package/dist/esm/hooks/useHover/useHover.mjs +16 -16
  151. package/dist/esm/hooks/useHover/useHover.mjs.map +1 -1
  152. package/dist/esm/hooks/useInfiniteScroll/useInfiniteScroll.mjs +16 -16
  153. package/dist/esm/hooks/useInfiniteScroll/useInfiniteScroll.mjs.map +1 -1
  154. package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.mjs +26 -18
  155. package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.mjs.map +1 -1
  156. package/dist/esm/hooks/useInterval/useInterval.mjs +2 -2
  157. package/dist/esm/hooks/useInterval/useInterval.mjs.map +1 -1
  158. package/dist/esm/hooks/useKeyPress/useKeyPress.mjs +15 -15
  159. package/dist/esm/hooks/useKeyPress/useKeyPress.mjs.map +1 -1
  160. package/dist/esm/hooks/useKeyPressEvent/useKeyPressEvent.mjs +22 -15
  161. package/dist/esm/hooks/useKeyPressEvent/useKeyPressEvent.mjs.map +1 -1
  162. package/dist/esm/hooks/useKeyboard/useKeyboard.mjs +10 -10
  163. package/dist/esm/hooks/useKeyboard/useKeyboard.mjs.map +1 -1
  164. package/dist/esm/hooks/useKeysPressed/useKeysPressed.mjs +12 -12
  165. package/dist/esm/hooks/useKeysPressed/useKeysPressed.mjs.map +1 -1
  166. package/dist/esm/hooks/useLockScroll/useLockScroll.mjs +23 -23
  167. package/dist/esm/hooks/useLockScroll/useLockScroll.mjs.map +1 -1
  168. package/dist/esm/hooks/useLongPress/useLongPress.mjs +16 -16
  169. package/dist/esm/hooks/useLongPress/useLongPress.mjs.map +1 -1
  170. package/dist/esm/hooks/useMeasure/useMeasure.mjs +15 -15
  171. package/dist/esm/hooks/useMeasure/useMeasure.mjs.map +1 -1
  172. package/dist/esm/hooks/useMediaControls/useMediaControls.mjs +28 -28
  173. package/dist/esm/hooks/useMediaControls/useMediaControls.mjs.map +1 -1
  174. package/dist/esm/hooks/useMouse/useMouse.mjs +17 -17
  175. package/dist/esm/hooks/useMouse/useMouse.mjs.map +1 -1
  176. package/dist/esm/hooks/useMutationObserver/useMutationObserver.mjs +17 -16
  177. package/dist/esm/hooks/useMutationObserver/useMutationObserver.mjs.map +1 -1
  178. package/dist/esm/hooks/useOtpCredential/useOtpCredential.mjs +2 -2
  179. package/dist/esm/hooks/useOtpCredential/useOtpCredential.mjs.map +1 -1
  180. package/dist/esm/hooks/usePaint/usePaint.mjs +31 -31
  181. package/dist/esm/hooks/usePaint/usePaint.mjs.map +1 -1
  182. package/dist/esm/hooks/useParallax/useParallax.mjs +24 -23
  183. package/dist/esm/hooks/useParallax/useParallax.mjs.map +1 -1
  184. package/dist/esm/hooks/usePictureInPicture/usePictureInPicture.mjs +25 -25
  185. package/dist/esm/hooks/usePictureInPicture/usePictureInPicture.mjs.map +1 -1
  186. package/dist/esm/hooks/useRefState/useRefState.mjs +1 -0
  187. package/dist/esm/hooks/useRefState/useRefState.mjs.map +1 -1
  188. package/dist/esm/hooks/useResizeObserver/useResizeObserver.mjs +16 -16
  189. package/dist/esm/hooks/useResizeObserver/useResizeObserver.mjs.map +1 -1
  190. package/dist/esm/hooks/useRightClick/useRightClick.mjs +14 -14
  191. package/dist/esm/hooks/useRightClick/useRightClick.mjs.map +1 -1
  192. package/dist/esm/hooks/useScroll/useScroll.mjs +22 -22
  193. package/dist/esm/hooks/useScroll/useScroll.mjs.map +1 -1
  194. package/dist/esm/hooks/useScrollIntoView/useScrollIntoView.mjs +16 -16
  195. package/dist/esm/hooks/useScrollIntoView/useScrollIntoView.mjs.map +1 -1
  196. package/dist/esm/hooks/useScrollTo/useScrollTo.mjs +10 -10
  197. package/dist/esm/hooks/useScrollTo/useScrollTo.mjs.map +1 -1
  198. package/dist/esm/hooks/useSticky/useSticky.mjs +17 -17
  199. package/dist/esm/hooks/useSticky/useSticky.mjs.map +1 -1
  200. package/dist/esm/hooks/useStopwatch/useStopwatch.mjs +4 -4
  201. package/dist/esm/hooks/useStopwatch/useStopwatch.mjs.map +1 -1
  202. package/dist/esm/hooks/useStorage/useStorage.mjs +2 -2
  203. package/dist/esm/hooks/useStorage/useStorage.mjs.map +1 -1
  204. package/dist/esm/hooks/useTextDirection/useTextDirection.mjs +12 -12
  205. package/dist/esm/hooks/useTextDirection/useTextDirection.mjs.map +1 -1
  206. package/dist/esm/hooks/useTextareaAutosize/useTextareaAutosize.mjs +58 -0
  207. package/dist/esm/hooks/useTextareaAutosize/useTextareaAutosize.mjs.map +1 -0
  208. package/dist/esm/hooks/useTimer/useTimer.mjs +3 -3
  209. package/dist/esm/hooks/useTimer/useTimer.mjs.map +1 -1
  210. package/dist/esm/hooks/useUrlSearchParam/useUrlSearchParam.mjs +2 -2
  211. package/dist/esm/hooks/useUrlSearchParam/useUrlSearchParam.mjs.map +1 -1
  212. package/dist/esm/hooks/useUrlSearchParams/useUrlSearchParams.mjs +2 -2
  213. package/dist/esm/hooks/useUrlSearchParams/useUrlSearchParams.mjs.map +1 -1
  214. package/dist/esm/hooks/useVisibility/useVisibility.mjs +25 -17
  215. package/dist/esm/hooks/useVisibility/useVisibility.mjs.map +1 -1
  216. package/dist/esm/index.mjs +255 -251
  217. package/dist/esm/index.mjs.map +1 -1
  218. package/dist/esm/utils/helpers/isTarget.mjs +10 -8
  219. package/dist/esm/utils/helpers/isTarget.mjs.map +1 -1
  220. package/dist/types/hooks/elements.d.ts +1 -0
  221. package/dist/types/hooks/useBreakpoints/useBreakpoints.d.ts +1 -11
  222. package/dist/types/hooks/useClickOutside/useClickOutside.d.ts +1 -1
  223. package/dist/types/hooks/useHover/useHover.d.ts +6 -6
  224. package/dist/types/hooks/useRefState/useRefState.d.ts +1 -0
  225. package/dist/types/hooks/useTextareaAutosize/useTextareaAutosize.d.ts +60 -0
  226. package/dist/types/utils/helpers/isTarget.d.ts +9 -1
  227. package/package.json +12 -12
@@ -1 +1 @@
1
- {"version":3,"file":"useMeasure.mjs","sources":["../../../../src/hooks/useMeasure/useMeasure.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The use measure return type */\nexport type UseMeasureReturn = Pick<\n DOMRectReadOnly,\n 'bottom' | 'height' | 'left' | 'right' | 'top' | 'width' | 'x' | 'y'\n>;\n\nexport interface UseMeasure {\n (target: HookTarget): UseMeasureReturn;\n\n <Target extends Element>(\n target?: never\n ): UseMeasureReturn & {\n ref: StateRef<Target>;\n };\n}\n\n/**\n * @name useMeasure\n * @description - Hook to measure the size and position of an element\n * @category Browser\n * @usage low\n *\n * @overload\n * @param {HookTarget} target The element to measure\n * @returns {UseMeasureReturn} The element's size and position\n *\n * @example\n * const { x, y, width, height, top, left, bottom, right } = useMeasure(ref);\n *\n * @overload\n * @template Target The element to measure\n * @returns {UseMeasureReturn & { ref: StateRef<Target> }} The element's size and position\n *\n * @example\n * const { ref, x, y, width, height, top, left, bottom, right } = useMeasure();\n */\nexport const useMeasure = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n\n const internalRef = useRefState<Element>();\n const [rect, setRect] = useState({\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n top: 0,\n left: 0,\n bottom: 0,\n right: 0\n });\n\n useEffect(() => {\n if (!target && !internalRef.state) return;\n\n const element = (target ? isTarget.getElement(target) : internalRef.current) as Element;\n if (!element) return;\n\n const resizeObserver = new ResizeObserver((entries) => {\n const entry = entries[0];\n if (!entry) return;\n\n const { x, y, width, height, top, left, bottom, right } = entry.contentRect;\n setRect({ x, y, width, height, top, left, bottom, right });\n });\n\n resizeObserver.observe(element);\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [target, internalRef.state]);\n\n if (target) return rect;\n return { ref: internalRef, ...rect };\n}) as UseMeasure;\n"],"names":["useMeasure","params","target","isTarget","internalRef","useRefState","rect","setRect","useState","useEffect","element","resizeObserver","entries","entry","x","y","width","height","top","left","bottom","right"],"mappings":";;;AA8CO,MAAMA,IAAc,IAAIC,MAAkB;AAC/C,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE5CG,IAAcC,EAAA,GACd,CAACC,GAAMC,CAAO,IAAIC,EAAS;AAAA,IAC/B,GAAG;AAAA,IACH,GAAG;AAAA,IACH,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,KAAK;AAAA,IACL,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,EAAA,CACR;AAuBD,SArBAC,EAAU,MAAM;AACd,QAAI,CAACP,KAAU,CAACE,EAAY,MAAO;AAEnC,UAAMM,IAAWR,IAASC,EAAS,WAAWD,CAAM,IAAIE,EAAY;AACpE,QAAI,CAACM,EAAS;AAEd,UAAMC,IAAiB,IAAI,eAAe,CAACC,MAAY;AACrD,YAAMC,IAAQD,EAAQ,CAAC;AACvB,UAAI,CAACC,EAAO;AAEZ,YAAM,EAAE,GAAAC,GAAG,GAAAC,GAAG,OAAAC,GAAO,QAAAC,GAAQ,KAAAC,GAAK,MAAAC,GAAM,QAAAC,GAAQ,OAAAC,EAAA,IAAUR,EAAM;AAChE,MAAAN,EAAQ,EAAE,GAAAO,GAAG,GAAAC,GAAG,OAAAC,GAAO,QAAAC,GAAQ,KAAAC,GAAK,MAAAC,GAAM,QAAAC,GAAQ,OAAAC,GAAO;AAAA,IAAA,CAC1D;AAED,WAAAV,EAAe,QAAQD,CAAO,GAEvB,MAAM;AACX,MAAAC,EAAe,WAAA;AAAA,IAAW;AAAA,EAC5B,GACC,CAACT,GAAQE,EAAY,KAAK,CAAC,GAE1BF,IAAeI,IACZ,EAAE,KAAKF,GAAa,GAAGE,EAAA;AAChC;"}
1
+ {"version":3,"file":"useMeasure.mjs","sources":["../../../../src/hooks/useMeasure/useMeasure.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The use measure return type */\nexport type UseMeasureReturn = Pick<\n DOMRectReadOnly,\n 'bottom' | 'height' | 'left' | 'right' | 'top' | 'width' | 'x' | 'y'\n>;\n\nexport interface UseMeasure {\n (target: HookTarget): UseMeasureReturn;\n\n <Target extends Element>(\n target?: never\n ): UseMeasureReturn & {\n ref: StateRef<Target>;\n };\n}\n\n/**\n * @name useMeasure\n * @description - Hook to measure the size and position of an element\n * @category Browser\n * @usage low\n *\n * @overload\n * @param {HookTarget} target The element to measure\n * @returns {UseMeasureReturn} The element's size and position\n *\n * @example\n * const { x, y, width, height, top, left, bottom, right } = useMeasure(ref);\n *\n * @overload\n * @template Target The element to measure\n * @returns {UseMeasureReturn & { ref: StateRef<Target> }} The element's size and position\n *\n * @example\n * const { ref, x, y, width, height, top, left, bottom, right } = useMeasure();\n */\nexport const useMeasure = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n\n const internalRef = useRefState<Element>();\n const [rect, setRect] = useState({\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n top: 0,\n left: 0,\n bottom: 0,\n right: 0\n });\n\n useEffect(() => {\n if (!target && !internalRef.state) return;\n\n const element = (target ? isTarget.getElement(target) : internalRef.current) as Element;\n if (!element) return;\n\n const resizeObserver = new ResizeObserver((entries) => {\n const entry = entries[0];\n if (!entry) return;\n\n const { x, y, width, height, top, left, bottom, right } = entry.contentRect;\n setRect({ x, y, width, height, top, left, bottom, right });\n });\n\n resizeObserver.observe(element);\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [target, internalRef.state, isTarget.getRefState(target)]);\n\n if (target) return rect;\n return { ref: internalRef, ...rect };\n}) as UseMeasure;\n"],"names":["useMeasure","params","target","isTarget","internalRef","useRefState","rect","setRect","useState","useEffect","element","resizeObserver","entries","entry","x","y","width","height","top","left","bottom","right"],"mappings":";;;AA8CO,MAAMA,KAAc,IAAIC,MAAkB;AAC/C,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE5CG,IAAcC,EAAA,GACd,CAACC,GAAMC,CAAO,IAAIC,EAAS;AAAA,IAC/B,GAAG;AAAA,IACH,GAAG;AAAA,IACH,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,KAAK;AAAA,IACL,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,EAAA,CACR;AAuBD,SArBAC,EAAU,MAAM;AACd,QAAI,CAACP,KAAU,CAACE,EAAY,MAAO;AAEnC,UAAMM,IAAWR,IAASC,EAAS,WAAWD,CAAM,IAAIE,EAAY;AACpE,QAAI,CAACM,EAAS;AAEd,UAAMC,IAAiB,IAAI,eAAe,CAACC,MAAY;AACrD,YAAMC,IAAQD,EAAQ,CAAC;AACvB,UAAI,CAACC,EAAO;AAEZ,YAAM,EAAE,GAAAC,GAAG,GAAAC,GAAG,OAAAC,GAAO,QAAAC,GAAQ,KAAAC,GAAK,MAAAC,GAAM,QAAAC,GAAQ,OAAAC,EAAA,IAAUR,EAAM;AAChE,MAAAN,EAAQ,EAAE,GAAAO,GAAG,GAAAC,GAAG,OAAAC,GAAO,QAAAC,GAAQ,KAAAC,GAAK,MAAAC,GAAM,QAAAC,GAAQ,OAAAC,GAAO;AAAA,IAAA,CAC1D;AAED,WAAAV,EAAe,QAAQD,CAAO,GAEvB,MAAM;AACX,MAAAC,EAAe,WAAA;AAAA,IAAW;AAAA,EAC5B,GACC,CAACT,GAAQE,EAAY,OAAOD,EAAS,YAAYD,CAAM,CAAC,CAAC,GAExDA,IAAeI,IACZ,EAAE,KAAKF,GAAa,GAAGE,EAAA;AAChC;"}
@@ -1,37 +1,37 @@
1
1
  import { useRef as J, useState as r, useEffect as K } from "react";
2
2
  import { useRefState as N } from "../useRefState/useRefState.mjs";
3
- import { isTarget as C } from "../../utils/helpers/isTarget.mjs";
3
+ import { isTarget as i } from "../../utils/helpers/isTarget.mjs";
4
4
  const O = (n) => {
5
- let a = [];
6
- for (let s = 0; s < n.length; ++s)
7
- a = [...a, [n.start(s), n.end(s)]];
8
- return a;
9
- }, re = (...n) => {
10
- const a = C(n[0]) ? n[0] : void 0, s = a ? typeof n[1] == "object" ? n[1] : { src: n[1] } : typeof n[0] == "object" ? n[0] : { src: n[0] }, c = N(), t = J(null), [i, o] = r(!1), [u, d] = r(0), [j, l] = r(0), [D, m] = r(!1), [W, B] = r(!1), [U, q] = r([]), [z, v] = r(!1), [F, f] = r(!1), [G, g] = r(1), [H, E] = r(!1), [I, L] = r(1);
5
+ let s = [];
6
+ for (let a = 0; a < n.length; ++a)
7
+ s = [...s, [n.start(a), n.end(a)]];
8
+ return s;
9
+ }, re = ((...n) => {
10
+ const s = i(n[0]) ? n[0] : void 0, a = s ? typeof n[1] == "object" ? n[1] : { src: n[1] } : typeof n[0] == "object" ? n[0] : { src: n[0] }, c = N(), t = J(null), [u, o] = r(!1), [d, l] = r(0), [j, m] = r(0), [D, f] = r(!1), [W, B] = r(!1), [U, q] = r([]), [z, v] = r(!1), [F, g] = r(!1), [G, E] = r(1), [H, L] = r(!1), [I, y] = r(1);
11
11
  K(() => {
12
- const e = a ? C.getElement(a) : c.current;
12
+ const e = s ? i.getElement(s) : c.current;
13
13
  if (!e) return;
14
- t.current = e, e.src = s.src, s.type && e.setAttribute("type", s.type), s.media && e.setAttribute("media", s.media), d(e.duration), l(e.currentTime), o(!1), f(e.ended), E(e.muted), L(e.volume), g(e.playbackRate);
15
- const k = () => {
14
+ t.current = e, e.src = a.src, a.type && e.setAttribute("type", a.type), a.media && e.setAttribute("media", a.media), l(e.duration), m(e.currentTime), o(!1), g(e.ended), L(e.muted), y(e.volume), E(e.playbackRate);
15
+ const h = () => {
16
16
  o(!0), v(!1);
17
- }, h = () => o(!1), b = () => B(!0), R = () => v(!0), S = () => m(!0), T = () => m(!1), P = () => {
18
- o(!1), f(!0);
19
- }, M = () => d(e.duration), w = () => l(e.currentTime), V = () => {
20
- E(e.muted), L(e.volume);
21
- }, x = () => g(e.playbackRate), A = () => q(O(e.buffered));
22
- return e.addEventListener("playing", k), e.addEventListener("pause", h), e.addEventListener("waiting", b), e.addEventListener("progress", A), e.addEventListener("stalled", R), e.addEventListener("seeking", S), e.addEventListener("seeked", T), e.addEventListener("ended", P), e.addEventListener("loadedmetadata", M), e.addEventListener("timeupdate", w), e.addEventListener("volumechange", V), e.addEventListener("ratechange", x), () => {
23
- e.removeEventListener("playing", k), e.removeEventListener("pause", h), e.removeEventListener("waiting", b), e.removeEventListener("progress", A), e.removeEventListener("stalled", R), e.removeEventListener("seeking", S), e.removeEventListener("seeked", T), e.removeEventListener("ended", P), e.removeEventListener("loadedmetadata", M), e.removeEventListener("timeupdate", w), e.removeEventListener("volumechange", V), e.removeEventListener("ratechange", x);
17
+ }, b = () => o(!1), R = () => B(!0), S = () => v(!0), T = () => f(!0), P = () => f(!1), M = () => {
18
+ o(!1), g(!0);
19
+ }, w = () => l(e.duration), V = () => m(e.currentTime), x = () => {
20
+ L(e.muted), y(e.volume);
21
+ }, A = () => E(e.playbackRate), C = () => q(O(e.buffered));
22
+ return e.addEventListener("playing", h), e.addEventListener("pause", b), e.addEventListener("waiting", R), e.addEventListener("progress", C), e.addEventListener("stalled", S), e.addEventListener("seeking", T), e.addEventListener("seeked", P), e.addEventListener("ended", M), e.addEventListener("loadedmetadata", w), e.addEventListener("timeupdate", V), e.addEventListener("volumechange", x), e.addEventListener("ratechange", A), () => {
23
+ e.removeEventListener("playing", h), e.removeEventListener("pause", b), e.removeEventListener("waiting", R), e.removeEventListener("progress", C), e.removeEventListener("stalled", S), e.removeEventListener("seeking", T), e.removeEventListener("seeked", P), e.removeEventListener("ended", M), e.removeEventListener("loadedmetadata", w), e.removeEventListener("timeupdate", V), e.removeEventListener("volumechange", x), e.removeEventListener("ratechange", A);
24
24
  };
25
- }, [a, c.state]);
26
- const y = async () => {
25
+ }, [s, c.state, i.getRefState(s)]);
26
+ const p = async () => {
27
27
  const e = t.current;
28
28
  e && await e.play();
29
- }, p = () => {
29
+ }, k = () => {
30
30
  t.current && t.current.pause();
31
31
  };
32
32
  return {
33
- playing: i,
34
- duration: u,
33
+ playing: u,
34
+ duration: d,
35
35
  currentTime: j,
36
36
  seeking: D,
37
37
  waiting: W,
@@ -41,11 +41,11 @@ const O = (n) => {
41
41
  playbackRate: G,
42
42
  muted: H,
43
43
  volume: I,
44
- play: y,
45
- pause: p,
46
- toggle: async () => i ? p() : y(),
44
+ play: p,
45
+ pause: k,
46
+ toggle: async () => u ? k() : p(),
47
47
  seek: (e) => {
48
- t.current && (t.current.currentTime = Math.min(Math.max(e, 0), u));
48
+ t.current && (t.current.currentTime = Math.min(Math.max(e, 0), d));
49
49
  },
50
50
  changeVolume: (e) => {
51
51
  t.current && (t.current.volume = Math.min(Math.max(e, 0), 1));
@@ -59,9 +59,9 @@ const O = (n) => {
59
59
  changePlaybackRate: (e) => {
60
60
  t.current && (t.current.playbackRate = e);
61
61
  },
62
- ...!a && { ref: c }
62
+ ...!s && { ref: c }
63
63
  };
64
- };
64
+ });
65
65
  export {
66
66
  O as timeRangeToArray,
67
67
  re as useMediaControls
@@ -1 +1 @@
1
- {"version":3,"file":"useMediaControls.mjs","sources":["../../../../src/hooks/useMediaControls/useMediaControls.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\nexport const timeRangeToArray = (timeRanges: TimeRanges) => {\n let ranges: [number, number][] = [];\n\n for (let i = 0; i < timeRanges.length; ++i)\n ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n\n return ranges;\n};\n\n/** The media source configuration type */\nexport interface UseMediaSource {\n /** The media attribute of the media */\n media?: string;\n /** The source URL of the media */\n src: string;\n /** The MIME type of the media */\n type?: string;\n}\n\n/** The media controls return type */\nexport interface UseMediaControlsReturn {\n /** Whether the media is currently buffering */\n buffered: [number, number][];\n /** The current playback position in seconds */\n currentTime: number;\n /** The total duration of the media in seconds */\n duration: number;\n /** Whether the media has ended */\n ended: boolean;\n /** Whether the media is currently muted */\n muted: boolean;\n /** The current playback rate (1.0 is normal speed) */\n playbackRate: number;\n /** Whether the media is currently playing */\n playing: boolean;\n /** Whether the media is currently seeking */\n seeking: boolean;\n /** Whether the media is currently stalled */\n stalled: boolean;\n /** The current volume level (0.0 to 1.0) */\n volume: number;\n /** Whether the media is currently waiting */\n waiting: boolean;\n\n /** Set the playback rate */\n changePlaybackRate: (rate: number) => void;\n /** Set the volume level (0.0 to 1.0) */\n changeVolume: (volume: number) => void;\n /** Set the muted state */\n mute: () => void;\n /** Pause the media */\n pause: () => void;\n /** Start playing the media */\n play: () => Promise<void>;\n /** Seek to a specific time in seconds */\n seek: (time: number) => void;\n /** Toggle between play and pause */\n toggle: () => Promise<void>;\n /** Set the unmuted state */\n unmute: () => void;\n}\n\nexport interface UseMediaControls {\n (target: HookTarget, src: string): UseMediaControlsReturn;\n\n (target: HookTarget, options: UseMediaSource): UseMediaControlsReturn;\n\n <Target extends HTMLMediaElement>(\n src: string\n ): UseMediaControlsReturn & {\n ref: StateRef<Target>;\n };\n\n <Target extends HTMLMediaElement>(\n options: UseMediaSource\n ): UseMediaControlsReturn & { ref: StateRef<Target> };\n}\n\n/**\n * @name useMediaControls\n * @description Hook that provides controls for HTML media elements (audio/video)\n * @category Browser\n * @usage low\n *\n * @overload\n * @param {HookTarget} target The target media element\n * @param {string} src The source URL of the media\n * @returns {UseMediaControlsReturn} An object containing media controls and state\n *\n * @example\n * const { playing, play, pause } = useMediaControls(videoRef, 'video.mp4');\n *\n * @overload\n * @param {HookTarget} target The target media element\n * @param {UseMediaSource} options The media source configuration\n * @returns {UseMediaControlsReturn} An object containing media controls and state\n *\n * @example\n * const { playing, play, pause } = useMediaControls(audioRef, { src: 'audio.mp3', type: 'audio/mp3' });\n *\n * @overload\n * @template Target The target media element type\n * @param {string} src The source URL of the media\n * @returns {UseMediaControlsReturn & { ref: StateRef<Target> }} An object containing media controls, state and ref\n *\n * @example\n * const { ref, playing, play, pause } = useMediaControls<HTMLVideoElement>('video.mp4');\n *\n * @overload\n * @template Target The target media element type\n * @param {UseMediaSource} options The media source configuration\n * @returns {UseMediaControlsReturn & { ref: StateRef<Target> }} An object containing media controls, state and ref\n *\n * @example\n * const { ref, playing, play, pause } = useMediaControls<HTMLVideoElement>({ src: 'video.mp4', type: 'video/mp4' });\n */\nexport const useMediaControls = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n const options = (\n target\n ? typeof params[1] === 'object'\n ? params[1]\n : { src: params[1] }\n : typeof params[0] === 'object'\n ? params[0]\n : { src: params[0] }\n ) as UseMediaSource;\n\n const internalRef = useRefState<HTMLMediaElement>();\n const elementRef = useRef<HTMLMediaElement | null>(null);\n\n const [playing, setPlaying] = useState(false);\n const [duration, setDuration] = useState(0);\n const [currentTime, setCurrentTime] = useState(0);\n const [seeking, setSeeking] = useState(false);\n const [waiting, setWaiting] = useState(false);\n const [buffered, setBuffered] = useState<[number, number][]>([]);\n const [stalled, setStalled] = useState(false);\n const [ended, setEnded] = useState(false);\n const [playbackRate, setPlaybackRateState] = useState(1);\n\n const [muted, setMutedState] = useState(false);\n const [volume, setVolumeState] = useState(1);\n\n useEffect(() => {\n const element = (\n target ? isTarget.getElement(target) : internalRef.current\n ) as HTMLMediaElement;\n\n if (!element) return;\n\n elementRef.current = element;\n element.src = options.src;\n\n if (options.type) element.setAttribute('type', options.type);\n if (options.media) element.setAttribute('media', options.media);\n\n setDuration(element.duration);\n setCurrentTime(element.currentTime);\n setPlaying(false);\n setEnded(element.ended);\n setMutedState(element.muted);\n setVolumeState(element.volume);\n setPlaybackRateState(element.playbackRate);\n\n const onPlaying = () => {\n setPlaying(true);\n setStalled(false);\n };\n const onPause = () => setPlaying(false);\n const onWaiting = () => setWaiting(true);\n const onStalled = () => setStalled(true);\n const onSeeking = () => setSeeking(true);\n const onSeeked = () => setSeeking(false);\n const onEnded = () => {\n setPlaying(false);\n setEnded(true);\n };\n const onDurationChange = () => setDuration(element.duration);\n const onTimeUpdate = () => setCurrentTime(element.currentTime);\n const onVolumechange = () => {\n setMutedState(element.muted);\n setVolumeState(element.volume);\n };\n const onRatechange = () => setPlaybackRateState(element.playbackRate);\n const onProgress = () => setBuffered(timeRangeToArray(element.buffered));\n\n element.addEventListener('playing', onPlaying);\n element.addEventListener('pause', onPause);\n element.addEventListener('waiting', onWaiting);\n element.addEventListener('progress', onProgress);\n element.addEventListener('stalled', onStalled);\n element.addEventListener('seeking', onSeeking);\n element.addEventListener('seeked', onSeeked);\n element.addEventListener('ended', onEnded);\n element.addEventListener('loadedmetadata', onDurationChange);\n element.addEventListener('timeupdate', onTimeUpdate);\n element.addEventListener('volumechange', onVolumechange);\n element.addEventListener('ratechange', onRatechange);\n\n return () => {\n element.removeEventListener('playing', onPlaying);\n element.removeEventListener('pause', onPause);\n element.removeEventListener('waiting', onWaiting);\n element.removeEventListener('progress', onProgress);\n element.removeEventListener('stalled', onStalled);\n element.removeEventListener('seeking', onSeeking);\n element.removeEventListener('seeked', onSeeked);\n element.removeEventListener('ended', onEnded);\n element.removeEventListener('loadedmetadata', onDurationChange);\n element.removeEventListener('timeupdate', onTimeUpdate);\n element.removeEventListener('volumechange', onVolumechange);\n element.removeEventListener('ratechange', onRatechange);\n };\n }, [target, internalRef.state]);\n\n const play = async () => {\n const element = elementRef.current;\n if (!element) return;\n\n await element.play();\n };\n\n const pause = () => {\n if (!elementRef.current) return;\n elementRef.current.pause();\n };\n\n const toggle = async () => {\n if (playing) return pause();\n return play();\n };\n\n const seek = (time: number) => {\n if (!elementRef.current) return;\n elementRef.current.currentTime = Math.min(Math.max(time, 0), duration);\n };\n\n const changeVolume = (value: number) => {\n if (!elementRef.current) return;\n elementRef.current.volume = Math.min(Math.max(value, 0), 1);\n };\n\n const mute = () => {\n if (!elementRef.current) return;\n elementRef.current.muted = true;\n };\n\n const unmute = () => {\n if (!elementRef.current) return;\n elementRef.current.muted = false;\n };\n\n const changePlaybackRate = (value: number) => {\n if (!elementRef.current) return;\n elementRef.current.playbackRate = value;\n };\n\n return {\n playing,\n duration,\n currentTime,\n seeking,\n waiting,\n buffered,\n stalled,\n ended,\n playbackRate,\n muted,\n volume,\n\n play,\n pause,\n toggle,\n seek,\n changeVolume,\n mute,\n unmute,\n changePlaybackRate,\n\n ...(!target && { ref: internalRef })\n };\n}) as UseMediaControls;\n"],"names":["timeRangeToArray","timeRanges","ranges","i","useMediaControls","params","target","isTarget","options","internalRef","useRefState","elementRef","useRef","playing","setPlaying","useState","duration","setDuration","currentTime","setCurrentTime","seeking","setSeeking","waiting","setWaiting","buffered","setBuffered","stalled","setStalled","ended","setEnded","playbackRate","setPlaybackRateState","muted","setMutedState","volume","setVolumeState","useEffect","element","onPlaying","onPause","onWaiting","onStalled","onSeeking","onSeeked","onEnded","onDurationChange","onTimeUpdate","onVolumechange","onRatechange","onProgress","play","pause","time","value"],"mappings":"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"}
1
+ {"version":3,"file":"useMediaControls.mjs","sources":["../../../../src/hooks/useMediaControls/useMediaControls.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\nexport const timeRangeToArray = (timeRanges: TimeRanges) => {\n let ranges: [number, number][] = [];\n\n for (let i = 0; i < timeRanges.length; ++i)\n ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n\n return ranges;\n};\n\n/** The media source configuration type */\nexport interface UseMediaSource {\n /** The media attribute of the media */\n media?: string;\n /** The source URL of the media */\n src: string;\n /** The MIME type of the media */\n type?: string;\n}\n\n/** The media controls return type */\nexport interface UseMediaControlsReturn {\n /** Whether the media is currently buffering */\n buffered: [number, number][];\n /** The current playback position in seconds */\n currentTime: number;\n /** The total duration of the media in seconds */\n duration: number;\n /** Whether the media has ended */\n ended: boolean;\n /** Whether the media is currently muted */\n muted: boolean;\n /** The current playback rate (1.0 is normal speed) */\n playbackRate: number;\n /** Whether the media is currently playing */\n playing: boolean;\n /** Whether the media is currently seeking */\n seeking: boolean;\n /** Whether the media is currently stalled */\n stalled: boolean;\n /** The current volume level (0.0 to 1.0) */\n volume: number;\n /** Whether the media is currently waiting */\n waiting: boolean;\n\n /** Set the playback rate */\n changePlaybackRate: (rate: number) => void;\n /** Set the volume level (0.0 to 1.0) */\n changeVolume: (volume: number) => void;\n /** Set the muted state */\n mute: () => void;\n /** Pause the media */\n pause: () => void;\n /** Start playing the media */\n play: () => Promise<void>;\n /** Seek to a specific time in seconds */\n seek: (time: number) => void;\n /** Toggle between play and pause */\n toggle: () => Promise<void>;\n /** Set the unmuted state */\n unmute: () => void;\n}\n\nexport interface UseMediaControls {\n (target: HookTarget, src: string): UseMediaControlsReturn;\n\n (target: HookTarget, options: UseMediaSource): UseMediaControlsReturn;\n\n <Target extends HTMLMediaElement>(\n src: string\n ): UseMediaControlsReturn & {\n ref: StateRef<Target>;\n };\n\n <Target extends HTMLMediaElement>(\n options: UseMediaSource\n ): UseMediaControlsReturn & { ref: StateRef<Target> };\n}\n\n/**\n * @name useMediaControls\n * @description Hook that provides controls for HTML media elements (audio/video)\n * @category Browser\n * @usage low\n *\n * @overload\n * @param {HookTarget} target The target media element\n * @param {string} src The source URL of the media\n * @returns {UseMediaControlsReturn} An object containing media controls and state\n *\n * @example\n * const { playing, play, pause } = useMediaControls(videoRef, 'video.mp4');\n *\n * @overload\n * @param {HookTarget} target The target media element\n * @param {UseMediaSource} options The media source configuration\n * @returns {UseMediaControlsReturn} An object containing media controls and state\n *\n * @example\n * const { playing, play, pause } = useMediaControls(audioRef, { src: 'audio.mp3', type: 'audio/mp3' });\n *\n * @overload\n * @template Target The target media element type\n * @param {string} src The source URL of the media\n * @returns {UseMediaControlsReturn & { ref: StateRef<Target> }} An object containing media controls, state and ref\n *\n * @example\n * const { ref, playing, play, pause } = useMediaControls<HTMLVideoElement>('video.mp4');\n *\n * @overload\n * @template Target The target media element type\n * @param {UseMediaSource} options The media source configuration\n * @returns {UseMediaControlsReturn & { ref: StateRef<Target> }} An object containing media controls, state and ref\n *\n * @example\n * const { ref, playing, play, pause } = useMediaControls<HTMLVideoElement>({ src: 'video.mp4', type: 'video/mp4' });\n */\nexport const useMediaControls = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n const options = (\n target\n ? typeof params[1] === 'object'\n ? params[1]\n : { src: params[1] }\n : typeof params[0] === 'object'\n ? params[0]\n : { src: params[0] }\n ) as UseMediaSource;\n\n const internalRef = useRefState<HTMLMediaElement>();\n const elementRef = useRef<HTMLMediaElement | null>(null);\n\n const [playing, setPlaying] = useState(false);\n const [duration, setDuration] = useState(0);\n const [currentTime, setCurrentTime] = useState(0);\n const [seeking, setSeeking] = useState(false);\n const [waiting, setWaiting] = useState(false);\n const [buffered, setBuffered] = useState<[number, number][]>([]);\n const [stalled, setStalled] = useState(false);\n const [ended, setEnded] = useState(false);\n const [playbackRate, setPlaybackRateState] = useState(1);\n\n const [muted, setMutedState] = useState(false);\n const [volume, setVolumeState] = useState(1);\n\n useEffect(() => {\n const element = (\n target ? isTarget.getElement(target) : internalRef.current\n ) as HTMLMediaElement;\n\n if (!element) return;\n\n elementRef.current = element;\n element.src = options.src;\n\n if (options.type) element.setAttribute('type', options.type);\n if (options.media) element.setAttribute('media', options.media);\n\n setDuration(element.duration);\n setCurrentTime(element.currentTime);\n setPlaying(false);\n setEnded(element.ended);\n setMutedState(element.muted);\n setVolumeState(element.volume);\n setPlaybackRateState(element.playbackRate);\n\n const onPlaying = () => {\n setPlaying(true);\n setStalled(false);\n };\n const onPause = () => setPlaying(false);\n const onWaiting = () => setWaiting(true);\n const onStalled = () => setStalled(true);\n const onSeeking = () => setSeeking(true);\n const onSeeked = () => setSeeking(false);\n const onEnded = () => {\n setPlaying(false);\n setEnded(true);\n };\n const onDurationChange = () => setDuration(element.duration);\n const onTimeUpdate = () => setCurrentTime(element.currentTime);\n const onVolumechange = () => {\n setMutedState(element.muted);\n setVolumeState(element.volume);\n };\n const onRatechange = () => setPlaybackRateState(element.playbackRate);\n const onProgress = () => setBuffered(timeRangeToArray(element.buffered));\n\n element.addEventListener('playing', onPlaying);\n element.addEventListener('pause', onPause);\n element.addEventListener('waiting', onWaiting);\n element.addEventListener('progress', onProgress);\n element.addEventListener('stalled', onStalled);\n element.addEventListener('seeking', onSeeking);\n element.addEventListener('seeked', onSeeked);\n element.addEventListener('ended', onEnded);\n element.addEventListener('loadedmetadata', onDurationChange);\n element.addEventListener('timeupdate', onTimeUpdate);\n element.addEventListener('volumechange', onVolumechange);\n element.addEventListener('ratechange', onRatechange);\n\n return () => {\n element.removeEventListener('playing', onPlaying);\n element.removeEventListener('pause', onPause);\n element.removeEventListener('waiting', onWaiting);\n element.removeEventListener('progress', onProgress);\n element.removeEventListener('stalled', onStalled);\n element.removeEventListener('seeking', onSeeking);\n element.removeEventListener('seeked', onSeeked);\n element.removeEventListener('ended', onEnded);\n element.removeEventListener('loadedmetadata', onDurationChange);\n element.removeEventListener('timeupdate', onTimeUpdate);\n element.removeEventListener('volumechange', onVolumechange);\n element.removeEventListener('ratechange', onRatechange);\n };\n }, [target, internalRef.state, isTarget.getRefState(target)]);\n\n const play = async () => {\n const element = elementRef.current;\n if (!element) return;\n\n await element.play();\n };\n\n const pause = () => {\n if (!elementRef.current) return;\n elementRef.current.pause();\n };\n\n const toggle = async () => {\n if (playing) return pause();\n return play();\n };\n\n const seek = (time: number) => {\n if (!elementRef.current) return;\n elementRef.current.currentTime = Math.min(Math.max(time, 0), duration);\n };\n\n const changeVolume = (value: number) => {\n if (!elementRef.current) return;\n elementRef.current.volume = Math.min(Math.max(value, 0), 1);\n };\n\n const mute = () => {\n if (!elementRef.current) return;\n elementRef.current.muted = true;\n };\n\n const unmute = () => {\n if (!elementRef.current) return;\n elementRef.current.muted = false;\n };\n\n const changePlaybackRate = (value: number) => {\n if (!elementRef.current) return;\n elementRef.current.playbackRate = value;\n };\n\n return {\n playing,\n duration,\n currentTime,\n seeking,\n waiting,\n buffered,\n stalled,\n ended,\n playbackRate,\n muted,\n volume,\n\n play,\n pause,\n toggle,\n seek,\n changeVolume,\n mute,\n unmute,\n changePlaybackRate,\n\n ...(!target && { ref: internalRef })\n };\n}) as UseMediaControls;\n"],"names":["timeRangeToArray","timeRanges","ranges","i","useMediaControls","params","target","isTarget","options","internalRef","useRefState","elementRef","useRef","playing","setPlaying","useState","duration","setDuration","currentTime","setCurrentTime","seeking","setSeeking","waiting","setWaiting","buffered","setBuffered","stalled","setStalled","ended","setEnded","playbackRate","setPlaybackRateState","muted","setMutedState","volume","setVolumeState","useEffect","element","onPlaying","onPause","onWaiting","onStalled","onSeeking","onSeeked","onEnded","onDurationChange","onTimeUpdate","onVolumechange","onRatechange","onProgress","play","pause","time","value"],"mappings":";;;AAUO,MAAMA,IAAmB,CAACC,MAA2B;AAC1D,MAAIC,IAA6B,CAAA;AAEjC,WAASC,IAAI,GAAGA,IAAIF,EAAW,QAAQ,EAAEE;AACvC,IAAAD,IAAS,CAAC,GAAGA,GAAQ,CAACD,EAAW,MAAME,CAAC,GAAGF,EAAW,IAAIE,CAAC,CAAC,CAAC;AAE/D,SAAOD;AACT,GA6GaE,MAAoB,IAAIC,MAAkB;AACrD,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAC5CG,IACJF,IACI,OAAOD,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,KAAKA,EAAO,CAAC,EAAA,IACjB,OAAOA,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,KAAKA,EAAO,CAAC,EAAA,GAGjBI,IAAcC,EAAA,GACdC,IAAaC,EAAgC,IAAI,GAEjD,CAACC,GAASC,CAAU,IAAIC,EAAS,EAAK,GACtC,CAACC,GAAUC,CAAW,IAAIF,EAAS,CAAC,GACpC,CAACG,GAAaC,CAAc,IAAIJ,EAAS,CAAC,GAC1C,CAACK,GAASC,CAAU,IAAIN,EAAS,EAAK,GACtC,CAACO,GAASC,CAAU,IAAIR,EAAS,EAAK,GACtC,CAACS,GAAUC,CAAW,IAAIV,EAA6B,CAAA,CAAE,GACzD,CAACW,GAASC,CAAU,IAAIZ,EAAS,EAAK,GACtC,CAACa,GAAOC,CAAQ,IAAId,EAAS,EAAK,GAClC,CAACe,GAAcC,CAAoB,IAAIhB,EAAS,CAAC,GAEjD,CAACiB,GAAOC,CAAa,IAAIlB,EAAS,EAAK,GACvC,CAACmB,GAAQC,CAAc,IAAIpB,EAAS,CAAC;AAE3C,EAAAqB,EAAU,MAAM;AACd,UAAMC,IACJ/B,IAASC,EAAS,WAAWD,CAAM,IAAIG,EAAY;AAGrD,QAAI,CAAC4B,EAAS;AAEd,IAAA1B,EAAW,UAAU0B,GACrBA,EAAQ,MAAM7B,EAAQ,KAElBA,EAAQ,QAAM6B,EAAQ,aAAa,QAAQ7B,EAAQ,IAAI,GACvDA,EAAQ,SAAO6B,EAAQ,aAAa,SAAS7B,EAAQ,KAAK,GAE9DS,EAAYoB,EAAQ,QAAQ,GAC5BlB,EAAekB,EAAQ,WAAW,GAClCvB,EAAW,EAAK,GAChBe,EAASQ,EAAQ,KAAK,GACtBJ,EAAcI,EAAQ,KAAK,GAC3BF,EAAeE,EAAQ,MAAM,GAC7BN,EAAqBM,EAAQ,YAAY;AAEzC,UAAMC,IAAY,MAAM;AACtB,MAAAxB,EAAW,EAAI,GACfa,EAAW,EAAK;AAAA,IAAA,GAEZY,IAAU,MAAMzB,EAAW,EAAK,GAChC0B,IAAY,MAAMjB,EAAW,EAAI,GACjCkB,IAAY,MAAMd,EAAW,EAAI,GACjCe,IAAY,MAAMrB,EAAW,EAAI,GACjCsB,IAAW,MAAMtB,EAAW,EAAK,GACjCuB,IAAU,MAAM;AACpB,MAAA9B,EAAW,EAAK,GAChBe,EAAS,EAAI;AAAA,IAAA,GAETgB,IAAmB,MAAM5B,EAAYoB,EAAQ,QAAQ,GACrDS,IAAe,MAAM3B,EAAekB,EAAQ,WAAW,GACvDU,IAAiB,MAAM;AAC3B,MAAAd,EAAcI,EAAQ,KAAK,GAC3BF,EAAeE,EAAQ,MAAM;AAAA,IAAA,GAEzBW,IAAe,MAAMjB,EAAqBM,EAAQ,YAAY,GAC9DY,IAAa,MAAMxB,EAAYzB,EAAiBqC,EAAQ,QAAQ,CAAC;AAEvE,WAAAA,EAAQ,iBAAiB,WAAWC,CAAS,GAC7CD,EAAQ,iBAAiB,SAASE,CAAO,GACzCF,EAAQ,iBAAiB,WAAWG,CAAS,GAC7CH,EAAQ,iBAAiB,YAAYY,CAAU,GAC/CZ,EAAQ,iBAAiB,WAAWI,CAAS,GAC7CJ,EAAQ,iBAAiB,WAAWK,CAAS,GAC7CL,EAAQ,iBAAiB,UAAUM,CAAQ,GAC3CN,EAAQ,iBAAiB,SAASO,CAAO,GACzCP,EAAQ,iBAAiB,kBAAkBQ,CAAgB,GAC3DR,EAAQ,iBAAiB,cAAcS,CAAY,GACnDT,EAAQ,iBAAiB,gBAAgBU,CAAc,GACvDV,EAAQ,iBAAiB,cAAcW,CAAY,GAE5C,MAAM;AACX,MAAAX,EAAQ,oBAAoB,WAAWC,CAAS,GAChDD,EAAQ,oBAAoB,SAASE,CAAO,GAC5CF,EAAQ,oBAAoB,WAAWG,CAAS,GAChDH,EAAQ,oBAAoB,YAAYY,CAAU,GAClDZ,EAAQ,oBAAoB,WAAWI,CAAS,GAChDJ,EAAQ,oBAAoB,WAAWK,CAAS,GAChDL,EAAQ,oBAAoB,UAAUM,CAAQ,GAC9CN,EAAQ,oBAAoB,SAASO,CAAO,GAC5CP,EAAQ,oBAAoB,kBAAkBQ,CAAgB,GAC9DR,EAAQ,oBAAoB,cAAcS,CAAY,GACtDT,EAAQ,oBAAoB,gBAAgBU,CAAc,GAC1DV,EAAQ,oBAAoB,cAAcW,CAAY;AAAA,IAAA;AAAA,EACxD,GACC,CAAC1C,GAAQG,EAAY,OAAOF,EAAS,YAAYD,CAAM,CAAC,CAAC;AAE5D,QAAM4C,IAAO,YAAY;AACvB,UAAMb,IAAU1B,EAAW;AAC3B,IAAK0B,KAEL,MAAMA,EAAQ,KAAA;AAAA,EAAK,GAGfc,IAAQ,MAAM;AAClB,IAAKxC,EAAW,WAChBA,EAAW,QAAQ,MAAA;AAAA,EAAM;AAiC3B,SAAO;AAAA,IACL,SAAAE;AAAA,IACA,UAAAG;AAAA,IACA,aAAAE;AAAA,IACA,SAAAE;AAAA,IACA,SAAAE;AAAA,IACA,UAAAE;AAAA,IACA,SAAAE;AAAA,IACA,OAAAE;AAAA,IACA,cAAAE;AAAA,IACA,OAAAE;AAAA,IACA,QAAAE;AAAA,IAEA,MAAAgB;AAAA,IACA,OAAAC;AAAA,IACA,QA7Ca,YACTtC,IAAgBsC,EAAA,IACbD,EAAA;AAAA,IA4CP,MAzCW,CAACE,MAAiB;AAC7B,MAAKzC,EAAW,YAChBA,EAAW,QAAQ,cAAc,KAAK,IAAI,KAAK,IAAIyC,GAAM,CAAC,GAAGpC,CAAQ;AAAA,IAAA;AAAA,IAwCrE,cArCmB,CAACqC,MAAkB;AACtC,MAAK1C,EAAW,YAChBA,EAAW,QAAQ,SAAS,KAAK,IAAI,KAAK,IAAI0C,GAAO,CAAC,GAAG,CAAC;AAAA,IAAA;AAAA,IAoC1D,MAjCW,MAAM;AACjB,MAAK1C,EAAW,YAChBA,EAAW,QAAQ,QAAQ;AAAA,IAAA;AAAA,IAgC3B,QA7Ba,MAAM;AACnB,MAAKA,EAAW,YAChBA,EAAW,QAAQ,QAAQ;AAAA,IAAA;AAAA,IA4B3B,oBAzByB,CAAC0C,MAAkB;AAC5C,MAAK1C,EAAW,YAChBA,EAAW,QAAQ,eAAe0C;AAAA,IAAA;AAAA,IAyBlC,GAAI,CAAC/C,KAAU,EAAE,KAAKG,EAAA;AAAA,EAAY;AAEtC;"}
@@ -1,8 +1,8 @@
1
- import { useState as g, useEffect as p } from "react";
1
+ import { useState as P, useEffect as p } from "react";
2
2
  import { useRefState as E } from "../useRefState/useRefState.mjs";
3
- import { isTarget as u } from "../../utils/helpers/isTarget.mjs";
4
- const M = (...l) => {
5
- const o = u(l[0]) ? l[0] : void 0, [m, n] = g({
3
+ import { isTarget as l } from "../../utils/helpers/isTarget.mjs";
4
+ const R = ((...m) => {
5
+ const o = l(m[0]) ? m[0] : void 0, [c, n] = P({
6
6
  x: 0,
7
7
  y: 0,
8
8
  elementX: 0,
@@ -13,17 +13,17 @@ const M = (...l) => {
13
13
  clientY: 0
14
14
  }), i = E();
15
15
  return p(() => {
16
- const c = (e) => {
17
- const X = o ? u.getElement(o) : i.current, t = {
16
+ const r = (e) => {
17
+ const Y = o ? l.getElement(o) : i.current, t = {
18
18
  x: e.pageX,
19
19
  y: e.pageY,
20
20
  clientX: e.clientX,
21
21
  clientY: e.clientY
22
22
  };
23
- if (X) {
24
- const { left: s, top: a } = X.getBoundingClientRect(), Y = s + window.scrollX, d = a + window.scrollY, w = e.pageX - Y, P = e.pageY - d;
25
- t.elementX = w, t.elementY = P, t.elementPositionX = Y, t.elementPositionY = d, n((f) => ({
26
- ...f,
23
+ if (Y) {
24
+ const { left: s, top: a } = Y.getBoundingClientRect(), d = s + window.scrollX, u = a + window.scrollY, f = e.pageX - d, g = e.pageY - u;
25
+ t.elementX = f, t.elementY = g, t.elementPositionX = d, t.elementPositionY = u, n((w) => ({
26
+ ...w,
27
27
  ...t
28
28
  }));
29
29
  } else
@@ -31,7 +31,7 @@ const M = (...l) => {
31
31
  ...s,
32
32
  ...t
33
33
  }));
34
- }, r = () => {
34
+ }, X = () => {
35
35
  n((e) => ({
36
36
  ...e,
37
37
  x: e.x + window.scrollX - e.elementPositionX,
@@ -40,15 +40,15 @@ const M = (...l) => {
40
40
  elementPositionY: window.scrollY
41
41
  }));
42
42
  };
43
- return document.addEventListener("scroll", r, { passive: !0 }), document.addEventListener("mousemove", c), () => {
44
- document.removeEventListener("scroll", r), document.removeEventListener("mousemove", c);
43
+ return document.addEventListener("scroll", X, { passive: !0 }), document.addEventListener("mousemove", r), () => {
44
+ document.removeEventListener("scroll", X), document.removeEventListener("mousemove", r);
45
45
  };
46
- }, [i.state, o]), o ? m : {
46
+ }, [i.state, o, l.getRefState(o)]), o ? c : {
47
47
  ref: i,
48
- ...m
48
+ ...c
49
49
  };
50
- };
50
+ });
51
51
  export {
52
- M as useMouse
52
+ R as useMouse
53
53
  };
54
54
  //# sourceMappingURL=useMouse.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useMouse.mjs","sources":["../../../../src/hooks/useMouse/useMouse.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The use mouse return type */\nexport interface UseMouseReturn {\n /** The current mouse client x position */\n clientX: number;\n /** The current mouse client y position */\n clientY: number;\n /** The current element position x */\n elementPositionX: number;\n /** The current element position y */\n elementPositionY: number;\n /** The current element x position */\n elementX: number;\n /** The current element y position */\n elementY: number;\n /** The current mouse x position */\n x: number;\n /** The current mouse y position */\n y: number;\n}\n\nexport interface UseMouse {\n (target: HookTarget): UseMouseReturn;\n\n <Target extends Element>(\n target?: never\n ): UseMouseReturn & {\n ref: StateRef<Target>;\n };\n\n (target?: Window): UseMouseReturn;\n}\n\n/**\n * @name useMouse\n * @description - Hook that manages a mouse position\n * @category Sensors\n * @usage low\n *\n * @overload\n * @param {HookTarget} [target=window] The target element to manage the mouse position for\n * @returns {UseMouseReturn} An object with the current mouse position\n *\n * @example\n * const { x, y, clientX, clientY, elementX, elementY, elementPositionX, elementPositionY } = useMouse(ref);\n *\n * @overload\n * @template Target The target element\n * @returns {UseMouseReturn & { ref: StateRef<Target> }} An object with the current mouse position and a ref\n *\n * @example\n * const { ref, x, y, clientX, clientY, elementX, elementY, elementPositionX, elementPositionY } = useMouse();\n */\nexport const useMouse = ((...params: any[]) => {\n const target = isTarget(params[0]) ? params[0] : undefined;\n\n const [value, setValue] = useState<UseMouseReturn>({\n x: 0,\n y: 0,\n elementX: 0,\n elementY: 0,\n elementPositionX: 0,\n elementPositionY: 0,\n clientX: 0,\n clientY: 0\n });\n\n const internalRef = useRefState<Element>();\n\n useEffect(() => {\n const onMouseMove = (event: MouseEvent) => {\n const element = (target ? isTarget.getElement(target) : internalRef.current) as\n | Element\n | undefined;\n\n const updatedValue = {\n x: event.pageX,\n y: event.pageY,\n clientX: event.clientX,\n clientY: event.clientY\n } as typeof value;\n\n if (element) {\n const { left, top } = element.getBoundingClientRect();\n const elementPositionX = left + window.scrollX;\n const elementPositionY = top + window.scrollY;\n const elementX = event.pageX - elementPositionX;\n const elementY = event.pageY - elementPositionY;\n\n updatedValue.elementX = elementX;\n updatedValue.elementY = elementY;\n updatedValue.elementPositionX = elementPositionX;\n updatedValue.elementPositionY = elementPositionY;\n\n setValue((prevValue) => ({\n ...prevValue,\n ...updatedValue\n }));\n } else {\n updatedValue.elementX = event.pageX;\n updatedValue.elementY = event.pageY;\n updatedValue.elementPositionX = 0;\n updatedValue.elementPositionY = 0;\n\n setValue((prevValue) => ({\n ...prevValue,\n ...updatedValue\n }));\n }\n };\n\n const onScroll = () => {\n setValue((prevValue) => ({\n ...prevValue,\n x: prevValue.x + window.scrollX - prevValue.elementPositionX,\n y: prevValue.y + window.scrollY - prevValue.elementPositionY,\n elementPositionX: window.scrollX,\n elementPositionY: window.scrollY\n }));\n };\n\n document.addEventListener('scroll', onScroll, { passive: true });\n document.addEventListener('mousemove', onMouseMove);\n return () => {\n document.removeEventListener('scroll', onScroll);\n document.removeEventListener('mousemove', onMouseMove);\n };\n }, [internalRef.state, target]);\n\n if (target) return value;\n return {\n ref: internalRef,\n ...value\n };\n}) as UseMouse;\n"],"names":["useMouse","params","target","isTarget","value","setValue","useState","internalRef","useRefState","useEffect","onMouseMove","event","element","updatedValue","left","top","elementPositionX","elementPositionY","elementX","elementY","prevValue","onScroll"],"mappings":";;;AA8DO,MAAMA,IAAY,IAAIC,MAAkB;AAC7C,QAAMC,IAASC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE3C,CAACG,GAAOC,CAAQ,IAAIC,EAAyB;AAAA,IACjD,GAAG;AAAA,IACH,GAAG;AAAA,IACH,UAAU;AAAA,IACV,UAAU;AAAA,IACV,kBAAkB;AAAA,IAClB,kBAAkB;AAAA,IAClB,SAAS;AAAA,IACT,SAAS;AAAA,EAAA,CACV,GAEKC,IAAcC,EAAA;AA8DpB,SA5DAC,EAAU,MAAM;AACd,UAAMC,IAAc,CAACC,MAAsB;AACzC,YAAMC,IAAWV,IAASC,EAAS,WAAWD,CAAM,IAAIK,EAAY,SAI9DM,IAAe;AAAA,QACnB,GAAGF,EAAM;AAAA,QACT,GAAGA,EAAM;AAAA,QACT,SAASA,EAAM;AAAA,QACf,SAASA,EAAM;AAAA,MAAA;AAGjB,UAAIC,GAAS;AACX,cAAM,EAAE,MAAAE,GAAM,KAAAC,MAAQH,EAAQ,sBAAA,GACxBI,IAAmBF,IAAO,OAAO,SACjCG,IAAmBF,IAAM,OAAO,SAChCG,IAAWP,EAAM,QAAQK,GACzBG,IAAWR,EAAM,QAAQM;AAE/B,QAAAJ,EAAa,WAAWK,GACxBL,EAAa,WAAWM,GACxBN,EAAa,mBAAmBG,GAChCH,EAAa,mBAAmBI,GAEhCZ,EAAS,CAACe,OAAe;AAAA,UACvB,GAAGA;AAAA,UACH,GAAGP;AAAA,QAAA,EACH;AAAA,MAAA;AAEF,QAAAA,EAAa,WAAWF,EAAM,OAC9BE,EAAa,WAAWF,EAAM,OAC9BE,EAAa,mBAAmB,GAChCA,EAAa,mBAAmB,GAEhCR,EAAS,CAACe,OAAe;AAAA,UACvB,GAAGA;AAAA,UACH,GAAGP;AAAA,QAAA,EACH;AAAA,IACJ,GAGIQ,IAAW,MAAM;AACrB,MAAAhB,EAAS,CAACe,OAAe;AAAA,QACvB,GAAGA;AAAA,QACH,GAAGA,EAAU,IAAI,OAAO,UAAUA,EAAU;AAAA,QAC5C,GAAGA,EAAU,IAAI,OAAO,UAAUA,EAAU;AAAA,QAC5C,kBAAkB,OAAO;AAAA,QACzB,kBAAkB,OAAO;AAAA,MAAA,EACzB;AAAA,IAAA;AAGJ,oBAAS,iBAAiB,UAAUC,GAAU,EAAE,SAAS,IAAM,GAC/D,SAAS,iBAAiB,aAAaX,CAAW,GAC3C,MAAM;AACX,eAAS,oBAAoB,UAAUW,CAAQ,GAC/C,SAAS,oBAAoB,aAAaX,CAAW;AAAA,IAAA;AAAA,EACvD,GACC,CAACH,EAAY,OAAOL,CAAM,CAAC,GAE1BA,IAAeE,IACZ;AAAA,IACL,KAAKG;AAAA,IACL,GAAGH;AAAA,EAAA;AAEP;"}
1
+ {"version":3,"file":"useMouse.mjs","sources":["../../../../src/hooks/useMouse/useMouse.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The use mouse return type */\nexport interface UseMouseReturn {\n /** The current mouse client x position */\n clientX: number;\n /** The current mouse client y position */\n clientY: number;\n /** The current element position x */\n elementPositionX: number;\n /** The current element position y */\n elementPositionY: number;\n /** The current element x position */\n elementX: number;\n /** The current element y position */\n elementY: number;\n /** The current mouse x position */\n x: number;\n /** The current mouse y position */\n y: number;\n}\n\nexport interface UseMouse {\n (target: HookTarget): UseMouseReturn;\n\n <Target extends Element>(\n target?: never\n ): UseMouseReturn & {\n ref: StateRef<Target>;\n };\n\n (target?: Window): UseMouseReturn;\n}\n\n/**\n * @name useMouse\n * @description - Hook that manages a mouse position\n * @category Sensors\n * @usage low\n *\n * @overload\n * @param {HookTarget} [target=window] The target element to manage the mouse position for\n * @returns {UseMouseReturn} An object with the current mouse position\n *\n * @example\n * const { x, y, clientX, clientY, elementX, elementY, elementPositionX, elementPositionY } = useMouse(ref);\n *\n * @overload\n * @template Target The target element\n * @returns {UseMouseReturn & { ref: StateRef<Target> }} An object with the current mouse position and a ref\n *\n * @example\n * const { ref, x, y, clientX, clientY, elementX, elementY, elementPositionX, elementPositionY } = useMouse();\n */\nexport const useMouse = ((...params: any[]) => {\n const target = isTarget(params[0]) ? params[0] : undefined;\n\n const [value, setValue] = useState<UseMouseReturn>({\n x: 0,\n y: 0,\n elementX: 0,\n elementY: 0,\n elementPositionX: 0,\n elementPositionY: 0,\n clientX: 0,\n clientY: 0\n });\n\n const internalRef = useRefState<Element>();\n\n useEffect(() => {\n const onMouseMove = (event: MouseEvent) => {\n const element = (target ? isTarget.getElement(target) : internalRef.current) as\n | Element\n | undefined;\n\n const updatedValue = {\n x: event.pageX,\n y: event.pageY,\n clientX: event.clientX,\n clientY: event.clientY\n } as typeof value;\n\n if (element) {\n const { left, top } = element.getBoundingClientRect();\n const elementPositionX = left + window.scrollX;\n const elementPositionY = top + window.scrollY;\n const elementX = event.pageX - elementPositionX;\n const elementY = event.pageY - elementPositionY;\n\n updatedValue.elementX = elementX;\n updatedValue.elementY = elementY;\n updatedValue.elementPositionX = elementPositionX;\n updatedValue.elementPositionY = elementPositionY;\n\n setValue((prevValue) => ({\n ...prevValue,\n ...updatedValue\n }));\n } else {\n updatedValue.elementX = event.pageX;\n updatedValue.elementY = event.pageY;\n updatedValue.elementPositionX = 0;\n updatedValue.elementPositionY = 0;\n\n setValue((prevValue) => ({\n ...prevValue,\n ...updatedValue\n }));\n }\n };\n\n const onScroll = () => {\n setValue((prevValue) => ({\n ...prevValue,\n x: prevValue.x + window.scrollX - prevValue.elementPositionX,\n y: prevValue.y + window.scrollY - prevValue.elementPositionY,\n elementPositionX: window.scrollX,\n elementPositionY: window.scrollY\n }));\n };\n\n document.addEventListener('scroll', onScroll, { passive: true });\n document.addEventListener('mousemove', onMouseMove);\n return () => {\n document.removeEventListener('scroll', onScroll);\n document.removeEventListener('mousemove', onMouseMove);\n };\n }, [internalRef.state, target, isTarget.getRefState(target)]);\n\n if (target) return value;\n return {\n ref: internalRef,\n ...value\n };\n}) as UseMouse;\n"],"names":["useMouse","params","target","isTarget","value","setValue","useState","internalRef","useRefState","useEffect","onMouseMove","event","element","updatedValue","left","top","elementPositionX","elementPositionY","elementX","elementY","prevValue","onScroll"],"mappings":";;;AA8DO,MAAMA,KAAY,IAAIC,MAAkB;AAC7C,QAAMC,IAASC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE3C,CAACG,GAAOC,CAAQ,IAAIC,EAAyB;AAAA,IACjD,GAAG;AAAA,IACH,GAAG;AAAA,IACH,UAAU;AAAA,IACV,UAAU;AAAA,IACV,kBAAkB;AAAA,IAClB,kBAAkB;AAAA,IAClB,SAAS;AAAA,IACT,SAAS;AAAA,EAAA,CACV,GAEKC,IAAcC,EAAA;AA8DpB,SA5DAC,EAAU,MAAM;AACd,UAAMC,IAAc,CAACC,MAAsB;AACzC,YAAMC,IAAWV,IAASC,EAAS,WAAWD,CAAM,IAAIK,EAAY,SAI9DM,IAAe;AAAA,QACnB,GAAGF,EAAM;AAAA,QACT,GAAGA,EAAM;AAAA,QACT,SAASA,EAAM;AAAA,QACf,SAASA,EAAM;AAAA,MAAA;AAGjB,UAAIC,GAAS;AACX,cAAM,EAAE,MAAAE,GAAM,KAAAC,MAAQH,EAAQ,sBAAA,GACxBI,IAAmBF,IAAO,OAAO,SACjCG,IAAmBF,IAAM,OAAO,SAChCG,IAAWP,EAAM,QAAQK,GACzBG,IAAWR,EAAM,QAAQM;AAE/B,QAAAJ,EAAa,WAAWK,GACxBL,EAAa,WAAWM,GACxBN,EAAa,mBAAmBG,GAChCH,EAAa,mBAAmBI,GAEhCZ,EAAS,CAACe,OAAe;AAAA,UACvB,GAAGA;AAAA,UACH,GAAGP;AAAA,QAAA,EACH;AAAA,MAAA;AAEF,QAAAA,EAAa,WAAWF,EAAM,OAC9BE,EAAa,WAAWF,EAAM,OAC9BE,EAAa,mBAAmB,GAChCA,EAAa,mBAAmB,GAEhCR,EAAS,CAACe,OAAe;AAAA,UACvB,GAAGA;AAAA,UACH,GAAGP;AAAA,QAAA,EACH;AAAA,IACJ,GAGIQ,IAAW,MAAM;AACrB,MAAAhB,EAAS,CAACe,OAAe;AAAA,QACvB,GAAGA;AAAA,QACH,GAAGA,EAAU,IAAI,OAAO,UAAUA,EAAU;AAAA,QAC5C,GAAGA,EAAU,IAAI,OAAO,UAAUA,EAAU;AAAA,QAC5C,kBAAkB,OAAO;AAAA,QACzB,kBAAkB,OAAO;AAAA,MAAA,EACzB;AAAA,IAAA;AAGJ,oBAAS,iBAAiB,UAAUC,GAAU,EAAE,SAAS,IAAM,GAC/D,SAAS,iBAAiB,aAAaX,CAAW,GAC3C,MAAM;AACX,eAAS,oBAAoB,UAAUW,CAAQ,GAC/C,SAAS,oBAAoB,aAAaX,CAAW;AAAA,IAAA;AAAA,EACvD,GACC,CAACH,EAAY,OAAOL,GAAQC,EAAS,YAAYD,CAAM,CAAC,CAAC,GAExDA,IAAeE,IACZ;AAAA,IACL,KAAKG;AAAA,IACL,GAAGH;AAAA,EAAA;AAEP;"}
@@ -1,21 +1,22 @@
1
- import { useState as v, useRef as g, useEffect as h } from "react";
1
+ import { useState as g, useRef as v, useEffect as h } from "react";
2
2
  import { useRefState as O } from "../useRefState/useRefState.mjs";
3
- import { isTarget as b } from "../../utils/helpers/isTarget.mjs";
4
- const k = (...t) => {
5
- const r = b(t[0]) ? t[0] : void 0, e = r ? typeof t[1] == "object" ? t[1] : { onChange: t[1] } : typeof t[0] == "object" ? t[0] : { onChange: t[0] }, c = e?.onChange, s = e?.enabled ?? !0, [u, l] = v(), n = O(), i = g(c);
6
- return i.current = c, h(() => {
7
- if (!s || !r && !n.state) return;
8
- const a = r ? b.getElement(r) : n.current;
9
- if (!a) return;
10
- const o = new MutationObserver((f, d) => {
11
- i.current?.(f, d);
3
+ import { isTarget as c } from "../../utils/helpers/isTarget.mjs";
4
+ const j = ((...t) => {
5
+ const r = c(t[0]) ? t[0] : void 0, e = r ? typeof t[1] == "object" ? t[1] : { onChange: t[1] } : typeof t[0] == "object" ? t[0] : { onChange: t[0] }, s = e?.onChange, u = e?.enabled ?? !0, [i, f] = g(), n = O(), a = v(s);
6
+ return a.current = s, h(() => {
7
+ if (!u || !r && !n.state) return;
8
+ const b = r ? c.getElement(r) : n.current;
9
+ if (!b) return;
10
+ const o = new MutationObserver((l, d) => {
11
+ a.current?.(l, d);
12
12
  });
13
- return l(o), o.observe(a, e), () => {
13
+ return f(o), o.observe(b, e), () => {
14
14
  o.disconnect();
15
15
  };
16
16
  }, [
17
17
  r,
18
18
  n.state,
19
+ c.getRefState(r),
19
20
  e?.childList,
20
21
  e?.attributes,
21
22
  e?.characterData,
@@ -23,13 +24,13 @@ const k = (...t) => {
23
24
  e?.attributeOldValue,
24
25
  e?.characterDataOldValue,
25
26
  e?.attributeFilter,
26
- s
27
- ]), r ? { observer: u } : {
27
+ u
28
+ ]), r ? { observer: i } : {
28
29
  ref: n,
29
- observer: u
30
+ observer: i
30
31
  };
31
- };
32
+ });
32
33
  export {
33
- k as useMutationObserver
34
+ j as useMutationObserver
34
35
  };
35
36
  //# sourceMappingURL=useMutationObserver.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"useMutationObserver.mjs","sources":["../../../../src/hooks/useMutationObserver/useMutationObserver.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The mutation observer callback type */\nexport type UseMutationObserverCallback = (\n mutations: MutationRecord[],\n observer: MutationObserver\n) => void;\n\n/** The mutation observer options type */\nexport interface UseMutationObserverOptions extends MutationObserverInit {\n /** The enabled state of the mutation observer */\n enabled?: boolean;\n /** The callback to execute when mutation is detected */\n onChange?: UseMutationObserverCallback;\n}\n\n/** The mutation observer return type */\nexport interface UseMutationObserverReturn {\n /** The mutation observer instance */\n observer?: MutationObserver;\n}\n\nexport interface UseMutationObserver {\n <Target extends Element>(\n options?: UseMutationObserverOptions,\n target?: never\n ): UseMutationObserverReturn & { ref: StateRef<Target> };\n\n (target: HookTarget, options?: UseMutationObserverOptions): UseMutationObserverReturn;\n\n <Target extends Element>(\n callback: UseMutationObserverCallback,\n target?: never\n ): UseMutationObserverReturn & { ref: StateRef<Target> };\n\n (target: HookTarget, callback: UseMutationObserverCallback): UseMutationObserverReturn;\n}\n\n/**\n * @name useMutationObserver\n * @description - Hook that gives you mutation observer state\n * @category Sensors\n * @usage low\n *\n * @browserapi MutationObserver https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver\n *\n * @overload\n * @param {HookTarget} target The target element to observe\n * @param {boolean} [options.enabled=true] The enabled state of the mutation observer\n * @param {UseMutationObserverCallback} [options.onChange] The callback to execute when mutation is detected\n * @param {boolean} [options.attributes] Set to true if mutations to target's attributes are to be observed\n * @param {boolean} [options.characterData] Set to true if mutations to target's data are to be observed\n * @param {boolean} [options.childList] Set to true if mutations to target's children are to be observed\n * @param {boolean} [options.subtree] Set to true if mutations to not just target, but also target's descendants are to be observed\n * @returns {UseMutationObserverReturn} An object containing the mutation observer state\n *\n * @example\n * const { observer, stop } = useMutationObserver(ref, { childList: true });\n *\n * @overload\n * @template Target The target element\n * @param {boolean} [options.enabled=true] The enabled state of the mutation observer\n * @param {UseMutationObserverCallback} [options.onChange] The callback to execute when mutation is detected\n * @param {boolean} [options.attributes] Set to true if mutations to target's attributes are to be observed\n * @param {boolean} [options.characterData] Set to true if mutations to target's data are to be observed\n * @param {boolean} [options.childList] Set to true if mutations to target's children are to be observed\n * @param {boolean} [options.subtree] Set to true if mutations to not just target, but also target's descendants are to be observed\n * @returns {UseMutationObserverReturn & { ref: StateRef<Target> }} A React ref to attach to the target element\n *\n * @example\n * const { ref, observer, stop } = useMutationObserver({ childList: true });\n *\n * @overload\n * @template Target The target element\n * @param {UseMutationObserverCallback} callback The callback to execute when mutation is detected\n * @returns {UseMutationObserverReturn & { ref: StateRef<Target> }} A React ref to attach to the target element\n *\n * @example\n * const { ref, observer, stop } = useMutationObserver((mutations) => console.log(mutations));\n *\n * @overload\n * @param {UseMutationObserverCallback} callback The callback to execute when mutation is detected\n * @param {HookTarget} target The target element to observe\n * @returns {UseMutationObserverReturn} An object containing the mutation observer state\n *\n * @example\n * const { observer, stop } = useMutationObserver((mutations) => console.log(mutations), ref);\n */\nexport const useMutationObserver = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n\n const options = (\n target\n ? typeof params[1] === 'object'\n ? params[1]\n : { onChange: params[1] }\n : typeof params[0] === 'object'\n ? params[0]\n : { onChange: params[0] }\n ) as UseMutationObserverOptions | undefined;\n\n const callback = options?.onChange;\n const enabled = options?.enabled ?? true;\n\n const [observer, setObserver] = useState<MutationObserver>();\n\n const internalRef = useRefState<Element>();\n const internalCallbackRef = useRef(callback);\n internalCallbackRef.current = callback;\n\n useEffect(() => {\n if (!enabled || (!target && !internalRef.state)) return;\n\n const element = target ? isTarget.getElement(target) : internalRef.current;\n if (!element) return;\n\n const observer = new MutationObserver((mutations, observer) => {\n internalCallbackRef.current?.(mutations, observer);\n });\n\n setObserver(observer);\n observer.observe(element as Element, options);\n\n return () => {\n observer.disconnect();\n };\n }, [\n target,\n internalRef.state,\n options?.childList,\n options?.attributes,\n options?.characterData,\n options?.subtree,\n options?.attributeOldValue,\n options?.characterDataOldValue,\n options?.attributeFilter,\n enabled\n ]);\n\n if (target) return { observer };\n return {\n ref: internalRef,\n observer\n };\n}) as UseMutationObserver;\n"],"names":["useMutationObserver","params","target","isTarget","options","callback","enabled","observer","setObserver","useState","internalRef","useRefState","internalCallbackRef","useRef","useEffect","element","mutations"],"mappings":";;;AAgGO,MAAMA,IAAuB,IAAIC,MAAkB;AACxD,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE5CG,IACJF,IACI,OAAOD,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,UAAUA,EAAO,CAAC,EAAA,IACtB,OAAOA,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,UAAUA,EAAO,CAAC,EAAA,GAGtBI,IAAWD,GAAS,UACpBE,IAAUF,GAAS,WAAW,IAE9B,CAACG,GAAUC,CAAW,IAAIC,EAAA,GAE1BC,IAAcC,EAAA,GACdC,IAAsBC,EAAOR,CAAQ;AAgC3C,SA/BAO,EAAoB,UAAUP,GAE9BS,EAAU,MAAM;AACd,QAAI,CAACR,KAAY,CAACJ,KAAU,CAACQ,EAAY,MAAQ;AAEjD,UAAMK,IAAUb,IAASC,EAAS,WAAWD,CAAM,IAAIQ,EAAY;AACnE,QAAI,CAACK,EAAS;AAEd,UAAMR,IAAW,IAAI,iBAAiB,CAACS,GAAWT,MAAa;AAC7D,MAAAK,EAAoB,UAAUI,GAAWT,CAAQ;AAAA,IAAA,CAClD;AAED,WAAAC,EAAYD,CAAQ,GACpBA,EAAS,QAAQQ,GAAoBX,CAAO,GAErC,MAAM;AACXG,MAAAA,EAAS,WAAA;AAAA,IAAW;AAAA,EACtB,GACC;AAAA,IACDL;AAAA,IACAQ,EAAY;AAAA,IACZN,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTE;AAAA,EAAA,CACD,GAEGJ,IAAe,EAAE,UAAAK,EAAA,IACd;AAAA,IACL,KAAKG;AAAA,IACL,UAAAH;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"useMutationObserver.mjs","sources":["../../../../src/hooks/useMutationObserver/useMutationObserver.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react';\n\nimport type { HookTarget } from '@/utils/helpers';\n\nimport { isTarget } from '@/utils/helpers';\n\nimport type { StateRef } from '../useRefState/useRefState';\n\nimport { useRefState } from '../useRefState/useRefState';\n\n/** The mutation observer callback type */\nexport type UseMutationObserverCallback = (\n mutations: MutationRecord[],\n observer: MutationObserver\n) => void;\n\n/** The mutation observer options type */\nexport interface UseMutationObserverOptions extends MutationObserverInit {\n /** The enabled state of the mutation observer */\n enabled?: boolean;\n /** The callback to execute when mutation is detected */\n onChange?: UseMutationObserverCallback;\n}\n\n/** The mutation observer return type */\nexport interface UseMutationObserverReturn {\n /** The mutation observer instance */\n observer?: MutationObserver;\n}\n\nexport interface UseMutationObserver {\n <Target extends Element>(\n options?: UseMutationObserverOptions,\n target?: never\n ): UseMutationObserverReturn & { ref: StateRef<Target> };\n\n (target: HookTarget, options?: UseMutationObserverOptions): UseMutationObserverReturn;\n\n <Target extends Element>(\n callback: UseMutationObserverCallback,\n target?: never\n ): UseMutationObserverReturn & { ref: StateRef<Target> };\n\n (target: HookTarget, callback: UseMutationObserverCallback): UseMutationObserverReturn;\n}\n\n/**\n * @name useMutationObserver\n * @description - Hook that gives you mutation observer state\n * @category Sensors\n * @usage low\n *\n * @browserapi MutationObserver https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver\n *\n * @overload\n * @param {HookTarget} target The target element to observe\n * @param {boolean} [options.enabled=true] The enabled state of the mutation observer\n * @param {UseMutationObserverCallback} [options.onChange] The callback to execute when mutation is detected\n * @param {boolean} [options.attributes] Set to true if mutations to target's attributes are to be observed\n * @param {boolean} [options.characterData] Set to true if mutations to target's data are to be observed\n * @param {boolean} [options.childList] Set to true if mutations to target's children are to be observed\n * @param {boolean} [options.subtree] Set to true if mutations to not just target, but also target's descendants are to be observed\n * @returns {UseMutationObserverReturn} An object containing the mutation observer state\n *\n * @example\n * const { observer, stop } = useMutationObserver(ref, { childList: true });\n *\n * @overload\n * @template Target The target element\n * @param {boolean} [options.enabled=true] The enabled state of the mutation observer\n * @param {UseMutationObserverCallback} [options.onChange] The callback to execute when mutation is detected\n * @param {boolean} [options.attributes] Set to true if mutations to target's attributes are to be observed\n * @param {boolean} [options.characterData] Set to true if mutations to target's data are to be observed\n * @param {boolean} [options.childList] Set to true if mutations to target's children are to be observed\n * @param {boolean} [options.subtree] Set to true if mutations to not just target, but also target's descendants are to be observed\n * @returns {UseMutationObserverReturn & { ref: StateRef<Target> }} A React ref to attach to the target element\n *\n * @example\n * const { ref, observer, stop } = useMutationObserver({ childList: true });\n *\n * @overload\n * @template Target The target element\n * @param {UseMutationObserverCallback} callback The callback to execute when mutation is detected\n * @returns {UseMutationObserverReturn & { ref: StateRef<Target> }} A React ref to attach to the target element\n *\n * @example\n * const { ref, observer, stop } = useMutationObserver((mutations) => console.log(mutations));\n *\n * @overload\n * @param {UseMutationObserverCallback} callback The callback to execute when mutation is detected\n * @param {HookTarget} target The target element to observe\n * @returns {UseMutationObserverReturn} An object containing the mutation observer state\n *\n * @example\n * const { observer, stop } = useMutationObserver((mutations) => console.log(mutations), ref);\n */\nexport const useMutationObserver = ((...params: any[]) => {\n const target = (isTarget(params[0]) ? params[0] : undefined) as HookTarget | undefined;\n\n const options = (\n target\n ? typeof params[1] === 'object'\n ? params[1]\n : { onChange: params[1] }\n : typeof params[0] === 'object'\n ? params[0]\n : { onChange: params[0] }\n ) as UseMutationObserverOptions | undefined;\n\n const callback = options?.onChange;\n const enabled = options?.enabled ?? true;\n\n const [observer, setObserver] = useState<MutationObserver>();\n\n const internalRef = useRefState<Element>();\n const internalCallbackRef = useRef(callback);\n internalCallbackRef.current = callback;\n\n useEffect(() => {\n if (!enabled || (!target && !internalRef.state)) return;\n\n const element = target ? isTarget.getElement(target) : internalRef.current;\n if (!element) return;\n\n const observer = new MutationObserver((mutations, observer) => {\n internalCallbackRef.current?.(mutations, observer);\n });\n\n setObserver(observer);\n observer.observe(element as Element, options);\n\n return () => {\n observer.disconnect();\n };\n }, [\n target,\n internalRef.state,\n isTarget.getRefState(target),\n options?.childList,\n options?.attributes,\n options?.characterData,\n options?.subtree,\n options?.attributeOldValue,\n options?.characterDataOldValue,\n options?.attributeFilter,\n enabled\n ]);\n\n if (target) return { observer };\n return {\n ref: internalRef,\n observer\n };\n}) as UseMutationObserver;\n"],"names":["useMutationObserver","params","target","isTarget","options","callback","enabled","observer","setObserver","useState","internalRef","useRefState","internalCallbackRef","useRef","useEffect","element","mutations"],"mappings":";;;AAgGO,MAAMA,KAAuB,IAAIC,MAAkB;AACxD,QAAMC,IAAUC,EAASF,EAAO,CAAC,CAAC,IAAIA,EAAO,CAAC,IAAI,QAE5CG,IACJF,IACI,OAAOD,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,UAAUA,EAAO,CAAC,EAAA,IACtB,OAAOA,EAAO,CAAC,KAAM,WACnBA,EAAO,CAAC,IACR,EAAE,UAAUA,EAAO,CAAC,EAAA,GAGtBI,IAAWD,GAAS,UACpBE,IAAUF,GAAS,WAAW,IAE9B,CAACG,GAAUC,CAAW,IAAIC,EAAA,GAE1BC,IAAcC,EAAA,GACdC,IAAsBC,EAAOR,CAAQ;AAiC3C,SAhCAO,EAAoB,UAAUP,GAE9BS,EAAU,MAAM;AACd,QAAI,CAACR,KAAY,CAACJ,KAAU,CAACQ,EAAY,MAAQ;AAEjD,UAAMK,IAAUb,IAASC,EAAS,WAAWD,CAAM,IAAIQ,EAAY;AACnE,QAAI,CAACK,EAAS;AAEd,UAAMR,IAAW,IAAI,iBAAiB,CAACS,GAAWT,MAAa;AAC7D,MAAAK,EAAoB,UAAUI,GAAWT,CAAQ;AAAA,IAAA,CAClD;AAED,WAAAC,EAAYD,CAAQ,GACpBA,EAAS,QAAQQ,GAAoBX,CAAO,GAErC,MAAM;AACXG,MAAAA,EAAS,WAAA;AAAA,IAAW;AAAA,EACtB,GACC;AAAA,IACDL;AAAA,IACAQ,EAAY;AAAA,IACZP,EAAS,YAAYD,CAAM;AAAA,IAC3BE,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTA,GAAS;AAAA,IACTE;AAAA,EAAA,CACD,GAEGJ,IAAe,EAAE,UAAAK,EAAA,IACd;AAAA,IACL,KAAKG;AAAA,IACL,UAAAH;AAAA,EAAA;AAEJ;"}
@@ -1,5 +1,5 @@
1
1
  import { useState as i, useRef as l } from "react";
2
- const b = (...t) => {
2
+ const b = ((...t) => {
3
3
  const e = typeof navigator < "u" && "OTPCredential" in navigator && !!navigator.OTPCredential, c = typeof t[0] == "function" ? t[0] : t[0]?.onSuccess, s = typeof t[0] == "function" ? t[0]?.onError : void 0, [a, n] = i(!1), r = l(new AbortController());
4
4
  return { supported: e, abort: () => {
5
5
  r.current.abort(), r.current = new AbortController(), r.current.signal.onabort = () => n(!0);
@@ -17,7 +17,7 @@ const b = (...t) => {
17
17
  }
18
18
  }
19
19
  } };
20
- };
20
+ });
21
21
  export {
22
22
  b as useOtpCredential
23
23
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useOtpCredential.mjs","sources":["../../../../src/hooks/useOtpCredential/useOtpCredential.ts"],"sourcesContent":["import { useRef, useState } from 'react';\n\ndeclare global {\n interface OTPOptions {\n readonly transport: string[];\n }\n\n interface CredentialRequestOptions {\n readonly otp: OTPOptions;\n }\n\n interface Credential {\n readonly code: string;\n }\n}\n\n/* The use otp credential callback type */\nexport type UseOtpCredentialCallback = (otp: Credential | null) => void;\n\n/* The use otp credential options type */\nexport interface UseOtpCredentialParams {\n /* The callback function to be invoked on error */\n onError: (error: any) => void;\n /* The callback function to be invoked on success */\n onSuccess: (credential: Credential | null) => void;\n}\n\n/* The use otp credential return type */\nexport interface UseOtpCredentialReturn {\n /* The abort function */\n abort: AbortController['abort'];\n /* The aborted state of the query */\n aborted: boolean;\n /* The supported state of the otp credential */\n supported: boolean;\n /* The get otp credential function */\n get: () => Promise<Credential | null>;\n}\n\nexport interface UseOtpCredential {\n (callback?: UseOtpCredentialCallback): UseOtpCredentialReturn;\n\n (params?: UseOtpCredentialParams): UseOtpCredentialReturn;\n}\n\n/**\n * @name useOtpCredential\n * @description - Hook that creates an otp credential\n * @category Browser\n * @usage low\n *\n * @browserapi navigator.credentials https://developer.mozilla.org/en-US/docs/Web/API/Navigator/credentials\n *\n * @overload\n * @param {UseOtpCredentialCallback} callback The callback function to be invoked\n * @returns {UseOtpCredentialReturn}\n *\n * @example\n * useOtpCredential((credential) => console.log(credential));\n *\n * @overload\n * @param {UseOtpCredentialCallback} params.onSuccess The callback function to be invoked on success\n * @param {UseOtpCredentialCallback} params.onError The callback function to be invoked on error\n * @returns {UseOtpCredentialReturn}\n *\n * @example\n * useOtpCredential({ onSuccess: (credential) => console.log(credential), onError: (error) => console.log(error) });\n */\nexport const useOtpCredential = ((...params: any[]) => {\n const supported =\n typeof navigator !== 'undefined' && 'OTPCredential' in navigator && !!navigator.OTPCredential;\n\n const onSuccess =\n typeof params[0] === 'function'\n ? (params[0] as UseOtpCredentialCallback | undefined)\n : (params[0] as UseOtpCredentialParams | undefined)?.onSuccess;\n\n const onError =\n typeof params[0] === 'function'\n ? (params[0] as UseOtpCredentialParams | undefined)?.onError\n : undefined;\n\n const [aborted, setAborted] = useState(false);\n\n const abortControllerRef = useRef<AbortController>(new AbortController());\n\n const get = async () => {\n if (!supported) return;\n\n abortControllerRef.current = new AbortController();\n try {\n const credential = await navigator.credentials.get({\n otp: { transport: ['sms'] },\n signal: abortControllerRef.current.signal\n });\n onSuccess?.(credential);\n setAborted(false);\n return credential;\n } catch (error) {\n onError?.(error);\n }\n };\n\n const abort = () => {\n abortControllerRef.current.abort();\n abortControllerRef.current = new AbortController();\n abortControllerRef.current.signal.onabort = () => setAborted(true);\n };\n\n return { supported, abort, aborted, get };\n}) as UseOtpCredential;\n"],"names":["useOtpCredential","params","supported","onSuccess","onError","aborted","setAborted","useState","abortControllerRef","useRef","credential","error"],"mappings":";AAoEO,MAAMA,IAAoB,IAAIC,MAAkB;AACrD,QAAMC,IACJ,OAAO,YAAc,OAAe,mBAAmB,aAAa,CAAC,CAAC,UAAU,eAE5EC,IACJ,OAAOF,EAAO,CAAC,KAAM,aAChBA,EAAO,CAAC,IACRA,EAAO,CAAC,GAA0C,WAEnDG,IACJ,OAAOH,EAAO,CAAC,KAAM,aAChBA,EAAO,CAAC,GAA0C,UACnD,QAEA,CAACI,GAASC,CAAU,IAAIC,EAAS,EAAK,GAEtCC,IAAqBC,EAAwB,IAAI,iBAAiB;AAyBxE,SAAO,EAAE,WAAAP,GAAW,OANN,MAAM;AAClB,IAAAM,EAAmB,QAAQ,MAAA,GAC3BA,EAAmB,UAAU,IAAI,gBAAA,GACjCA,EAAmB,QAAQ,OAAO,UAAU,MAAMF,EAAW,EAAI;AAAA,EAAA,GAGxC,SAAAD,GAAS,KAvBxB,YAAY;AACtB,QAAKH,GAEL;AAAA,MAAAM,EAAmB,UAAU,IAAI,gBAAA;AACjC,UAAI;AACF,cAAME,IAAa,MAAM,UAAU,YAAY,IAAI;AAAA,UACjD,KAAK,EAAE,WAAW,CAAC,KAAK,EAAA;AAAA,UACxB,QAAQF,EAAmB,QAAQ;AAAA,QAAA,CACpC;AACD,eAAAL,IAAYO,CAAU,GACtBJ,EAAW,EAAK,GACTI;AAAA,MAAA,SACAC,GAAO;AACd,QAAAP,IAAUO,CAAK;AAAA,MAAA;AAAA;AAAA,EACjB,EASkC;AACtC;"}
1
+ {"version":3,"file":"useOtpCredential.mjs","sources":["../../../../src/hooks/useOtpCredential/useOtpCredential.ts"],"sourcesContent":["import { useRef, useState } from 'react';\n\ndeclare global {\n interface OTPOptions {\n readonly transport: string[];\n }\n\n interface CredentialRequestOptions {\n readonly otp: OTPOptions;\n }\n\n interface Credential {\n readonly code: string;\n }\n}\n\n/* The use otp credential callback type */\nexport type UseOtpCredentialCallback = (otp: Credential | null) => void;\n\n/* The use otp credential options type */\nexport interface UseOtpCredentialParams {\n /* The callback function to be invoked on error */\n onError: (error: any) => void;\n /* The callback function to be invoked on success */\n onSuccess: (credential: Credential | null) => void;\n}\n\n/* The use otp credential return type */\nexport interface UseOtpCredentialReturn {\n /* The abort function */\n abort: AbortController['abort'];\n /* The aborted state of the query */\n aborted: boolean;\n /* The supported state of the otp credential */\n supported: boolean;\n /* The get otp credential function */\n get: () => Promise<Credential | null>;\n}\n\nexport interface UseOtpCredential {\n (callback?: UseOtpCredentialCallback): UseOtpCredentialReturn;\n\n (params?: UseOtpCredentialParams): UseOtpCredentialReturn;\n}\n\n/**\n * @name useOtpCredential\n * @description - Hook that creates an otp credential\n * @category Browser\n * @usage low\n *\n * @browserapi navigator.credentials https://developer.mozilla.org/en-US/docs/Web/API/Navigator/credentials\n *\n * @overload\n * @param {UseOtpCredentialCallback} callback The callback function to be invoked\n * @returns {UseOtpCredentialReturn}\n *\n * @example\n * useOtpCredential((credential) => console.log(credential));\n *\n * @overload\n * @param {UseOtpCredentialCallback} params.onSuccess The callback function to be invoked on success\n * @param {UseOtpCredentialCallback} params.onError The callback function to be invoked on error\n * @returns {UseOtpCredentialReturn}\n *\n * @example\n * useOtpCredential({ onSuccess: (credential) => console.log(credential), onError: (error) => console.log(error) });\n */\nexport const useOtpCredential = ((...params: any[]) => {\n const supported =\n typeof navigator !== 'undefined' && 'OTPCredential' in navigator && !!navigator.OTPCredential;\n\n const onSuccess =\n typeof params[0] === 'function'\n ? (params[0] as UseOtpCredentialCallback | undefined)\n : (params[0] as UseOtpCredentialParams | undefined)?.onSuccess;\n\n const onError =\n typeof params[0] === 'function'\n ? (params[0] as UseOtpCredentialParams | undefined)?.onError\n : undefined;\n\n const [aborted, setAborted] = useState(false);\n\n const abortControllerRef = useRef<AbortController>(new AbortController());\n\n const get = async () => {\n if (!supported) return;\n\n abortControllerRef.current = new AbortController();\n try {\n const credential = await navigator.credentials.get({\n otp: { transport: ['sms'] },\n signal: abortControllerRef.current.signal\n });\n onSuccess?.(credential);\n setAborted(false);\n return credential;\n } catch (error) {\n onError?.(error);\n }\n };\n\n const abort = () => {\n abortControllerRef.current.abort();\n abortControllerRef.current = new AbortController();\n abortControllerRef.current.signal.onabort = () => setAborted(true);\n };\n\n return { supported, abort, aborted, get };\n}) as UseOtpCredential;\n"],"names":["useOtpCredential","params","supported","onSuccess","onError","aborted","setAborted","useState","abortControllerRef","useRef","credential","error"],"mappings":";AAoEO,MAAMA,KAAoB,IAAIC,MAAkB;AACrD,QAAMC,IACJ,OAAO,YAAc,OAAe,mBAAmB,aAAa,CAAC,CAAC,UAAU,eAE5EC,IACJ,OAAOF,EAAO,CAAC,KAAM,aAChBA,EAAO,CAAC,IACRA,EAAO,CAAC,GAA0C,WAEnDG,IACJ,OAAOH,EAAO,CAAC,KAAM,aAChBA,EAAO,CAAC,GAA0C,UACnD,QAEA,CAACI,GAASC,CAAU,IAAIC,EAAS,EAAK,GAEtCC,IAAqBC,EAAwB,IAAI,iBAAiB;AAyBxE,SAAO,EAAE,WAAAP,GAAW,OANN,MAAM;AAClB,IAAAM,EAAmB,QAAQ,MAAA,GAC3BA,EAAmB,UAAU,IAAI,gBAAA,GACjCA,EAAmB,QAAQ,OAAO,UAAU,MAAMF,EAAW,EAAI;AAAA,EAAA,GAGxC,SAAAD,GAAS,KAvBxB,YAAY;AACtB,QAAKH,GAEL;AAAA,MAAAM,EAAmB,UAAU,IAAI,gBAAA;AACjC,UAAI;AACF,cAAME,IAAa,MAAM,UAAU,YAAY,IAAI;AAAA,UACjD,KAAK,EAAE,WAAW,CAAC,KAAK,EAAA;AAAA,UACxB,QAAQF,EAAmB,QAAQ;AAAA,QAAA,CACpC;AACD,eAAAL,IAAYO,CAAU,GACtBJ,EAAW,EAAK,GACTI;AAAA,MAAA,SACAC,GAAO;AACd,QAAAP,IAAUO,CAAK;AAAA,MAAA;AAAA;AAAA,EACjB,EASkC;AACtC;"}
@@ -1,7 +1,7 @@
1
- import { useRef as C, useState as A, useEffect as B } from "react";
1
+ import { useRef as P, useState as A, useEffect as S } from "react";
2
2
  import { useEvent as M } from "../useEvent/useEvent.mjs";
3
- import { useRefState as S } from "../useRefState/useRefState.mjs";
4
- import { isTarget as P } from "../../utils/helpers/isTarget.mjs";
3
+ import { useRefState as B } from "../useRefState/useRefState.mjs";
4
+ import { isTarget as b } from "../../utils/helpers/isTarget.mjs";
5
5
  const U = 10;
6
6
  class x {
7
7
  x;
@@ -59,34 +59,34 @@ class q {
59
59
  return this.brush.update(t), this.points.push(this.getBrushCoordinates()), !0;
60
60
  const e = this.pointer.getDistanceTo(this.brush), o = this.pointer.getAngleTo(this.brush);
61
61
  if (Math.round((e - this.radius) * 10) / 10 > 0) {
62
- const l = o + Math.PI / 2;
62
+ const f = o + Math.PI / 2;
63
63
  return this.brush.update({
64
- x: this.brush.x + Math.sin(l) * (e - this.radius),
65
- y: this.brush.y - Math.cos(l) * (e - this.radius)
64
+ x: this.brush.x + Math.sin(f) * (e - this.radius),
65
+ y: this.brush.y - Math.cos(f) * (e - this.radius)
66
66
  }), this.points.push(this.getBrushCoordinates()), !0;
67
67
  }
68
68
  return !1;
69
69
  }
70
70
  }
71
- const Y = (...p) => {
72
- const t = P(p[0]) ? p[0] : void 0, e = (t ? p[1] : p[0]) ?? {}, o = e?.color ?? "black", h = e?.opacity ?? 1, l = e?.radius ?? U, s = C(
71
+ const Y = ((...p) => {
72
+ const t = b(p[0]) ? p[0] : void 0, e = (t ? p[1] : p[0]) ?? {}, o = e?.color ?? "black", h = e?.opacity ?? 1, f = e?.radius ?? U, s = P(
73
73
  new q({
74
74
  x: 0,
75
75
  y: 0,
76
76
  radius: e?.radius ?? U,
77
77
  smooth: e?.smooth ?? !1
78
78
  })
79
- ), [m, b] = A(!1), g = S(), n = C(null), c = (r, u, f, a) => {
79
+ ), [m, w] = A(!1), g = B(), n = P(null), c = (r, u, l, a) => {
80
80
  if (!n.current) return;
81
- n.current.globalAlpha = f, n.current.strokeStyle = u, n.current.lineWidth = a * 2, n.current.lineCap = "round", n.current.lineJoin = "round";
81
+ n.current.globalAlpha = l, n.current.strokeStyle = u, n.current.lineWidth = a * 2, n.current.lineCap = "round", n.current.lineJoin = "round";
82
82
  let i = r[0], y = r[1];
83
83
  n.current.beginPath();
84
84
  for (let d = 1; d < r.length; d += 1) {
85
- const L = {
85
+ const C = {
86
86
  x: i.x + (y.x - i.x) / 2,
87
87
  y: i.y + (y.y - i.y) / 2
88
88
  };
89
- n.current.quadraticCurveTo(i.x, i.y, L.x, L.y), i = r[d], y = r[d + 1];
89
+ n.current.quadraticCurveTo(i.x, i.y, C.x, C.y), i = r[d], y = r[d + 1];
90
90
  }
91
91
  n.current.lineTo(i.x, i.y), n.current.stroke();
92
92
  }, v = () => {
@@ -96,7 +96,7 @@ const Y = (...p) => {
96
96
  n.current.canvas.width,
97
97
  n.current.canvas.height
98
98
  );
99
- }, w = M((r) => {
99
+ }, E = M((r) => {
100
100
  if (!m) return;
101
101
  e?.onMouseMove?.(r, s.current);
102
102
  const u = { x: r.offsetX, y: r.offsetY };
@@ -107,43 +107,43 @@ const Y = (...p) => {
107
107
  n.current.canvas.height
108
108
  ), s.current.lines.forEach(
109
109
  ({ points: a, color: i, opacity: y, radius: d }) => c(a, i, y, d)
110
- ), c(s.current.points, o, h, l));
111
- }), E = M((r) => {
110
+ ), c(s.current.points, o, h, f));
111
+ }), T = M((r) => {
112
112
  if (!n.current) return;
113
113
  const u = { x: r.offsetX, y: r.offsetY };
114
- s.current.brush.update(u), s.current.points.push(u), c(s.current.points, o, h, l), e?.onMouseDown?.(r, s.current), b(!0);
115
- }), T = M((r) => {
114
+ s.current.brush.update(u), s.current.points.push(u), c(s.current.points, o, h, f), e?.onMouseDown?.(r, s.current), w(!0);
115
+ }), R = M((r) => {
116
116
  n.current && (s.current.points.length && (s.current.lines.push({
117
117
  points: s.current.points,
118
118
  color: o,
119
119
  opacity: h,
120
- radius: l
121
- }), s.current.points = []), e?.onMouseUp?.(r, s.current), b(!1));
122
- }), R = () => {
120
+ radius: f
121
+ }), s.current.points = []), e?.onMouseUp?.(r, s.current), w(!1));
122
+ }), D = () => {
123
123
  n.current && (v(), s.current.lines = [], s.current.points = []);
124
- }, D = () => {
124
+ }, L = () => {
125
125
  n.current && (v(), s.current.lines.pop(), s.current.lines.forEach(
126
- ({ points: r, color: u, opacity: f, radius: a }) => c(r, u, f, a)
126
+ ({ points: r, color: u, opacity: l, radius: a }) => c(r, u, l, a)
127
127
  ));
128
128
  };
129
- return B(() => {
129
+ return S(() => {
130
130
  if (!t && !g.state) return;
131
- const r = t ? P.getElement(t) : g.current;
131
+ const r = t ? b.getElement(t) : g.current;
132
132
  if (r)
133
133
  return n.current = r.getContext("2d"), e?.initialLines && (s.current.lines = e.initialLines, e.initialLines.forEach(
134
- ({ points: u, color: f, opacity: a, radius: i }) => c(u, f, a, i)
135
- )), r.addEventListener("mousedown", E), r.addEventListener("mousemove", w), r.addEventListener("mouseup", T), () => {
136
- r && (r.removeEventListener("mousedown", E), r.removeEventListener("mousemove", w), r.removeEventListener("mouseup", T));
134
+ ({ points: u, color: l, opacity: a, radius: i }) => c(u, l, a, i)
135
+ )), r.addEventListener("mousedown", T), r.addEventListener("mousemove", E), r.addEventListener("mouseup", R), () => {
136
+ r && (r.removeEventListener("mousedown", T), r.removeEventListener("mousemove", E), r.removeEventListener("mouseup", R));
137
137
  };
138
- }, [t, g.state]), t ? { drawing: m, clear: R, undo: D, draw: c, lines: s.current.lines } : {
138
+ }, [t, g.state, b.getRefState(t)]), t ? { drawing: m, clear: D, undo: L, draw: c, lines: s.current.lines } : {
139
139
  ref: g,
140
140
  drawing: m,
141
- clear: R,
142
- undo: D,
141
+ clear: D,
142
+ undo: L,
143
143
  draw: c,
144
144
  lines: s.current.lines
145
145
  };
146
- };
146
+ });
147
147
  export {
148
148
  q as Paint,
149
149
  x as Pointer,