Skip to content

Commit

Permalink
Trigger update when container resizes
Browse files Browse the repository at this point in the history
  • Loading branch information
mmuzikar committed Jan 16, 2024
1 parent 22e5339 commit bee4737
Showing 1 changed file with 18 additions and 2 deletions.
20 changes: 18 additions & 2 deletions packages/module/src/LogViewer/LogViewer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,8 @@ const LogViewerBase: React.FunctionComponent<LogViewerProps> = memo(
const [loading, setLoading] = useState(true);
const [listKey, setListKey] = useState(1);

const [, setEmptyState] = useState({});

/* Parse data every time it changes */
const parsedData = React.useMemo(() => parseConsoleOutput(data), [data]);

Expand All @@ -113,16 +115,27 @@ const LogViewerBase: React.FunctionComponent<LogViewerProps> = memo(
let resizeTimer = null as any;

useEffect(() => {
let observer : ResizeObserver | undefined = undefined;
if (containerRef && containerRef.current) {
window.addEventListener('resize', callbackResize);
observer = new ResizeObserver((event) => {
setEmptyState({});
});
observer.observe(containerRef.current);
setLoading(false);
createDummyElements();
ansiUp.resetStyles();
}
return () => window.removeEventListener('resize', callbackResize);
return () => {
window.removeEventListener('resize', callbackResize);
observer?.disconnect();
}
}, [containerRef.current]);

const callbackResize = () => {
const callbackResize = (event : UIEvent) => {
if (event.type === 'scroll') {
return;
}
if (!resizing) {
setResizing(true);
}
Expand Down Expand Up @@ -168,6 +181,9 @@ const LogViewerBase: React.FunctionComponent<LogViewerProps> = memo(
}, [parsedData, scrollToRow]);

const createDummyElements = () => {
if (!(containerRef && containerRef.current)) {
return;
}
// create dummy elements
const dummyIndex = document.createElement('span');
dummyIndex.className = css(styles.logViewerIndex);
Expand Down

0 comments on commit bee4737

Please sign in to comment.