From 491b83d69f20f25394af6d4186f024fe89a75e86 Mon Sep 17 00:00:00 2001 From: hwna00 Date: Sun, 24 Sep 2023 01:41:17 +0900 Subject: [PATCH] =?UTF-8?q?Feat(user):=20Root=EC=97=90=EC=84=9C=20?= =?UTF-8?q?=EB=A1=9C=EA=B7=B8=EC=9D=B8=20=EC=97=AC=EB=B6=80=20=ED=8C=90?= =?UTF-8?q?=EB=B3=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Root 컴포넌트에서 현재 로그인 상태를 확인 - 로그인 O: Outlet 렌더링 - 로그인 X: 로그인 페이지로 이동 ref: #67 --- packages/apps/user/firebase.js | 62 ++++++++++--------- packages/apps/user/src/api.js | 11 +++- .../apps/user/src/components/Root/Root.js | 39 +++++------- packages/apps/user/src/hooks/useUser.js | 15 +++++ packages/apps/user/src/index.js | 20 +++--- .../apps/user/src/views/Auth/LogIn/LogIn.js | 8 +-- 6 files changed, 87 insertions(+), 68 deletions(-) create mode 100644 packages/apps/user/src/hooks/useUser.js diff --git a/packages/apps/user/firebase.js b/packages/apps/user/firebase.js index f84957e2..444020cd 100644 --- a/packages/apps/user/firebase.js +++ b/packages/apps/user/firebase.js @@ -4,9 +4,10 @@ import { signInWithEmailAndPassword, GoogleAuthProvider, signInWithPopup, + createUserWithEmailAndPassword, } from 'firebase/auth'; -import { getStorage, ref, uploadBytes } from 'firebase/storage'; -import { checkUserExist, signUpWithFb } from './src/api'; +import { getDownloadURL, getStorage, ref, uploadBytes } from 'firebase/storage'; +import { checkUserExist, createUser } from './src/api'; const firebaseConfig = { apiKey: process.env.REACT_APP_FB_API_KEY, @@ -22,48 +23,51 @@ const auth = getAuth(app); const storage = getStorage(app); const provider = new GoogleAuthProvider(); -const uploadBlob = (blob, email) => { +export const uploadBlob = async (blob, email) => { const storageRef = ref(storage, `${email}/profileImg.png`); + await uploadBytes(storageRef, blob); +}; - uploadBytes(storageRef, blob).catch(() => {}); +export const getUserImage = email => { + getDownloadURL(ref(storage, `${email}/profileImg.png`)) + .then(url => console.log(url)) + .catch(() => null); }; -const fbSignUp = data => { +export const fbSignUp = async data => { const { email, password, ...rest } = data; const isUserExist = checkUserExist(email); - if (isUserExist) { + if (!isUserExist) { return null; } else { - createUserWithEmailAndPassword(auth, email, password).then( - userCredential => { - const { email } = userCredential.user; - uploadBlob(rest.profileImgBlob, email); - return signUpWithFb({ ...rest, email }); - }, - ); + await createUserWithEmailAndPassword(auth, email, password); + uploadBlob(rest.profileImgBlob, email); + return createUser({ ...rest, email }); } }; -const fbLogIn = data => { - const { email, data } = data; +export const fbLogIn = async data => { + const { email, password } = data; + const isUserExist = true; //checkUserExist(email); - //TODO: DB에 해당 email과 같은 메일이 존재하는지 확인. 존재한다면 해당 아이디가 이미 존재한다는 경고메시지 전송 + if (!isUserExist) { + //TODO: 존재하지 않는 회원입니다 알림 발송 + } else { + const userCredential = await signInWithEmailAndPassword( + auth, + email, + password, + ); + console.log(userCredential); + console.log(userCredential._tokenResponse); + //TODO: email을 가지는 user 정보를 DB에서 가져온다. - signInWithEmailAndPassword(auth, email, password) - .then(userCredential => { - const { email } = userCredential.user; - //TODO: email을 가지는 user 정보를 DB에서 가져온다. - }) - .catch(error => { - //TODO: CASE1. 이미 존재하는 경우 -> 경고알림 or 바로 로그인 - //TODO: CASE2. 존재하지 않는 경우 -> 회원가입 진행 - console.log(error); - }); + //TODO: CASE1. 이미 존재하는 경우 -> 경고알림 or 바로 로그인 + //TODO: CASE2. 존재하지 않는 경우 -> 회원가입 진행 + } }; -const googleLogin = () => { +export const googleLogin = () => { return signInWithPopup(auth, provider); }; - -export { auth, fbSignUp, fbLogIn, googleLogin, provider, storage }; diff --git a/packages/apps/user/src/api.js b/packages/apps/user/src/api.js index e2bc94ed..6f86cf9e 100644 --- a/packages/apps/user/src/api.js +++ b/packages/apps/user/src/api.js @@ -1,10 +1,11 @@ import axios from 'axios'; +import { getUserImage } from '../firebase'; const instance = axios.create({ baseURL: 'http://localhost:3000/api', }); -export const signUpWithFb = data => { +export const createUser = data => { instance.post('/auth/firebase/sign-up', data).then(user => user); }; @@ -14,3 +15,11 @@ export const checkUserExist = email => { .then(res => res.data) .catch(error => error); }; + +export const getMe = () => { + //TODO: instance.get(`/users/me`).then(res => res.data); + return { + name: '하철환', + profileImg: getUserImage(), + }; +}; diff --git a/packages/apps/user/src/components/Root/Root.js b/packages/apps/user/src/components/Root/Root.js index 2c1e8d0e..96a97d02 100644 --- a/packages/apps/user/src/components/Root/Root.js +++ b/packages/apps/user/src/components/Root/Root.js @@ -1,37 +1,30 @@ -import { useEffect, useState } from 'react'; - import { Outlet, useNavigate } from 'react-router-dom'; -import { useDispatch } from 'react-redux'; -import { onAuthStateChanged, getAuth } from 'firebase/auth'; import { Box } from '@chakra-ui/react'; import StatusBar from '../StatusBar/StatusBar'; import SideBar from '../SideBar/SideBar'; -import { setUser } from '../../store'; +import useUser from '../../hooks/useUser'; const Root = function () { const navigate = useNavigate(); - const dispatch = useDispatch(); - - useEffect(() => { - const auth = getAuth(); - - onAuthStateChanged(auth, user => { - if (user) { - dispatch(setUser(user)); - } else { - navigate('/auth/log-in'); - } - }); - }, [navigate]); + const { userLoading, user, isLoggedIn } = useUser(); + console.log(userLoading, user, isLoggedIn); return ( <> - - - - - + {userLoading ? ( + 'loading...' + ) : user ? ( + <> + + + + + + + ) : ( + navigate('/auth/log-in') + )} ); }; diff --git a/packages/apps/user/src/hooks/useUser.js b/packages/apps/user/src/hooks/useUser.js new file mode 100644 index 00000000..192794b2 --- /dev/null +++ b/packages/apps/user/src/hooks/useUser.js @@ -0,0 +1,15 @@ +import { useQuery } from '@tanstack/react-query'; +import { getMe } from '../api'; + +const useUser = () => { + const { isLoading, data, isError } = useQuery(['me'], getMe, { + retry: false, + }); + return { + userLoading: isLoading, + user: data, + isLoggedIn: !isError, + }; +}; + +export default useUser; diff --git a/packages/apps/user/src/index.js b/packages/apps/user/src/index.js index 625ad0e2..15606805 100644 --- a/packages/apps/user/src/index.js +++ b/packages/apps/user/src/index.js @@ -4,26 +4,30 @@ import { RouterProvider } from 'react-router-dom'; import { Provider } from 'react-redux'; import ReactDOM from 'react-dom/client'; import { ChakraProvider } from '@chakra-ui/react'; +import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; import theme from '../theme'; - import { store } from './store'; import router from './routes/index'; import { AnimatePresence } from 'framer-motion'; +const client = new QueryClient(); + const root = ReactDOM.createRoot(document.getElementById('root')); // In a browser environment, render instead of exporting if (typeof window !== 'undefined') { root.render( - - - - - - - + + + + + + + + + , ); } diff --git a/packages/apps/user/src/views/Auth/LogIn/LogIn.js b/packages/apps/user/src/views/Auth/LogIn/LogIn.js index bff088cd..2f14b3f0 100644 --- a/packages/apps/user/src/views/Auth/LogIn/LogIn.js +++ b/packages/apps/user/src/views/Auth/LogIn/LogIn.js @@ -25,13 +25,7 @@ import { Icon, } from '@chakra-ui/react'; -import { - logIn, - googleLogin, - auth, - provider, - fbLogIn, -} from '../../../../firebase'; +import { googleLogin, auth, provider, fbLogIn } from '../../../../firebase'; function LogIn() { const [showPassword, setShowPassword] = useState(false);