From 8f21ec7240dbb30ab85258cfe2486337a166097d Mon Sep 17 00:00:00 2001 From: NancyAanchal Date: Sat, 10 Aug 2024 13:50:36 +0545 Subject: [PATCH] added hover and navigate --- nepalingo-web/src/components/UserAvatar.tsx | 35 +++++++++++++++---- .../src/components/header/UserProfile.tsx | 8 ++++- 2 files changed, 35 insertions(+), 8 deletions(-) diff --git a/nepalingo-web/src/components/UserAvatar.tsx b/nepalingo-web/src/components/UserAvatar.tsx index e7dda8d..8434ce2 100644 --- a/nepalingo-web/src/components/UserAvatar.tsx +++ b/nepalingo-web/src/components/UserAvatar.tsx @@ -1,17 +1,38 @@ -import React from "react"; +import React, { HTMLAttributes } from "react"; import { useAuth } from "@/hooks/Auth"; +import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"; +import { faPen } from "@fortawesome/free-solid-svg-icons"; -const UserAvatar: React.FC = () => { +interface UserAvatarProps extends HTMLAttributes { + showPenOnHover?: boolean; +} + +const UserAvatar: React.FC = ({ + onClick, + showPenOnHover = false, + ...props +}) => { const { user } = useAuth(); const username = user?.user_metadata?.username; const avatarUrl = `https://robohash.org/${username}.png?set=set4`; return ( - User Avatar +
+ User Avatar + {showPenOnHover && ( +
+ +
+ )} +
); }; diff --git a/nepalingo-web/src/components/header/UserProfile.tsx b/nepalingo-web/src/components/header/UserProfile.tsx index 546806a..83842f9 100644 --- a/nepalingo-web/src/components/header/UserProfile.tsx +++ b/nepalingo-web/src/components/header/UserProfile.tsx @@ -4,6 +4,7 @@ import { StreakContext } from "@/hooks/StreakContext"; import { getPhrase } from "@/components/header/StreakPhrase"; import { useAuth } from "@/hooks/Auth"; import fire from "@/assets/fire.svg"; +import { useNavigate } from "react-router-dom"; const UserProfile: React.FC = () => { const [isOpen, setIsOpen] = useState(false); @@ -11,6 +12,7 @@ const UserProfile: React.FC = () => { const { currentStreak, longestStreak } = useContext(StreakContext); const phrase = getPhrase(currentStreak); const dropdownRef = useRef(null); + const navigate = useNavigate(); const toggleMenu = () => { setIsOpen(!isOpen); @@ -25,6 +27,10 @@ const UserProfile: React.FC = () => { } }; + const handleAvatarClick = () => { + navigate("/edit-profile"); + }; + useEffect(() => { document.addEventListener("mousedown", handleClickOutside); return () => { @@ -47,7 +53,7 @@ const UserProfile: React.FC = () => {
- +
{user?.user_metadata?.username}