UNPKG

@mui/x-data-grid

Version:

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

30 lines (28 loc) 1.83 kB
export const isEscapeKey = key => key === 'Escape'; // TODO remove export const isEnterKey = key => key === 'Enter'; // TODO remove export const isTabKey = key => key === 'Tab'; // TODO remove export const isSpaceKey = key => key === ' '; export const isArrowKeys = key => key.indexOf('Arrow') === 0; export const isHomeOrEndKeys = key => key === 'Home' || key === 'End'; export const isPageKeys = key => key.indexOf('Page') === 0; export const isDeleteKeys = key => key === 'Delete' || key === 'Backspace'; // Non printable keys have a name, e.g. "ArrowRight", see the whole list: // https://developer.mozilla.org/en-US/docs/Web/API/UI_Events/Keyboard_event_key_values // So event.key.length === 1 is often enough. // // However, we also need to ignore shortcuts, for example: select all: // - Windows: Ctrl+A, event.ctrlKey is true // - macOS: ⌘ Command+A, event.metaKey is true export function isPrintableKey(event) { return event.key.length === 1 && !event.ctrlKey && !event.metaKey; } export const GRID_MULTIPLE_SELECTION_KEYS = ['Meta', 'Control', 'Shift']; export const GRID_CELL_EXIT_EDIT_MODE_KEYS = ['Enter', 'Escape', 'Tab']; export const GRID_CELL_EDIT_COMMIT_KEYS = ['Enter', 'Tab']; export const isMultipleKey = key => GRID_MULTIPLE_SELECTION_KEYS.indexOf(key) > -1; export const isCellEnterEditModeKeys = event => isEnterKey(event.key) || isDeleteKeys(event.key) || isPrintableKey(event); export const isCellExitEditModeKeys = key => GRID_CELL_EXIT_EDIT_MODE_KEYS.indexOf(key) > -1; export const isCellEditCommitKeys = key => GRID_CELL_EDIT_COMMIT_KEYS.indexOf(key) > -1; export const isNavigationKey = key => isHomeOrEndKeys(key) || isArrowKeys(key) || isPageKeys(key) || isSpaceKey(key); export const isKeyboardEvent = event => !!event.key; export const isHideMenuKey = key => isTabKey(key) || isEscapeKey(key);