tdesign-react
Version:
TDesign Component for React
80 lines (74 loc) • 2.67 kB
JavaScript
/**
* tdesign v1.16.6
* (c) 2026 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-1f6c39e3.js');
require('../_chunks/dep-90a93885.js');
require('../_chunks/dep-875a5344.js');
require('../_chunks/dep-20f09a63.js');
require('dayjs');
require('../_chunks/dep-e691746e.js');
require('../_chunks/dep-9d3b1a05.js');
require('../_chunks/dep-1f8c969d.js');
require('../_chunks/dep-615c149d.js');
require('../_chunks/dep-0173c82c.js');
require('../_chunks/dep-a8d5081a.js');
require('../_chunks/dep-403f5edf.js');
require('../_chunks/dep-d24b94bc.js');
require('../_chunks/dep-6478e7e3.js');
require('../_chunks/dep-c9025587.js');
require('../_chunks/dep-8663a5c9.js');
require('../_chunks/dep-50349518.js');
require('../_chunks/dep-8c9795f9.js');
require('../_chunks/dep-723e29d6.js');
require('../_chunks/dep-0bd8b970.js');
require('../_chunks/dep-73ef2133.js');
require('../_chunks/dep-cae1e5aa.js');
require('../_chunks/dep-0b97e212.js');
require('../_chunks/dep-0652d2a6.js');
require('../_chunks/dep-1a7ce20e.js');
require('../_chunks/dep-116af952.js');
require('../_chunks/dep-f6a777ad.js');
require('../_chunks/dep-ff301423.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