@mui/x-data-grid
Version:
The Community plan edition of the Data Grid components (MUI X).
27 lines (26 loc) • 1.47 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useGridRowAriaAttributes = void 0;
var React = _interopRequireWildcard(require("react"));
var _rowSelection = require("../rowSelection");
var _useGridSelector = require("../../utils/useGridSelector");
var _gridColumnGroupsSelector = require("../columnGrouping/gridColumnGroupsSelector");
var _useGridPrivateApiContext = require("../../utils/useGridPrivateApiContext");
const useGridRowAriaAttributes = () => {
const apiRef = (0, _useGridPrivateApiContext.useGridPrivateApiContext)();
const selectedIdsLookup = (0, _useGridSelector.useGridSelector)(apiRef, _rowSelection.selectedIdsLookupSelector);
const headerGroupingMaxDepth = (0, _useGridSelector.useGridSelector)(apiRef, _gridColumnGroupsSelector.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]);
};
exports.useGridRowAriaAttributes = useGridRowAriaAttributes;
;