recharts
Version:
React charts
44 lines (41 loc) • 1.34 kB
JavaScript
import { useEffect } from 'react';
import { useIsPanorama } from '../context/PanoramaContext';
import { setChartSize, setLayout, setMargin } from './layoutSlice';
import { useAppDispatch } from './hooks';
/**
* "Main" props are props that are only accepted on the main chart,
* as opposed to the small panorama chart inside a Brush.
*/
export function ReportMainChartProps(_ref) {
var {
layout,
width,
height,
margin
} = _ref;
var dispatch = useAppDispatch();
/*
* Skip dispatching properties in panorama chart for two reasons:
* 1. The root chart should be deciding on these properties, and
* 2. Brush reads these properties from redux store, and so they must remain stable
* to avoid circular dependency and infinite re-rendering.
*/
var isPanorama = useIsPanorama();
/*
* useEffect here is required to avoid the "Cannot update a component while rendering a different component" error.
* https://github.com/facebook/react/issues/18178
*
* Reported in https://github.com/recharts/recharts/issues/5514
*/
useEffect(() => {
if (!isPanorama) {
dispatch(setLayout(layout));
dispatch(setChartSize({
width,
height
}));
dispatch(setMargin(margin));
}
}, [dispatch, isPanorama, layout, width, height, margin]);
return null;
}