<script>
import { quantize, interpolatePlasma, pie, arc } from 'd3';
import data from './donut-data'
const width = $ChartDocs[0].value
const height = width
const percent = $ChartDocs[1].value
const fontSize = $ChartDocs[2].value;
const strokeWidth = $ChartDocs[3].value;
const strokeLinejoin = 'round';
const outerRadius = Math.min(width, height) * 0.5 - 60;
const innerRadius = $ChartDocs[4].value;
const labelPosition = $ChartDocs[5].value;
const labelRadius = (innerRadius * labelPosition + outerRadius * 0.6);
const strokeColorWOR = $ChartDocs[6].value;
const strokeColorWIR = $ChartDocs[7].value;
const stroke = innerRadius > 0 ? strokeColorWIR : strokeColorWOR;
const padAngle = stroke === 'none' ? 1 / outerRadius : 0;
const x = Object.keys(data[0])[0];
const y = Object.keys(data[0])[1];
const xVals = data.map((el) => el[x]);
let yVals = data.map((el) => Number(el[y]));
if (percent) {
const total = yVals.reduce((a, b) => a + b, 0);
yVals = yVals.map((el) => el / total);
}
const iVals = data.map((el, i) => i);
let colors;
if (!colors) colors = quantize(t => interpolatePlasma(t * 0.7 + 0.3), xVals.length);
const wedges = pie().
padAngle(padAngle).
sort(null).
value(i => yVals[i])(iVals);
const arcPath = arc()
.innerRadius(innerRadius)
.outerRadius(outerRadius);
const arcLabel = arc()
.innerRadius(labelRadius)
.outerRadius(labelRadius);
</script>
<svg {width} {height} viewBox="{-width / 2} {-height / 2} {width} {height}">
{#each wedges as wedge, i}
<path fill={colors[i]} d={arcPath(wedge)} stroke={stroke} stroke-width={strokeWidth} stroke-linejoin={strokeLinejoin} />
<g text-anchor='middle' transform='translate({arcLabel.centroid(wedge)})'>
<text font-size={fontSize}>
<tspan font-weight='bold'>{xVals[i]}</tspan>
<tspan x = '0' dy='1.1em'>{percent ? `${(yVals[i] * 100).toFixed(2)}%` : yVals[i].toLocaleString('en-US')}</tspan>
</text>
</g>
{/each}
</svg>
<style>
</style>
export default [
{ ages: '<18', count: '727432' },
{ ages: '18-24', count: '341435' },
{ ages: '25-34', count: '444509' },
{ ages: '35-44', count: '426967' },
{ ages: '45-54', count: '480565' },
{ ages: '55-64', count: '515347' },
{ ages: '≥65', count: '629032' }
];
const data = [
{ xKey: x-value1, yKey: y-value1 },
{ xKey: x-value2, yKey: y-value2 },
{ xKey: x-value3, yKey: y-value3 },
]