tdesign-react
Version:
TDesign Component for React
79 lines (73 loc) • 2.63 kB
JavaScript
/**
* tdesign v1.11.6
* (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-56a79f9c.js');
require('../_chunks/dep-5b35215f.js');
require('../_chunks/dep-fa2097c1.js');
require('../_chunks/dep-f6f16bd8.js');
require('dayjs');
require('../_chunks/dep-59bb0827.js');
require('../_chunks/dep-68f8743f.js');
require('../_chunks/dep-a8d0483a.js');
require('../_chunks/dep-6e34d7d7.js');
require('../_chunks/dep-d45b3350.js');
require('../_chunks/dep-ec3beb8d.js');
require('../_chunks/dep-b7e21379.js');
require('../_chunks/dep-73937edb.js');
require('../_chunks/dep-8d4e8f1c.js');
require('../_chunks/dep-1d022321.js');
require('../_chunks/dep-ab08e148.js');
require('../_chunks/dep-9df70348.js');
require('../_chunks/dep-af16359b.js');
require('../_chunks/dep-e11afe29.js');
require('../_chunks/dep-346ac5f4.js');
require('../_chunks/dep-612ec5c9.js');
require('../_chunks/dep-4d25d6c0.js');
require('../_chunks/dep-496c0353.js');
require('../_chunks/dep-1f530d81.js');
require('../_chunks/dep-a4bc3144.js');
require('../_chunks/dep-535a3b69.js');
require('../_chunks/dep-d11b328f.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