/* eslint-disable @next/next/no-img-element */ import {InteractiveSpeakingExercise} from "@/interfaces/exam"; import {CommonProps} from "."; import {useEffect, useState} from "react"; import Button from "../Low/Button"; import dynamic from "next/dynamic"; import axios from "axios"; import {speakingReverseMarking} from "@/utils/score"; import {Tab} from "@headlessui/react"; import clsx from "clsx"; import Modal from "../Modal"; import ReactDiffViewer, {DiffMethod} from "react-diff-viewer"; const Waveform = dynamic(() => import("../Waveform"), {ssr: false}); export default function InteractiveSpeaking({ id, type, title, text, prompts, userSolutions, onNext, onBack, }: InteractiveSpeakingExercise & CommonProps) { const [solutionsURL, setSolutionsURL] = useState([]); const [diffNumber, setDiffNumber] = useState<0 | 1 | 2 | 3>(0); useEffect(() => { if (userSolutions && userSolutions.length > 0 && userSolutions[0].solution) { Promise.all(userSolutions[0].solution.map((x) => axios.post(`/api/speaking`, {path: x.answer}, {responseType: "arraybuffer"}))).then( (values) => { setSolutionsURL( values.map(({data}) => { const blob = new Blob([data], {type: "audio/wav"}); const url = URL.createObjectURL(blob); return url; }), ); }, ); } }, [userSolutions]); return ( <> setDiffNumber(0)}> <> {userSolutions && userSolutions.length > 0 && diffNumber !== 0 && userSolutions[0].evaluation && userSolutions[0].evaluation[`transcript_${diffNumber}`] && userSolutions[0].evaluation[`fixed_text_${diffNumber}`] && (
Transcript Recommended Improvements
)}
{title}
You should talk about the following things:
{prompts.map((x, index) => (
{x.text}
))}
{solutionsURL.map((x, index) => (
{userSolutions && userSolutions.length > 0 && userSolutions[0].evaluation && userSolutions[0].evaluation[`transcript_${(index + 1) as 1 | 2 | 3}`] && userSolutions[0].evaluation[`fixed_text_${(index + 1) as 1 | 2 | 3}`] && ( )}
))}
{userSolutions && userSolutions.length > 0 && userSolutions[0].evaluation && typeof userSolutions[0].evaluation !== "string" && (
{Object.keys(userSolutions[0].evaluation!.task_response).map((key) => (
{key}: Level {userSolutions[0].evaluation!.task_response[key]}
))}
{userSolutions[0].evaluation && Object.keys(userSolutions[0].evaluation).filter((x) => x.startsWith("perfect_answer")).length === 3 ? ( clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-speaking/80", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-speaking 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-speaking", ) }> Evaluation clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-speaking/80", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-speaking 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-speaking", ) }> Recommended Answer (Prompt 1) clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-speaking/80", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-speaking 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-speaking", ) }> Recommended Answer (Prompt 2) clsx( "w-full rounded-lg py-2.5 text-sm font-medium leading-5 text-ielts-speaking/80", "ring-white ring-opacity-60 ring-offset-2 ring-offset-ielts-speaking 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-speaking", ) }> Recommended Answer (Prompt 3) {userSolutions[0].evaluation!.comment} {userSolutions[0].evaluation!.perfect_answer_1!.answer.replaceAll(/\s{2,}/g, "\n\n")} {userSolutions[0].evaluation!.perfect_answer_2!.answer.replaceAll(/\s{2,}/g, "\n\n")} {userSolutions[0].evaluation!.perfect_answer_3!.answer.replaceAll(/\s{2,}/g, "\n\n")} ) : (
{userSolutions[0].evaluation!.comment}
)}
)}
); }