From 15b981c170e2210b508946c2eecf13fd28778d74 Mon Sep 17 00:00:00 2001 From: kuwsh1n Date: Fri, 12 Apr 2024 14:32:31 +0300 Subject: [PATCH] one --- src/assets/styles/adminPanel.module.scss | 104 +++++++++++++++++++++++ src/assets/styles/profile.module.scss | 16 ++++ src/components/NavBar.jsx | 27 +++++- src/hooks/api/enterAccountApi.js | 9 +- src/hooks/api/formApi.js | 10 +-- src/hooks/api/listFormsApi.js | 25 ++++-- src/pages/AdminPanel.jsx | 74 ++++++++++++++++ src/pages/EnterAccount.jsx | 14 +-- src/pages/Forms.jsx | 9 +- src/pages/NewForm.jsx | 5 +- src/pages/Profile.jsx | 8 +- src/router/router.js | 5 ++ 12 files changed, 275 insertions(+), 31 deletions(-) create mode 100644 src/assets/styles/adminPanel.module.scss create mode 100644 src/pages/AdminPanel.jsx diff --git a/src/assets/styles/adminPanel.module.scss b/src/assets/styles/adminPanel.module.scss new file mode 100644 index 0000000..f2b25cf --- /dev/null +++ b/src/assets/styles/adminPanel.module.scss @@ -0,0 +1,104 @@ +.main { + width: 100%; + height: 100%; +} + +.wrapper { + width: 100%; + height: 100%; + display: flex; + justify-content: center; + align-items: center; +} + +.admin { + width: 70%; + height: 70%; + box-shadow: 0 0 5px 1px rgb(200, 200, 200); + padding: 1.5%; + position: relative; + &__linkProfile { + position: absolute; + bottom: 103%; + left: 10px; + cursor: pointer; + span { + font-size: 15px; + font-family: "Montserrat", sans-serif; + color: rgb(100, 100, 100); + &:hover { + text-decoration: underline; + color: rgb(66, 68, 189); + } + } + } + &__wrapper { + &__header { + width: 100%; + height: 15%; + display: flex; + justify-content: space-between; + align-items: center; + margin-bottom: 10px; + h3 { + font-size: 25px; + font-family: "Montserrat", sans-serif; + color: rgb(100, 100, 100); + } + } + &__body { + width: 100%; + height: 85%; + &__columns { + width: 100%; + height: 20%; + border-bottom: 1px solid rgb(200, 200, 200); + display: flex; + justify-content: space-between; + align-items: center; + &__item { + font-size: 15px; + font-family: "Montserrat", sans-serif; + color: rgb(70, 70, 70); + width: 33.3%; + text-align: center; + } + } + &__users { + width: 100%; + height: 80%; + margin-top: 10px; + &__item { + width: 100%; + height: 20%; + display: flex; + justify-content: space-between; + align-items: center; + border-bottom: 1px solid rgb(200, 200, 200); + &__link { + font-size: 15px; + font-family: "Montserrat", sans-serif; + color: rgb(70, 70, 70); + width: 33.3%; + text-align: center; + cursor: pointer; + &:hover { + text-decoration: underline; + color: rgb(66, 68, 189); + } + } + &__info { + font-size: 15px; + font-family: "Montserrat", sans-serif; + color: rgb(100, 100, 100); + width: 33.3%; + text-align: center; + } + } + } + &__item { + padding: 5px; + } + } + } +} \ No newline at end of file diff --git a/src/assets/styles/profile.module.scss b/src/assets/styles/profile.module.scss index e69a0be..c7069ab 100644 --- a/src/assets/styles/profile.module.scss +++ b/src/assets/styles/profile.module.scss @@ -16,6 +16,22 @@ height: 70%; box-shadow: 0 0 5px 1px rgb(200, 200, 200); padding: 1.5%; + position: relative; + &__linkAdmin { + position: absolute; + bottom: 103%; + left: 10px; + span { + font-size: 15px; + font-family: "Montserrat", sans-serif; + color: rgb(100, 100, 100); + cursor: pointer; + &:hover { + text-decoration: underline; + color: rgb(66, 68, 189); + } + } + } &__wrapper { &__header { width: 100%; diff --git a/src/components/NavBar.jsx b/src/components/NavBar.jsx index 304db25..462cc52 100644 --- a/src/components/NavBar.jsx +++ b/src/components/NavBar.jsx @@ -1,7 +1,28 @@ -import React, { useState } from "react"; -import classes from "../assets/styles/components/navbar.module.scss" +import React, { useState, useEffect } from "react"; +import { useCookies } from "react-cookie"; +import classes from "../assets/styles/components/navbar.module.scss"; +import { verifyUserApi } from "../hooks/api/enterAccountApi"; const NavBar = ({navigate, auth, setAuth}) => { + // const [cookies, _, __] = useCookies(["user"]); + + // useEffect(() => { + // async function verifyUser() { + // const response = await verifyUserApi(cookies.token); + + // if (response) { + // if (response.status === 200) { + // setAuth(response.data); + // } + // else { + // console.log(response) + // } + // } + // } + + // verifyUser() + // }, []); + return (
@@ -9,7 +30,7 @@ const NavBar = ({navigate, auth, setAuth}) => {
navigate("/")}>Главная {auth ? - navigate("/forms")}>Мои формы : + auth.is_admin ? navigate("/forms")}>Мои формы : : }
diff --git a/src/hooks/api/enterAccountApi.js b/src/hooks/api/enterAccountApi.js index 24a8143..eeab6ea 100644 --- a/src/hooks/api/enterAccountApi.js +++ b/src/hooks/api/enterAccountApi.js @@ -3,7 +3,7 @@ import axios from "axios"; async function logIn(login, password) { try { - const response = await axios.post("http://localhost:8080/auth/signIn", {"login": login, "password": password}) + const response = await axios.post("https://api.minerva.krbl.ru/auth/signIn", {"login": login, "password": password}) return response } catch (e) { @@ -16,7 +16,10 @@ async function completeRegistration(data) { if (validate.status) { try { - const response = await axios.post("http://localhost:8080/auth/signUp", {"login": data.login, "password": data.password}) + const response = await axios.post("https://api.minerva.krbl.ru/auth/signUp", { + "login": data.login, + "password": data.password, + }) return response } catch (e) { @@ -29,7 +32,7 @@ async function completeRegistration(data) { async function verifyUserApi(token=false) { if (token) { try { - const response = await axios.get("http://localhost:8080/auth/me", { + const response = await axios.get("https://api.minerva.krbl.ru/auth/me", { headers: { "Authorization": `Token ${token}`, }, diff --git a/src/hooks/api/formApi.js b/src/hooks/api/formApi.js index cb6ec4a..efb3814 100644 --- a/src/hooks/api/formApi.js +++ b/src/hooks/api/formApi.js @@ -2,7 +2,7 @@ import axios from "axios"; async function listFormBlockApi(token, formId) { try { - const response = await axios.get(`http://localhost:8080/formBuilder/edit/${formId}/list`, + const response = await axios.get(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/list`, { headers: { "Authorization": `Token ${token}`, @@ -17,7 +17,7 @@ async function listFormBlockApi(token, formId) { async function addFormBlockApi(token, formId, data) { try { - const response = await axios.post(`http://localhost:8080/formBuilder/edit/${formId}/add`, + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/add`, { data: data }, @@ -50,7 +50,7 @@ async function addFormBlockApi(token, formId, data) { async function updateBlockApi(token, blockId, data) { try { - const response = await axios.post(`http://localhost:8080/formBuilder/edit/${blockId}/set`, + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${blockId}/set`, { data: data }, @@ -68,7 +68,7 @@ async function updateBlockApi(token, blockId, data) { async function updateOrderBlockApi(token, formId, data) { try { - const response = await axios.post(`http://localhost:8080/formBuilder/edit/${formId}/moveTo`, + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/moveTo`, { "new_order": data.new, "old_order": data.old @@ -87,7 +87,7 @@ async function updateOrderBlockApi(token, formId, data) { async function saveFormApi(token) { try { - const response = await axios.post("http://localhost:8080/formBuilder/new", + const response = await axios.post("https://api.minerva.krbl.ru/formBuilder/new", { title: "Новая форма" }, diff --git a/src/hooks/api/listFormsApi.js b/src/hooks/api/listFormsApi.js index e27912f..90ff574 100644 --- a/src/hooks/api/listFormsApi.js +++ b/src/hooks/api/listFormsApi.js @@ -3,7 +3,7 @@ import axios from "axios"; async function listFormsApi(token) { try { - const response = await axios.get("http://localhost:8080/formBuilder/list", { + const response = await axios.get("https://api.minerva.krbl.ru/formBuilder/list", { headers: { "Authorization": `Token ${token}`, } @@ -17,7 +17,7 @@ async function listFormsApi(token) { async function createFormApi(token) { try { - const response = await axios.post("http://localhost:8080/formBuilder/new", + const response = await axios.post("https://api.minerva.krbl.ru/formBuilder/new", { title: "Новая форма" }, @@ -35,7 +35,7 @@ async function createFormApi(token) { async function removeFormApi(token, formId) { try { - const response = await axios.post(`http://localhost:8080/formBuilder/edit/${formId}/delete`, { + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/delete`, { headers: { "Authorization": `Token ${token}`, }, @@ -49,7 +49,7 @@ async function removeFormApi(token, formId) { async function updateTitleFormApi(token, formId, title) { try { - const response = await axios.post(`http://localhost:8080/formBuilder/edit/${formId}/setTitle`, + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/setTitle`, { title: title }, @@ -65,4 +65,19 @@ async function updateTitleFormApi(token, formId, title) { } }; -export { listFormsApi, createFormApi, removeFormApi, updateTitleFormApi }; \ No newline at end of file +async function newFormTokenApi(token, formId) { + try { + const response = await axios.post(`https://api.minerva.krbl.ru/formBuilder/edit/${formId}/access/new`, + { + headers: { + "Authorization": `Token ${token}` + } + }) + return response + } + catch (e) { + return e + } +}; + +export { listFormsApi, createFormApi, removeFormApi, updateTitleFormApi, newFormTokenApi }; \ No newline at end of file diff --git a/src/pages/AdminPanel.jsx b/src/pages/AdminPanel.jsx new file mode 100644 index 0000000..c6acd8a --- /dev/null +++ b/src/pages/AdminPanel.jsx @@ -0,0 +1,74 @@ +import React, { useState } from "react"; +import { useNavigate } from "react-router-dom"; +import classes from "../assets/styles/adminPanel.module.scss"; + +const AdminPanel = () => { + const [token, setToken] = useState(""); + const navigate = useNavigate(); + + const [users, setUsers] = useState([ + { + "email": "senya.bogachev@mail.ru", + "first_name": "Арсений", + "id": "1", + "is_admin": false, + "last_name": "Богачев", + "login": "Ars", + "phone": "89110128244" + }, + { + "email": "dasha@mail.ru", + "first_name": "Дарья", + "id": "1", + "is_admin": false, + "last_name": "Утешева", + "login": "dasha", + "phone": "89111032339" + }, + { + "email": "kirik@mail.ru", + "first_name": "Кирилл", + "id": "string", + "is_admin": false, + "last_name": "Жердев", + "login": "Kirik", + "phone": "89110045673" + } + ]) + + return ( +
+
+
+
+ navigate("/profile")}>Профиль +
+
+
+

Пользователи

+ +
+
+
+
Логин
+
Фамилия
+
Email
+
+
+ {users.map(item => +
+
{item.login}
+
{item.last_name}
+
{item.email}
+
+ )} +
+
+
+
+
+
+ ) +} + +export default AdminPanel; \ No newline at end of file diff --git a/src/pages/EnterAccount.jsx b/src/pages/EnterAccount.jsx index 92fac4b..80ff43b 100644 --- a/src/pages/EnterAccount.jsx +++ b/src/pages/EnterAccount.jsx @@ -42,8 +42,8 @@ const EnterAccount = () => { // email: email, // phone: phone, login: login, - // surname: surname, - // patronymic: patronymic, + // first_name: surname, + // last_name: patronymic, password: password, repiedPassword: repiedPassword }); @@ -59,7 +59,8 @@ const EnterAccount = () => { }); setCookie("token", response.data.token); cleanState(); - navigate("/"); + window.location.reload(); + // navigate("/"); } else { console.log("Error") @@ -75,7 +76,8 @@ const EnterAccount = () => { setUser({ login: login }) - navigate("/") + window.location.reload(); + // navigate("/") // window.location.reload() } else { @@ -123,8 +125,8 @@ const EnterAccount = () => {
- - + +
diff --git a/src/pages/Forms.jsx b/src/pages/Forms.jsx index ed60d2e..ed970a0 100644 --- a/src/pages/Forms.jsx +++ b/src/pages/Forms.jsx @@ -5,7 +5,7 @@ import classes from "../assets/styles/forms.module.scss" import MyButton from "../components/MyButton.jsx"; import MyInput from "../components/MyInput.jsx"; import { FormsData, UserData } from "../context"; -import { listFormsApi, createFormApi, removeFormApi } from "../hooks/api/listFormsApi.js"; +import { listFormsApi, createFormApi, removeFormApi, newFormTokenApi } from "../hooks/api/listFormsApi.js"; const Forms = () => { const navigate = useNavigate(); @@ -17,7 +17,7 @@ const Forms = () => { useEffect(() => { async function listForms() { - const response = await listFormsApi(cookies.token) + const response = await listFormsApi(cookies.token); if (response.data) { setForms(response.data) @@ -35,10 +35,13 @@ const Forms = () => { async function createForm() { setStateLoading(true); - const response = await createFormApi(cookies.token) + const response = await createFormApi(cookies.token); + console.log("response", response) setStateLoading(false); if (response.data) { + const token = await newFormTokenApi(cookies.token, response.data.id) + console.log("token", token) navigate(`/forms/${response.data.id}/edit`) } else { diff --git a/src/pages/NewForm.jsx b/src/pages/NewForm.jsx index 2515c9c..1c4b363 100644 --- a/src/pages/NewForm.jsx +++ b/src/pages/NewForm.jsx @@ -65,8 +65,8 @@ const NewForm = () => { setTitleForm(responseForms.data.find(item => item.id === formId).title); } else { - console.log(responseBlock); - console.log(responseForms); + setListBlock([]) + setTitleForm("Новыя форма") } }; @@ -308,7 +308,6 @@ const NewForm = () => { return typeItem.text } })} - {item.order}
{editAnswerByForm(item.id)}}> diff --git a/src/pages/Profile.jsx b/src/pages/Profile.jsx index aa13546..27562c5 100644 --- a/src/pages/Profile.jsx +++ b/src/pages/Profile.jsx @@ -1,4 +1,5 @@ import React, { useState, useContext, useEffect } from "react"; +import { useNavigate } from "react-router-dom"; import classes from "../assets/styles/profile.module.scss"; import MyButton from "../components/MyButton.jsx"; import { UserData } from "../context"; @@ -9,8 +10,6 @@ const Profile = () => { const [edit, setEdit] = useState(true); const {user, setUser} = useContext(UserData); - console.log(user) - const [email, setEmail] = useState(""); const [phone, setPhone] = useState(""); const [login, setLogin] = useState(""); @@ -18,9 +17,9 @@ const Profile = () => { const [last_name, setLast_name] = useState(""); const [cookies, _, __] = useCookies(["user"]); + const navigate = useNavigate(); useEffect(() => { - console.log(1) async function verifyUser() { const response = await verifyUserApi(cookies.token); @@ -78,6 +77,9 @@ const Profile = () => {
+
+ navigate("/admin")}>Админ панель +

Ваши данные

diff --git a/src/router/router.js b/src/router/router.js index 1ac3507..7864d31 100644 --- a/src/router/router.js +++ b/src/router/router.js @@ -7,6 +7,7 @@ import Home from "../pages/Home.jsx"; import App from "../App.jsx"; import Profile from "../pages/Profile.jsx"; import ViewForm from "../pages/ViewForm.jsx"; +import AdminPanel from '../pages/AdminPanel.jsx'; const router = createBrowserRouter([ { @@ -35,6 +36,10 @@ const router = createBrowserRouter([ { path: "/forms/:formId", element: + }, + { + path: "/admin", + element: } ] }