85 lines
1.4 KiB
Vue
85 lines
1.4 KiB
Vue
<script setup>
|
||
import { computed } from 'vue'
|
||
import { BaseEdge, EdgeLabelRenderer, getBezierPath, useVueFlow } from '@vue-flow/core'
|
||
|
||
const props = defineProps({
|
||
id: {
|
||
type: String,
|
||
required: true,
|
||
},
|
||
sourceX: {
|
||
type: Number,
|
||
required: true,
|
||
},
|
||
sourceY: {
|
||
type: Number,
|
||
required: true,
|
||
},
|
||
targetX: {
|
||
type: Number,
|
||
required: true,
|
||
},
|
||
targetY: {
|
||
type: Number,
|
||
required: true,
|
||
},
|
||
sourcePosition: {
|
||
type: String,
|
||
required: true,
|
||
},
|
||
targetPosition: {
|
||
type: String,
|
||
required: true,
|
||
},
|
||
data: {
|
||
type: Object,
|
||
required: false,
|
||
},
|
||
markerEnd: {
|
||
type: String,
|
||
required: false,
|
||
},
|
||
style: {
|
||
type: Object,
|
||
required: false,
|
||
},
|
||
})
|
||
|
||
const { removeEdges } = useVueFlow()
|
||
|
||
const path = computed(() => getBezierPath(props))
|
||
</script>
|
||
|
||
<script>
|
||
export default {
|
||
inheritAttrs: false,
|
||
}
|
||
</script>
|
||
|
||
<template>
|
||
<BaseEdge :path="path[0]" />
|
||
|
||
<EdgeLabelRenderer>
|
||
<div
|
||
:style="{
|
||
pointerEvents: 'all',
|
||
position: 'absolute',
|
||
transform: `translate(-50%, -50%) translate(${path[1]}px,${path[2]}px)`,
|
||
}"
|
||
class="nodrag nopan"
|
||
>
|
||
<button class="edgebutton" @click="removeEdges(id)">×</button>
|
||
</div>
|
||
</EdgeLabelRenderer>
|
||
</template>
|
||
|
||
<style>
|
||
.edgebutton {
|
||
border-radius: 999px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.edgebutton:hover {
|
||
box-shadow: 0 0 0 2px pink, 0 0 0 4px #f05f75;
|
||
}
|
||
</style> |