@mui/x-date-pickers
Version:
The community edition of the MUI X Date and Time Picker components.
67 lines (63 loc) • 2.1 kB
JavaScript
import ownerDocument from '@mui/utils/ownerDocument';
/* Use it instead of .includes method for IE support */
export function arrayIncludes(array, itemOrItems) {
if (Array.isArray(itemOrItems)) {
return itemOrItems.every(item => array.indexOf(item) !== -1);
}
return array.indexOf(itemOrItems) !== -1;
}
export const onSpaceOrEnter = (innerFn, externalEvent) => event => {
if (event.key === 'Enter' || event.key === ' ') {
innerFn(event);
// prevent any side effects
event.preventDefault();
event.stopPropagation();
}
if (externalEvent) {
externalEvent(event);
}
};
export const executeInTheNextEventLoopTick = fn => {
setTimeout(fn, 0);
};
// https://www.abeautifulsite.net/posts/finding-the-active-element-in-a-shadow-root/
const getActiveElementInternal = (root = document) => {
const activeEl = root.activeElement;
if (!activeEl) {
return null;
}
if (activeEl.shadowRoot) {
return getActiveElementInternal(activeEl.shadowRoot);
}
return activeEl;
};
/**
* Gets the currently active element within a given node's document.
* This function traverses shadow DOM if necessary.
* @param node - The node from which to get the active element.
* @returns The currently active element, or null if none is found.
*/
export const getActiveElement = node => {
return getActiveElementInternal(ownerDocument(node));
};
/**
* Gets the index of the focused list item in a given ul list element.
*
* @param {HTMLUListElement} listElement - The list element to search within.
* @returns {number} The index of the focused list item, or -1 if none is focused.
*/
export const getFocusedListItemIndex = listElement => {
const children = Array.from(listElement.children);
return children.indexOf(getActiveElement(listElement));
};
export const DEFAULT_DESKTOP_MODE_MEDIA_QUERY = '@media (pointer: fine)';
export function mergeSx(...sxProps) {
return sxProps.reduce((acc, sxProp) => {
if (Array.isArray(sxProp)) {
acc.push(...sxProp);
} else if (sxProp != null) {
acc.push(sxProp);
}
return acc;
}, []);
}