import { defineAsyncComponent, reactive, ref } from 'vue' export type ContextMenuContext = Record export const useContextMenu = () => { const BaseContextMenu = defineAsyncComponent(() => import('@/components/ui/context-menu.vue')) const base = ref>() const context = reactive({}) const open = (top: number, left: number, ctx: ContextMenuContext = {}) => { base.value?.open(top, left, ctx) Object.assign(context, ctx) } const close = () => base.value?.close() return { base, BaseContextMenu, open, close, context } }