@mui/x-data-grid
Version:
The Community plan edition of the Data Grid components (MUI X).
19 lines • 1.08 kB
JavaScript
import * as React from 'react';
import { selectedIdsLookupSelector } from '../rowSelection';
import { useGridSelector } from '../../utils/useGridSelector';
import { gridColumnGroupsHeaderMaxDepthSelector } from '../columnGrouping/gridColumnGroupsSelector';
import { useGridPrivateApiContext } from '../../utils/useGridPrivateApiContext';
export const useGridRowAriaAttributes = () => {
const apiRef = useGridPrivateApiContext();
const selectedIdsLookup = useGridSelector(apiRef, selectedIdsLookupSelector);
const headerGroupingMaxDepth = useGridSelector(apiRef, gridColumnGroupsHeaderMaxDepthSelector);
return React.useCallback((rowNode, index) => {
const ariaAttributes = {};
const ariaRowIndex = index + headerGroupingMaxDepth + 2; // 1 for the header row and 1 as it's 1-based
ariaAttributes['aria-rowindex'] = ariaRowIndex;
if (apiRef.current.isRowSelectable(rowNode.id)) {
ariaAttributes['aria-selected'] = selectedIdsLookup[rowNode.id] !== undefined;
}
return ariaAttributes;
}, [apiRef, selectedIdsLookup, headerGroupingMaxDepth]);
};