UNPKG

ahooks

Version:
32 lines 1.13 kB
import { __read } from "tslib"; import { useState } from 'react'; import useEventListener from '../useEventListener'; export default function useFocusWithin(target, options) { var _a = __read(useState(false), 2), isFocusWithin = _a[0], setIsFocusWithin = _a[1]; var _b = options || {}, onFocus = _b.onFocus, onBlur = _b.onBlur, onChange = _b.onChange; useEventListener('focusin', function (e) { if (!isFocusWithin) { onFocus === null || onFocus === void 0 ? void 0 : onFocus(e); onChange === null || onChange === void 0 ? void 0 : onChange(true); setIsFocusWithin(true); } }, { target: target }); useEventListener('focusout', function (e) { var _a, _b; if (isFocusWithin && !((_b = (_a = e.currentTarget) === null || _a === void 0 ? void 0 : _a.contains) === null || _b === void 0 ? void 0 : _b.call(_a, e.relatedTarget))) { onBlur === null || onBlur === void 0 ? void 0 : onBlur(e); onChange === null || onChange === void 0 ? void 0 : onChange(false); setIsFocusWithin(false); } }, { target: target }); return isFocusWithin; }