UNPKG

recharts

Version:
84 lines (80 loc) 3.32 kB
import { createSelector } from 'reselect'; /** * This selector always returns the data with the indexes set by a Brush. * Trouble is, that might or might not be what you want. * * In charts with Brush, you will sometimes want to select the full range of data, and sometimes the one decided by the Brush * - even if the Brush is active, the panorama inside the Brush should show the full range of data. * * So instead of this selector, consider using either selectChartDataAndAlwaysIgnoreIndexes or selectChartDataWithIndexesIfNotInPanorama * * @param state RechartsRootState * @returns data defined on the chart root element, such as BarChart or ScatterChart */ export var selectChartDataWithIndexes = state => state.chartData; /** * This selector will always return the full range of data, ignoring the indexes set by a Brush. * Useful for when you want to render the full range of data, even if a Brush is active. * For example: in the Brush panorama, in Legend, in Tooltip. */ export var selectChartDataAndAlwaysIgnoreIndexes = createSelector([selectChartDataWithIndexes], dataState => { var dataEndIndex = dataState.chartData != null ? dataState.chartData.length - 1 : 0; return { chartData: dataState.chartData, computedData: dataState.computedData, dataEndIndex, dataStartIndex: 0 }; }); export var selectChartDataWithIndexesIfNotInPanoramaPosition4 = (state, _unused1, _unused2, isPanorama) => { if (isPanorama) { return selectChartDataAndAlwaysIgnoreIndexes(state); } return selectChartDataWithIndexes(state); }; export var selectChartDataWithIndexesIfNotInPanoramaPosition3 = (state, _unused1, isPanorama) => { if (isPanorama) { return selectChartDataAndAlwaysIgnoreIndexes(state); } return selectChartDataWithIndexes(state); }; /** * Returns the chart-level data slice (respecting Brush indexes), memoized by content so that * spurious Immer reference changes (e.g. dispatching `setChartData(undefined)` when data is * already `undefined`) do not propagate to downstream selectors. * * Used when a selector needs chart-level data but must avoid extra recomputes when the * data content has not actually changed. */ export var selectChartDataSliceIfNotInPanorama = createSelector([selectChartDataWithIndexesIfNotInPanoramaPosition4], _ref => { var { chartData, dataStartIndex, dataEndIndex } = _ref; return chartData != null ? chartData.slice(dataStartIndex, dataEndIndex + 1) : []; }); /** * Returns the chart-level data slice (ignoring Brush indexes), memoized by content. * Used in tooltip and polar selectors that always need the full data range. */ export var selectChartDataSliceIgnoringIndexes = createSelector([selectChartDataAndAlwaysIgnoreIndexes], _ref2 => { var { chartData, dataStartIndex, dataEndIndex } = _ref2; return chartData != null ? chartData.slice(dataStartIndex, dataEndIndex + 1) : []; }); /** * Returns the chart-level data slice (with Brush indexes applied), memoized by content. * Used in tooltip selectors. */ export var selectChartDataSliceWithIndexes = createSelector([selectChartDataWithIndexes], _ref3 => { var { chartData, dataStartIndex, dataEndIndex } = _ref3; return chartData != null ? chartData.slice(dataStartIndex, dataEndIndex + 1) : []; });