{ const data = await d3$1.csv(csvUrl); return data; }; // Select the SVG from the HTML body const svg = d3$1.select("svg"); const width = + svg.attr('width'); const height = + svg.attr('height'); // Format axes text const xAxisTickFormat = number => d3$1.format('.4~g')(number); // Render Pie Chart on the canvas const render = (data, total) => { const pieData = d3$1.pie().value(d=>d.Deaths)(data); const colors = d3$1.scaleOrdinal() .domain(data) .range(sectionColors); // Object for generating Arcs of the sections const arcGenerator = d3.arc() .innerRadius(0) .outerRadius(250); // Segments are the partition in the Pie Chart const segments = d3$1.arc() .innerRadius(0) .outerRadius(175) .padAngle(0) .padRadius(0); const sections = svg.append("g") .attr("transform", `translate(250,250)`) .selectAll("path").data(pieData); sections.enter() .append("path") .attr("d", segments) .attr("fill", d => colors(d.data.Deaths)); // Render text on each section sections .enter() .append('text') .text(d => xAxisTickFormat((d.data.Deaths/1000))+"K") .attr("transform", function(d) { return "translate(" + arcGenerator.centroid(d) + ")"; }) .style("text-anchor", "middle") .style('fill', 'black') .style("font-size", 15); // Render legend for the data const legends = svg.append("g") .attr("transform", "translate(500,100)") .selectAll(".legends").data(pieData); const legend = legends.enter().append("g").classed(".legends",true) .attr("transform", (d,i)=>{ return `translate(0,${(i+1)*30})`; }); // Formats the legend for Deaths legend.append("rect").attr("width",20).attr("height",20) .attr("fill", d => colors(d.data.Deaths)); legend.append("text") .attr("x", 250) .attr("y", 15) .attr("class","legend_value") .text(d=>xAxisTickFormat((d.data.Deaths/1000))+"K"); // Formats the legend for Countries legend.append("text") .attr("x", 25) .attr("y", 15) .attr("class","legend_text") .text(d => d.data.Country); }; // Main function const run = async () => { let data = await fetchData(); let total = 0; data.forEach(d=>{ d.Deaths = +d.Deaths; total += d.Deaths; }); render(data); }; run(); }(d3)); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["index.js"],"sourcesContent":["import { csv } from 'd3';\nimport {\n  select,\n  json,\n  pie,\n  arc,\n  scaleOrdinal,\n  format\n} from 'd3';\n\n// Colors for the sections in Pie Chart\nconst sectionColors = [\n  \t\t'red', 'blue', 'yellow', 'lime', 'orange', 'skyblue', 'crimson', 'wheat', 'turquoise', 'aqua'\n\t\t  ];\n\n// Data set URI\nconst csvUrl = 'https://gist.githubusercontent.com/AishwaryaManjunath/71a19fc09632d08b715e55cc6d212795/raw/5a9bdefae778e255ff25f34f0bd2ae312aeee0f4/new_file.txt';\n\n// Function to fetch data from the URI\nconst fetchData = async () => {\n  const data = await csv(csvUrl);\n  return data;\n};\n\n// Select the SVG from the HTML body\nconst svg = select(\"svg\");\nconst width = + svg.attr('width');\nconst height = + svg.attr('height');\n\n// Format axes text\nconst xAxisTickFormat = number =>\n  \tformat('.4~g')(number);\n\n// Render Pie Chart on the canvas\nconst render = (data, total) => {\n  const pieData = pie().value(d=>d.Deaths)(data);\n  const colors = scaleOrdinal()\n  \t.domain(data)\n  \t.range(sectionColors);\n  \n  // Object for generating Arcs of the sections\n  const arcGenerator = d3.arc()\n  .innerRadius(0)\n  .outerRadius(250);\n\n  // Segments are the partition in the Pie Chart\n\tconst segments = arc()\n  \t.innerRadius(0)\n  \t.outerRadius(175)\n  \t.padAngle(0)\n  \t.padRadius(0);\n  \n  const sections = svg.append(\"g\")\n  \t.attr(\"transform\", `translate(250,250)`)\n  \t.selectAll(\"path\").data(pieData);\n  \n  sections.enter()\n    .append(\"path\")\n    .attr(\"d\", segments)\n  \t.attr(\"fill\", d => colors(d.data.Deaths));\n  \n  // Render text on each section\n  sections\n    .enter()\n    .append('text')\n    .text(d => xAxisTickFormat((d.data.Deaths/1000))+\"K\")\n    .attr(\"transform\", function(d) { return \"translate(\" + arcGenerator.centroid(d) + \")\";  })\n    .style(\"text-anchor\", \"middle\")\n  \t.style('fill', 'black')\n    .style(\"font-size\", 15);\n  \n  // Render legend for the data\n  const legends = svg.append(\"g\")\n  \t.attr(\"transform\", \"translate(500,100)\")\n    .selectAll(\".legends\").data(pieData);\n  \n  const legend = legends.enter().append(\"g\").classed(\".legends\",true)\n  \t.attr(\"transform\", (d,i)=>{\n      return `translate(0,${(i+1)*30})`;\n    });\n  \n  // Formats the legend for Deaths\n  legend.append(\"rect\").attr(\"width\",20).attr(\"height\",20)\n  \t.attr(\"fill\", d => colors(d.data.Deaths));\n  \n  legend.append(\"text\")\n  \t.attr(\"x\", 250)\n  \t.attr(\"y\", 15)\n  \t.attr(\"class\",\"legend_value\")\n  \t.text(d=>xAxisTickFormat((d.data.Deaths/1000))+\"K\");\n  \n  // Formats the legend for Countries \n  legend.append(\"text\")\n  \t.attr(\"x\", 25)\n  \t.attr(\"y\", 15)\n  \t.attr(\"class\",\"legend_text\")\n  \t.text(d => d.data.Country);\n  \n}\n\n// Main function\nconst run = async () => {\n  let data = await fetchData()\n  let total = 0\n  data.forEach(d=>{\n    d.Deaths = +d.Deaths;\n    total += d.Deaths\n  });\n\trender(data,total);\n};\nrun();"],"names":["csv","select","format","pie","scaleOrdinal","arc"],"mappings":"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"}