touchstudy-core 0.1.150 → 0.1.151

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -18511,6 +18511,7 @@ var TimeOrderChart = function TimeOrderChart(_ref) {
18511
18511
  };
18512
18512
 
18513
18513
  var TextbookAnswerItem = function TextbookAnswerItem(_ref) {
18514
+ var _data$selectedAnswers, _data$textualAnswers, _data$selectedAnswers2, _data$textualAnswers2, _data$selectedAnswers3, _data$textualAnswers3;
18514
18515
  var data = _ref.data,
18515
18516
  nextData = _ref.nextData,
18516
18517
  isFirst = _ref.isFirst,
@@ -18564,11 +18565,11 @@ var TextbookAnswerItem = function TextbookAnswerItem(_ref) {
18564
18565
  alignItems: "center",
18565
18566
  gap: "4px"
18566
18567
  }
18567
- }, data.isCorrect && data.selectedAnswers !== "" && React__default.createElement(Fragment$1, null, React__default.createElement(iconCorrectAnswer, null), React__default.createElement("span", {
18568
+ }, data.isCorrect && (!!((_data$selectedAnswers = data.selectedAnswers) !== null && _data$selectedAnswers !== void 0 && _data$selectedAnswers.length) || !!((_data$textualAnswers = data.textualAnswers) !== null && _data$textualAnswers !== void 0 && _data$textualAnswers.length)) && React__default.createElement(Fragment$1, null, React__default.createElement(iconCorrectAnswer, null), React__default.createElement("span", {
18568
18569
  className: styles$4["answerCorrect"]
18569
- }, t("correct"))), !data.isCorrect && data.selectedAnswers !== "" && React__default.createElement(Fragment$1, null, React__default.createElement(iconCorrectAnswer$1, null), React__default.createElement("span", {
18570
+ }, t("correct"))), !data.isCorrect && (!!((_data$selectedAnswers2 = data.selectedAnswers) !== null && _data$selectedAnswers2 !== void 0 && _data$selectedAnswers2.length) || !!((_data$textualAnswers2 = data.textualAnswers) !== null && _data$textualAnswers2 !== void 0 && _data$textualAnswers2.length)) && React__default.createElement(Fragment$1, null, React__default.createElement(iconCorrectAnswer$1, null), React__default.createElement("span", {
18570
18571
  className: styles$4["answerIncorrect"]
18571
- }, t("incorrect"))), data.selectedAnswers === "" && React__default.createElement(Fragment$1, null, React__default.createElement(iconNoGrass, null), React__default.createElement("span", {
18572
+ }, t("incorrect"))), !((_data$selectedAnswers3 = data.selectedAnswers) !== null && _data$selectedAnswers3 !== void 0 && _data$selectedAnswers3.length) && !((_data$textualAnswers3 = data.textualAnswers) !== null && _data$textualAnswers3 !== void 0 && _data$textualAnswers3.length) && React__default.createElement(Fragment$1, null, React__default.createElement(iconNoGrass, null), React__default.createElement("span", {
18572
18573
  className: styles$4["answerNograss"]
18573
18574
  }, t("no_solution")))), React__default.createElement("div", {
18574
18575
  className: styles["custom-col-2"],
@@ -18952,11 +18953,30 @@ var TextbookVulnerable = function TextbookVulnerable(_ref) {
18952
18953
  var isOpen = openProblem === keyOpen;
18953
18954
  var incorrectQuestions = useMemo(function () {
18954
18955
  return data === null || data === void 0 ? void 0 : data.studentQuestionResults.filter(function (i) {
18955
- return i.selectedAnswers !== "" && i.isCorrect === false && i.isStar === false && i.overallCorrectRate >= correctRateThreshHold$1;
18956
+ var _i$selectedAnswers, _i$textualAnswers;
18957
+ return (((_i$selectedAnswers = i.selectedAnswers) === null || _i$selectedAnswers === void 0 ? void 0 : _i$selectedAnswers.length) || ((_i$textualAnswers = i.textualAnswers) === null || _i$textualAnswers === void 0 ? void 0 : _i$textualAnswers.length)) && i.isCorrect === false && i.isStar === false && i.overallCorrectRate >= correctRateThreshHold$1;
18956
18958
  }).sort(function (q1, q2) {
18957
18959
  return q2.overallCorrectRate === q1.overallCorrectRate ? q1.questionOrder - q2.questionOrder : q2.overallCorrectRate - q1.overallCorrectRate;
18958
18960
  }).slice(0, limitQuestions$1);
18959
18961
  }, [JSON.stringify(data === null || data === void 0 ? void 0 : data.studentQuestionResults)]);
18962
+ var renderTextbookAnswer = function renderTextbookAnswer(type, answers, textualAnswers, isCorrect) {
18963
+ var _textualAnswers$;
18964
+ switch (type) {
18965
+ case QuestionAnswerType.ShortAnswer:
18966
+ case QuestionAnswerType.SynonymProcessing:
18967
+ return isCorrect ? textualAnswers === null || textualAnswers === void 0 ? void 0 : textualAnswers.join(" | ") : (_textualAnswers$ = textualAnswers === null || textualAnswers === void 0 ? void 0 : textualAnswers[0]) != null ? _textualAnswers$ : "";
18968
+ case QuestionAnswerType.SingleChoice:
18969
+ case QuestionAnswerType.MultipleChoice:
18970
+ if (!(answers !== null && answers !== void 0 && answers.length)) return "";
18971
+ return answers.map(function (i) {
18972
+ return t("number_question", {
18973
+ number: i
18974
+ });
18975
+ }).join(",");
18976
+ default:
18977
+ return textualAnswers === null || textualAnswers === void 0 ? void 0 : textualAnswers.join(", ");
18978
+ }
18979
+ };
18960
18980
  var renderAnswer = function renderAnswer(type, content) {
18961
18981
  var _content$split, _content$split$map;
18962
18982
  if (!content) return "";
@@ -19013,12 +19033,12 @@ var TextbookVulnerable = function TextbookVulnerable(_ref) {
19013
19033
  fontSize: "13px",
19014
19034
  fontWeight: 500
19015
19035
  }
19016
- }, renderAnswer(item === null || item === void 0 ? void 0 : item.questionAnswerType, item === null || item === void 0 ? void 0 : item.selectedAnswers)), React__default.createElement("td", {
19036
+ }, typeof item.selectedAnswers === "string" ? renderAnswer(item.questionAnswerType, item.selectedAnswers) : renderTextbookAnswer(item.questionAnswerType, item.selectedAnswers, item.textualAnswers)), React__default.createElement("td", {
19017
19037
  style: {
19018
19038
  textAlign: "center",
19019
19039
  color: styles$4.gray_700
19020
19040
  }
19021
- }, renderAnswer(item === null || item === void 0 ? void 0 : item.questionAnswerType, item === null || item === void 0 ? void 0 : item.correctAnswers)), React__default.createElement("td", {
19041
+ }, typeof item.correctAnswers === "string" ? renderAnswer(item.questionAnswerType, item.correctAnswers) : renderTextbookAnswer(item.questionAnswerType, item.correctAnswers, item.correctTextualAnswers, true)), React__default.createElement("td", {
19022
19042
  style: {
19023
19043
  textAlign: "center",
19024
19044
  color: styles$4.gray_700
@@ -19030,7 +19050,6 @@ var TextbookVulnerable = function TextbookVulnerable(_ref) {
19030
19050
  };
19031
19051
  var renderQuestions = function renderQuestions(questions) {
19032
19052
  return questions.map(function (question) {
19033
- var _question$selectedAns, _question$selectedAns2, _question$selectedAns3, _question$correctAnsw, _question$correctAnsw2, _question$correctAnsw3;
19034
19053
  return React__default.createElement(Grid, {
19035
19054
  container: true,
19036
19055
  flexWrap: "nowrap",
@@ -19057,29 +19076,9 @@ var TextbookVulnerable = function TextbookVulnerable(_ref) {
19057
19076
  className: styles$4["span2"]
19058
19077
  }, t("my_wrong_answer"))), React__default.createElement("div", null, React__default.createElement("span", {
19059
19078
  className: styles$4["overallCorrectRate"]
19060
- }, question.overallCorrectRate.toFixed(2), "%"), (question === null || question === void 0 ? void 0 : question.questionAnswerType) === QuestionAnswerType.ShortAnswer ? React__default.createElement("span", {
19061
- className: styles$4["answer"]
19062
- }, React__default.createElement(MathJaxContainer, {
19063
- content: question === null || question === void 0 ? void 0 : question.selectedAnswers
19064
- }), " ", React__default.createElement(MathJaxContainer, {
19065
- content: question === null || question === void 0 ? void 0 : question.correctAnswers
19066
- })) : QuestionAnswerType.MultipleChoice ? React__default.createElement("span", {
19067
- className: styles$4["answer"]
19068
- }, (_question$selectedAns = question.selectedAnswers) === null || _question$selectedAns === void 0 ? void 0 : (_question$selectedAns2 = _question$selectedAns.split("|")) === null || _question$selectedAns2 === void 0 ? void 0 : (_question$selectedAns3 = _question$selectedAns2.map(function (i) {
19069
- return t("number_question", {
19070
- number: i
19071
- });
19072
- })) === null || _question$selectedAns3 === void 0 ? void 0 : _question$selectedAns3.join(","), " ", "(", t("answer"), " ", (_question$correctAnsw = question.correctAnswers) === null || _question$correctAnsw === void 0 ? void 0 : (_question$correctAnsw2 = _question$correctAnsw.split("|")) === null || _question$correctAnsw2 === void 0 ? void 0 : (_question$correctAnsw3 = _question$correctAnsw2.map(function (i) {
19073
- return t("number_question", {
19074
- number: i
19075
- });
19076
- })) === null || _question$correctAnsw3 === void 0 ? void 0 : _question$correctAnsw3.join(","), ")", " ") : React__default.createElement("span", {
19079
+ }, question.overallCorrectRate.toFixed(2), "%"), React__default.createElement("span", {
19077
19080
  className: styles$4["answer"]
19078
- }, t("number_question", {
19079
- number: question.selectedAnswers
19080
- }), " ", "(", t("answer"), " ", t("number_question", {
19081
- number: question.correctAnswers
19082
- }), ")"))));
19081
+ }, typeof question.selectedAnswers === "string" ? renderAnswer(question.questionAnswerType, question.selectedAnswers) : renderTextbookAnswer(question.questionAnswerType, question.selectedAnswers, question.textualAnswers), " ", t("answer"), " ", typeof question.correctAnswers === "string" ? renderAnswer(question.questionAnswerType, question.correctAnswers) : renderTextbookAnswer(question.questionAnswerType, question.correctAnswers, question.correctTextualAnswers, true)))));
19083
19082
  });
19084
19083
  };
19085
19084
  var handleToggle = function handleToggle() {