2024-06-29 09:32:16 +00:00
|
|
|
import { sendAnswer } from "@/api/quizRelase";
|
|
|
|
import { RealTypedQuizQuestion } from "@/model/questionTypes/shared";
|
2024-09-12 08:43:50 +00:00
|
|
|
import { OwnVariant, QuestionAnswer, createQuizViewStore } from "@/stores/quizView";
|
2024-06-29 09:32:16 +00:00
|
|
|
import moment from "moment";
|
|
|
|
import { notReachable } from "./notReachable";
|
|
|
|
|
2025-05-01 13:23:10 +00:00
|
|
|
export async function sendQuestionAnswer(
|
2024-07-05 17:05:26 +00:00
|
|
|
quizId: string,
|
|
|
|
question: RealTypedQuizQuestion,
|
2024-09-12 08:43:50 +00:00
|
|
|
questionAnswer: QuestionAnswer | undefined,
|
|
|
|
ownVariants: OwnVariant[]
|
2024-07-05 17:05:26 +00:00
|
|
|
) {
|
|
|
|
if (!questionAnswer) {
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: "",
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
2024-06-29 09:32:16 +00:00
|
|
|
switch (question.type) {
|
|
|
|
case "date": {
|
2024-10-08 14:27:17 +00:00
|
|
|
let answer = "";
|
2024-06-29 09:32:16 +00:00
|
|
|
|
2024-10-08 14:27:17 +00:00
|
|
|
if (question.content.isRange) {
|
|
|
|
if (!Array.isArray(questionAnswer.answer)) throw new Error("Cannot send answer in range question");
|
|
|
|
|
|
|
|
let from = Number(questionAnswer.answer[0]);
|
|
|
|
let to = Number(questionAnswer.answer[1]);
|
|
|
|
|
|
|
|
if (
|
|
|
|
from !== 0 &&
|
|
|
|
to !== 0 &&
|
|
|
|
from !== Math.min(Number(questionAnswer.answer[0]), Number(questionAnswer.answer[1]))
|
|
|
|
) {
|
|
|
|
from = Math.min(Number(questionAnswer.answer[0]), Number(questionAnswer.answer[1]));
|
|
|
|
to = Math.max(Number(questionAnswer.answer[0]), Number(questionAnswer.answer[1]));
|
|
|
|
}
|
|
|
|
|
|
|
|
answer = `${!from ? "_" : moment(from).format("YYYY.MM.DD")} - ${!to ? "_" : moment(to).format("YYYY.MM.DD")}`;
|
|
|
|
} else {
|
|
|
|
if (!moment.isMoment(questionAnswer.answer)) throw new Error("Cannot send answer in date question");
|
|
|
|
|
|
|
|
answer = moment(questionAnswer.answer).format("YYYY.MM.DD");
|
|
|
|
}
|
2024-06-29 09:32:16 +00:00
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
2024-10-08 14:27:17 +00:00
|
|
|
body: answer,
|
2024-06-29 09:32:16 +00:00
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "emoji": {
|
2024-09-12 15:55:25 +00:00
|
|
|
if (question.content.multi) {
|
2025-06-20 13:37:04 +00:00
|
|
|
const answer = questionAnswer.answer as string[];
|
|
|
|
let answerString = ``;
|
2024-09-12 15:55:25 +00:00
|
|
|
|
|
|
|
const selectedVariants = question.content.variants.filter((v) => answer.includes(v.id));
|
|
|
|
|
2025-06-20 13:37:04 +00:00
|
|
|
selectedVariants.forEach((variant) => {
|
|
|
|
const ownVariantData = ownVariants.find((v) => v.id === variant.id)?.variant;
|
|
|
|
const customEmoji = ownVariantData?.extendedText || "";
|
|
|
|
const emojiToSend = customEmoji || variant.extendedText;
|
|
|
|
const textToSend = variant.isOwn ? ownVariantData?.answer || "" : variant.answer;
|
|
|
|
answerString += `\`${emojiToSend} ${textToSend}\`,`;
|
2024-09-12 15:55:25 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
answerString = answerString.slice(0, -1);
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: answerString,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2025-06-20 13:37:04 +00:00
|
|
|
// Fallback for old string format for single choice
|
|
|
|
const answer = questionAnswer.answer as string;
|
|
|
|
const variant = question.content.variants.find((v) => v.id === answer);
|
|
|
|
if (!variant) {
|
|
|
|
// This can happen if the answer is not set, so we don't throw an error, just send empty
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: "",
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const ownVariantData = ownVariants.find((v) => v.id === variant.id)?.variant;
|
|
|
|
const customEmoji = ownVariantData?.extendedText || "";
|
|
|
|
const emojiToSend = customEmoji || variant.extendedText;
|
|
|
|
const textToSend = variant.isOwn ? ownVariantData?.answer || "" : variant.answer;
|
|
|
|
const body = `${emojiToSend} ${textToSend}`.trim();
|
2024-06-29 09:32:16 +00:00
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
2025-06-20 13:37:04 +00:00
|
|
|
body: body,
|
2024-06-29 09:32:16 +00:00
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "file": {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
case "images": {
|
2024-09-12 08:43:50 +00:00
|
|
|
if (question.content.multi) {
|
|
|
|
const answer = questionAnswer.answer;
|
2024-09-12 15:55:25 +00:00
|
|
|
const ownAnswer = Array.isArray(answer)
|
|
|
|
? ownVariants[ownVariants.findIndex((variant) => answer.some((a: string) => a === variant.id))]?.variant
|
|
|
|
?.answer || ""
|
|
|
|
: ownVariants[ownVariants.findIndex((variant) => variant.id === questionAnswer.answer)]?.variant?.answer ||
|
|
|
|
"";
|
|
|
|
|
|
|
|
if (moment.isMoment(answer)) throw new Error("Answer is Moment in Variant question");
|
2024-09-12 08:43:50 +00:00
|
|
|
|
|
|
|
//Оставляем только выбранные варианты
|
|
|
|
const selectedVariants = question.content.variants.filter((v) => answer.includes(v.id));
|
|
|
|
|
|
|
|
let answerString = ``;
|
2024-09-12 15:55:25 +00:00
|
|
|
selectedVariants.forEach((e) => {
|
2024-09-15 17:00:06 +00:00
|
|
|
if (!e.isOwn || (e.isOwn && question.content.own)) {
|
2025-06-20 16:24:07 +00:00
|
|
|
let imageValue = e.extendedText;
|
|
|
|
if (e.isOwn) {
|
|
|
|
// Берем fileId из ownVariants для own вариантов
|
|
|
|
const ownVariantData = ownVariants.find((v) => v.id === e.id)?.variant;
|
|
|
|
if (ownVariantData?.originalImageUrl) {
|
|
|
|
// Конструируем полный URL для own вариантов
|
|
|
|
const baseUrl =
|
|
|
|
"https://s3.timeweb.cloud/3c580be9-cf31f296-d055-49cf-b39e-30c7959dc17b/squizimages/55c25eb9-4533-4d51-9da5-54e63e8aeace/";
|
|
|
|
// Убираем расширение файла из fileId
|
|
|
|
const fileIdWithoutExtension = ownVariantData.originalImageUrl.replace(
|
|
|
|
/\.(jpg|jpeg|png|gif|webp)$/i,
|
|
|
|
""
|
|
|
|
);
|
|
|
|
imageValue = baseUrl + fileIdWithoutExtension;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-15 17:00:06 +00:00
|
|
|
const body = {
|
2025-06-20 16:24:07 +00:00
|
|
|
Image: imageValue,
|
2024-09-15 17:00:06 +00:00
|
|
|
Description: e.isOwn ? ownAnswer : e.answer,
|
|
|
|
};
|
|
|
|
answerString += `\`${JSON.stringify(body)}\`,`;
|
|
|
|
}
|
2024-09-12 08:43:50 +00:00
|
|
|
});
|
|
|
|
answerString = answerString.slice(0, -1);
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: answerString,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-06-29 09:32:16 +00:00
|
|
|
const variant = question.content.variants.find((v) => v.id === questionAnswer.answer);
|
2024-09-12 08:43:50 +00:00
|
|
|
|
2024-06-29 09:32:16 +00:00
|
|
|
if (!variant) throw new Error(`Cannot find variant with id ${questionAnswer.answer} in question ${question.id}`);
|
2025-06-20 16:24:07 +00:00
|
|
|
|
|
|
|
let imageValue = variant.extendedText;
|
|
|
|
if (variant.isOwn) {
|
|
|
|
// Берем fileId из ownVariants для own вариантов
|
|
|
|
const ownVariantData = ownVariants.find((v) => v.id === variant.id)?.variant;
|
|
|
|
if (ownVariantData?.originalImageUrl) {
|
|
|
|
// Конструируем полный URL для own вариантов
|
|
|
|
const baseUrl =
|
|
|
|
"https://s3.timeweb.cloud/3c580be9-cf31f296-d055-49cf-b39e-30c7959dc17b/squizimages/55c25eb9-4533-4d51-9da5-54e63e8aeace/";
|
|
|
|
// Убираем расширение файла из fileId
|
|
|
|
const fileIdWithoutExtension = ownVariantData.originalImageUrl.replace(/\.(jpg|jpeg|png|gif|webp)$/i, "");
|
|
|
|
imageValue = baseUrl + fileIdWithoutExtension;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-11 19:26:46 +00:00
|
|
|
const body = {
|
2025-06-20 16:24:07 +00:00
|
|
|
Image: imageValue,
|
2024-07-11 19:26:46 +00:00
|
|
|
Description: variant.answer,
|
|
|
|
};
|
2024-07-05 16:59:20 +00:00
|
|
|
if (!body) throw new Error(`Body of answer in question ${question.id} is undefined`);
|
2024-06-29 09:32:16 +00:00
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
2025-04-02 10:10:15 +00:00
|
|
|
body: `\`${JSON.stringify(body)}\``,
|
2024-06-29 09:32:16 +00:00
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "number": {
|
|
|
|
if (typeof questionAnswer.answer !== "string") throw new Error("Cannot send answer in select question");
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: questionAnswer.answer,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "page": {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
case "rating": {
|
|
|
|
if (typeof questionAnswer.answer !== "string") throw new Error("Cannot send answer in select question");
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: String(questionAnswer.answer) + " из " + question.content.steps,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "select": {
|
|
|
|
if (typeof questionAnswer.answer !== "string") throw new Error("Cannot send answer in select question");
|
|
|
|
|
|
|
|
const variant = question.content.variants[Number(questionAnswer.answer)];
|
|
|
|
if (!variant) throw new Error(`Cannot find variant with id ${questionAnswer.answer} in question ${question.id}`);
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: variant.answer,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "text": {
|
|
|
|
if (moment.isMoment(questionAnswer.answer)) throw new Error("Cannot send Moment in text question");
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: questionAnswer.answer,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "variant": {
|
|
|
|
if (question.content.multi) {
|
|
|
|
const answer = questionAnswer.answer;
|
2024-09-12 11:14:54 +00:00
|
|
|
if (moment.isMoment(answer)) throw new Error("Answer is Moment in Variant question");
|
|
|
|
|
|
|
|
const ownAnswer = Array.isArray(answer)
|
|
|
|
? ownVariants[ownVariants.findIndex((variant) => answer.some((a: string) => a === variant.id))]?.variant
|
|
|
|
?.answer || ""
|
|
|
|
: ownVariants[ownVariants.findIndex((variant) => variant.id === questionAnswer.answer)]?.variant?.answer ||
|
|
|
|
"";
|
|
|
|
|
2024-09-08 08:31:11 +00:00
|
|
|
//Оставляем только выбранные варианты
|
2024-06-29 09:32:16 +00:00
|
|
|
const selectedVariants = question.content.variants.filter((v) => answer.includes(v.id));
|
2024-09-12 08:43:50 +00:00
|
|
|
|
2024-09-08 08:31:11 +00:00
|
|
|
let answerString = ``;
|
|
|
|
selectedVariants.forEach((e) => {
|
2024-09-12 11:14:54 +00:00
|
|
|
if (!e.isOwn) answerString += `\`${e.answer}\`,`;
|
2024-09-08 08:31:11 +00:00
|
|
|
});
|
2024-09-12 11:14:54 +00:00
|
|
|
|
|
|
|
if (question.content.own && selectedVariants.some((v) => v.isOwn)) {
|
|
|
|
answerString += `\`${ownAnswer}\`,`;
|
|
|
|
}
|
2024-09-08 08:31:11 +00:00
|
|
|
answerString = answerString.slice(0, -1);
|
2024-06-29 09:32:16 +00:00
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
2024-09-08 08:31:11 +00:00
|
|
|
body: answerString,
|
2024-06-29 09:32:16 +00:00
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const variant = question.content.variants.find((v) => v.id === questionAnswer.answer);
|
|
|
|
if (!variant) throw new Error(`Cannot find variant with id ${questionAnswer.answer} in question ${question.id}`);
|
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
|
|
|
body: variant.answer,
|
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
case "varimg": {
|
|
|
|
const variant = question.content.variants.find((v) => v.id === questionAnswer.answer);
|
2024-09-12 08:43:50 +00:00
|
|
|
const ownAnswer =
|
2024-09-12 11:14:54 +00:00
|
|
|
ownVariants[ownVariants.findIndex((variant) => variant.id === questionAnswer.answer)]?.variant?.answer || "";
|
2024-09-12 08:43:50 +00:00
|
|
|
|
2024-06-29 09:32:16 +00:00
|
|
|
if (!variant) throw new Error(`Cannot find variant with id ${questionAnswer.answer} in question ${question.id}`);
|
2025-06-20 19:22:18 +00:00
|
|
|
|
|
|
|
let imageValue = variant.extendedText;
|
|
|
|
if (variant.isOwn) {
|
|
|
|
// Берем fileId из ownVariants для own вариантов
|
|
|
|
const ownVariantData = ownVariants.find((v) => v.id === variant.id)?.variant;
|
|
|
|
if (ownVariantData?.originalImageUrl) {
|
|
|
|
// Конструируем полный URL для own вариантов
|
|
|
|
const baseUrl =
|
|
|
|
"https://s3.timeweb.cloud/3c580be9-cf31f296-d055-49cf-b39e-30c7959dc17b/squizimages/55c25eb9-4533-4d51-9da5-54e63e8aeace/";
|
|
|
|
// Убираем расширение файла из fileId
|
|
|
|
const fileIdWithoutExtension = ownVariantData.originalImageUrl.replace(/\.(jpg|jpeg|png|gif|webp)$/i, "");
|
|
|
|
imageValue = baseUrl + fileIdWithoutExtension;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-11 19:26:46 +00:00
|
|
|
const body = {
|
2025-06-20 19:22:18 +00:00
|
|
|
Image: imageValue,
|
|
|
|
Description: variant.isOwn ? ownAnswer : variant.answer,
|
2024-07-11 19:26:46 +00:00
|
|
|
};
|
2024-07-05 16:59:20 +00:00
|
|
|
if (!body) throw new Error(`Body of answer in question ${question.id} is undefined`);
|
2024-06-29 09:32:16 +00:00
|
|
|
|
|
|
|
return sendAnswer({
|
|
|
|
questionId: question.id,
|
2024-09-15 17:00:06 +00:00
|
|
|
body: `\`${JSON.stringify(body)}\``,
|
2024-06-29 09:32:16 +00:00
|
|
|
qid: quizId,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
notReachable(question);
|
|
|
|
}
|
|
|
|
}
|