-
Notifications
You must be signed in to change notification settings - Fork 2.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixes for test app crashes for 12 schema data #33542
base: master
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
{ | ||
"type": "patch", | ||
"comment": "Fixes for test app crashes for 12 schema data", | ||
"packageName": "@fluentui/react-charting", | ||
"email": "[email protected]", | ||
"dependentChangeType": "patch" | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -90,6 +90,7 @@ export const DeclarativeChart: React.FunctionComponent<DeclarativeChartProps> = | |
const { data, layout } = plotlySchema; | ||
let { selectedLegends } = plotlySchema; | ||
const xValues = data[0].x; | ||
const yValues = data[0].y; | ||
const isXDate = isDateArray(xValues); | ||
const isXNumber = isNumberArray(xValues); | ||
const isXMonth = isMonthArray(xValues); | ||
|
@@ -148,6 +149,40 @@ export const DeclarativeChart: React.FunctionComponent<DeclarativeChartProps> = | |
selectedLegends: activeLegends, | ||
}; | ||
|
||
const checkAndRenderChart = (renderChart: any, isAreaChart: boolean = false) => { | ||
if (isXDate || isXNumber) { | ||
const chartProps = { | ||
...transformPlotlyJsonToScatterChartProps({ data, layout }, isAreaChart, colorMap, isDarkTheme), | ||
legendProps, | ||
componentRef: chartRef, | ||
calloutProps: { layerProps: { eventBubblingEnabled: true } }, | ||
}; | ||
return renderChart(chartProps); | ||
} else if (isXMonth) { | ||
const updatedData = data.map((dataPoint: any) => ({ | ||
...dataPoint, | ||
x: updateXValues(dataPoint.x), | ||
})); | ||
const chartProps = { | ||
...transformPlotlyJsonToScatterChartProps({ data: updatedData, layout }, isAreaChart, colorMap, isDarkTheme), | ||
legendProps, | ||
componentRef: chartRef, | ||
calloutProps: { layerProps: { eventBubblingEnabled: true } }, | ||
}; | ||
return renderChart(chartProps); | ||
} | ||
// Unsupported schema, render as VerticalStackedBarChart | ||
data[0].type = 'Unsupported Schema'; | ||
return ( | ||
<VerticalStackedBarChart | ||
{...transformPlotlyJsonToVSBCProps(plotlySchema, colorMap, isDarkTheme)} | ||
legendProps={multiSelectLegendProps} | ||
componentRef={chartRef} | ||
calloutProps={{ layerProps: { eventBubblingEnabled: true } }} | ||
/> | ||
); | ||
}; | ||
|
||
switch (data[0].type) { | ||
case 'pie': | ||
return ( | ||
|
@@ -214,35 +249,7 @@ export const DeclarativeChart: React.FunctionComponent<DeclarativeChartProps> = | |
/> | ||
); | ||
}; | ||
if (isXDate || isXNumber) { | ||
const chartProps = { | ||
...transformPlotlyJsonToScatterChartProps({ data, layout }, isAreaChart, colorMap, isDarkTheme), | ||
legendProps, | ||
componentRef: chartRef, | ||
calloutProps: { layerProps: { eventBubblingEnabled: true } }, | ||
}; | ||
return renderChart(chartProps); | ||
} else if (isXMonth) { | ||
const updatedData = data.map((dataPoint: any) => ({ | ||
...dataPoint, | ||
x: updateXValues(dataPoint.x), | ||
})); | ||
const chartProps = { | ||
...transformPlotlyJsonToScatterChartProps({ data: updatedData, layout }, isAreaChart, colorMap, isDarkTheme), | ||
legendProps, | ||
componentRef: chartRef, | ||
calloutProps: { layerProps: { eventBubblingEnabled: true } }, | ||
}; | ||
return renderChart(chartProps); | ||
} | ||
return ( | ||
<VerticalStackedBarChart | ||
{...transformPlotlyJsonToVSBCProps(plotlySchema, colorMap, isDarkTheme)} | ||
legendProps={multiSelectLegendProps} | ||
componentRef={chartRef} | ||
calloutProps={{ layerProps: { eventBubblingEnabled: true } }} | ||
/> | ||
); | ||
return checkAndRenderChart(renderChart, isAreaChart); | ||
case 'heatmap': | ||
return ( | ||
<HeatMapChart | ||
|
@@ -281,6 +288,23 @@ export const DeclarativeChart: React.FunctionComponent<DeclarativeChartProps> = | |
/> | ||
); | ||
default: | ||
if (xValues.length > 0 && yValues.length > 0) { | ||
const renderLineChart = (chartProps: any) => { | ||
return ( | ||
<LineChart | ||
{...{ | ||
...chartProps, | ||
legendProps: { | ||
onChange: onActiveLegendsChange, | ||
canSelectMultipleLegends: true, | ||
selectedLegends: activeLegends, | ||
}, | ||
}} | ||
/> | ||
); | ||
}; | ||
return checkAndRenderChart(renderLineChart); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. in case x and y are not defined, it will throw new Error('Unsupported chart schema'); |
||
} | ||
throw new Error('Unsupported chart schema'); | ||
} | ||
}); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -65,6 +65,7 @@ export const updateXValues = (xValues: any[]): any[] => { | |
}); | ||
return xValues; | ||
}; | ||
|
||
export const getColor = ( | ||
legendLabel: string, | ||
colorMap: React.MutableRefObject<Map<string, string>>, | ||
|
@@ -143,7 +144,7 @@ export const transformPlotlyJsonToVSBCProps = ( | |
mapXToDataPoints[x] = { xAxisPoint: x, chartData: [], lineData: [] }; | ||
} | ||
const legend: string = series.name || `Series ${index1 + 1}`; | ||
if (series.type === 'bar' || series.type === 'scatter') { | ||
if (series.type === 'bar' || series.type === 'scatter' || series.type === 'Unsupported Schema') { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This I am setting in Declarative chart for any type that is not supported for uniformity. |
||
const color = getColor(legend, colorMap, isDarkTheme); | ||
mapXToDataPoints[x].chartData.push({ | ||
legend, | ||
|
@@ -414,9 +415,15 @@ export const transformPlotlyJsonToHeatmapProps = (jsonObj: any): IHeatMapChartPr | |
|
||
// Convert normalized values to actual values | ||
const domainValuesForColorScale: number[] = firstData.colorscale | ||
? firstData.colorscale.map((arr: any) => arr[0] * (zMax - zMin) + zMin) | ||
? isArrayOrTypedArray(firstData.colorscale) | ||
? firstData.colorscale.map((arr: any) => arr[0] * (zMax - zMin) + zMin) | ||
: [] | ||
: []; | ||
const rangeValuesForColorScale: string[] = firstData.colorscale | ||
? isArrayOrTypedArray(firstData.colorscale) | ||
? firstData.colorscale.map((arr: any) => arr[1]) | ||
: [] | ||
: []; | ||
const rangeValuesForColorScale: string[] = firstData.colorscale ? firstData.colorscale.map((arr: any) => arr[1]) : []; | ||
|
||
return { | ||
data: [heatmapData], | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
how can unsupported schema be rendered as vertical bar chart?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we discussed that only right, plotly falls back to line chart in case x and y axis are defined which in turn falls back to VSBC.