From 9602b6c03c61f46907b836c01b2e8e50b9a87e2c Mon Sep 17 00:00:00 2001 From: Sayna Parida Date: Sun, 29 Aug 2021 21:33:38 +0530 Subject: [PATCH] Changed the table header to sticky headers --- src/components/Table.js | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/src/components/Table.js b/src/components/Table.js index 3b7056828..be6522ea8 100644 --- a/src/components/Table.js +++ b/src/components/Table.js @@ -243,6 +243,43 @@ function Table({ useKeyPressEvent('?', () => { setIsInfoVisible(!isInfoVisible); }); + + useEffect(() =>{ + let table = document.querySelector('.table-container>.table'); + let headers = document.querySelectorAll('.table-container>.table>.row.heading:first-child>.cell'); + + // Set config values, set the special z indices for the header divs + const stickBottomLimit = 150; + const firstHeaderZ = 140; + const otherHeaderZ = 120; + headers.forEach((el, index)=>{ + el.style.zIndex = index==0 ? firstHeaderZ : otherHeaderZ; + }); + + // Build the handler that makes headers stick + const handleScroll = ()=>{ + const rect = table.getBoundingClientRect(); + let offset = 0; + if (rect.top < 0) { + offset = Math.min(-rect.top, rect.height-stickBottomLimit); + } + headers.forEach((el)=>{ + el.style.transform = 'translateY('+offset+'px)'; + }); + }; + + // Build debounced scroll listener + let ticking = false; + document.addEventListener('scroll', (e)=>{ + if (!ticking) { + window.requestAnimationFrame(()=>{ + handleScroll(); + ticking = false; + }); + ticking = true; + } + }); + }) return (