UNPKG

recharts

Version:
80 lines (78 loc) 4.07 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.selectLinePoints = void 0; var _reselect = require("reselect"); var _Line = require("../../cartesian/Line"); var _dataSelectors = require("./dataSelectors"); var _chartLayoutContext = require("../../context/chartLayoutContext"); var _axisSelectors = require("./axisSelectors"); var _ChartUtils = require("../../util/ChartUtils"); var selectXAxisWithScale = (state, xAxisId, _yAxisId, isPanorama) => (0, _axisSelectors.selectAxisWithScale)(state, 'xAxis', xAxisId, isPanorama); var selectXAxisTicks = (state, xAxisId, _yAxisId, isPanorama) => (0, _axisSelectors.selectTicksOfGraphicalItem)(state, 'xAxis', xAxisId, isPanorama); var selectYAxisWithScale = (state, _xAxisId, yAxisId, isPanorama) => (0, _axisSelectors.selectAxisWithScale)(state, 'yAxis', yAxisId, isPanorama); var selectYAxisTicks = (state, _xAxisId, yAxisId, isPanorama) => (0, _axisSelectors.selectTicksOfGraphicalItem)(state, 'yAxis', yAxisId, isPanorama); var selectBandSize = (0, _reselect.createSelector)([_chartLayoutContext.selectChartLayout, selectXAxisWithScale, selectYAxisWithScale, selectXAxisTicks, selectYAxisTicks], (layout, xAxis, yAxis, xAxisTicks, yAxisTicks) => { if ((0, _ChartUtils.isCategoricalAxis)(layout, 'xAxis')) { return (0, _ChartUtils.getBandSizeOfAxis)(xAxis, xAxisTicks, false); } return (0, _ChartUtils.getBandSizeOfAxis)(yAxis, yAxisTicks, false); }); var pickLineSettings = (_state, _xAxisId, _yAxisId, _isPanorama, lineSettings) => lineSettings; /* * There is a race condition problem because we read some data from props and some from the state. * The state is updated through a dispatch and is one render behind, * and so we have this weird one tick render where the displayedData in one selector have the old dataKey * but the new dataKey in another selector. * * A proper fix is to either move everything into the state, or read the dataKey always from props * - but this is a smaller change. */ var selectSynchronisedLineSettings = (0, _reselect.createSelector)([_axisSelectors.selectUnfilteredCartesianItems, pickLineSettings], (graphicalItems, lineSettingsFromProps) => { if (graphicalItems.some(cgis => cgis.type === 'line' && lineSettingsFromProps.dataKey === cgis.dataKey && lineSettingsFromProps.data === cgis.data)) { /* * now, at least one of the lines has the same dataKey as the one in props. * Is this a perfect match? Maybe not because we could theoretically have two different Lines with the same dataKey * and the same stackId and the same data but still different lines, yes, * but the chances of that happening are ... lowish. * * A proper fix would be to store the lineSettings in a state too, and compare references directly instead of enumerating the properties. */ return lineSettingsFromProps; } return undefined; }); var selectLinePoints = exports.selectLinePoints = (0, _reselect.createSelector)([_chartLayoutContext.selectChartLayout, selectXAxisWithScale, selectYAxisWithScale, selectXAxisTicks, selectYAxisTicks, selectSynchronisedLineSettings, selectBandSize, _dataSelectors.selectChartDataWithIndexesIfNotInPanorama], (layout, xAxis, yAxis, xAxisTicks, yAxisTicks, lineSettings, bandSize, _ref) => { var { chartData, dataStartIndex, dataEndIndex } = _ref; if (lineSettings == null || xAxis == null || yAxis == null || xAxisTicks == null || yAxisTicks == null || xAxisTicks.length === 0 || yAxisTicks.length === 0 || bandSize == null) { return undefined; } var { dataKey, data } = lineSettings; var displayedData; if (data != null && data.length > 0) { displayedData = data; } else { displayedData = chartData === null || chartData === void 0 ? void 0 : chartData.slice(dataStartIndex, dataEndIndex + 1); } if (displayedData == null) { return undefined; } return (0, _Line.computeLinePoints)({ layout, xAxis, yAxis, xAxisTicks, yAxisTicks, dataKey, bandSize, displayedData }); });