{
const svg = d3.create('svg').attr('viewBox', [0, 0, width, 200]);
svg
.append('defs')
.append('marker')
.attr('id', 'dot')
.attr('viewBox', [0, 0, 20, 20])
.attr('refX', 10)
.attr('refY', 10)
.attr('markerWidth', 10)
.attr('markerHeight', 10)
.append('circle')
.attr('cx', 10)
.attr('cy', 10)
.attr('r', 10)
.style('fill', 'green');
svg
.append('path')
.attr('d', d3.line()([[100, 60], [40, 90], [200, 80], [300, 150]]))
.attr('stroke', 'black')
.attr('marker-start', 'url(#dot)')
.attr('marker-mid', 'url(#dot)')
.attr('marker-end', 'url(#dot)')
.attr('fill', 'none');
return svg.node();
}