arcs = {
const data = Array.from(Array(12), (v, i) => (i + 1)**2);
const max = data[data.length - 1] * 7;
const viz = d3.select(DOM.svg(max, max));
var t = d3.transition()
.duration(5000);
const start = d3.arc()
.innerRadius(d => d * 2)
.outerRadius(d => d * 2 + 15)
.startAngle(0)
.endAngle(0);
const sweep = d3.arc()
.innerRadius(d => d * 2)
.outerRadius(d => d * 2 + 15)
.startAngle(0)
.endAngle(d => d * 0.01 * Math.PI);
viz.selectAll("path").data(data).enter().append("path")
.attr("d", start)
.attr("fill", "blue")
.attr("transform", `translate(${max / 2}, ${max / 2})`)
.transition(t)
.attr("d", sweep);
return viz.node();
}