@reactuses/core 1.0.3 → 1.0.5

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.
package/index.mjs CHANGED
@@ -2294,4 +2294,68 @@ function useElementBounding(target, options = {}) {
2294
2294
  };
2295
2295
  }
2296
2296
 
2297
- export { useActiveElement, useCounter, useCustomCompareEffect, useDarkMode, useDebounce, useDebounceFn, useDeepCompareEffect, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementSize, useEvent, useEventEmitter, useEventListener, useFavicon, useFileDialog, useFirstMountState, useFps$1 as useFps, useFullscreen, useGeolocation, useIdle, useInfiniteScroll, useIntersectionObserver, useInterval, useIsomorphicLayoutEffect, useKeyModifier, useLatest, useLocalStorage, useLongPress, useMarkdown, useMediaDevices$1 as useMediaDevices, useMediaQuery, useMount, useMountedState, useMouse, useMousePressed, useMutationObserver, useNetwork, useObjectUrl, useOnline, useOrientation, usePageLeave, usePermission, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePrevious, useRafFn, useRafState, useResizeObserver, useScriptTag, useScroll, useScrollLock, useSessionStorage, useTextDirection, useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useTitle, useToggle, useUnmount, useUpdate, useUpdateEffect, useUpdateLayoutEffect, useVirtualList };
2297
+ function useElementVisibility(target, options = {}) {
2298
+ const [visible, setVisible] = useState(false);
2299
+ const callback = useCallback((entries) => {
2300
+ const rect = entries[0].boundingClientRect;
2301
+ setVisible(
2302
+ rect.top <= (window.innerHeight || document.documentElement.clientHeight) && rect.left <= (window.innerWidth || document.documentElement.clientWidth) && rect.bottom >= 0 && rect.right >= 0
2303
+ );
2304
+ }, []);
2305
+ const stop = useIntersectionObserver(target, callback, options);
2306
+ return [visible, stop];
2307
+ }
2308
+
2309
+ function useWindowsFocus() {
2310
+ const [focused, setFocused] = useState(() => {
2311
+ if (!window) {
2312
+ return false;
2313
+ }
2314
+ return window.document.hasFocus();
2315
+ });
2316
+ useEventListener("blur", () => {
2317
+ setFocused(false);
2318
+ });
2319
+ useEventListener("focus", () => {
2320
+ setFocused(true);
2321
+ });
2322
+ return focused;
2323
+ }
2324
+
2325
+ function useWindowSize() {
2326
+ const [windowSize, setWindowSize] = useState({
2327
+ width: 0,
2328
+ height: 0
2329
+ });
2330
+ const handleSize = () => {
2331
+ setWindowSize({
2332
+ width: window.innerWidth,
2333
+ height: window.innerHeight
2334
+ });
2335
+ };
2336
+ useEventListener("resize", handleSize);
2337
+ useIsomorphicLayoutEffect(() => {
2338
+ handleSize();
2339
+ }, []);
2340
+ return windowSize;
2341
+ }
2342
+
2343
+ function useWindowScroll() {
2344
+ const [state, setState] = useRafState(() => ({
2345
+ x: 0,
2346
+ y: 0
2347
+ }));
2348
+ const handleScroll = () => {
2349
+ setState({ x: window.scrollX, y: window.screenY });
2350
+ };
2351
+ useEventListener("scroll", handleScroll, window, {
2352
+ capture: false,
2353
+ passive: true
2354
+ });
2355
+ useIsomorphicLayoutEffect(() => {
2356
+ handleScroll();
2357
+ }, []);
2358
+ return state;
2359
+ }
2360
+
2361
+ export { useActiveElement, useCounter, useCustomCompareEffect, useDarkMode, useDebounce, useDebounceFn, useDeepCompareEffect, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementSize, useElementVisibility, useEvent, useEventEmitter, useEventListener, useFavicon, useFileDialog, useFirstMountState, useFps$1 as useFps, useFullscreen, useGeolocation, useIdle, useInfiniteScroll, useIntersectionObserver, useInterval, useIsomorphicLayoutEffect, useKeyModifier, useLatest, useLocalStorage, useLongPress, useMarkdown, useMediaDevices$1 as useMediaDevices, useMediaQuery, useMount, useMountedState, useMouse, useMousePressed, useMutationObserver, useNetwork, useObjectUrl, useOnline, useOrientation, usePageLeave, usePermission, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePrevious, useRafFn, useRafState, useResizeObserver, useScriptTag, useScroll, useScrollLock, useSessionStorage, useTextDirection, useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useTitle, useToggle, useUnmount, useUpdate, useUpdateEffect, useUpdateLayoutEffect, useVirtualList, useWindowScroll, useWindowSize, useWindowsFocus };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@reactuses/core",
3
- "version": "1.0.3",
3
+ "version": "1.0.5",
4
4
  "main": "./index.cjs",
5
5
  "module": "./index.mjs",
6
6
  "types": "./index.d.ts",