{
const svg = d3.select(DOM.svg(width, height));
const defs = svg.append("defs");
const linearGradient = defs.append("linearGradient")
.attr("id", "linear-gradient");
linearGradient.selectAll("stop")
.data(colorScale.ticks().map((t, i, n) => ({ offset: `${100*i/n.length}%`, color: colorScale(t) })))
.enter().append("stop")
.attr("offset", d => d.offset)
.attr("stop-color", d => d.color);
svg.append('g')
.attr("transform", `translate(0,${height - margin.bottom - barHeight})`)
.append("rect")
.attr('transform', `translate(${margin.left}, 0)`)
.attr("width", width - margin.right - margin.left)
.attr("height", barHeight)
.style("fill", "url(#linear-gradient)");
svg.append('g')
.call(axisBottom);
return svg.node();
}