@wordpress/components
Version:
UI components for WordPress.
59 lines (49 loc) • 1.41 kB
JavaScript
/**
* WordPress dependencies
*/
import { useEffect } from '@wordpress/element';
/*
* Setting `overflow: hidden` on html and body elements resets body scroll in iOS.
* Save scroll top so we can restore it after locking scroll.
*
* NOTE: It would be cleaner and possibly safer to find a localized solution such
* as preventing default on certain touchmove events.
*/
let previousScrollTop = 0;
/**
* @param {boolean} locked
*/
function setLocked(locked) {
const scrollingElement = document.scrollingElement || document.body;
if (locked) {
previousScrollTop = scrollingElement.scrollTop;
}
const methodName = locked ? 'add' : 'remove';
scrollingElement.classList[methodName]('lockscroll'); // Adding the class to the document element seems to be necessary in iOS.
document.documentElement.classList[methodName]('lockscroll');
if (!locked) {
scrollingElement.scrollTop = previousScrollTop;
}
}
let lockCounter = 0;
/**
* A component that will lock scrolling when it is mounted and unlock scrolling when it is unmounted.
*
* @return {null} Render nothing.
*/
export default function ScrollLock() {
useEffect(() => {
if (lockCounter === 0) {
setLocked(true);
}
++lockCounter;
return () => {
if (lockCounter === 1) {
setLocked(false);
}
--lockCounter;
};
}, []);
return null;
}
//# sourceMappingURL=index.js.map