From ed2cac5ef3968a51c827dc7bbbd193ce51cfe7ce Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BA=8C=E8=B4=A7=E7=88=B1=E5=90=83=E7=99=BD=E8=90=9D?= =?UTF-8?q?=E5=8D=9C?= Date: Tue, 25 Jun 2024 19:37:15 +0800 Subject: [PATCH] fix: scale scroll (#280) --- src/ScrollBar.tsx | 5 +++-- tests/scrollWidth.test.tsx | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/ScrollBar.tsx b/src/ScrollBar.tsx index dcfe1e1..d8f90a7 100644 --- a/src/ScrollBar.tsx +++ b/src/ScrollBar.tsx @@ -142,7 +142,8 @@ const ScrollBar = React.forwardRef((props, ref) => } = stateRef.current; raf.cancel(moveRafId); - const scale = containerSize / scrollbarRef.current.getBoundingClientRect().height; + const rect = scrollbarRef.current.getBoundingClientRect(); + const scale = containerSize / (horizontal ? rect.width : rect.height); if (stateDragging) { const offset = (getPageXY(e, horizontal) - statePageY) * scale; @@ -193,7 +194,7 @@ const ScrollBar = React.forwardRef((props, ref) => React.useEffect(() => { delayHidden(); - return () => { + return () => { clearTimeout(visibleTimeoutRef.current); }; }, [scrollOffset]); diff --git a/tests/scrollWidth.test.tsx b/tests/scrollWidth.test.tsx index b1f8fd1..79a141c 100644 --- a/tests/scrollWidth.test.tsx +++ b/tests/scrollWidth.test.tsx @@ -37,7 +37,7 @@ describe('List.scrollWidth', () => { }, clientHeight: { get() { - return holderWidth; + return holderHeight; }, }, getBoundingClientRect() {