Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | import { useVueFlow } from '@vue-flow/core' import { useNodeOperations } from './useNodeOperations' export function useDragAndDrop() { const { project, vueFlowRef } = useVueFlow() const { createNode } = useNodeOperations() const handleDragOver = (event: DragEvent) => { event.preventDefault() if (event.dataTransfer) { event.dataTransfer.dropEffect = 'move' } } const handleDrop = (event: DragEvent) => { event.preventDefault() const data = event.dataTransfer?.getData('application/vueflow') if (!data) return const template = JSON.parse(data) const position = project({ x: event.clientX - vueFlowRef.value!.getBoundingClientRect().left, y: event.clientY - vueFlowRef.value!.getBoundingClientRect().top, }) createNode(template, position) } return { handleDragOver, handleDrop, } } |