mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
🐛 Fixed jerky scrolling in Site Design for Safari (#19974)
no issue - Keeping state of the scroll location to keep in sync with iframe buffering caused performance issues in Safari. - This adds a debounce to when the scroll location is updated which fixes jerky scrolling in Safari.
This commit is contained in:
parent
2332f339dc
commit
a732164d54
1 changed files with 16 additions and 2 deletions
|
@ -11,6 +11,19 @@ type IframeBufferingProps = {
|
|||
addDelay?: boolean;
|
||||
};
|
||||
|
||||
function debounce(func: any, wait: number) { // eslint-disable-line
|
||||
let timeout: NodeJS.Timeout;
|
||||
|
||||
return function executedFunction(...args: any) { // eslint-disable-line
|
||||
const later = () => {
|
||||
clearTimeout(timeout);
|
||||
func(...args);
|
||||
};
|
||||
clearTimeout(timeout);
|
||||
timeout = setTimeout(later, wait);
|
||||
};
|
||||
}
|
||||
|
||||
const IframeBuffering: React.FC<IframeBufferingProps> = ({generateContent, className, height, width, parentClassName, testId, addDelay = false}) => {
|
||||
const [visibleIframeIndex, setVisibleIframeIndex] = useState(0);
|
||||
const iframes = [useRef<HTMLIFrameElement>(null), useRef<HTMLIFrameElement>(null)]; // eslint-disable-line
|
||||
|
@ -48,9 +61,10 @@ const IframeBuffering: React.FC<IframeBufferingProps> = ({generateContent, class
|
|||
|
||||
useEffect(() => {
|
||||
const iframe = iframes[visibleIframeIndex].current;
|
||||
const onScroll = () => {
|
||||
|
||||
const onScroll = debounce(() => {
|
||||
setScrollPosition(iframe?.contentWindow?.scrollY || 0);
|
||||
};
|
||||
}, 250);
|
||||
|
||||
iframe?.contentWindow?.addEventListener('scroll', onScroll);
|
||||
|
||||
|
|
Loading…
Reference in a new issue