Skip to content

Commit

Permalink
aggregate Y column values rather than displaying last Y value (getred…
Browse files Browse the repository at this point in the history
  • Loading branch information
lvitti authored and harveyrendell committed Jan 8, 2025
1 parent a7733ce commit 42a5d30
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -28,19 +28,19 @@
"series": [
{
"visible": true,
"values": [10, 60, 100, 30],
"labels": ["Slice 0", "Slice 0", "Slice 0", "Slice 0"],
"values": [200],
"labels": ["Slice 0"],
"type": "pie",
"hole": 0.4,
"marker": {
"colors": ["#356AFF", "#E92828", "#3BD973", "#604FE9"]
"colors": ["#356AFF"]
},
"hoverinfo": "text+label",
"hover": [],
"text": ["15% (30)", "15% (30)", "15% (30)", "15% (30)"],
"text": ["100% (200)"],
"textinfo": "percent",
"textposition": "inside",
"textfont": { "color": ["#ffffff", "#ffffff", "#333333", "#ffffff"] },
"textfont": { "color": ["#ffffff"] },
"name": "a",
"direction": "counterclockwise",
"domain": { "x": [0, 0.98], "y": [0, 0.9] }
Expand Down
22 changes: 17 additions & 5 deletions viz-lib/src/visualizations/chart/plotly/prepareDefaultData.ts
Original file line number Diff line number Diff line change
Expand Up @@ -91,27 +91,39 @@ function prepareSeries(series: any, options: any, additionalOptions: any) {
};

const sourceData = new Map();
const xValues: any = [];
const yValues: any = [];

//we hold the labels and values in a dictionary so that we can aggregate multiple values for a single label
//once we reach the end of the data, we'll convert the dictionary to separate arrays for labels and values
const labelsValuesDict: { [key: string]: any } = {};

const yErrorValues: any = [];
each(data, row => {
const x = normalizeValue(row.x, options.xAxis.type); // number/datetime/category
const y = cleanYValue(row.y, seriesYAxis === "y2" ? options.yAxis[1].type : options.yAxis[0].type); // depends on series type!
const yError = cleanNumber(row.yError); // always number
const size = cleanNumber(row.size); // always number
if (x in labelsValuesDict){
labelsValuesDict[x] += y;
}
else{
labelsValuesDict[x] = y;
}
const aggregatedY = labelsValuesDict[x];

sourceData.set(x, {
x,
y,
y: aggregatedY,
yError,
size,
yPercent: null, // will be updated later
row,
});
xValues.push(x);
yValues.push(y);
yErrorValues.push(yError);
});

const xValues = Object.keys(labelsValuesDict);
const yValues = Object.values(labelsValuesDict);

const plotlySeries = {
visible: true,
hoverinfo: hoverInfoPattern,
Expand Down
26 changes: 19 additions & 7 deletions viz-lib/src/visualizations/chart/plotly/preparePieData.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,10 @@ function prepareSeries(series: any, options: any, additionalOptions: any) {
const xPosition = (index % cellsInRow) * cellWidth;
const yPosition = Math.floor(index / cellsInRow) * cellHeight;

const labels: any = [];
const values: any = [];
//we hold the labels and values in a dictionary so that we can aggregate multiple values for a single label
//once we reach the end of the data, we'll convert the dictionary to separate arrays for labels and values
const labelsValuesDict: { [key: string]: any } = {};

const sourceData = new Map();
const seriesTotal = reduce(
series.data,
Expand All @@ -55,19 +57,29 @@ function prepareSeries(series: any, options: any, additionalOptions: any) {
each(series.data, row => {
const x = hasX ? normalizeValue(row.x, options.xAxis.type) : `Slice ${index}`;
const y = cleanNumber(row.y);
labels.push(x);
values.push(y);

if (x in labelsValuesDict){
labelsValuesDict[x] += y;
}
else{
labelsValuesDict[x] = y;
}
const aggregatedY = labelsValuesDict[x];

sourceData.set(x, {
x,
y,
yPercent: (y / seriesTotal) * 100,
y: aggregatedY,
yPercent: (aggregatedY / seriesTotal) * 100,
row,
});
});

const markerColors = map(series.data, row => getValueColor(row.x));
const markerColors = map(Array.from(sourceData.values()), data => getValueColor(data.row.x));
const textColors = map(markerColors, c => chooseTextColorForBackground(c));

const labels = Object.keys(labelsValuesDict);
const values = Object.values(labelsValuesDict);

return {
visible: true,
values,
Expand Down

0 comments on commit 42a5d30

Please sign in to comment.