@@ -2,13 +2,40 @@ import React, {useState, useRef, useEffect} from 'react';
22import { useUser } from '../../hooks/useUser/useUser.jsx' ;
33import { useEasyauth } from '../../hooks/useEasyauth/useEasyauth.jsx' ;
44import PropTypes from 'prop-types' ;
5+ import { iconUser } from '../uiComponents/iconUser.js' ;
6+ import { Box , Modal } from '@mui/material' ;
7+ import { UserProfile } from '../UserProfile/UserProfile.jsx' ;
58
69
7- export const UserButton = ( { position} ) => {
10+ export const UserButton = ( { position, profileRedirect } ) => {
811 const auth = useEasyauth ( ) ;
912 const { user} = useUser ( ) ;
1013 const [ isOpen , setIsOpen ] = useState ( false ) ;
1114 const cardRef = useRef ( null ) ;
15+ const [ open , setOpen ] = useState ( false ) ;
16+
17+
18+ const ProfileModal = ( ) => {
19+ const handleClose = ( ) => {
20+ setOpen ( false ) ;
21+ } ;
22+ return (
23+ < >
24+ < Modal open = { open } onClose = { handleClose } >
25+ < Box >
26+ < div
27+ style = { {
28+ display : 'flex' ,
29+ justifyContent : 'center' ,
30+ } }
31+ >
32+ < UserProfile />
33+ </ div >
34+ </ Box >
35+ </ Modal >
36+ </ >
37+ ) ;
38+ } ;
1239
1340 const handleButtonClick = ( ) => {
1441 setIsOpen ( ! isOpen ) ;
@@ -19,9 +46,22 @@ export const UserButton = ({position}) => {
1946 } ;
2047
2148 const handleAccount = ( ) => {
22- // Redirect to account page
49+ setIsOpen ( false ) ;
50+ if ( ! profileRedirect ) {
51+ setOpen ( true ) ;
52+ }
2353 } ;
2454
55+ const cardStyle = {
56+ position : 'absolute' ,
57+ top : '50px' ,
58+ borderRadius : '8px' ,
59+ backgroundColor : '#fff' ,
60+ boxShadow : '0 2px 4px rgba(0, 0, 0, 0.1)' ,
61+ padding : '10px' ,
62+ display : 'flex' ,
63+ flexDirection : 'column' ,
64+ } ;
2565 useEffect ( ( ) => {
2666 function handleClickOutside ( event ) {
2767 if ( cardRef . current && ! cardRef . current . contains ( event . target ) ) {
@@ -34,18 +74,6 @@ export const UserButton = ({position}) => {
3474 document . removeEventListener ( 'mousedown' , handleClickOutside ) ;
3575 } ;
3676 } , [ ] ) ;
37-
38- const cardStyle = {
39- position : 'absolute' ,
40- top : '50px' ,
41- borderRadius : '8px' ,
42- backgroundColor : '#fff' ,
43- boxShadow : '0 2px 4px rgba(0, 0, 0, 0.1)' ,
44- padding : '10px' ,
45- display : 'flex' ,
46- flexDirection : 'column' ,
47- } ;
48-
4977 if ( position === 'left' ) {
5078 cardStyle . left = '0' ;
5179 } else if ( position === 'right' ) {
@@ -55,87 +83,97 @@ export const UserButton = ({position}) => {
5583 }
5684
5785 return (
58- < div style = { { position : 'relative' , display : 'inline-block' } } >
59- < button
60- style = { {
61- width : '40px' ,
62- height : '40px' ,
63- borderRadius : '50%' ,
64- padding : '0' ,
65- border : 'none' ,
66- backgroundColor : '#ccc' ,
67- } }
68- onClick = { handleButtonClick }
69- >
70- < img
71- src = ""
72- style = { { width : '100%' , height : '100%' } }
73- />
74- </ button >
75-
76- { isOpen && (
77- < div
78- ref = { cardRef }
79- style = { cardStyle }
86+ < >
87+ < div style = { { position : 'relative' , display : 'inline-block' } } >
88+ < button
89+ style = { {
90+ width : '40px' ,
91+ height : '40px' ,
92+ borderRadius : '50%' ,
93+ padding : '0' ,
94+ border : 'none' ,
95+ backgroundColor : '#ccc' ,
96+ } }
97+ onClick = { handleButtonClick }
8098 >
81- < div
82- style = { {
83- display : 'flex' ,
84- alignItems : 'center' ,
85- marginBottom : '10px' ,
86- overflow : 'hidden' ,
87- textOverflow : 'ellipsis' ,
88- } }
89- >
90- < img
91- src = ""
92- alt = "Profile Icon"
93- style = { { width : '30px' , height : '30px' , marginRight : '10px' } }
94- />
99+ < img
100+ src = { iconUser ( ) }
101+ alt = "profile icon"
102+ style = { { width : '100%' , height : '100%' } }
103+ />
104+ </ button >
105+
106+ < ProfileModal />
107+ { isOpen && (
108+ < div ref = { cardRef } style = { cardStyle } >
95109 < div
96110 style = { {
97- color : 'black' ,
98- fontSize : '16px' ,
111+ display : 'flex' ,
112+ alignItems : 'center' ,
113+ marginBottom : '10px' ,
99114 overflow : 'hidden' ,
100115 textOverflow : 'ellipsis' ,
101116 } }
102117 >
103- { user . email }
118+ < img
119+ src = { iconUser ( ) }
120+ alt = "Profile Icon"
121+ style = { { width : '30px' , height : '30px' , marginRight : '10px' } }
122+ />
123+ < div
124+ style = { {
125+ color : 'black' ,
126+ fontSize : '16px' ,
127+ overflow : 'hidden' ,
128+ textOverflow : 'ellipsis' ,
129+ } }
130+ >
131+ { user . email }
132+ </ div >
104133 </ div >
134+ < button
135+ style = { {
136+ backgroundColor : '#007bff' ,
137+ color : '#fff' ,
138+ padding : '5px 10px' ,
139+ marginBottom : '10px' ,
140+ border : 'none' ,
141+ borderRadius : '3px' ,
142+ cursor : 'pointer' ,
143+ } }
144+ onClick = { handleLogout }
145+ >
146+ Logout
147+ </ button >
148+ < a
149+ href = { profileRedirect }
150+ style = { {
151+ backgroundColor : '#17a2b8' ,
152+ } }
153+ >
154+ < button
155+ style = { {
156+ backgroundColor : '#17a2b8' ,
157+ color : '#fff' ,
158+ padding : '5px 10px' ,
159+ border : 'none' ,
160+ borderRadius : '3px' ,
161+ cursor : 'pointer' ,
162+ } }
163+ onClick = { handleAccount }
164+ >
165+ Account
166+ </ button >
167+ </ a >
105168 </ div >
106- < button
107- style = { {
108- backgroundColor : '#007bff' ,
109- color : '#fff' ,
110- padding : '5px 10px' ,
111- marginBottom : '10px' ,
112- border : 'none' ,
113- borderRadius : '3px' ,
114- cursor : 'pointer' ,
115- } }
116- onClick = { handleLogout }
117- >
118- Logout
119- </ button >
120- < button
121- style = { {
122- backgroundColor : '#17a2b8' ,
123- color : '#fff' ,
124- padding : '5px 10px' ,
125- border : 'none' ,
126- borderRadius : '3px' ,
127- cursor : 'pointer' ,
128- } }
129- onClick = { handleAccount }
130- >
131- Account
132- </ button >
133- </ div >
134- ) }
135- </ div >
169+ ) }
170+ </ div >
171+ </ >
136172 ) ;
137173} ;
138174
175+
139176UserButton . propTypes = {
140177 position : PropTypes . string ,
178+ profileRedirect : PropTypes . string ,
141179} ;
0 commit comments