0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

🐛 Fixed iFrame not keeping scroll position

no issue

- Added position tracking in the iFrame to allow it to remain in the
  same place in the preview after making changes.
This commit is contained in:
Ronald Langeveld 2024-02-21 17:08:56 +02:00
parent c64c0c2123
commit 532703a04c

View file

@ -12,7 +12,8 @@ type IframeBufferingProps = {
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)];
const iframes = [useRef<HTMLIFrameElement>(null), useRef<HTMLIFrameElement>(null)]; // eslint-disable-line
const [scrollPosition, setScrollPosition] = useState(0);
useEffect(() => {
const invisibleIframeIndex = visibleIframeIndex === 0 ? 1 : 0;
@ -44,11 +45,34 @@ const IframeBuffering: React.FC<IframeBufferingProps> = ({generateContent, class
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [generateContent]);
// track the scroll position of the visible iframe and set scroll position of the invisible iframe
useEffect(() => {
const iframe = iframes[visibleIframeIndex].current;
const onScroll = () => {
setScrollPosition(iframe?.contentWindow?.scrollY || 0);
};
iframe?.contentWindow?.addEventListener('scroll', onScroll);
return () => {
iframe?.contentWindow?.removeEventListener('scroll', onScroll);
};
}, [visibleIframeIndex, iframes]);
useEffect(() => {
const invisibleIframeIndex = visibleIframeIndex === 0 ? 1 : 0;
const iframe = iframes[invisibleIframeIndex].current;
if (iframe) {
iframe.contentWindow?.scrollTo(0, scrollPosition);
}
}, [scrollPosition, visibleIframeIndex, iframes]);
return (
<div className={parentClassName} data-testid={testId}>
<iframe
ref={iframes[0]}
className={`${className} ${visibleIframeIndex !== 0 ? 'z-10 opacity-0' : 'z-20 opacity-100'}`}
className={`${className} ${visibleIframeIndex !== 0 ? 'invisible z-10' : 'z-20'}`}
data-visible={visibleIframeIndex === 0}
frameBorder="0"
height={height}
@ -58,7 +82,7 @@ const IframeBuffering: React.FC<IframeBufferingProps> = ({generateContent, class
<iframe
ref={iframes[1]}
className={`${className} ${visibleIframeIndex !== 1 ? 'z-10 opacity-0' : 'z-20 opacity-100'}`}
className={`${className} ${visibleIframeIndex !== 1 ? 'invisible z-10' : 'z-20'}`}
data-visible={visibleIframeIndex === 1}
frameBorder="0"
height={height}