aiflowy-ui-admin/node_modules/.vite/deps/chunk-PBZHTG65.js

171 lines
5.4 KiB
JavaScript

import {
require_xe_utils
} from "./chunk-YJNUXQVJ.js";
import {
__toESM
} from "./chunk-V4OQ3NZ2.js";
// ../node_modules/.pnpm/vxe-pc-ui@4.10.22_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-pc-ui/es/ui/src/dom.js
var import_xe_utils = __toESM(require_xe_utils());
var tpImgEl;
function initTpImg() {
if (!tpImgEl) {
tpImgEl = new Image();
tpImgEl.src = "";
}
return tpImgEl;
}
function getTpImg() {
if (!tpImgEl) {
return initTpImg();
}
return tpImgEl;
}
var reClsMap = {};
function getClsRE(cls) {
if (!reClsMap[cls]) {
reClsMap[cls] = new RegExp(`(?:^|\\s)${cls}(?!\\S)`, "g");
}
return reClsMap[cls];
}
function hasClass(elem, cls) {
return !!(elem && elem.className && elem.className.match && elem.className.match(getClsRE(cls)));
}
function hasControlKey(evnt) {
return evnt.ctrlKey || evnt.metaKey;
}
function toCssUnit(val, unit = "px") {
if (import_xe_utils.default.isNumber(val) || /^\d+$/.test(`${val}`)) {
return `${val}${unit}`;
}
return `${val || ""}`;
}
function getDomNode() {
const documentElement = document.documentElement;
const bodyElem = document.body;
return {
scrollTop: documentElement.scrollTop || bodyElem.scrollTop,
scrollLeft: documentElement.scrollLeft || bodyElem.scrollLeft,
visibleHeight: documentElement.clientHeight || bodyElem.clientHeight,
visibleWidth: documentElement.clientWidth || bodyElem.clientWidth
};
}
function getEventTargetNode(evnt, container, queryCls, queryMethod) {
let targetElem;
let target = evnt.target.shadowRoot && evnt.composed ? evnt.composedPath()[0] || evnt.target : evnt.target;
while (target && target.nodeType && target !== document) {
if (queryCls && hasClass(target, queryCls) && (!queryMethod || queryMethod(target))) {
targetElem = target;
} else if (target === container) {
return { flag: queryCls ? !!targetElem : true, container, targetElem };
}
target = target.parentNode;
}
return { flag: false };
}
function getAbsolutePos(elem) {
const bounding = elem.getBoundingClientRect();
const boundingTop = bounding.top;
const boundingLeft = bounding.left;
const { scrollTop, scrollLeft, visibleHeight, visibleWidth } = getDomNode();
return { boundingTop, top: scrollTop + boundingTop, boundingLeft, left: scrollLeft + boundingLeft, visibleHeight, visibleWidth };
}
function updatePanelPlacement(targetElem, panelElem, options) {
const { placement, teleportTo, marginSize } = Object.assign({ teleportTo: false, marginSize: 18 }, options);
let panelPlacement = "bottom";
let top = "";
let bottom = "";
let left = "";
const right = "";
let minWidth = "";
const stys = {};
if (panelElem && targetElem) {
const documentElement = document.documentElement;
const bodyElem = document.body;
const targetHeight = targetElem.offsetHeight;
const panelHeight = panelElem.offsetHeight;
const panelWidth = panelElem.offsetWidth;
const panelRect = panelElem.getBoundingClientRect();
const targetRect = targetElem.getBoundingClientRect();
const visibleHeight = documentElement.clientHeight || bodyElem.clientHeight;
const visibleWidth = documentElement.clientWidth || bodyElem.clientWidth;
minWidth = targetElem.offsetWidth;
if (teleportTo) {
left = targetRect.left;
top = targetRect.top + targetHeight;
if (placement === "top") {
panelPlacement = "top";
top = targetRect.top - panelHeight;
} else if (!placement) {
if (top + panelHeight + marginSize > visibleHeight) {
panelPlacement = "top";
top = targetRect.top - panelHeight;
}
if (top < marginSize) {
panelPlacement = "bottom";
top = targetRect.top + targetHeight;
}
}
if (left + panelWidth + marginSize > visibleWidth) {
left -= left + panelWidth + marginSize - visibleWidth;
}
if (left < marginSize) {
left = marginSize;
}
} else {
if (placement === "top") {
panelPlacement = "top";
bottom = targetHeight;
} else if (!placement) {
top = targetHeight;
if (targetRect.top + targetRect.height + marginSize > visibleHeight) {
if (targetRect.top - targetHeight - panelHeight > marginSize) {
panelPlacement = "top";
top = "";
bottom = targetHeight;
}
}
}
if (panelRect.left + panelRect.width + marginSize > visibleWidth) {
left = -(panelRect.left + panelRect.width + marginSize - visibleWidth);
}
}
if (import_xe_utils.default.isNumber(top)) {
stys.top = toCssUnit(top);
}
if (import_xe_utils.default.isNumber(bottom)) {
stys.bottom = toCssUnit(bottom);
}
if (import_xe_utils.default.isNumber(left)) {
stys.left = toCssUnit(left);
}
if (import_xe_utils.default.isNumber(right)) {
stys.right = toCssUnit(right);
}
if (import_xe_utils.default.isNumber(minWidth)) {
stys.minWidth = toCssUnit(minWidth);
}
}
return {
top: top || 0,
bottom: bottom || 0,
left: left || 0,
right: right || 0,
style: stys,
placement: panelPlacement
};
}
export {
initTpImg,
getTpImg,
hasClass,
hasControlKey,
toCssUnit,
getDomNode,
getEventTargetNode,
getAbsolutePos,
updatePanelPlacement
};
//# sourceMappingURL=chunk-PBZHTG65.js.map