import Input from "@/components/Low/Input"; import {WritingExam} from "@/interfaces/exam"; import useExamStore from "@/stores/examStore"; import {getExamById} from "@/utils/exams"; import {playSound} from "@/utils/sound"; import {Tab} from "@headlessui/react"; import axios from "axios"; import clsx from "clsx"; import {useRouter} from "next/router"; import {useState} from "react"; import {BsArrowRepeat} from "react-icons/bs"; import {toast} from "react-toastify"; import {v4} from "uuid"; const TaskTab = ({task, index, setTask}: {task?: string; index: number; setTask: (task: string) => void}) => { const [isLoading, setIsLoading] = useState(false); const generate = () => { setIsLoading(true); axios .get(`/api/exam/writing/generate/writing_task${index}_general`) .then((result) => { playSound("check"); setTask(result.data.question); }) .catch((error) => { console.log(error); toast.error("Something went wrong!"); }) .finally(() => setIsLoading(false)); }; return (
{isLoading && (
Generating...
)} {task && (
{task}
)}
); }; const WritingGeneration = () => { const [task1, setTask1] = useState(); const [task2, setTask2] = useState(); const [isLoading, setIsLoading] = useState(false); const [resultingExam, setResultingExam] = useState(); const router = useRouter(); const setExams = useExamStore((state) => state.setExams); const setSelectedModules = useExamStore((state) => state.setSelectedModules); const loadExam = async (examId: string) => { const exam = await getExamById("writing", examId.trim()); if (!exam) { toast.error("Unknown Exam ID! Please make sure you selected the right module and entered the right exam ID", { toastId: "invalid-exam-id", }); return; } setExams([exam]); setSelectedModules(["writing"]); router.push("/exercises"); }; const submitExam = () => { if (!task1 || !task2) { toast.error("Please generate all tasks before submitting"); return; } setIsLoading(true); const exam: WritingExam = { isDiagnostic: false, minTimer: 60, module: "writing", exercises: [ { id: v4(), type: "writing", prefix: `You should spend about 20 minutes on this task.`, prompt: task1, userSolutions: [], suffix: "You should write at least 150 words.", wordCounter: { limit: 150, type: "min", }, }, { id: v4(), type: "writing", prefix: `You should spend about 40 minutes on this task.`, prompt: task2, userSolutions: [], suffix: "You should write at least 250 words.", wordCounter: { limit: 250, type: "min", }, }, ], id: v4(), }; axios .post(`/api/exam/writing`, exam) .then((result) => { console.log(`Generated Exam ID: ${result.data.id}`); playSound("sent"); toast.success("This new exam has been generated successfully! Check the ID in our browser's console."); setResultingExam(result.data); setTask1(undefined); setTask2(undefined); }) .catch((error) => { console.log(error); toast.error("Something went wrong while generating, please try again later."); }) .finally(() => setIsLoading(false)); }; return ( <> clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-writing/70", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-writing focus:outline-none focus:ring-2", "transition duration-300 ease-in-out", selected ? "bg-white shadow" : "text-blue-100 hover:bg-white/[0.12] hover:text-ielts-writing", ) }> Task 1 clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-writing/70", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-writing focus:outline-none focus:ring-2", "transition duration-300 ease-in-out", selected ? "bg-white shadow" : "text-blue-100 hover:bg-white/[0.12] hover:text-ielts-writing", ) }> Task 2 {[ {task: task1, setTask: setTask1}, {task: task2, setTask: setTask2}, ].map(({task, setTask}, index) => ( ))}
{resultingExam && ( )}
); }; export default WritingGeneration;