tdesign-react
Version:
TDesign Component for React
78 lines (72 loc) • 2.59 kB
JavaScript
/**
* tdesign v1.16.2
* (c) 2025 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var hooks_useConfig = require('./useConfig.js');
require('../config-provider/ConfigContext.js');
require('../_chunks/dep-0fe55884.js');
require('../_chunks/dep-b325182b.js');
require('../_chunks/dep-17dea53e.js');
require('../_chunks/dep-a0cbf081.js');
require('dayjs');
require('../_chunks/dep-481a1ecc.js');
require('../_chunks/dep-474eb386.js');
require('../_chunks/dep-3b256bc0.js');
require('../_chunks/dep-4ce0670e.js');
require('../_chunks/dep-3448f35f.js');
require('../_chunks/dep-b6a3ada9.js');
require('../_chunks/dep-967e785f.js');
require('../_chunks/dep-5c8525ea.js');
require('../_chunks/dep-735cd5b9.js');
require('../_chunks/dep-bdafd287.js');
require('../_chunks/dep-4d300b8f.js');
require('../_chunks/dep-3332ad6f.js');
require('../_chunks/dep-98783318.js');
require('../_chunks/dep-fc884a8e.js');
require('../_chunks/dep-008b21d4.js');
require('../_chunks/dep-9193eded.js');
require('../_chunks/dep-afe817f9.js');
require('../_chunks/dep-0b70c7ec.js');
require('../_chunks/dep-a1e3e59b.js');
require('../_chunks/dep-24ab8f68.js');
require('../_chunks/dep-753b7d52.js');
function useClickOutside(refs, handler, includePopup) {
var _useConfig = hooks_useConfig["default"](),
classPrefix = _useConfig.classPrefix;
var POPUP_SELECTOR = ".".concat(classPrefix, "-popup");
React.useEffect(function () {
var listener = function listener(event) {
if (!Array.isArray(refs)) {
return;
}
var elements = [];
if (includePopup) {
document.querySelectorAll(POPUP_SELECTOR).forEach(function (ele) {
elements.push(ele);
});
}
elements = Array.from(new Set(elements));
if (refs.find(function (ref) {
var _ref$current;
return (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.contains(event.target);
}) || elements.find(function (el) {
return el === null || el === void 0 ? void 0 : el.contains(event.target);
})) {
return;
}
handler(event);
};
document.addEventListener("mousedown", listener);
document.addEventListener("touchstart", listener);
return function () {
document.removeEventListener("mousedown", listener);
document.removeEventListener("touchstart", listener);
};
}, [refs, handler, includePopup]);
}
exports["default"] = useClickOutside;
//# sourceMappingURL=useClickOutside.js.map