UNPKG

@mui/x-data-grid

Version:

The community edition of the data grid component (MUI X).

63 lines (61 loc) 2.13 kB
import { gridClasses } from '../constants/gridClasses'; export function isOverflown(element) { return element.scrollHeight > element.clientHeight || element.scrollWidth > element.clientWidth; } export function findParentElementFromClassName(elem, className) { return elem.closest(`.${className}`); } export function getRowEl(cell) { if (!cell) { return null; } return findParentElementFromClassName(cell, gridClasses.row); } // TODO remove export function isGridCellRoot(elem) { return elem != null && elem.classList.contains(gridClasses.cell); } export function isGridHeaderCellRoot(elem) { return elem != null && elem.classList.contains(gridClasses.columnHeader); } function escapeOperandAttributeSelector(operand) { return operand.replace(/["\\]/g, '\\$&'); } export function getGridColumnHeaderElement(root, field) { return root.querySelector(`[role="columnheader"][data-field="${escapeOperandAttributeSelector(field)}"]`); } function getGridRowElementSelector(id) { return `.${gridClasses.row}[data-id="${escapeOperandAttributeSelector(String(id))}"]`; } export function getGridRowElement(root, id) { return root.querySelector(getGridRowElementSelector(id)); } export function getGridCellElement(root, { id, field }) { const rowSelector = getGridRowElementSelector(id); const cellSelector = `.${gridClasses.cell}[data-field="${escapeOperandAttributeSelector(field)}"]`; const selector = `${rowSelector} ${cellSelector}`; return root.querySelector(selector); } // https://www.abeautifulsite.net/posts/finding-the-active-element-in-a-shadow-root/ export const getActiveElement = (root = document) => { const activeEl = root.activeElement; if (!activeEl) { return null; } if (activeEl.shadowRoot) { return getActiveElement(activeEl.shadowRoot); } return activeEl; }; export function isEventTargetInPortal(event) { if ( // The target is not an element when triggered by a Select inside the cell // See https://github.com/mui/material-ui/issues/10534 event.target.nodeType === 1 && !event.currentTarget.contains(event.target)) { return true; } return false; }