useWinClick.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. "use strict";
  2. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = useWinClick;
  7. var _shadow = require("rc-util/lib/Dom/shadow");
  8. var _warning = require("rc-util/lib/warning");
  9. var React = _interopRequireWildcard(require("react"));
  10. var _util = require("../util");
  11. function useWinClick(open, clickToHide, targetEle, popupEle, mask, maskClosable, inPopupOrChild, triggerOpen) {
  12. var openRef = React.useRef(open);
  13. openRef.current = open;
  14. var popupPointerDownRef = React.useRef(false);
  15. // Click to hide is special action since click popup element should not hide
  16. React.useEffect(function () {
  17. if (clickToHide && popupEle && (!mask || maskClosable)) {
  18. var onPointerDown = function onPointerDown() {
  19. popupPointerDownRef.current = false;
  20. };
  21. var onTriggerClose = function onTriggerClose(e) {
  22. var _e$composedPath;
  23. 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) {
  24. triggerOpen(false);
  25. }
  26. };
  27. var win = (0, _util.getWin)(popupEle);
  28. win.addEventListener('pointerdown', onPointerDown, true);
  29. win.addEventListener('mousedown', onTriggerClose, true);
  30. win.addEventListener('contextmenu', onTriggerClose, true);
  31. // shadow root
  32. var targetShadowRoot = (0, _shadow.getShadowRoot)(targetEle);
  33. if (targetShadowRoot) {
  34. targetShadowRoot.addEventListener('mousedown', onTriggerClose, true);
  35. targetShadowRoot.addEventListener('contextmenu', onTriggerClose, true);
  36. }
  37. // Warning if target and popup not in same root
  38. if (process.env.NODE_ENV !== 'production') {
  39. var _targetEle$getRootNod, _popupEle$getRootNode;
  40. var targetRoot = targetEle === null || targetEle === void 0 || (_targetEle$getRootNod = targetEle.getRootNode) === null || _targetEle$getRootNod === void 0 ? void 0 : _targetEle$getRootNod.call(targetEle);
  41. var popupRoot = (_popupEle$getRootNode = popupEle.getRootNode) === null || _popupEle$getRootNode === void 0 ? void 0 : _popupEle$getRootNode.call(popupEle);
  42. (0, _warning.warning)(targetRoot === popupRoot, "trigger element and popup element should in same shadow root.");
  43. }
  44. return function () {
  45. win.removeEventListener('pointerdown', onPointerDown, true);
  46. win.removeEventListener('mousedown', onTriggerClose, true);
  47. win.removeEventListener('contextmenu', onTriggerClose, true);
  48. if (targetShadowRoot) {
  49. targetShadowRoot.removeEventListener('mousedown', onTriggerClose, true);
  50. targetShadowRoot.removeEventListener('contextmenu', onTriggerClose, true);
  51. }
  52. };
  53. }
  54. }, [clickToHide, targetEle, popupEle, mask, maskClosable]);
  55. function onPopupPointerDown() {
  56. popupPointerDownRef.current = true;
  57. }
  58. return onPopupPointerDown;
  59. }