UNPKG

reka-ui

Version:

Vue port for Radix UI Primitives.

88 lines (85 loc) 2.65 kB
import { createContext } from "../shared/createContext.js"; import { useForwardExpose } from "../shared/useForwardExpose.js"; import { PopperRoot_default } from "../Popper/PopperRoot.js"; import { createBlock, defineComponent, openBlock, ref, renderSlot, toRefs, unref, withCtx } from "vue"; import { useVModel } from "@vueuse/core"; //#region src/HoverCard/HoverCardRoot.vue?vue&type=script&setup=true&lang.ts const [injectHoverCardRootContext, provideHoverCardRootContext] = createContext("HoverCardRoot"); var HoverCardRoot_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({ __name: "HoverCardRoot", props: { defaultOpen: { type: Boolean, required: false, default: false }, open: { type: Boolean, required: false, default: void 0 }, openDelay: { type: Number, required: false, default: 700 }, closeDelay: { type: Number, required: false, default: 300 } }, emits: ["update:open"], setup(__props, { emit: __emit }) { const props = __props; const emit = __emit; const { openDelay, closeDelay } = toRefs(props); useForwardExpose(); const open = useVModel(props, "open", emit, { defaultValue: props.defaultOpen, passive: props.open === void 0 }); const openTimerRef = ref(0); const closeTimerRef = ref(0); const hasSelectionRef = ref(false); const isPointerDownOnContentRef = ref(false); const isPointerInTransitRef = ref(false); const triggerElement = ref(); function handleOpen() { clearTimeout(closeTimerRef.value); openTimerRef.value = window.setTimeout(() => open.value = true, openDelay.value); } function handleClose() { clearTimeout(openTimerRef.value); if (!hasSelectionRef.value && !isPointerDownOnContentRef.value) closeTimerRef.value = window.setTimeout(() => open.value = false, closeDelay.value); } function handleDismiss() { open.value = false; } provideHoverCardRootContext({ open, onOpenChange(value) { open.value = value; }, onOpen: handleOpen, onClose: handleClose, onDismiss: handleDismiss, hasSelectionRef, isPointerDownOnContentRef, isPointerInTransitRef, triggerElement }); return (_ctx, _cache) => { return openBlock(), createBlock(unref(PopperRoot_default), null, { default: withCtx(() => [renderSlot(_ctx.$slots, "default", { open: unref(open) })]), _: 3 }); }; } }); //#endregion //#region src/HoverCard/HoverCardRoot.vue var HoverCardRoot_default = HoverCardRoot_vue_vue_type_script_setup_true_lang_default; //#endregion export { HoverCardRoot_default, injectHoverCardRootContext }; //# sourceMappingURL=HoverCardRoot.js.map