createLegend = (g, colorScale, scaleType) => {
const x = d3.scaleLinear()
.domain(d3.extent(colorScale.domain()))
.rangeRound([0, 350]);
g.selectAll("rect")
.data(color.range().map(d => colorScale.invertExtent(d)))
.join("rect")
.attr("height", 8)
.attr("x", d => x(d[0]))
.attr("width", d => x(d[1]) - x(d[0]))
.attr("fill", d => colorScale(d[0]));
g.append("text")
.attr("x", x.range()[0])
.attr("y", 50)
.attr("fill", "currentColor")
.attr("text-anchor", "start")
.attr("font-weight", "bold")
.text(`Tweeted 311s per neighborhood (${scaleType} scale)`)
g.call(d3.axisBottom(x)
.tickSize(13)
.tickFormat(d => d.toFixed(2))
.tickValues(color.range().slice(1).map(d => colorScale.invertExtent(d)[0])))
.select(".domain")
.remove();
return color.range().map(d => colorScale.invertExtent(d))
}