diff --git a/frontend/src/components/mapMenu/MapMenu.tsx b/frontend/src/components/mapMenu/MapMenu.tsx index 539f443..8d80c8d 100644 --- a/frontend/src/components/mapMenu/MapMenu.tsx +++ b/frontend/src/components/mapMenu/MapMenu.tsx @@ -1,4 +1,4 @@ -import React, {useEffect} from 'react'; +import React, {useEffect, useState} from 'react'; import authStore from "../../store/authStore.ts"; import {useNavigate} from "react-router-dom"; import Coins from "./UIMapMenu/Coins.tsx"; @@ -8,10 +8,34 @@ import UserProfile from "./UIMapMenu/UserProfile/UserProfile.tsx"; import Module from "./UIMapMenu/Level/Module.tsx"; import mapMenuStore from "../../store/mapMenuStore.ts"; import {observer} from "mobx-react-lite"; +import {IUserType} from "../../types/UserType.ts"; +import axios from "axios"; const MapMenu: React.FC = observer(() => { const navigate = useNavigate() + const [user, setUser] = useState() + const [formattedDate, setFormattedDate] = useState("") + const [allUsers, setAllUsers] = useState() + + useEffect(() => { + axios.get("http://localhost:8000/users/").then((response) => { + response.data.map((user: IUserType) => { + if (user.username === authStore.userLogin) { + setUser(user) + } + }) + + setAllUsers(response.data) + + if (user) { + console.log(user) + const date = new Date(Date.parse(user!.registered_at)) + setFormattedDate(`${date.getDay()}.${date.getMonth()}.${date.getUTCFullYear()}`) + } + }) + }, []) + useEffect(() => { if (!authStore.isUserAuthorized) navigate("/") @@ -21,7 +45,7 @@ const MapMenu: React.FC = observer(() => { mapMenuStore.fetchModules().then(() => { mapMenuStore.fetchModuleById(mapMenuStore.availableModules[0].id).then(() => { mapMenuStore.fetchLevels().then(() => { - console.log(mapMenuStore.availableLevels) + }).catch(() => alert("Нет доступных уровней для данного модуля")) }) }).catch(() => alert("Нет доступных модулей для данной карты")) @@ -31,18 +55,31 @@ const MapMenu: React.FC = observer(() => { return (
- - - -
-
-
- {mapMenuStore.availableLevels.map((level, index) => { - return - })} -
-
+ {user?.is_superuser + ? ( +
+ +
+ ) : ( +
+ + + +
+
+
+ {mapMenuStore.availableLevels.map((level, index) => { + return + })} +
+
+
+ )} +
); }); diff --git a/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfile.tsx b/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfile.tsx index 27ce93b..bf72a39 100644 --- a/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfile.tsx +++ b/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfile.tsx @@ -2,12 +2,14 @@ import React, {useState} from 'react'; import ModalWindow from "../../../../UIComponents/modalWindow/ModalWindow.tsx"; import UserProfileModalBody from "./UserProfileModalBody.tsx"; import "./userProfileModalBody.scss" +import {IUserType} from "../../../../types/UserType.ts"; interface IPropTypes { - + user?: IUserType, + formattedDate: string, } -const UserProfile: React.FC = () => { +const UserProfile: React.FC = ({user, formattedDate}) => { const [isModalOpen, setIsModalOpen] = useState(false) return ( @@ -27,7 +29,7 @@ const UserProfile: React.FC = () => { - {isModalOpen && setIsModalOpen(!isModalOpen)} body={}/>} + {isModalOpen && setIsModalOpen(!isModalOpen)} body={}/>} ); }; diff --git a/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfileModalBody.tsx b/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfileModalBody.tsx index 96f36bd..8808bb7 100644 --- a/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfileModalBody.tsx +++ b/frontend/src/components/mapMenu/UIMapMenu/UserProfile/UserProfileModalBody.tsx @@ -1,29 +1,20 @@ -import React, {useEffect, useState} from 'react'; +import React, {useEffect} from 'react'; import CustomInput from "../../../../UIComponents/customInput/CustomInput.tsx"; import Achievement from "./Achievement.tsx"; -import axios from "axios"; import {IUserType} from "../../../../types/UserType.ts"; interface IUserProfileModalProps { img?: string + user?: IUserType, + formattedDate: string, } -const UserProfileModalBody: React.FC = () => { - const [user, setUser] = useState() - const [formattedDate, setFormattedDate] = useState("") - +const UserProfileModalBody: React.FC = ({user, formattedDate}) => { useEffect(() => { - axios.get("http://localhost:8000/users/").then((response) => { - setUser(response.data[0]) - - if (user) { - const date = new Date(Date.parse(user.registered_at)) - setFormattedDate(`${date.getDay()}.${date.getMonth()}.${date.getUTCFullYear()}`) - } - }) - }, [user, setUser]) + console.log(1) + }, []) return (
@@ -34,10 +25,11 @@ const UserProfileModalBody: React.FC = () => { src="" alt="Фото профиля"/>
- - - +
diff --git a/frontend/src/store/authStore.ts b/frontend/src/store/authStore.ts index 108c769..3550d73 100644 --- a/frontend/src/store/authStore.ts +++ b/frontend/src/store/authStore.ts @@ -49,7 +49,8 @@ class AuthStore { 'Content-Type': 'application/x-www-form-urlencoded' }, withCredentials: true }) - .then(() => { + .then((response) => { + console.log(response) this.signInUser() }) .catch((reason) => { diff --git a/frontend/src/types/UserType.ts b/frontend/src/types/UserType.ts index 090cd28..904310a 100644 --- a/frontend/src/types/UserType.ts +++ b/frontend/src/types/UserType.ts @@ -1,5 +1,6 @@ export interface IUserType { username: string, email: string, - registered_at: string + registered_at: string, + is_superuser: boolean }