Skip to content

Commit

Permalink
добавляет разделение на суперюзера и не суперюзера
Browse files Browse the repository at this point in the history
  • Loading branch information
semant1cs committed Nov 21, 2023
1 parent e5c167f commit f22cc60
Show file tree
Hide file tree
Showing 5 changed files with 70 additions and 37 deletions.
65 changes: 51 additions & 14 deletions frontend/src/components/mapMenu/MapMenu.tsx
Original file line number Diff line number Diff line change
@@ -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";
Expand All @@ -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<IUserType>()
const [formattedDate, setFormattedDate] = useState("")
const [allUsers, setAllUsers] = useState<IUserType[]>()

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("/")
Expand All @@ -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("Нет доступных модулей для данной карты"))
Expand All @@ -31,18 +55,31 @@ const MapMenu: React.FC = observer(() => {

return (
<div>
<Coins coins={100} additionalClassname="coins"/>
<ChooseModuleWindow moduleName={mapMenuStore.currentModule?.title}/>
<UserProfile/>
<br/>
<div className="geolocations">
<div className="geolocations__wrapper">
{mapMenuStore.availableLevels.map((level, index) => {
return <Module id={(index + 1).toString()} key={level.id} title={level.title}
theoryUnits={level.theoryUnits} taskUnits={level.taskUnits}/>
})}
</div>
</div>
{user?.is_superuser
? (
<div>
<select>
{allUsers?.map((user) =>
<option key={user.username} value={user.username}>{user.username}</option>)}
</select>
</div>
) : (
<div className="employee-interface">
<Coins coins={100} additionalClassname="coins"/>
<ChooseModuleWindow moduleName={mapMenuStore.currentModule?.title}/>
<UserProfile user={user} formattedDate={formattedDate}/>
<br/>
<div className="geolocations">
<div className="geolocations__wrapper">
{mapMenuStore.availableLevels.map((level, index) => {
return <Module id={(index + 1).toString()} key={level.id} title={level.title}
theoryUnits={level.theoryUnits} taskUnits={level.taskUnits}/>
})}
</div>
</div>
</div>
)}

</div>
);
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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<IPropTypes> = () => {
const UserProfile: React.FC<IPropTypes> = ({user, formattedDate}) => {
const [isModalOpen, setIsModalOpen] = useState<boolean>(false)

return (
Expand All @@ -27,7 +29,7 @@ const UserProfile: React.FC<IPropTypes> = () => {
</g>
</svg>
</div>
{isModalOpen && <ModalWindow onClose={() => setIsModalOpen(!isModalOpen)} body={<UserProfileModalBody/>}/>}
{isModalOpen && <ModalWindow onClose={() => setIsModalOpen(!isModalOpen)} body={<UserProfileModalBody user={user} formattedDate={formattedDate}/>}/>}
</div>
);
};
Expand Down
Original file line number Diff line number Diff line change
@@ -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<IUserProfileModalProps> = () => {
const [user, setUser] = useState<IUserType>()
const [formattedDate, setFormattedDate] = useState("")

const UserProfileModalBody: React.FC<IUserProfileModalProps> = ({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 (
<div>
Expand All @@ -34,10 +25,11 @@ const UserProfileModalBody: React.FC<IUserProfileModalProps> = () => {
src=""
alt="Фото профиля"/>
<div className="user-info-fields">
<CustomInput type="text" width="350px" defaultValue={user?.username}
<CustomInput type="text" width="350px" disabled={true} defaultValue={user?.username}
height="55px" placeholder="ФИО"/>
<CustomInput type="email" width="350px" placeholder="email" defaultValue={user?.email} height="55px"/>
<CustomInput type="text" width="350px" placeholder="Дата трудоустройства" defaultValue={formattedDate}
<CustomInput type="email" width="350px" placeholder="email" disabled={true} defaultValue={user?.email}
height="55px"/>
<CustomInput type="text" width="350px" placeholder="Дата трудоустройства" disabled={true} defaultValue={formattedDate}
height="55px"/>
</div>
<div className="achievements">
Expand Down
3 changes: 2 additions & 1 deletion frontend/src/store/authStore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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) => {
Expand Down
3 changes: 2 additions & 1 deletion frontend/src/types/UserType.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
export interface IUserType {
username: string,
email: string,
registered_at: string
registered_at: string,
is_superuser: boolean
}

0 comments on commit f22cc60

Please sign in to comment.