import React, { useState, useEffect } from "react";
import { Container, Col, Row, Button, Spinner } from "react-bootstrap";
import axios from "axios";
import { ToastContainer, toast } from "react-toastify";
import "react-toastify/dist/ReactToastify.css";
import Navbar from "./Navbar";
function HomePage(props) {
const notifyLoading = () => {
toast.info("Logging Out Successfull..");
};
const [user, setUser] = useState(null);
const [loading, setLoading] = useState(true);
const handleLogout = () => {
axios
.get("http://localhost:8080/auth/logout", {
withCredentials: true,
})
.then(() => {
window.location.href = "/";
setUser(null);
localStorage.removeItem("user");
notifyLoading();
})
.catch((error) => {
console.error("Error logging out:", error);
});
};
const fetchUser = async () => {
const loggedInUser = localStorage.getItem("user");
if (loggedInUser) {
setUser(JSON.parse(loggedInUser));
setLoading(false);
} else {
try {
const response = await axios.get(
`http://localhost:8080/api/user/profile/`,
{
withCredentials: true,
}
);
setUser(response.data.user);
setLoading(false);
} catch (error) {
console.error("Error fetching user data:", error);
setLoading(false);
}
}
};
useEffect(() => {
fetchUser();
}, []);
return (
<>
Username: {user.username}
Email: {user.email}