2025-03-07 10:18:56 +00:00
|
|
|
"use client";
|
|
|
|
|
import { Queries } from "@/api/queries";
|
|
|
|
|
import QuizHeader from "@/components/quiz/QuizHeader";
|
|
|
|
|
import QuizTapgyrResults from "@/components/quiz/QuizTapgyrResults";
|
|
|
|
|
import QuizTapgyrWinners from "@/components/quiz/QuizTapgyrWinners";
|
|
|
|
|
import { Data } from "@/models/quizQuestions.model";
|
2025-03-13 16:21:41 +00:00
|
|
|
import { notFound } from "next/navigation";
|
2025-03-07 10:18:56 +00:00
|
|
|
import React, { useEffect, useState } from "react";
|
|
|
|
|
|
|
|
|
|
interface IParams {
|
|
|
|
|
params: {
|
|
|
|
|
quiz_id: string;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const Page = ({ params }: IParams) => {
|
|
|
|
|
const [data, setData] = useState<Data>();
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
2025-03-13 16:21:41 +00:00
|
|
|
Queries.getQuizById(params.quiz_id)
|
|
|
|
|
.then((res) => setData(res.data))
|
|
|
|
|
.catch(() => notFound());
|
2025-03-07 10:18:56 +00:00
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<section className="container py-[40px]">
|
|
|
|
|
<div className="flex flex-col w-full py-[40px] gap-[80px]">
|
|
|
|
|
<QuizHeader data={data} />
|
|
|
|
|
<QuizTapgyrResults
|
|
|
|
|
id={params.quiz_id}
|
|
|
|
|
steps={
|
|
|
|
|
data?.steps ? data?.steps?.map((item) => String(item.tapgyr)) : []
|
|
|
|
|
}
|
|
|
|
|
/>
|
|
|
|
|
{data?.has_steps &&
|
|
|
|
|
data.steps &&
|
|
|
|
|
data.steps?.length > 0 &&
|
|
|
|
|
data.steps.map((step) => (
|
2025-03-13 16:21:41 +00:00
|
|
|
<QuizTapgyrWinners
|
|
|
|
|
key={step.tapgyr}
|
|
|
|
|
id={params.quiz_id}
|
|
|
|
|
tapgyr={step.tapgyr}
|
|
|
|
|
questions={step.questions}
|
|
|
|
|
/>
|
2025-03-07 10:18:56 +00:00
|
|
|
))}
|
|
|
|
|
</div>
|
|
|
|
|
</section>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default Page;
|