UNPKG

@nextui-org/react-utils

Version:

A set of utilities for react on client side

173 lines (171 loc) 5.07 kB
"use client"; "use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/dom.ts var dom_exports = {}; __export(dom_exports, { areRectsIntersecting: () => areRectsIntersecting, canUseDOM: () => canUseDOM, createDOMRef: () => createDOMRef, createFocusableRef: () => createFocusableRef, detectBrowser: () => detectBrowser, detectDeviceType: () => detectDeviceType, detectOS: () => detectOS, detectTouch: () => detectTouch, getUserAgentBrowser: () => getUserAgentBrowser, getUserAgentOS: () => getUserAgentOS, isBrowser: () => isBrowser, useDOMRef: () => useDOMRef, useFocusableRef: () => useFocusableRef, useSyncRef: () => useSyncRef }); module.exports = __toCommonJS(dom_exports); var import_react = require("react"); function canUseDOM() { return !!(typeof window !== "undefined" && window.document && window.document.createElement); } var isBrowser = canUseDOM(); function getUserAgentBrowser(navigator) { const { userAgent: ua, vendor } = navigator; const android = /(android)/i.test(ua); switch (true) { case /CriOS/.test(ua): return "Chrome for iOS"; case /Edg\//.test(ua): return "Edge"; case (android && /Silk\//.test(ua)): return "Silk"; case (/Chrome/.test(ua) && /Google Inc/.test(vendor)): return "Chrome"; case /Firefox\/\d+\.\d+$/.test(ua): return "Firefox"; case android: return "AOSP"; case /MSIE|Trident/.test(ua): return "IE"; case (/Safari/.test(navigator.userAgent) && /Apple Computer/.test(ua)): return "Safari"; case /AppleWebKit/.test(ua): return "WebKit"; default: return null; } } function getUserAgentOS(navigator) { const { userAgent: ua, platform } = navigator; switch (true) { case /Android/.test(ua): return "Android"; case /iPhone|iPad|iPod/.test(platform): return "iOS"; case /Win/.test(platform): return "Windows"; case /Mac/.test(platform): return "Mac"; case /CrOS/.test(ua): return "Chrome OS"; case /Firefox/.test(ua): return "Firefox OS"; default: return null; } } function detectDeviceType(navigator) { const { userAgent: ua } = navigator; if (/(tablet)|(iPad)|(Nexus 9)/i.test(ua)) return "tablet"; if (/(mobi)/i.test(ua)) return "phone"; return "desktop"; } function detectOS(os) { if (!isBrowser) return false; return getUserAgentOS(window.navigator) === os; } function detectBrowser(browser) { if (!isBrowser) return false; return getUserAgentBrowser(window.navigator) === browser; } function detectTouch() { if (!isBrowser) return false; return window.ontouchstart === null && window.ontouchmove === null && window.ontouchend === null; } function createDOMRef(ref) { return { UNSAFE_getDOMNode() { return ref.current; } }; } function createFocusableRef(domRef, focusableRef = domRef) { return { ...createDOMRef(domRef), focus() { if (focusableRef.current) { focusableRef.current.focus(); } } }; } function useDOMRef(ref) { const domRef = (0, import_react.useRef)(null); (0, import_react.useImperativeHandle)(ref, () => domRef.current); return domRef; } function useFocusableRef(ref, focusableRef) { const domRef = (0, import_react.useRef)(null); (0, import_react.useImperativeHandle)(ref, () => createFocusableRef(domRef, focusableRef)); return domRef; } function useSyncRef(context, ref) { (0, import_react.useLayoutEffect)(() => { if (context && context.ref && ref && ref.current) { context.ref.current = ref.current; return () => { var _a; if ((_a = context.ref) == null ? void 0 : _a.current) { context.ref.current = null; } }; } }, [context, ref]); } function areRectsIntersecting(rect1, rect2) { return rect1 && rect2 && rect1.x < rect2.x + rect2.width && rect1.x + rect1.width > rect2.x && rect1.y < rect2.y + rect2.height && rect1.y + rect1.height > rect2.y; } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { areRectsIntersecting, canUseDOM, createDOMRef, createFocusableRef, detectBrowser, detectDeviceType, detectOS, detectTouch, getUserAgentBrowser, getUserAgentOS, isBrowser, useDOMRef, useFocusableRef, useSyncRef });