@mui/x-data-grid
Version:
The Community plan edition of the MUI X Data Grid components.
32 lines • 1.81 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import { createSelector, createSelectorMemoized } from "../../../utils/createSelector.js";
import { gridVisibleColumnDefinitionsSelector } from "../columns/gridColumnsSelector.js";
import { gridRenderContextSelector } from "./gridVirtualizationSelectors.js";
import { gridFocusCellSelector } from "../focus/index.js";
import { gridVisibleRowsSelector } from "../pagination/index.js";
const gridIsFocusedCellOutOfContext = createSelector(gridFocusCellSelector, gridRenderContextSelector, gridVisibleRowsSelector, gridVisibleColumnDefinitionsSelector, (focusedCell, renderContext, currentPage, visibleColumns) => {
if (!focusedCell) {
return false;
}
const rowIndex = currentPage.rowIdToIndexMap.get(focusedCell.id);
const columnIndex = visibleColumns.slice(renderContext.firstColumnIndex, renderContext.lastColumnIndex).findIndex(column => column.field === focusedCell.field);
const isInRenderContext = rowIndex !== undefined && columnIndex !== -1 && rowIndex >= renderContext.firstRowIndex && rowIndex <= renderContext.lastRowIndex;
return !isInRenderContext;
});
export const gridFocusedVirtualCellSelector = createSelectorMemoized(gridIsFocusedCellOutOfContext, gridVisibleColumnDefinitionsSelector, gridVisibleRowsSelector, gridFocusCellSelector, (isFocusedCellOutOfRenderContext, visibleColumns, currentPage, focusedCell) => {
if (!isFocusedCellOutOfRenderContext) {
return null;
}
const rowIndex = currentPage.rowIdToIndexMap.get(focusedCell.id);
if (rowIndex === undefined) {
return null;
}
const columnIndex = visibleColumns.findIndex(column => column.field === focusedCell.field);
if (columnIndex === -1) {
return null;
}
return _extends({}, focusedCell, {
rowIndex,
columnIndex
});
});