chart = {
const svg = d3.create('svg')
.attr('viewBox', [0, 0, width, height])
.attr('style', 'border: 1px solid #eee')
.attr('xmlns', 'http://www.w3.org/2000/svg')
gradient(svg);
svg.call(xAxis);
svg.call(yAxis)
svg
.append("g")
.selectAll("g")
.data(dataCategoryByName)
.join("g")
.attr("transform", d => {
return `translate(${xScale(d[0])},0)`;
})
.attr("fill", 'red')
.attr("width", xScale.bandwidth())
.attr("height", yScale(0) - margin.top)
.attr("y", margin.top)
.attr('id', d => d)
.attr('class', 'bar-container')
.selectAll("rect")
.data(d => {
return xBarDomains.map(key => ({ key, ...dataCategoryByName.get(d[0]).find(item => item[seriesField] === key) }));
})
.join("rect")
.attr("x", d => xBarScale(d.key))
.attr("y", d => yScale(d[yField]))
.attr("width", xBarScale.bandwidth())
.attr("height", d => yScale(0) - yScale(+d[yField]))
.attr("fill", d => color(d.key))
return svg.node();
}