@mui/x-charts
Version:
The community edition of the Charts components (MUI X).
45 lines (41 loc) • 1.49 kB
JavaScript
;
'use client';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useReducedMotion = void 0;
var _web = require("@react-spring/web");
const handleMediaChange = event => {
_web.Globals.assign({
// Modification such the react-spring implementation such that this hook can remove animation but never activate animation.
skipAnimation: event.matches || undefined
});
};
/**
* Returns `boolean` or `null`, used to automatically
* set skipAnimations to the value of the user's
* `prefers-reduced-motion` query.
*
* The return value, post-effect, is the value of their preferred setting
*/
const useReducedMotion = () => {
// Taken from: https://github.com/pmndrs/react-spring/blob/fd65b605b85c3a24143c4ce9dd322fdfca9c66be/packages/shared/src/hooks/useReducedMotion.ts
(0, _web.useIsomorphicLayoutEffect)(() => {
// Skip animation test/jsdom
const shouldSkipAnimation = !window?.matchMedia;
if (shouldSkipAnimation) {
handleMediaChange({
matches: true
});
return undefined;
}
const mql = window.matchMedia('(prefers-reduced-motion)');
handleMediaChange(mql);
// MatchMedia is not fully supported in all environments, so we need to check if it exists before calling addEventListener
mql.addEventListener?.('change', handleMediaChange);
return () => {
mql.removeEventListener?.('change', handleMediaChange);
};
}, []);
};
exports.useReducedMotion = useReducedMotion;