69 lines
1.7 KiB
TypeScript
69 lines
1.7 KiB
TypeScript
import { AnyTypedQuizQuestion } from "@model/questionTypes/shared";
|
|
import { QuizSettings } from "@model/settingsData";
|
|
|
|
export interface GetQuizDataResponse {
|
|
cnt: number;
|
|
settings?: {
|
|
fp: boolean;
|
|
rep: boolean;
|
|
name: string;
|
|
cfg: string;
|
|
lim: number;
|
|
due: number;
|
|
delay: number;
|
|
pausable: boolean;
|
|
status: "start" | "stop" | "ai";
|
|
};
|
|
items: {
|
|
id: number;
|
|
title: string;
|
|
desc: string;
|
|
typ: string;
|
|
req: boolean;
|
|
p: number;
|
|
c: string;
|
|
}[];
|
|
show_badge: boolean;
|
|
}
|
|
|
|
export function parseQuizData(quizDataResponse: GetQuizDataResponse): Omit<QuizSettings, "recentlyCompleted"> {
|
|
const readyData = {
|
|
cnt: quizDataResponse.cnt,
|
|
show_badge: quizDataResponse.show_badge,
|
|
settings: {} as QuizSettings["settings"],
|
|
questions: [] as QuizSettings["questions"],
|
|
} as QuizSettings;
|
|
|
|
const items: QuizSettings["questions"] = quizDataResponse.items.map((item) => {
|
|
const content = JSON.parse(item.c);
|
|
|
|
return {
|
|
description: item.desc,
|
|
id: item.id,
|
|
page: item.p,
|
|
required: item.req,
|
|
title: item.title,
|
|
type: item.typ,
|
|
content,
|
|
} as unknown as AnyTypedQuizQuestion;
|
|
});
|
|
|
|
readyData.questions = items;
|
|
|
|
if (quizDataResponse?.settings !== undefined) {
|
|
readyData.settings = {
|
|
fp: quizDataResponse.settings.fp,
|
|
rep: quizDataResponse.settings.rep,
|
|
name: quizDataResponse.settings.name,
|
|
cfg: JSON.parse(quizDataResponse?.settings.cfg),
|
|
lim: quizDataResponse.settings.lim,
|
|
due: quizDataResponse.settings.due,
|
|
delay: quizDataResponse.settings.delay,
|
|
pausable: quizDataResponse.settings.pausable,
|
|
status: quizDataResponse.settings.status,
|
|
};
|
|
}
|
|
|
|
return readyData;
|
|
}
|