From c1416bd1c05256e047997220b95983728d96e753 Mon Sep 17 00:00:00 2001 From: Sujit Date: Wed, 25 Sep 2024 14:02:03 +0545 Subject: [PATCH 1/6] feat: add `ScrollToTop` component --- .../components/common/ScrollToTop/index.tsx | 49 +++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 src/frontend/src/components/common/ScrollToTop/index.tsx diff --git a/src/frontend/src/components/common/ScrollToTop/index.tsx b/src/frontend/src/components/common/ScrollToTop/index.tsx new file mode 100644 index 00000000..bb83d703 --- /dev/null +++ b/src/frontend/src/components/common/ScrollToTop/index.tsx @@ -0,0 +1,49 @@ +import React, { useState, useEffect } from 'react'; + +const ScrollToTop: React.FC = () => { + const [isVisible, setIsVisible] = useState(false); + + useEffect(() => { + const toggleVisibility = () => { + const playgroundElement = document.getElementById('app_playground'); + if (playgroundElement && playgroundElement?.scrollTop > 400) { + setIsVisible(true); + } else { + setIsVisible(false); + } + }; + + const playgroundElement = document.getElementById('app_playground'); + playgroundElement?.addEventListener('scroll', toggleVisibility); + + return () => { + playgroundElement?.removeEventListener('scroll', toggleVisibility); + }; + }, []); + + const scrollToTop = () => { + const playgroundElement = document.getElementById('app_playground'); + playgroundElement?.scrollTo({ + top: 0, + behavior: 'smooth', + }); + }; + + return ( +
+ +
+ ); +}; + +export default ScrollToTop; From ce1a88f5e65d5fa4390c98e9dc9f038cdb3a16e7 Mon Sep 17 00:00:00 2001 From: Sujit Date: Wed, 25 Sep 2024 14:05:26 +0545 Subject: [PATCH 2/6] feat: make navbar fixed height --- src/frontend/src/components/common/Navbar/index.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/frontend/src/components/common/Navbar/index.tsx b/src/frontend/src/components/common/Navbar/index.tsx index ff1a955a..f0db1d0c 100644 --- a/src/frontend/src/components/common/Navbar/index.tsx +++ b/src/frontend/src/components/common/Navbar/index.tsx @@ -10,7 +10,7 @@ export default function Navbar() { const navigate = useNavigate(); return ( -