diff --git a/client/package.json b/client/package.json index 04d0a7b..dcac2fe 100644 --- a/client/package.json +++ b/client/package.json @@ -12,6 +12,7 @@ "dependencies": { "@emotion/react": "^11.11.4", "@emotion/styled": "^11.11.5", + "@fortawesome/fontawesome-free": "^6.5.2", "@mui/material": "^5.15.19", "@tabler/icons-react": "^3.5.0", "axios": "^1.6.8", @@ -25,7 +26,8 @@ "react-dom": "^18.2.0", "react-heatmap-grid": "^0.9.0", "react-icons": "^5.2.1", - "react-router-dom": "^6.23.1" + "react-router-dom": "^6.23.1", + "react-scroll": "^1.9.0" }, "devDependencies": { "@types/react": "^18.2.66", diff --git a/client/src/components/FloatBtn.jsx b/client/src/components/FloatBtn.jsx index 5d74616..a6b08c1 100644 --- a/client/src/components/FloatBtn.jsx +++ b/client/src/components/FloatBtn.jsx @@ -1,19 +1,84 @@ -const FloatBtn = () => { - const scrollToTop = () => { - window.scrollTo({ - top: 0, - behavior: "smooth" - }); - }; - - return ( - - ); +'use client'; + +import React, { useState, useEffect } from "react"; +import { animateScroll } from 'react-scroll'; +import '@fortawesome/fontawesome-free/css/all.min.css'; + +const BackToTop = () => { + const [showButton, setShowButton] = useState(false); + + useEffect(() => { + const handleScroll = () => { + if (window.scrollY > 90) { + setShowButton(true); + } else { + setShowButton(false); + } + }; + + window.addEventListener("scroll", handleScroll); + + return () => { + window.removeEventListener("scroll", handleScroll); + }; + }, []); + + const handleClick = () => { + animateScroll.scrollToTop({ + top: 0, + behavior: "smooth", + duration: 500 + }); + }; + + const buttonStyles = { + position: 'fixed', + bottom: '20px', + right: '10px', + zIndex: 1000, + backgroundColor: '#7E22CE', + color: '#ffffff', + border: 'none', + padding: '10px', + fontSize: '14px', + cursor: 'pointer', + opacity: showButton ? 1 : 0, + transition: 'opacity 0.1s ease', + borderRadius: '60%', + display: 'flex', + alignItems: 'center', + justifyContent: 'center', + width: '42px', + height: '42px' + }; + + const iconStyles = { + fontSize: '20px' + }; + + return ( + <> + + + + ); }; -export default FloatBtn; \ No newline at end of file +export default BackToTop; \ No newline at end of file