chart = {
const svg = d3.create("svg")
.attr("viewBox", [0, 0, width, height]);
const defs= svg.append("defs")
svg.append("path")
.datum(data)
.attr("fill", "url(#mask)")
.attr("d", area)
const mask = defs.append("pattern").attr("id", "mask").attr("x", 0)
.attr("y", 0) .attr("width",1)
.attr("height", 1) .attr("patternUnits", 'objectBoundingBox')
mask.append("rect")
.attr("x", 0)
.attr("y", 0)
.attr("width", 760)
.attr("height", 250)
.attr("fill", "red")
.attr("stroke", "white")
mask.append("rect")
.attr("x",0)
.attr("y", 250)
.attr("width", 760)
.attr("height", 250)
.attr("fill", "green")
.attr("stroke", "white")
svg.append("g")
.call(xAxis);
svg.append("g")
.call(yAxis);
return svg.node();
}