2023-11-21 17:31:22 +03:00
|
|
|
|
import React, { useEffect, useState } from "react";
|
2023-05-31 08:36:15 +03:00
|
|
|
|
import { useSelector } from "react-redux";
|
2023-11-21 17:31:22 +03:00
|
|
|
|
import { Link, useNavigate, useParams } from "react-router-dom";
|
2023-05-31 11:24:46 +03:00
|
|
|
|
import { completedTestSelector } from "@redux/quizSlice";
|
2023-05-31 08:36:15 +03:00
|
|
|
|
import { Footer } from "@components/Common/Footer/Footer";
|
|
|
|
|
import { ProfileBreadcrumbs } from "@components/ProfileBreadcrumbs/ProfileBreadcrumbs";
|
|
|
|
|
import { ProfileHeader } from "@components/ProfileHeader/ProfileHeader";
|
|
|
|
|
import { HeadBottom } from "@components/features/Candidate-lk/HeadBottom";
|
|
|
|
|
import { BlockCompletedTest } from "@components/features/quiz/BlockCompletedTest";
|
|
|
|
|
import { CardIntroduction } from "@components/features/quiz/Card-introduction";
|
|
|
|
|
import { QuizPassingInformation } from "@components/features/quiz/Quiz-passing-information";
|
|
|
|
|
import { TaskQuiz } from "@components/features/quiz/Task";
|
2023-11-21 17:31:22 +03:00
|
|
|
|
import { useTimer } from "react-timer-hook";
|
|
|
|
|
import moment from "moment";
|
2023-05-31 08:36:15 +03:00
|
|
|
|
|
|
|
|
|
export const PassingTests = () => {
|
|
|
|
|
|
|
|
|
|
const [startTest, setStartTest] = useState(false);
|
2023-11-21 17:31:22 +03:00
|
|
|
|
const navigate = useNavigate()
|
2023-05-31 08:36:15 +03:00
|
|
|
|
const completedTest = useSelector(completedTestSelector);
|
2023-11-21 17:31:22 +03:00
|
|
|
|
const { uuid } = useParams()
|
|
|
|
|
|
|
|
|
|
const timer = useTimer({
|
|
|
|
|
expiryTimestamp: moment(),
|
|
|
|
|
autoStart: false,
|
|
|
|
|
onExpire: () => {
|
|
|
|
|
navigate("/quiz")
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const onCloseWindow = (e) => {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
if(startTest){
|
|
|
|
|
let confirmationMessage = "\o/";
|
|
|
|
|
(e || window.e).returnValue = confirmationMessage;
|
|
|
|
|
return confirmationMessage;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-05-31 08:36:15 +03:00
|
|
|
|
|
|
|
|
|
const introduction = [
|
|
|
|
|
{
|
|
|
|
|
title: "Зачем?",
|
|
|
|
|
description:
|
|
|
|
|
"Тесты itguild предназначены для того, чтобы подтверждать навыки, которые вы указали у себя.",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Почему именно тестирование?",
|
|
|
|
|
description:
|
|
|
|
|
"Тесты itguild заменяют первое техническое собеседование по любой вакансии.",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Какие тесты нужно проходить?",
|
|
|
|
|
description:
|
|
|
|
|
"Здесь все довольно просто — следует проходить тесты по инструментам и навыкам, которыми вы владеете.",
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
|
2023-11-21 17:31:22 +03:00
|
|
|
|
function onSwitchTab(e) {
|
|
|
|
|
console.log(e,document.visibilityState);
|
|
|
|
|
if (document.visibilityState === "hidden" && startTest) {
|
|
|
|
|
alert("Убедительная просьба не покидать страницу и не переключаться. Рассчитывайте только на свои знания и умения!!!")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
useEffect(()=>{
|
|
|
|
|
window.addEventListener("beforeunload", onCloseWindow);
|
|
|
|
|
window.addEventListener("visibilitychange", onSwitchTab);
|
|
|
|
|
window.onblur = onSwitchTab
|
|
|
|
|
return () => {
|
|
|
|
|
window.removeEventListener("beforeunload", onCloseWindow);
|
|
|
|
|
window.removeEventListener("visibilitychange", onSwitchTab);
|
|
|
|
|
}
|
|
|
|
|
}, [startTest])
|
|
|
|
|
|
2023-05-31 08:36:15 +03:00
|
|
|
|
return (
|
|
|
|
|
<div className="passing-tests-page">
|
|
|
|
|
<ProfileHeader />
|
|
|
|
|
<HeadBottom />
|
|
|
|
|
<div className="passing-tests-page__container">
|
|
|
|
|
<ProfileBreadcrumbs
|
|
|
|
|
links={[
|
|
|
|
|
{ name: "Главная", link: "/profile-candidate" },
|
|
|
|
|
{ name: "Тестирование", link: "/quiz" },
|
|
|
|
|
{ name: "Прохождение тестов", link: "/quiz/test" },
|
|
|
|
|
]}
|
|
|
|
|
/>
|
|
|
|
|
<div className="passing-tests-page__title main-title">
|
2023-11-21 17:31:22 +03:00
|
|
|
|
Тестирование в позиции Junior разработчик
|
2023-05-31 08:36:15 +03:00
|
|
|
|
</div>
|
|
|
|
|
<div className="passing-tests-page__passing-information">
|
|
|
|
|
<QuizPassingInformation
|
2023-11-21 17:31:22 +03:00
|
|
|
|
timer={timer}
|
2023-05-31 08:36:15 +03:00
|
|
|
|
setStartTest={setStartTest}
|
2023-11-21 17:31:22 +03:00
|
|
|
|
uuid={uuid}
|
2023-05-31 08:36:15 +03:00
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
{!completedTest && (
|
|
|
|
|
<>
|
|
|
|
|
{startTest && (
|
|
|
|
|
<div className="passing-tests-page__block-green">
|
|
|
|
|
Тестирование началось
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
{startTest ? (
|
2023-11-21 17:31:22 +03:00
|
|
|
|
<TaskQuiz timer={timer}/>
|
2023-05-31 08:36:15 +03:00
|
|
|
|
) : (
|
|
|
|
|
<div className="passing-tests-page__introduction">
|
|
|
|
|
{introduction.map((item, i) => (
|
|
|
|
|
<CardIntroduction
|
|
|
|
|
description={item.description}
|
|
|
|
|
title={item.title}
|
|
|
|
|
key={i}
|
|
|
|
|
/>
|
|
|
|
|
))}
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
{!startTest && (
|
|
|
|
|
<div className="passing-tests-page__block-text block-text">
|
|
|
|
|
ИЛИ <Link to={""}>выполните тестове задание</Link> , без
|
|
|
|
|
прохождения тестов
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
{completedTest && (
|
|
|
|
|
<>
|
|
|
|
|
<div className="passing-tests-page__block-green">
|
|
|
|
|
Тестирование завершено
|
|
|
|
|
</div>
|
|
|
|
|
<BlockCompletedTest />
|
|
|
|
|
</>
|
|
|
|
|
)}
|
|
|
|
|
</div>
|
|
|
|
|
<Footer />
|
2023-11-21 17:31:22 +03:00
|
|
|
|
{/*<Prompt*/}
|
|
|
|
|
{/* when={showPrompt}*/}
|
|
|
|
|
{/* message="Unsaved changes detected, continue?"*/}
|
|
|
|
|
{/* beforeUnload={true}*/}
|
|
|
|
|
{/*/>*/}
|
2023-05-31 08:36:15 +03:00
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
2023-11-21 17:31:22 +03:00
|
|
|
|
|
|
|
|
|
|