upd
This commit is contained in:
@@ -1,10 +1,23 @@
|
|||||||
import { Navigate, Outlet } from "react-router";
|
import { Navigate, Outlet } from "react-router";
|
||||||
import useAuthStore from "../stores/useAuthStore";
|
import useAuthStore from "../stores/useAuthStore";
|
||||||
|
import api from "../utils/api";
|
||||||
|
import { useQuery } from "@tanstack/react-query";
|
||||||
|
import { IUser } from "../types/IUser";
|
||||||
|
|
||||||
function ProtectedPage() {
|
function ProtectedPage() {
|
||||||
const { token } = useAuthStore();
|
const { token } = useAuthStore();
|
||||||
|
|
||||||
return token ? <Outlet /> : <Navigate to="/login" />;
|
const { data: user, isLoading } = useQuery({
|
||||||
|
queryKey: ["me"],
|
||||||
|
queryFn: () => api.get("auth/me").json<IUser>(),
|
||||||
|
enabled: !!token,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (isLoading) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return user ? <Outlet /> : <Navigate to="/login" />;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default ProtectedPage;
|
export default ProtectedPage;
|
||||||
|
|||||||
Reference in New Issue
Block a user