Skip to content

Commit

Permalink
Fix : manage login state only in Header #83
Browse files Browse the repository at this point in the history
Signed-off-by: bentshrimp <[email protected]>
  • Loading branch information
bentshrimp committed Oct 6, 2023
1 parent f55db23 commit 3a8152f
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 38 deletions.
41 changes: 35 additions & 6 deletions src/layout/Header.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import axios from "axios";
import { useRecoilState } from "recoil";
import { avatar, id, name, isLogin } from "../recoil/authorize";
import styled from "styled-components";

const ElevationScroll = (props) => {
const { children, window } = props;
// Note that you normally won't need to set the window ref as useScrollTrigger
Expand All @@ -42,19 +43,45 @@ ElevationScroll.propTypes = {
*/
window: PropTypes.func,
};

async function checkTokenValid() {
const isTokenValid = await axios.get(
`${process.env.REACT_APP_SERVER_URL}/auth/checkToken`,
{
validateStatus: (status) => {
return status < 500;
},
withCredentials: true,
},
);
return isTokenValid.status < 400;
}

export const Header = (props) => {
const [anchorElNav, setAnchorElNav] = useState(null);
const [anchorElUser, setAnchorElUser] = useState(null);
const [src, setSrc] = useRecoilState(avatar);
const [userId, setUserId] = useRecoilState(id);
const [userName, setUserName] = useRecoilState(name);
const [Login, setLogin] = useRecoilState(isLogin);
React.useEffect(() => {
if (Login) {
const [login, setIsLogin] = useRecoilState(isLogin);

const checkIsLogin = async () => {
const loggedIn = await checkTokenValid();
if (loggedIn) {
setSrc(localStorage.avatar);
setUserId(localStorage.id);
setUserName(localStorage.name);
} else {
localStorage.removeItem("id");
localStorage.removeItem("name");
localStorage.removeItem("avatar");

}
setIsLogin(loggedIn);
};

React.useEffect(() => {
checkIsLogin();
}, []);
const handleOpenNavMenu = (event) => {
setAnchorElNav(event.currentTarget);
Expand All @@ -78,7 +105,7 @@ export const Header = (props) => {
"",
{ withCredentials: true },
);
setLogin(false);
setIsLogin(false);
localStorage.setItem("id", "guest");
localStorage.setItem("name", "guest");
localStorage.setItem("avatar", "");
Expand Down Expand Up @@ -162,7 +189,7 @@ export const Header = (props) => {
<MenuItem
key={"Docs"}
onClick={() =>
handleOpenNewTab("https://docs.open-set-go.com")
handleOpenNewTab("https://open-set-go.netlify.app/")
}
>
<Typography textAlign="center">Docs</Typography>
Expand Down Expand Up @@ -211,7 +238,9 @@ export const Header = (props) => {
))}
<MenuItemWrapper
key="docs"
onClick={() => handleOpenNewTab("https://docs.open-set-go.com")}
onClick={() =>
handleOpenNewTab("https://open-set-go.netlify.app/")
}
>
Docs
</MenuItemWrapper>
Expand Down
32 changes: 0 additions & 32 deletions src/pages/MainPage.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,40 +3,8 @@ import Footer from "../components/main/Footer";
import Steps from "../components/main/Steps";
import propTypes from "prop-types";
import { Header } from "../layout/Header";
import { useEffect } from "react";
import { useSetRecoilState } from "recoil";
import { isLogin } from "../recoil/authorize";
import axios from "axios";

async function checkTokenValid() {
const isTokenValid = await axios.get(
`${process.env.REACT_APP_SERVER_URL}/auth/checkToken`,
{
validateStatus: (status) => {
return status < 500;
},
withCredentials: true,
},
);
return isTokenValid.status < 400;
}

function MainPage() {
const setIsLogin = useSetRecoilState(isLogin);

const checkIsLogin = async () => {
const loggedIn = await checkTokenValid();
if (!loggedIn) {
localStorage.removeItem("id");
localStorage.removeItem("name");
localStorage.removeItem("avatar");
}
setIsLogin(loggedIn);
};

useEffect(() => {
checkIsLogin();
}, []);
return (
<>
<Header burger={true} pages={["Steps"]} settings={["Logout"]} />
Expand Down

0 comments on commit 3a8152f

Please sign in to comment.