"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = useWinClick; var _shadow = require("rc-util/lib/Dom/shadow"); var _warning = require("rc-util/lib/warning"); var React = _interopRequireWildcard(require("react")); var _util = require("../util"); function useWinClick(open, clickToHide, targetEle, popupEle, mask, maskClosable, inPopupOrChild, triggerOpen) { var openRef = React.useRef(open); openRef.current = open; var popupPointerDownRef = React.useRef(false); // Click to hide is special action since click popup element should not hide React.useEffect(function () { if (clickToHide && popupEle && (!mask || maskClosable)) { var onPointerDown = function onPointerDown() { popupPointerDownRef.current = false; }; var onTriggerClose = function onTriggerClose(e) { var _e$composedPath; if (openRef.current && !inPopupOrChild(((_e$composedPath = e.composedPath) === null || _e$composedPath === void 0 || (_e$composedPath = _e$composedPath.call(e)) === null || _e$composedPath === void 0 ? void 0 : _e$composedPath[0]) || e.target) && !popupPointerDownRef.current) { triggerOpen(false); } }; var win = (0, _util.getWin)(popupEle); win.addEventListener('pointerdown', onPointerDown, true); win.addEventListener('mousedown', onTriggerClose, true); win.addEventListener('contextmenu', onTriggerClose, true); // shadow root var targetShadowRoot = (0, _shadow.getShadowRoot)(targetEle); if (targetShadowRoot) { targetShadowRoot.addEventListener('mousedown', onTriggerClose, true); targetShadowRoot.addEventListener('contextmenu', onTriggerClose, true); } // Warning if target and popup not in same root if (process.env.NODE_ENV !== 'production') { var _targetEle$getRootNod, _popupEle$getRootNode; var targetRoot = targetEle === null || targetEle === void 0 || (_targetEle$getRootNod = targetEle.getRootNode) === null || _targetEle$getRootNod === void 0 ? void 0 : _targetEle$getRootNod.call(targetEle); var popupRoot = (_popupEle$getRootNode = popupEle.getRootNode) === null || _popupEle$getRootNode === void 0 ? void 0 : _popupEle$getRootNode.call(popupEle); (0, _warning.warning)(targetRoot === popupRoot, "trigger element and popup element should in same shadow root."); } return function () { win.removeEventListener('pointerdown', onPointerDown, true); win.removeEventListener('mousedown', onTriggerClose, true); win.removeEventListener('contextmenu', onTriggerClose, true); if (targetShadowRoot) { targetShadowRoot.removeEventListener('mousedown', onTriggerClose, true); targetShadowRoot.removeEventListener('contextmenu', onTriggerClose, true); } }; } }, [clickToHide, targetEle, popupEle, mask, maskClosable]); function onPopupPointerDown() { popupPointerDownRef.current = true; } return onPopupPointerDown; }