Files
brk/website_next/learn/charts/area/index.js
T
2026-06-09 13:35:21 +02:00

56 lines
1.2 KiB
JavaScript

import { createAreaPathData, createLinePathData } from "../path.js";
import { appendSeriesPath } from "../series-path.js";
import { createOrderedIndexes } from "../order.js";
import { createLineSeries } from "../line/series.js";
/**
* @param {number} height
* @param {ChartPoint[]} points
* @returns {StackedPoint[]}
*/
function createAreaPoints(height, points) {
return points.map((point) => ({
...point,
y0: height,
y1: point.y,
}));
}
/**
* @param {PlotContext} context
*/
export function renderAreaPlot({
group,
loadedSeries,
height,
highlight,
scale,
order,
}) {
const plottedSeries = createLineSeries(loadedSeries, height, scale);
const indexes = createOrderedIndexes(plottedSeries.length, order);
for (const index of indexes) {
const { color, points } = plottedSeries[index];
appendSeriesPath({
group,
highlight,
index,
chart: "area",
color,
d: createAreaPathData(createAreaPoints(height, points)),
});
appendSeriesPath({
group,
highlight,
index,
chart: "line",
color,
d: createLinePathData(points),
});
}
return plottedSeries;
}