This commit is contained in:
parent
ea0b47a061
commit
695cc690d9
112
src/App.jsx
112
src/App.jsx
@ -3,13 +3,13 @@ import { Outlet, useNavigate } from "react-router-dom";
|
||||
import { FormsData, UserData, TypeAnswerData, answersData } from "./context";
|
||||
import { useCookies } from "react-cookie";
|
||||
import { globalRender } from "./router/protectedRouting.js";
|
||||
import { verifyUserApi } from "./hooks/api/enterAccountApi.js"
|
||||
import classes from "./assets/styles/app.module.scss"
|
||||
import { verifyUserApi } from "./hooks/api/enterAccountApi.js";
|
||||
import classes from "./assets/styles/app.module.scss";
|
||||
import NavBar from "./components/NavBar.jsx";
|
||||
import 'bootstrap/dist/css/bootstrap.min.css';
|
||||
import "bootstrap/dist/css/bootstrap.min.css";
|
||||
import InputText from "./components/typeAnswer/InputText.jsx";
|
||||
import TextArea from "./components/typeAnswer/TextArea.jsx";
|
||||
import YesNo from "./components/typeAnswer/YesNo.jsx"
|
||||
import YesNo from "./components/typeAnswer/YesNo.jsx";
|
||||
import InputDate from "./components/typeAnswer/InputDate.jsx";
|
||||
import InputMultipleRadio from "./components/typeAnswer/InputMultipleRadio.jsx";
|
||||
import InputRadio from "./components/typeAnswer/InputRadio.jsx";
|
||||
@ -17,61 +17,63 @@ import DropDownList from "./components/typeAnswer/DropDownList.jsx";
|
||||
import InputFile from "./components/typeAnswer/InputFile.jsx";
|
||||
|
||||
const App = () => {
|
||||
const navigate = useNavigate();
|
||||
const [forms, setForms] = useState([]);
|
||||
const [user, setUser] = useState(false);
|
||||
const [answersList, setAnswersList] = useState([]);
|
||||
const [listTypeAnswer, setListTypeAnswer] = useState([
|
||||
{id: 1, text: 'Краткий ответ', typeTag: InputText},
|
||||
{id: 2, text: 'Расширенный ответ', typeTag: TextArea},
|
||||
{id: 3, text: 'Выбор из вариантов', typeTag: InputRadio},
|
||||
{id: 4, text: 'Множественный выбор', typeTag: InputMultipleRadio},
|
||||
{id: 5, text: 'Выпадающий список', typeTag: DropDownList},
|
||||
{id: 6, text: 'Да/Нет', typeTag: YesNo},
|
||||
{id: 7, text: 'Файл', typeTag: InputFile},
|
||||
{id: 8, text: 'Дата', typeTag: InputDate}
|
||||
]);
|
||||
const navigate = useNavigate();
|
||||
const [forms, setForms] = useState([]);
|
||||
const [user, setUser] = useState(false);
|
||||
const [answersList, setAnswersList] = useState([]);
|
||||
const [listTypeAnswer, setListTypeAnswer] = useState([
|
||||
{ id: 1, text: "Краткий ответ", typeTag: InputText },
|
||||
{ id: 2, text: "Расширенный ответ", typeTag: TextArea },
|
||||
{ id: 3, text: "Выбор из вариантов", typeTag: InputRadio },
|
||||
{ id: 4, text: "Множественный выбор", typeTag: InputMultipleRadio },
|
||||
{ id: 5, text: "Выпадающий список", typeTag: DropDownList },
|
||||
{ id: 6, text: "Да/Нет", typeTag: YesNo },
|
||||
{ id: 7, text: "Файл", typeTag: InputFile },
|
||||
{ id: 8, text: "Дата", typeTag: InputDate },
|
||||
]);
|
||||
|
||||
// useEffect(() => globalRender(window.location.pathname, user, navigate));
|
||||
const [cookies, _, __] = useCookies(["user"]);
|
||||
// useEffect(() => globalRender(window.location.pathname, user, navigate));
|
||||
const [cookies, _, __] = useCookies(["user"]);
|
||||
|
||||
useEffect(() => {
|
||||
async function verifyUser() {
|
||||
const response = await verifyUserApi(cookies.token);
|
||||
useEffect(() => {
|
||||
async function verifyUser() {
|
||||
const response = await verifyUserApi(cookies.token);
|
||||
console.log("app", user);
|
||||
|
||||
if (response) {
|
||||
if (response.status === 200) {
|
||||
setUser(response.data);
|
||||
}
|
||||
else {
|
||||
console.log(response)
|
||||
}
|
||||
}
|
||||
if (response) {
|
||||
if (response.status === 200) {
|
||||
setUser(response.data);
|
||||
} else {
|
||||
console.log(response);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
verifyUser();
|
||||
}, [])
|
||||
verifyUser();
|
||||
}, []);
|
||||
|
||||
return (
|
||||
<UserData.Provider value={{ user, setUser }}>
|
||||
<answersData.Provider value={{ answersList, setAnswersList }}>
|
||||
<FormsData.Provider value={{ forms, setForms }}>
|
||||
<TypeAnswerData.Provider value={{ listTypeAnswer, setListTypeAnswer }}>
|
||||
<div className={classes.main}>
|
||||
<div className={classes.container}>
|
||||
<div className={classes.header}>
|
||||
<NavBar navigate={navigate} auth={user} setAuth={setUser}/>
|
||||
</div>
|
||||
<div className={classes.content}>
|
||||
<Outlet/>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</TypeAnswerData.Provider>
|
||||
</FormsData.Provider>
|
||||
</answersData.Provider>
|
||||
</UserData.Provider>
|
||||
)
|
||||
}
|
||||
return (
|
||||
<UserData.Provider value={{ user, setUser }}>
|
||||
<answersData.Provider value={{ answersList, setAnswersList }}>
|
||||
<FormsData.Provider value={{ forms, setForms }}>
|
||||
<TypeAnswerData.Provider
|
||||
value={{ listTypeAnswer, setListTypeAnswer }}
|
||||
>
|
||||
<div className={classes.main}>
|
||||
<div className={classes.container}>
|
||||
<div className={classes.header}>
|
||||
<NavBar navigate={navigate} auth={user} setAuth={setUser} />
|
||||
</div>
|
||||
<div className={classes.content}>
|
||||
<Outlet />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</TypeAnswerData.Provider>
|
||||
</FormsData.Provider>
|
||||
</answersData.Provider>
|
||||
</UserData.Provider>
|
||||
);
|
||||
};
|
||||
|
||||
export default App;
|
||||
export default App;
|
||||
|
@ -3,49 +3,46 @@ 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"]);
|
||||
const NavBar = ({ navigate, auth, setAuth }) => {
|
||||
useEffect(() => {
|
||||
console.log("nav", auth);
|
||||
});
|
||||
|
||||
// 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 (
|
||||
<div className={classes.main}>
|
||||
<div className={classes.wrapper}>
|
||||
<div className={classes.menu}>
|
||||
<div className={classes.menu__authorized}>
|
||||
<span onClick={() => navigate("/")}>Главная</span>
|
||||
{auth ?
|
||||
auth.is_admin ? <span onClick={() => navigate("/forms")}>Мои формы</span> : <span></span> :
|
||||
<span></span>}
|
||||
</div>
|
||||
</div>
|
||||
<div className={classes.profile}>
|
||||
{auth ?
|
||||
<div className={classes.profile__authorized}>
|
||||
<span onClick={() => navigate("/profile")}>Профиль ({auth.login})</span>
|
||||
</div> :
|
||||
<div className={classes.profile__nonAuthorized}>
|
||||
<span onClick={() => navigate("/enter")}>Вход <i class="fa-solid fa-arrow-right-to-bracket"></i></span>
|
||||
</div>}
|
||||
</div>
|
||||
</div>
|
||||
return (
|
||||
<div className={classes.main}>
|
||||
<div className={classes.wrapper}>
|
||||
<div className={classes.menu}>
|
||||
<div className={classes.menu__authorized}>
|
||||
<span onClick={() => navigate("/")}>Главная</span>
|
||||
{auth ? (
|
||||
auth.is_admin ? (
|
||||
<span onClick={() => navigate("/forms")}>Мои формы</span>
|
||||
) : (
|
||||
<span></span>
|
||||
)
|
||||
) : (
|
||||
<span></span>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
<div className={classes.profile}>
|
||||
{auth ? (
|
||||
<div className={classes.profile__authorized}>
|
||||
<span onClick={() => navigate("/profile")}>
|
||||
Профиль ({auth.login})
|
||||
</span>
|
||||
</div>
|
||||
) : (
|
||||
<div className={classes.profile__nonAuthorized}>
|
||||
<span onClick={() => navigate("/enter")}>
|
||||
Вход <i class="fa-solid fa-arrow-right-to-bracket"></i>
|
||||
</span>
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default NavBar;
|
||||
export default NavBar;
|
||||
|
@ -1,31 +1,38 @@
|
||||
const constructorAnswerValidate = (state, messageReject = "Ошибка", messageResolve = undefined) => {
|
||||
return state ?
|
||||
{
|
||||
status: true,
|
||||
message: messageResolve
|
||||
} :
|
||||
{
|
||||
status: false,
|
||||
message: messageReject
|
||||
}
|
||||
}
|
||||
const constructorAnswerValidate = (
|
||||
state,
|
||||
messageReject = "Ошибка",
|
||||
messageResolve = undefined
|
||||
) => {
|
||||
return state
|
||||
? {
|
||||
status: true,
|
||||
message: messageResolve,
|
||||
}
|
||||
: {
|
||||
status: false,
|
||||
message: messageReject,
|
||||
};
|
||||
};
|
||||
|
||||
const totalRegisterValidate = (data) => {
|
||||
const listValidation = [
|
||||
constructorAnswerValidate(data.login.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.surname.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.email.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.phone.length, "Обязательное поле."),
|
||||
constructorAnswerValidate(data.password === data.repiedPassword, "Введенные пароли не совпадают."),
|
||||
constructorAnswerValidate(data.password >= 8, "Пароль должен иметь более 8 символов.")
|
||||
]
|
||||
const listValidation = [
|
||||
constructorAnswerValidate(data.login.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.surname.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.email.length, "Обязательное поле."),
|
||||
// constructorAnswerValidate(data.phone.length, "Обязательное поле."),
|
||||
constructorAnswerValidate(
|
||||
data.password === data.repiedPassword,
|
||||
"Введенные пароли не совпадают."
|
||||
),
|
||||
// constructorAnswerValidate(data.password >= 8, "Пароль должен иметь более 8 символов.")
|
||||
];
|
||||
|
||||
for (let value of listValidation) {
|
||||
if (!value.status) {
|
||||
return value
|
||||
}
|
||||
for (let value of listValidation) {
|
||||
if (!value.status) {
|
||||
return value;
|
||||
}
|
||||
return { status: true }
|
||||
}
|
||||
}
|
||||
return { status: true };
|
||||
};
|
||||
|
||||
export { totalRegisterValidate, constructorAnswerValidate }
|
||||
export { totalRegisterValidate, constructorAnswerValidate };
|
||||
|
@ -49,18 +49,19 @@ const EnterAccount = () => {
|
||||
});
|
||||
|
||||
if (response.status === 200) {
|
||||
setUser({
|
||||
email: email,
|
||||
phone: phone,
|
||||
login: login,
|
||||
surname: surname,
|
||||
patronymic: patronymic,
|
||||
password: password,
|
||||
});
|
||||
// setUser({
|
||||
// email: email,
|
||||
// phone: phone,
|
||||
// login: login,
|
||||
// surname: surname,
|
||||
// patronymic: patronymic,
|
||||
// password: password,
|
||||
// });
|
||||
const responseMe = await verifyUserApi(response.data.token);
|
||||
setUser(responseMe.data);
|
||||
setCookie("token", response.data.token);
|
||||
cleanState();
|
||||
window.location.reload();
|
||||
// navigate("/");
|
||||
navigate("/");
|
||||
} else {
|
||||
console.log("Error");
|
||||
}
|
||||
@ -71,13 +72,10 @@ const EnterAccount = () => {
|
||||
|
||||
if (response.status === 200) {
|
||||
setCookie("token", response.data.token);
|
||||
const responseMe = await verifyUserApi(response.data.token);
|
||||
setUser(responseMe.data);
|
||||
cleanState();
|
||||
// setUser({
|
||||
// login: login
|
||||
// })
|
||||
window.location.reload();
|
||||
// navigate("/")
|
||||
// window.location.reload()
|
||||
navigate("/");
|
||||
} else {
|
||||
console.log(response);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user