element-plus
Version:
A Component Library for Vue 3
85 lines (80 loc) • 2.49 kB
JavaScript
;
Object.defineProperty(exports, '__esModule', { value: true });
var vue = require('vue');
var core = require('@vueuse/core');
require('../../../hooks/index.js');
require('../../../utils/index.js');
require('../../../tokens/index.js');
var root = require('./root.js');
var types = require('../../../utils/types.js');
var index = require('../../../hooks/use-id/index.js');
var tooltipV2 = require('../../../tokens/tooltip-v2.js');
const __default__ = {
name: "ElTooltipV2Root"
};
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
...__default__,
props: root.tooltipV2RootProps,
setup(__props, { expose }) {
const props = __props;
const _open = vue.ref(props.defaultOpen);
const triggerRef = vue.ref(null);
const open = vue.computed({
get: () => types.isPropAbsent(props.open) ? _open.value : props.open,
set: (open2) => {
var _a;
_open.value = open2;
(_a = props["onUpdate:open"]) == null ? void 0 : _a.call(props, open2);
}
});
const isOpenDelayed = vue.computed(() => core.isNumber(props.delayDuration) && props.delayDuration > 0);
const { start: onDelayedOpen, stop: clearTimer } = core.useTimeoutFn(() => {
open.value = true;
}, vue.computed(() => props.delayDuration));
const contentId = index.useId();
const onNormalOpen = () => {
clearTimer();
open.value = true;
};
const onDelayOpen = () => {
vue.unref(isOpenDelayed) ? onDelayedOpen() : onNormalOpen();
};
const onOpen = onNormalOpen;
const onClose = () => {
clearTimer();
open.value = false;
};
const onChange = (open2) => {
var _a;
if (open2) {
document.dispatchEvent(new CustomEvent(tooltipV2.TOOLTIP_V2_OPEN));
onOpen();
}
(_a = props.onOpenChange) == null ? void 0 : _a.call(props, open2);
};
vue.watch(open, onChange);
vue.onMounted(() => {
document.addEventListener(tooltipV2.TOOLTIP_V2_OPEN, onClose);
});
vue.onBeforeUnmount(() => {
clearTimer();
document.removeEventListener(tooltipV2.TOOLTIP_V2_OPEN, onClose);
});
vue.provide(tooltipV2.tooltipV2RootKey, {
contentId,
triggerRef,
onClose,
onDelayOpen,
onOpen
});
expose({
onOpen,
onClose
});
return (_ctx, _cache) => {
return vue.renderSlot(_ctx.$slots, "default");
};
}
});
exports["default"] = _sfc_main;
//# sourceMappingURL=root2.js.map