@mantine/hooks
Version:
A collection of 50+ hooks for state and UI management
28 lines (27 loc) • 1.18 kB
JavaScript
"use client";
const require_use_did_update = require("../use-did-update/use-did-update.cjs");
let react = require("react");
//#region packages/@mantine/hooks/src/use-focus-return/use-focus-return.ts
function useFocusReturn({ opened, shouldReturnFocus = true }) {
const lastActiveElement = (0, react.useRef)(null);
const returnFocus = () => {
if (lastActiveElement.current && "focus" in lastActiveElement.current && typeof lastActiveElement.current.focus === "function") lastActiveElement.current?.focus({ preventScroll: true });
};
require_use_did_update.useDidUpdate(() => {
let timeout = -1;
const clearFocusTimeout = (event) => {
if (event.key === "Tab") window.clearTimeout(timeout);
};
document.addEventListener("keydown", clearFocusTimeout);
if (opened) lastActiveElement.current = document.activeElement;
else if (shouldReturnFocus) timeout = window.setTimeout(returnFocus, 10);
return () => {
window.clearTimeout(timeout);
document.removeEventListener("keydown", clearFocusTimeout);
};
}, [opened, shouldReturnFocus]);
return returnFocus;
}
//#endregion
exports.useFocusReturn = useFocusReturn;
//# sourceMappingURL=use-focus-return.cjs.map