Detect Prefers Reduced Motion 🥴 🔍️ 👀️
A micro ES6 module (~0.5KB) for detecting a users prefers-reduced-motion
and watching for changes.
data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt="License: MIT"
Installation
npm install @egstad / detect - motion
Usage
import detectMotion from '@egstad/detect-motion'
window.addEventListener('reducedMotionUpdated', (e) => {
if (e.detail.reduce) {
} else {
}
})
detectMotion.watch()
Methods
The watch()
method is more than likely all you'll need. Here's a list of what each method in the module does.
detectMotion.get()
detectMotion.watch()
detectMotion.destroy()
Example
Here is a screencap demonstrating the realtime updates on Mac OS (System Preferences > Accessibility > Display > Reduce Motion).
data:image/s3,"s3://crabby-images/0adf7/0adf7525a2a50cc85a75f9b57218f18ba5e1c3a2" alt="Example of changing Prefer Reduced Motion on Mac OS"