<EdgeLabelRenderer />
Edges are SVG-based. If you want to render more complex labels you can use the
<EdgeLabelRenderer />
component to access a div based renderer. This component
is a portal that renders the label in a <div />
that is positioned on top of
the edges. You can see an example usage of the component in the
edge label renderer example. We are using
the EdgeLabelRenderer internally to render edge labels.
CustomEdge.svelte
<script lang="ts">
import { getBezierPath, EdgeLabelRenderer, BaseEdge } from '@xyflow/svelte';
export let id: $$Props['id'];
export let data: $$Props['data'];
$: [edgePath, labelX, labelY] = getBezierPath($$props);
</script>
<BaseEdge id={id} path={edgePath} />
<EdgeLabelRenderer>
<div
style={{
position: 'absolute',
transform: `translate(-50%, -50%) translate(${labelX}px,${labelY}px)`,
background: '#ffcc00',
padding: 10,
borderRadius: 5,
fontSize: 12,
fontWeight: 700,
}}
class="nodrag nopan"
>
{data.label}
</div>
</EdgeLabelRenderer>
Props
Name | Type |
---|---|
# children |
Notes
- The
<EdgeLabelRenderer />
has no pointer events by default. If you want to add mouse interactions you need to set the stylepointerEvents: all
and add thenopan
class on the label or the element you want to interact with.