@digabi/exam-engine-core 16.4.1-alpha.1 → 16.4.4

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.
Files changed (345) hide show
  1. package/dist/__tests__/tsconfig.tsbuildinfo +1 -1
  2. package/dist/components/results/internal/QuestionAutoScore.js +1 -1
  3. package/dist/components/results/internal/QuestionAutoScore.js.map +1 -1
  4. package/dist/components/results/internal/QuestionManualScore.js +1 -1
  5. package/dist/components/results/internal/QuestionManualScore.js.map +1 -1
  6. package/dist/i18n/index.d.ts +0 -6
  7. package/dist/i18n/index.d.ts.map +1 -1
  8. package/dist/i18n/index.js +1 -0
  9. package/dist/i18n/index.js.map +1 -1
  10. package/dist/main-bundle.js +20 -12
  11. package/dist/main-bundle.js.map +1 -0
  12. package/dist/main.css +1 -1
  13. package/package.json +4 -4
  14. package/dist/components/AttachmentContext.d.ts +0 -14
  15. package/dist/components/AttachmentContext.d.ts.map +0 -1
  16. package/dist/components/AttachmentContext.js +0 -12
  17. package/dist/components/AttachmentContext.js.map +0 -1
  18. package/dist/components/AttachmentLink.d.ts +0 -5
  19. package/dist/components/AttachmentLink.d.ts.map +0 -1
  20. package/dist/components/AttachmentLink.js +0 -28
  21. package/dist/components/AttachmentLink.js.map +0 -1
  22. package/dist/components/AttachmentLinkAnchor.d.ts +0 -7
  23. package/dist/components/AttachmentLinkAnchor.d.ts.map +0 -1
  24. package/dist/components/AttachmentLinkAnchor.js +0 -4
  25. package/dist/components/AttachmentLinkAnchor.js.map +0 -1
  26. package/dist/components/AttachmentLinks.d.ts +0 -5
  27. package/dist/components/AttachmentLinks.d.ts.map +0 -1
  28. package/dist/components/AttachmentLinks.js +0 -62
  29. package/dist/components/AttachmentLinks.js.map +0 -1
  30. package/dist/components/Attachments.d.ts +0 -6
  31. package/dist/components/Attachments.d.ts.map +0 -1
  32. package/dist/components/Attachments.js +0 -55
  33. package/dist/components/Attachments.js.map +0 -1
  34. package/dist/components/AttachmentsAttachment.d.ts +0 -5
  35. package/dist/components/AttachmentsAttachment.d.ts.map +0 -1
  36. package/dist/components/AttachmentsAttachment.js +0 -8
  37. package/dist/components/AttachmentsAttachment.js.map +0 -1
  38. package/dist/components/AttachmentsAttachmentTitle.d.ts +0 -6
  39. package/dist/components/AttachmentsAttachmentTitle.d.ts.map +0 -1
  40. package/dist/components/AttachmentsAttachmentTitle.js +0 -12
  41. package/dist/components/AttachmentsAttachmentTitle.js.map +0 -1
  42. package/dist/components/AttachmentsExternalMaterial.d.ts +0 -9
  43. package/dist/components/AttachmentsExternalMaterial.d.ts.map +0 -1
  44. package/dist/components/AttachmentsExternalMaterial.js +0 -40
  45. package/dist/components/AttachmentsExternalMaterial.js.map +0 -1
  46. package/dist/components/AttachmentsQuestion.d.ts +0 -5
  47. package/dist/components/AttachmentsQuestion.d.ts.map +0 -1
  48. package/dist/components/AttachmentsQuestion.js +0 -17
  49. package/dist/components/AttachmentsQuestion.js.map +0 -1
  50. package/dist/components/AttachmentsQuestionTitle.d.ts +0 -6
  51. package/dist/components/AttachmentsQuestionTitle.d.ts.map +0 -1
  52. package/dist/components/AttachmentsQuestionTitle.js +0 -13
  53. package/dist/components/AttachmentsQuestionTitle.js.map +0 -1
  54. package/dist/components/Audio.d.ts +0 -6
  55. package/dist/components/Audio.d.ts.map +0 -1
  56. package/dist/components/Audio.js +0 -31
  57. package/dist/components/Audio.js.map +0 -1
  58. package/dist/components/AudioGroup.d.ts +0 -6
  59. package/dist/components/AudioGroup.d.ts.map +0 -1
  60. package/dist/components/AudioGroup.js +0 -9
  61. package/dist/components/AudioGroup.js.map +0 -1
  62. package/dist/components/AudioPlaybackError.d.ts +0 -7
  63. package/dist/components/AudioPlaybackError.d.ts.map +0 -1
  64. package/dist/components/AudioPlaybackError.js +0 -13
  65. package/dist/components/AudioPlaybackError.js.map +0 -1
  66. package/dist/components/AudioTest.d.ts +0 -6
  67. package/dist/components/AudioTest.d.ts.map +0 -1
  68. package/dist/components/AudioTest.js +0 -29
  69. package/dist/components/AudioTest.js.map +0 -1
  70. package/dist/components/ChoiceAnswer.d.ts +0 -12
  71. package/dist/components/ChoiceAnswer.d.ts.map +0 -1
  72. package/dist/components/ChoiceAnswer.js +0 -62
  73. package/dist/components/ChoiceAnswer.js.map +0 -1
  74. package/dist/components/CommonExamContext.d.ts +0 -19
  75. package/dist/components/CommonExamContext.d.ts.map +0 -1
  76. package/dist/components/CommonExamContext.js +0 -25
  77. package/dist/components/CommonExamContext.js.map +0 -1
  78. package/dist/components/DropdownAnswer.d.ts +0 -12
  79. package/dist/components/DropdownAnswer.d.ts.map +0 -1
  80. package/dist/components/DropdownAnswer.js +0 -100
  81. package/dist/components/DropdownAnswer.js.map +0 -1
  82. package/dist/components/ErrorIndicator.d.ts +0 -4
  83. package/dist/components/ErrorIndicator.d.ts.map +0 -1
  84. package/dist/components/ErrorIndicator.js +0 -43
  85. package/dist/components/ErrorIndicator.js.map +0 -1
  86. package/dist/components/Exam.d.ts +0 -32
  87. package/dist/components/Exam.d.ts.map +0 -1
  88. package/dist/components/Exam.js +0 -103
  89. package/dist/components/Exam.js.map +0 -1
  90. package/dist/components/ExamAttachment.d.ts +0 -5
  91. package/dist/components/ExamAttachment.d.ts.map +0 -1
  92. package/dist/components/ExamAttachment.js +0 -8
  93. package/dist/components/ExamAttachment.js.map +0 -1
  94. package/dist/components/ExamContext.d.ts +0 -10
  95. package/dist/components/ExamContext.d.ts.map +0 -1
  96. package/dist/components/ExamContext.js +0 -11
  97. package/dist/components/ExamContext.js.map +0 -1
  98. package/dist/components/ExamFooter.d.ts +0 -6
  99. package/dist/components/ExamFooter.d.ts.map +0 -1
  100. package/dist/components/ExamFooter.js +0 -7
  101. package/dist/components/ExamFooter.js.map +0 -1
  102. package/dist/components/ExamInstruction.d.ts +0 -6
  103. package/dist/components/ExamInstruction.d.ts.map +0 -1
  104. package/dist/components/ExamInstruction.js +0 -6
  105. package/dist/components/ExamInstruction.js.map +0 -1
  106. package/dist/components/ExamQuestion.d.ts +0 -5
  107. package/dist/components/ExamQuestion.d.ts.map +0 -1
  108. package/dist/components/ExamQuestion.js +0 -16
  109. package/dist/components/ExamQuestion.js.map +0 -1
  110. package/dist/components/ExamQuestionInstruction.d.ts +0 -6
  111. package/dist/components/ExamQuestionInstruction.d.ts.map +0 -1
  112. package/dist/components/ExamQuestionInstruction.js +0 -6
  113. package/dist/components/ExamQuestionInstruction.js.map +0 -1
  114. package/dist/components/ExamQuestionTitle.d.ts +0 -5
  115. package/dist/components/ExamQuestionTitle.d.ts.map +0 -1
  116. package/dist/components/ExamQuestionTitle.js +0 -24
  117. package/dist/components/ExamQuestionTitle.js.map +0 -1
  118. package/dist/components/ExamSection.d.ts +0 -5
  119. package/dist/components/ExamSection.d.ts.map +0 -1
  120. package/dist/components/ExamSection.js +0 -31
  121. package/dist/components/ExamSection.js.map +0 -1
  122. package/dist/components/ExamSectionTitle.d.ts +0 -6
  123. package/dist/components/ExamSectionTitle.d.ts.map +0 -1
  124. package/dist/components/ExamSectionTitle.js +0 -22
  125. package/dist/components/ExamSectionTitle.js.map +0 -1
  126. package/dist/components/ExternalMaterialList.d.ts +0 -10
  127. package/dist/components/ExternalMaterialList.d.ts.map +0 -1
  128. package/dist/components/ExternalMaterialList.js +0 -33
  129. package/dist/components/ExternalMaterialList.js.map +0 -1
  130. package/dist/components/File.d.ts +0 -6
  131. package/dist/components/File.d.ts.map +0 -1
  132. package/dist/components/File.js +0 -15
  133. package/dist/components/File.js.map +0 -1
  134. package/dist/components/Formula.d.ts +0 -6
  135. package/dist/components/Formula.d.ts.map +0 -1
  136. package/dist/components/Formula.js +0 -13
  137. package/dist/components/Formula.js.map +0 -1
  138. package/dist/components/Hints.d.ts +0 -5
  139. package/dist/components/Hints.d.ts.map +0 -1
  140. package/dist/components/Hints.js +0 -30
  141. package/dist/components/Hints.js.map +0 -1
  142. package/dist/components/Image.d.ts +0 -6
  143. package/dist/components/Image.d.ts.map +0 -1
  144. package/dist/components/Image.js +0 -28
  145. package/dist/components/Image.js.map +0 -1
  146. package/dist/components/ImageOverlay.d.ts +0 -6
  147. package/dist/components/ImageOverlay.d.ts.map +0 -1
  148. package/dist/components/ImageOverlay.js +0 -44
  149. package/dist/components/ImageOverlay.js.map +0 -1
  150. package/dist/components/ProgressBar.d.ts +0 -7
  151. package/dist/components/ProgressBar.d.ts.map +0 -1
  152. package/dist/components/ProgressBar.js +0 -19
  153. package/dist/components/ProgressBar.js.map +0 -1
  154. package/dist/components/QuestionContext.d.ts +0 -14
  155. package/dist/components/QuestionContext.d.ts.map +0 -1
  156. package/dist/components/QuestionContext.js +0 -20
  157. package/dist/components/QuestionContext.js.map +0 -1
  158. package/dist/components/Reference.d.ts +0 -6
  159. package/dist/components/Reference.d.ts.map +0 -1
  160. package/dist/components/Reference.js +0 -71
  161. package/dist/components/Reference.js.map +0 -1
  162. package/dist/components/References.d.ts +0 -6
  163. package/dist/components/References.d.ts.map +0 -1
  164. package/dist/components/References.js +0 -25
  165. package/dist/components/References.js.map +0 -1
  166. package/dist/components/ResponsiveMediaContainer.d.ts +0 -18
  167. package/dist/components/ResponsiveMediaContainer.d.ts.map +0 -1
  168. package/dist/components/ResponsiveMediaContainer.js +0 -21
  169. package/dist/components/ResponsiveMediaContainer.js.map +0 -1
  170. package/dist/components/RestrictedAudioPlayer.d.ts +0 -12
  171. package/dist/components/RestrictedAudioPlayer.d.ts.map +0 -1
  172. package/dist/components/RestrictedAudioPlayer.js +0 -32
  173. package/dist/components/RestrictedAudioPlayer.js.map +0 -1
  174. package/dist/components/RichTextAnswer.d.ts +0 -33
  175. package/dist/components/RichTextAnswer.d.ts.map +0 -1
  176. package/dist/components/RichTextAnswer.js +0 -61
  177. package/dist/components/RichTextAnswer.js.map +0 -1
  178. package/dist/components/SaveIndicator.d.ts +0 -5
  179. package/dist/components/SaveIndicator.d.ts.map +0 -1
  180. package/dist/components/SaveIndicator.js +0 -16
  181. package/dist/components/SaveIndicator.js.map +0 -1
  182. package/dist/components/Score.d.ts +0 -8
  183. package/dist/components/Score.d.ts.map +0 -1
  184. package/dist/components/Score.js +0 -13
  185. package/dist/components/Score.js.map +0 -1
  186. package/dist/components/Section.d.ts +0 -4
  187. package/dist/components/Section.d.ts.map +0 -1
  188. package/dist/components/Section.js +0 -8
  189. package/dist/components/Section.js.map +0 -1
  190. package/dist/components/SectionContext.d.ts +0 -13
  191. package/dist/components/SectionContext.d.ts.map +0 -1
  192. package/dist/components/SectionContext.js +0 -21
  193. package/dist/components/SectionContext.js.map +0 -1
  194. package/dist/components/SectionInstruction.d.ts +0 -6
  195. package/dist/components/SectionInstruction.d.ts.map +0 -1
  196. package/dist/components/SectionInstruction.js +0 -6
  197. package/dist/components/SectionInstruction.js.map +0 -1
  198. package/dist/components/TableOfContents.d.ts +0 -13
  199. package/dist/components/TableOfContents.d.ts.map +0 -1
  200. package/dist/components/TableOfContents.js +0 -66
  201. package/dist/components/TableOfContents.js.map +0 -1
  202. package/dist/components/TextAnswer.d.ts +0 -6
  203. package/dist/components/TextAnswer.d.ts.map +0 -1
  204. package/dist/components/TextAnswer.js +0 -17
  205. package/dist/components/TextAnswer.js.map +0 -1
  206. package/dist/components/TextAnswerInput.d.ts +0 -36
  207. package/dist/components/TextAnswerInput.d.ts.map +0 -1
  208. package/dist/components/TextAnswerInput.js +0 -145
  209. package/dist/components/TextAnswerInput.js.map +0 -1
  210. package/dist/components/Video.d.ts +0 -6
  211. package/dist/components/Video.d.ts.map +0 -1
  212. package/dist/components/Video.js +0 -15
  213. package/dist/components/Video.js.map +0 -1
  214. package/dist/components/exam/TableOfContents.d.ts +0 -13
  215. package/dist/components/exam/TableOfContents.d.ts.map +0 -1
  216. package/dist/components/exam/TableOfContents.js +0 -66
  217. package/dist/components/exam/TableOfContents.js.map +0 -1
  218. package/dist/components/grading-instruction/AnswerGradingInstruction.d.ts +0 -5
  219. package/dist/components/grading-instruction/AnswerGradingInstruction.d.ts.map +0 -1
  220. package/dist/components/grading-instruction/AnswerGradingInstruction.js +0 -6
  221. package/dist/components/grading-instruction/AnswerGradingInstruction.js.map +0 -1
  222. package/dist/components/grading-instruction/Audio.d.ts +0 -5
  223. package/dist/components/grading-instruction/Audio.d.ts.map +0 -1
  224. package/dist/components/grading-instruction/Audio.js +0 -6
  225. package/dist/components/grading-instruction/Audio.js.map +0 -1
  226. package/dist/components/grading-instruction/AudioTitle.d.ts +0 -5
  227. package/dist/components/grading-instruction/AudioTitle.d.ts.map +0 -1
  228. package/dist/components/grading-instruction/AudioTitle.js +0 -10
  229. package/dist/components/grading-instruction/AudioTitle.js.map +0 -1
  230. package/dist/components/grading-instruction/AutogradedAnswer.d.ts +0 -5
  231. package/dist/components/grading-instruction/AutogradedAnswer.d.ts.map +0 -1
  232. package/dist/components/grading-instruction/AutogradedAnswer.js +0 -31
  233. package/dist/components/grading-instruction/AutogradedAnswer.js.map +0 -1
  234. package/dist/components/grading-instruction/AutogradedAnswerOption.d.ts +0 -5
  235. package/dist/components/grading-instruction/AutogradedAnswerOption.d.ts.map +0 -1
  236. package/dist/components/grading-instruction/AutogradedAnswerOption.js +0 -14
  237. package/dist/components/grading-instruction/AutogradedAnswerOption.js.map +0 -1
  238. package/dist/components/grading-instruction/ExamGradingInstruction.d.ts +0 -5
  239. package/dist/components/grading-instruction/ExamGradingInstruction.d.ts.map +0 -1
  240. package/dist/components/grading-instruction/ExamGradingInstruction.js +0 -6
  241. package/dist/components/grading-instruction/ExamGradingInstruction.js.map +0 -1
  242. package/dist/components/grading-instruction/GradingInstruction.d.ts +0 -5
  243. package/dist/components/grading-instruction/GradingInstruction.d.ts.map +0 -1
  244. package/dist/components/grading-instruction/GradingInstruction.js +0 -85
  245. package/dist/components/grading-instruction/GradingInstruction.js.map +0 -1
  246. package/dist/components/grading-instruction/Question.d.ts +0 -5
  247. package/dist/components/grading-instruction/Question.d.ts.map +0 -1
  248. package/dist/components/grading-instruction/Question.js +0 -12
  249. package/dist/components/grading-instruction/Question.js.map +0 -1
  250. package/dist/components/grading-instruction/QuestionTitle.d.ts +0 -5
  251. package/dist/components/grading-instruction/QuestionTitle.d.ts.map +0 -1
  252. package/dist/components/grading-instruction/QuestionTitle.js +0 -19
  253. package/dist/components/grading-instruction/QuestionTitle.js.map +0 -1
  254. package/dist/components/grading-instruction/Section.d.ts +0 -5
  255. package/dist/components/grading-instruction/Section.d.ts.map +0 -1
  256. package/dist/components/grading-instruction/Section.js +0 -10
  257. package/dist/components/grading-instruction/Section.js.map +0 -1
  258. package/dist/components/grading-instruction/SectionTitle.d.ts +0 -5
  259. package/dist/components/grading-instruction/SectionTitle.d.ts.map +0 -1
  260. package/dist/components/grading-instruction/SectionTitle.js +0 -16
  261. package/dist/components/grading-instruction/SectionTitle.js.map +0 -1
  262. package/dist/components/grading-instructions/Audio.d.ts +0 -5
  263. package/dist/components/grading-instructions/Audio.d.ts.map +0 -1
  264. package/dist/components/grading-instructions/Audio.js +0 -8
  265. package/dist/components/grading-instructions/Audio.js.map +0 -1
  266. package/dist/components/grading-instructions/AudioTitle.d.ts +0 -5
  267. package/dist/components/grading-instructions/AudioTitle.d.ts.map +0 -1
  268. package/dist/components/grading-instructions/AudioTitle.js +0 -11
  269. package/dist/components/grading-instructions/AudioTitle.js.map +0 -1
  270. package/dist/components/results/AnnotationList.d.ts +0 -5
  271. package/dist/components/results/AnnotationList.d.ts.map +0 -1
  272. package/dist/components/results/AnnotationList.js +0 -43
  273. package/dist/components/results/AnnotationList.js.map +0 -1
  274. package/dist/components/results/GradingStructure.d.ts +0 -5
  275. package/dist/components/results/GradingStructure.d.ts.map +0 -1
  276. package/dist/components/results/GradingStructure.js +0 -21
  277. package/dist/components/results/GradingStructure.js.map +0 -1
  278. package/dist/components/results/Hvp.d.ts +0 -15
  279. package/dist/components/results/Hvp.d.ts.map +0 -1
  280. package/dist/components/results/Hvp.js +0 -73
  281. package/dist/components/results/Hvp.js.map +0 -1
  282. package/dist/components/results/HvpTextAnswer.d.ts +0 -6
  283. package/dist/components/results/HvpTextAnswer.d.ts.map +0 -1
  284. package/dist/components/results/HvpTextAnswer.js +0 -51
  285. package/dist/components/results/HvpTextAnswer.js.map +0 -1
  286. package/dist/components/results/ResultsChoiceAnswer.d.ts +0 -6
  287. package/dist/components/results/ResultsChoiceAnswer.d.ts.map +0 -1
  288. package/dist/components/results/ResultsChoiceAnswer.js +0 -57
  289. package/dist/components/results/ResultsChoiceAnswer.js.map +0 -1
  290. package/dist/components/results/ResultsContext.d.ts +0 -18
  291. package/dist/components/results/ResultsContext.d.ts.map +0 -1
  292. package/dist/components/results/ResultsContext.js +0 -68
  293. package/dist/components/results/ResultsContext.js.map +0 -1
  294. package/dist/components/results/ResultsDropdownAnswer.d.ts +0 -6
  295. package/dist/components/results/ResultsDropdownAnswer.d.ts.map +0 -1
  296. package/dist/components/results/ResultsDropdownAnswer.js +0 -43
  297. package/dist/components/results/ResultsDropdownAnswer.js.map +0 -1
  298. package/dist/components/results/ResultsExamQuestion.d.ts +0 -5
  299. package/dist/components/results/ResultsExamQuestion.d.ts.map +0 -1
  300. package/dist/components/results/ResultsExamQuestion.js +0 -23
  301. package/dist/components/results/ResultsExamQuestion.js.map +0 -1
  302. package/dist/components/results/ResultsExamQuestionAutoScore.d.ts +0 -10
  303. package/dist/components/results/ResultsExamQuestionAutoScore.d.ts.map +0 -1
  304. package/dist/components/results/ResultsExamQuestionAutoScore.js +0 -17
  305. package/dist/components/results/ResultsExamQuestionAutoScore.js.map +0 -1
  306. package/dist/components/results/ResultsExamQuestionManualScore.d.ts +0 -12
  307. package/dist/components/results/ResultsExamQuestionManualScore.d.ts.map +0 -1
  308. package/dist/components/results/ResultsExamQuestionManualScore.js +0 -61
  309. package/dist/components/results/ResultsExamQuestionManualScore.js.map +0 -1
  310. package/dist/components/results/ResultsExamQuestionScoresContainer.d.ts +0 -10
  311. package/dist/components/results/ResultsExamQuestionScoresContainer.d.ts.map +0 -1
  312. package/dist/components/results/ResultsExamQuestionScoresContainer.js +0 -12
  313. package/dist/components/results/ResultsExamQuestionScoresContainer.js.map +0 -1
  314. package/dist/components/results/ResultsExamQuestionTitle.d.ts +0 -6
  315. package/dist/components/results/ResultsExamQuestionTitle.d.ts.map +0 -1
  316. package/dist/components/results/ResultsExamQuestionTitle.js +0 -21
  317. package/dist/components/results/ResultsExamQuestionTitle.js.map +0 -1
  318. package/dist/components/results/ResultsExamSection.d.ts +0 -5
  319. package/dist/components/results/ResultsExamSection.d.ts.map +0 -1
  320. package/dist/components/results/ResultsExamSection.js +0 -18
  321. package/dist/components/results/ResultsExamSection.js.map +0 -1
  322. package/dist/components/results/ResultsMultiLineAnswer.d.ts +0 -8
  323. package/dist/components/results/ResultsMultiLineAnswer.d.ts.map +0 -1
  324. package/dist/components/results/ResultsMultiLineAnswer.js +0 -19
  325. package/dist/components/results/ResultsMultiLineAnswer.js.map +0 -1
  326. package/dist/components/results/ResultsScoredTextAnswer.d.ts +0 -6
  327. package/dist/components/results/ResultsScoredTextAnswer.d.ts.map +0 -1
  328. package/dist/components/results/ResultsScoredTextAnswer.js +0 -22
  329. package/dist/components/results/ResultsScoredTextAnswer.js.map +0 -1
  330. package/dist/components/results/ResultsSingleLineAnswer.d.ts +0 -12
  331. package/dist/components/results/ResultsSingleLineAnswer.d.ts.map +0 -1
  332. package/dist/components/results/ResultsSingleLineAnswer.js +0 -23
  333. package/dist/components/results/ResultsSingleLineAnswer.js.map +0 -1
  334. package/dist/components/results/ResultsTextAnswer.d.ts +0 -6
  335. package/dist/components/results/ResultsTextAnswer.d.ts.map +0 -1
  336. package/dist/components/results/ResultsTextAnswer.js +0 -50
  337. package/dist/components/results/ResultsTextAnswer.js.map +0 -1
  338. package/dist/components/results/helpers.d.ts +0 -9
  339. package/dist/components/results/helpers.d.ts.map +0 -1
  340. package/dist/components/results/helpers.js +0 -11
  341. package/dist/components/results/helpers.js.map +0 -1
  342. package/dist/components/withContext.d.ts +0 -3
  343. package/dist/components/withContext.d.ts.map +0 -1
  344. package/dist/components/withContext.js +0 -12
  345. package/dist/components/withContext.js.map +0 -1
@@ -1,30 +0,0 @@
1
- import classNames from 'classnames';
2
- import React from 'react';
3
- import { useSelector } from 'react-redux';
4
- import { findChildElement, getNumericAttribute, queryAll } from '../dom-utils';
5
- import { shortDisplayNumber } from '../shortDisplayNumber';
6
- const Hints = ({ element, renderChildNodes }) => {
7
- const focusedQuestionId = useSelector((state) => state.answers.focusedQuestionId);
8
- const answersWithHints = queryAll(element, ['text-answer', 'scored-text-answer']).filter((answer) => findChildElement(answer, 'hint') != null);
9
- return (React.createElement("div", { className: "e-columns" },
10
- React.createElement("div", { className: "e-column e-column--8" }, renderChildNodes(element)),
11
- React.createElement("div", { className: "e-hints e-column e-column--4", "aria-hidden": "true" }, answersWithHints.map((answer, i) => (React.createElement(Hint, Object.assign({}, { answer, focusedQuestionId, renderChildNodes }, { key: i })))))));
12
- };
13
- function Hint({ answer, focusedQuestionId, renderChildNodes, }) {
14
- const questionId = getNumericAttribute(answer, 'question-id');
15
- const displayNumber = answer.getAttribute('display-number');
16
- const hint = findChildElement(answer, 'hint');
17
- return (React.createElement("p", { className: classNames('e-hints__hint', {
18
- 'e-hints__hint--focused': focusedQuestionId === questionId,
19
- }), onClick: () => {
20
- const question = document.querySelector(`.text-answer[data-question-id="${questionId}"]`);
21
- if (question) {
22
- question.focus();
23
- }
24
- }, "data-question-id": questionId },
25
- shortDisplayNumber(displayNumber),
26
- " ",
27
- renderChildNodes(hint)));
28
- }
29
- export default Hints;
30
- //# sourceMappingURL=Hints.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Hints.js","sourceRoot":"","sources":["../../src/components/Hints.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAEzC,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AAC9E,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AAI1D,MAAM,KAAK,GAAgD,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,EAAE;IAC3F,MAAM,iBAAiB,GAAG,WAAW,CAAC,CAAC,KAAe,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAC3F,MAAM,gBAAgB,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC,aAAa,EAAE,oBAAoB,CAAC,CAAC,CAAC,MAAM,CACtF,CAAC,MAAM,EAAE,EAAE,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,IAAI,CACrD,CAAA;IAED,OAAO,CACL,6BAAK,SAAS,EAAC,WAAW;QACxB,6BAAK,SAAS,EAAC,sBAAsB,IAAE,gBAAgB,CAAC,OAAO,CAAC,CAAO;QAIvE,6BAAK,SAAS,EAAC,8BAA8B,iBAAa,MAAM,IAC7D,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,CACnC,oBAAC,IAAI,oBAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,IAAE,GAAG,EAAE,CAAC,IAAI,CACtE,CAAC,CACE,CACF,CACP,CAAA;AACH,CAAC,CAAA;AAED,SAAS,IAAI,CAAC,EACZ,MAAM,EACN,iBAAiB,EACjB,gBAAgB,GAKjB;IACC,MAAM,UAAU,GAAG,mBAAmB,CAAC,MAAM,EAAE,aAAa,CAAE,CAAA;IAC9D,MAAM,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC,gBAAgB,CAAE,CAAA;IAC5D,MAAM,IAAI,GAAG,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAE,CAAA;IAE9C,OAAO,CACL,2BACE,SAAS,EAAE,UAAU,CAAC,eAAe,EAAE;YACrC,wBAAwB,EAAE,iBAAiB,KAAK,UAAU;SAC3D,CAAC,EACF,OAAO,EAAE,GAAG,EAAE;YACZ,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAc,kCAAkC,UAAU,IAAI,CAAC,CAAA;YACtG,IAAI,QAAQ,EAAE;gBACZ,QAAQ,CAAC,KAAK,EAAE,CAAA;aACjB;QACH,CAAC,sBACiB,UAAU;QAE3B,kBAAkB,CAAC,aAAa,CAAC;;QAAG,gBAAgB,CAAC,IAAI,CAAC,CACzD,CACL,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAA"}
@@ -1,6 +0,0 @@
1
- import React from 'react';
2
- import { ExamComponentProps } from '../createRenderChildNodes';
3
- declare function Image({ element, className, renderChildNodes }: ExamComponentProps): JSX.Element;
4
- declare const _default: React.MemoExoticComponent<typeof Image>;
5
- export default _default;
6
- //# sourceMappingURL=Image.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Image.d.ts","sourceRoot":"","sources":["../../src/components/Image.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAO9D,iBAAS,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAsC1E;;AAED,wBAAgC"}
@@ -1,28 +0,0 @@
1
- import React, { useContext } from 'react';
2
- import { getNumericAttribute, queryAncestors } from '../dom-utils';
3
- import { useExamTranslation } from '../i18n';
4
- import { imageCaptionId } from '../ids';
5
- import { CommonExamContext } from './CommonExamContext';
6
- import ResponsiveMediaContainer from './ResponsiveMediaContainer';
7
- function Image({ element, className, renderChildNodes }) {
8
- const { t } = useExamTranslation();
9
- const src = element.getAttribute('src');
10
- const width = getNumericAttribute(element, 'width');
11
- const height = getNumericAttribute(element, 'height');
12
- const caption = element.hasChildNodes() ? renderChildNodes(element) : undefined;
13
- const imgUrl = useContext(CommonExamContext).resolveAttachment(src);
14
- const captionId = caption != null ? imageCaptionId(element) : undefined;
15
- const Img = () => React.createElement("img", { className: "e-image", src: imgUrl, "aria-labelledby": captionId });
16
- return (React.createElement(React.Fragment, null,
17
- React.createElement(ResponsiveMediaContainer, Object.assign({}, {
18
- className,
19
- width,
20
- height,
21
- caption,
22
- captionId,
23
- bordered: caption != null || queryAncestors(element, 'choice-answer') != null,
24
- }), queryAncestors(element, ['choice-answer', 'hint']) != null ? (React.createElement(Img, null)) : (React.createElement("a", { title: t.raw('zoom-in'), href: imgUrl, target: "original-picture", className: "e-zoomable", "aria-hidden": caption == null },
25
- React.createElement(Img, null))))));
26
- }
27
- export default React.memo(Image);
28
- //# sourceMappingURL=Image.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Image.js","sourceRoot":"","sources":["../../src/components/Image.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAA;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AACvD,OAAO,wBAAwB,MAAM,4BAA4B,CAAA;AAEjE,SAAS,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAsB;IACzE,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,CAAC,KAAK,CAAE,CAAA;IACxC,MAAM,KAAK,GAAG,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAE,CAAA;IACpD,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAE,CAAA;IACtD,MAAM,OAAO,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAC/E,MAAM,MAAM,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAA;IACnE,MAAM,SAAS,GAAG,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IACvE,MAAM,GAAG,GAAG,GAAG,EAAE,CAAC,6BAAK,SAAS,EAAC,SAAS,EAAC,GAAG,EAAE,MAAM,qBAAmB,SAAS,GAAI,CAAA;IAEtF,OAAO,CACL;QACE,oBAAC,wBAAwB,oBACnB;YACF,SAAS;YACT,KAAK;YACL,MAAM;YACN,OAAO;YACP,SAAS;YACT,QAAQ,EAAE,OAAO,IAAI,IAAI,IAAI,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,IAAI,IAAI;SAC9E,GAEA,cAAc,CAAC,OAAO,EAAE,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAC5D,oBAAC,GAAG,OAAG,CACR,CAAC,CAAC,CAAC,CACF,2BACE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,EACvB,IAAI,EAAE,MAAM,EACZ,MAAM,EAAC,kBAAkB,EACzB,SAAS,EAAC,YAAY,iBACT,OAAO,IAAI,IAAI;YAE5B,oBAAC,GAAG,OAAG,CACL,CACL,CACwB,CAC1B,CACJ,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA"}
@@ -1,6 +0,0 @@
1
- import React from 'react';
2
- import { ExamComponentProps } from '../createRenderChildNodes';
3
- declare function ImageOverlay({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
4
- declare const _default: React.MemoExoticComponent<typeof ImageOverlay>;
5
- export default _default;
6
- //# sourceMappingURL=ImageOverlay.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ImageOverlay.d.ts","sourceRoot":"","sources":["../../src/components/ImageOverlay.tsx"],"names":[],"mappings":"AAIA,OAAO,KAA+B,MAAM,OAAO,CAAA;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAK9D,iBAAS,YAAY,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAsCtE;;AAsDD,wBAAuC"}
@@ -1,44 +0,0 @@
1
- import { faEye, faEyeSlash } from '@fortawesome/free-solid-svg-icons';
2
- import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
3
- import classNames from 'classnames';
4
- import * as _ from 'lodash-es';
5
- import React, { useContext, useState } from 'react';
6
- import { getNumericAttribute, mapChildElements } from '../dom-utils';
7
- import { CommonExamContext } from './CommonExamContext';
8
- import ResponsiveMediaContainer from './ResponsiveMediaContainer';
9
- function ImageOverlay({ element, renderChildNodes }) {
10
- const [opacities, setOpacities] = useState(() => _.times(element.children.length, (i) => (i === 0 ? 1 : 0)));
11
- const mkSetOpacity = (index) => (opacity) => {
12
- const updatedOpacities = [...opacities];
13
- updatedOpacities[index] = opacity;
14
- setOpacities(updatedOpacities);
15
- };
16
- return (React.createElement("div", { className: "e-image-overlay e-mrg-b-1" },
17
- React.createElement("div", { className: "e-columns e-columns--center-h" },
18
- React.createElement("div", null, mapChildElements(element, (child, index) => (React.createElement(Slider, { key: index, opacity: opacities[index], element: child, setOpacity: mkSetOpacity(index), renderChildNodes: renderChildNodes }))))),
19
- React.createElement("div", null,
20
- React.createElement("div", { className: "e-image-overlay__images-wrapper" }, mapChildElements(element, (child, index) => (React.createElement(ImageOverlayImage, { key: index, element: child, renderChildNodes: renderChildNodes, opacity: opacities[index], absolute: index > 0 })))))));
21
- }
22
- function Slider({ opacity, setOpacity, element, renderChildNodes }) {
23
- return (React.createElement("div", { className: "e-columns e-columns--center-v e-mrg-b-1" },
24
- React.createElement("div", { className: "e-column e-text-right e-mrg-r-1" }, renderChildNodes(element)),
25
- React.createElement(FontAwesomeIcon, { icon: faEyeSlash, className: "e-mrg-r-1 e-pointer", onClick: () => setOpacity(0) }),
26
- React.createElement("input", { type: "range", min: 0, max: 1, step: 0.01, value: opacity, onChange: (e) => setOpacity(Number(e.target.value)) }),
27
- React.createElement(FontAwesomeIcon, { icon: faEye, className: "e-mrg-l-1 e-pointer", onClick: () => setOpacity(1) })));
28
- }
29
- function ImageOverlayImage({ element, absolute, opacity }) {
30
- const src = element.getAttribute('src');
31
- const width = getNumericAttribute(element, 'width');
32
- const height = getNumericAttribute(element, 'height');
33
- const imgUrl = useContext(CommonExamContext).resolveAttachment(src);
34
- return (React.createElement("div", { className: classNames('e-columns e-columns--center-h', { 'e-image-overlay__image-absolute': absolute }), style: {
35
- opacity: opacity,
36
- } },
37
- React.createElement(ResponsiveMediaContainer, Object.assign({}, {
38
- width,
39
- height,
40
- }),
41
- React.createElement("img", { className: "e-image", src: imgUrl }))));
42
- }
43
- export default React.memo(ImageOverlay);
44
- //# sourceMappingURL=ImageOverlay.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ImageOverlay.js","sourceRoot":"","sources":["../../src/components/ImageOverlay.tsx"],"names":[],"mappings":"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"}
@@ -1,7 +0,0 @@
1
- import React from 'react';
2
- declare const ProgressBar: React.FunctionComponent<{
3
- duration: number;
4
- className?: string;
5
- }>;
6
- export default ProgressBar;
7
- //# sourceMappingURL=ProgressBar.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"AACA,OAAO,KAAsC,MAAM,OAAO,CAAA;AAE1D,QAAA,MAAM,WAAW,EAAE,KAAK,CAAC,iBAAiB,CAAC;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAqBlF,CAAA;AAED,eAAe,WAAW,CAAA"}
@@ -1,19 +0,0 @@
1
- import classNames from 'classnames';
2
- import React, { useEffect, useRef, useState } from 'react';
3
- const ProgressBar = ({ duration, className }) => {
4
- const progressBarRef = useRef(null);
5
- const [animating, setAnimating] = useState(false);
6
- useEffect(() => {
7
- // when this code runs as bundled inside koe for some reason or another
8
- // there is only a single render and the element in dom immeadiately has
9
- // "--animating" class which breaks the css transformation (the progress
10
- // bar is completely filled from start). By reading clientTop we force a
11
- // synchronous layout/reflow in a browser
12
- progressBarRef.current.clientTop;
13
- setAnimating(true);
14
- }, []);
15
- return (React.createElement("div", { className: classNames('e-progress-bar', className), ref: progressBarRef },
16
- React.createElement("div", { className: classNames('e-progress-bar__fill', { 'e-progress-bar__fill--animating': animating }), style: { transitionDuration: `${duration}s` } })));
17
- };
18
- export default ProgressBar;
19
- //# sourceMappingURL=ProgressBar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../src/components/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE1D,MAAM,WAAW,GAAsE,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,EAAE;IACjH,MAAM,cAAc,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IACnD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACjD,SAAS,CAAC,GAAG,EAAE;QACb,uEAAuE;QACvE,wEAAwE;QACxE,wEAAwE;QACxE,wEAAwE;QACxE,yCAAyC;QACzC,cAAc,CAAC,OAAQ,CAAC,SAAS,CAAA;QACjC,YAAY,CAAC,IAAI,CAAC,CAAA;IACpB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL,6BAAK,SAAS,EAAE,UAAU,CAAC,gBAAgB,EAAE,SAAS,CAAC,EAAE,GAAG,EAAE,cAAc;QAC1E,6BACE,SAAS,EAAE,UAAU,CAAC,sBAAsB,EAAE,EAAE,iCAAiC,EAAE,SAAS,EAAE,CAAC,EAC/F,KAAK,EAAE,EAAE,kBAAkB,EAAE,GAAG,QAAQ,GAAG,EAAE,GAC7C,CACE,CACP,CAAA;AACH,CAAC,CAAA;AAED,eAAe,WAAW,CAAA"}
@@ -1,14 +0,0 @@
1
- import React from 'react';
2
- import { ExamComponentProps } from '../createRenderChildNodes';
3
- export interface QuestionContext {
4
- answers: Element[];
5
- displayNumber: string;
6
- hasExternalMaterial: boolean;
7
- maxAnswers?: number;
8
- maxScore: number;
9
- level: number;
10
- childQuestions: Element[];
11
- }
12
- export declare const QuestionContext: React.Context<QuestionContext>;
13
- export declare const withQuestionContext: (Component: React.ComponentType<ExamComponentProps>) => React.ComponentType<ExamComponentProps>;
14
- //# sourceMappingURL=QuestionContext.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"QuestionContext.d.ts","sourceRoot":"","sources":["../../src/components/QuestionContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAE9D,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,EAAE,CAAA;IAClB,aAAa,EAAE,MAAM,CAAA;IACrB,mBAAmB,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,EAAE,MAAM,CAAA;IACb,cAAc,EAAE,OAAO,EAAE,CAAA;CAC1B;AAED,eAAO,MAAM,eAAe,gCAA8D,CAAA;AAE1F,eAAO,MAAM,mBAAmB,iGAe9B,CAAA"}
@@ -1,20 +0,0 @@
1
- import React from 'react';
2
- import { findChildElement, getNumericAttribute, parentElements, queryAll } from '../dom-utils';
3
- import { withContext } from './withContext';
4
- export const QuestionContext = React.createContext({});
5
- export const withQuestionContext = withContext(QuestionContext, ({ element }) => {
6
- const childQuestions = queryAll(element, 'question', false);
7
- const answers = childQuestions.length
8
- ? []
9
- : queryAll(element, ['text-answer', 'scored-text-answer', 'dropdown-answer', 'choice-answer'], false);
10
- return {
11
- answers,
12
- displayNumber: element.getAttribute('display-number'),
13
- hasExternalMaterial: findChildElement(element, 'external-material') != null,
14
- maxAnswers: getNumericAttribute(element, 'max-answers'),
15
- maxScore: getNumericAttribute(element, 'max-score'),
16
- level: parentElements(element, 'question').length,
17
- childQuestions,
18
- };
19
- });
20
- //# sourceMappingURL=QuestionContext.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"QuestionContext.js","sourceRoot":"","sources":["../../src/components/QuestionContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AAC9F,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAa3C,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC,aAAa,CAAkB,EAAqB,CAAC,CAAA;AAE1F,MAAM,CAAC,MAAM,mBAAmB,GAAG,WAAW,CAAsC,eAAe,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IACnH,MAAM,cAAc,GAAG,QAAQ,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,CAAA;IAC3D,MAAM,OAAO,GAAG,cAAc,CAAC,MAAM;QACnC,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,aAAa,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,eAAe,CAAC,EAAE,KAAK,CAAC,CAAA;IAEvG,OAAO;QACL,OAAO;QACP,aAAa,EAAE,OAAO,CAAC,YAAY,CAAC,gBAAgB,CAAE;QACtD,mBAAmB,EAAE,gBAAgB,CAAC,OAAO,EAAE,mBAAmB,CAAC,IAAI,IAAI;QAC3E,UAAU,EAAE,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC;QACvD,QAAQ,EAAE,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAE;QACpD,KAAK,EAAE,cAAc,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC,MAAM;QACjD,cAAc;KACf,CAAA;AACH,CAAC,CAAC,CAAA"}
@@ -1,6 +0,0 @@
1
- import React from 'react';
2
- import { ExamComponentProps } from '../createRenderChildNodes';
3
- declare function Reference({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
4
- declare const _default: React.MemoExoticComponent<typeof Reference>;
5
- export default _default;
6
- //# sourceMappingURL=Reference.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Reference.d.ts","sourceRoot":"","sources":["../../src/components/Reference.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAO9D,iBAAS,SAAS,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAqDnE;;AA+BD,wBAAoC"}
@@ -1,71 +0,0 @@
1
- import React, { useContext } from 'react';
2
- import { findChildElement, getBooleanAttribute, NBSP } from '../dom-utils';
3
- import { useExamTranslation } from '../i18n';
4
- import { CommonExamContext } from './CommonExamContext';
5
- import RenderChildNodes from './RenderChildNodes';
6
- import classNames from 'classnames';
7
- function Reference({ element, renderChildNodes }) {
8
- const { t } = useExamTranslation();
9
- function renderWith(localName, Component) {
10
- const childElement = findChildElement(element, localName);
11
- if (childElement) {
12
- const key = childElement.localName;
13
- const content = React.createElement(Component, Object.assign({}, { element: childElement, renderChildNodes, key }));
14
- if (content) {
15
- const isHidden = getBooleanAttribute(childElement, 'hidden');
16
- return isHidden ? React.createElement("del", { key: key }, content) : content;
17
- }
18
- }
19
- }
20
- function renderWithPrefix(localName, translationKey, Component) {
21
- const childElement = findChildElement(element, localName);
22
- return (childElement && (React.createElement(React.Fragment, { key: childElement.localName },
23
- t(translationKey),
24
- ' ',
25
- React.createElement(Component, Object.assign({}, { element: childElement, renderChildNodes, key: childElement.localName })))));
26
- }
27
- return (React.createElement("span", { className: classNames('e-break-word', { 'e-line-through': getBooleanAttribute(element, 'hidden') }) },
28
- t('references.source'),
29
- NBSP,
30
- intersperse('. ', [
31
- renderWith('author', RenderChildNodes),
32
- renderWith('title', Italic),
33
- renderWith('publisher', RenderChildNodes),
34
- renderWith('publication', RenderChildNodes),
35
- renderWith('howpublished', RenderChildNodes),
36
- renderWith('url', Link),
37
- renderWithPrefix('publication-date', 'references.date', AsDate),
38
- renderWithPrefix('reference-date', 'references.reference-date', AsDate),
39
- renderWithPrefix('translator', 'references.translator', RenderChildNodes),
40
- renderWithPrefix('modified-by', 'references.modified-by', RenderChildNodes),
41
- renderWith('note', RenderChildNodes),
42
- ])));
43
- }
44
- function Italic({ element, renderChildNodes }) {
45
- return React.createElement("em", null, renderChildNodes(element));
46
- }
47
- function Link({ element, renderChildNodes }) {
48
- return React.createElement("a", { href: element.textContent }, renderChildNodes(element));
49
- }
50
- function AsDate({ element }) {
51
- const textContent = element.textContent;
52
- if (/^[0-9]{4}$/.test(textContent)) {
53
- return React.createElement(React.Fragment, null, textContent);
54
- }
55
- else {
56
- const date = new Date(textContent);
57
- const { dateTimeFormatter } = useContext(CommonExamContext);
58
- return React.createElement(React.Fragment, null, dateTimeFormatter.format(date));
59
- }
60
- }
61
- function intersperse(separator, contents) {
62
- return contents.filter(Boolean).reduce((acc, curr, i) => {
63
- acc.push(curr);
64
- if (i !== contents.length - 1) {
65
- acc.push(separator);
66
- }
67
- return acc;
68
- }, []);
69
- }
70
- export default React.memo(Reference);
71
- //# sourceMappingURL=Reference.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Reference.js","sourceRoot":"","sources":["../../src/components/Reference.tsx"],"names":[],"mappings":"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"}
@@ -1,6 +0,0 @@
1
- import React from 'react';
2
- import { ExamComponentProps } from '../createRenderChildNodes';
3
- declare function References(_props: ExamComponentProps): JSX.Element | null;
4
- declare const _default: React.MemoExoticComponent<typeof References>;
5
- export default _default;
6
- //# sourceMappingURL=References.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"References.d.ts","sourceRoot":"","sources":["../../src/components/References.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAA0B,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAUtF,iBAAS,UAAU,CAAC,MAAM,EAAE,kBAAkB,sBAuB7C;;AAED,wBAAqC"}
@@ -1,25 +0,0 @@
1
- import React, { useContext } from 'react';
2
- import { createRenderChildNodes } from '../createRenderChildNodes';
3
- import { queryAll, queryAncestors } from '../dom-utils';
4
- import { formatQuestionDisplayNumber } from '../formatting';
5
- import { useExamTranslation } from '../i18n';
6
- import { referencesTitleId } from '../ids';
7
- import { CommonExamContext } from './CommonExamContext';
8
- import Reference from './Reference';
9
- import Section from './Section';
10
- const renderChildNodes = createRenderChildNodes({});
11
- function References(_props) {
12
- const { root } = useContext(CommonExamContext);
13
- const { t } = useExamTranslation();
14
- const internalReferences = queryAll(root, 'reference').filter((reference) => queryAncestors(reference, 'external-material') == null);
15
- return internalReferences.length > 0 ? (React.createElement(Section, { "aria-labelledby": referencesTitleId },
16
- React.createElement("h2", { id: referencesTitleId }, t('references.heading')),
17
- React.createElement("ol", { className: "e-list-data e-color-darkgrey e-light" }, internalReferences.map((reference, i) => {
18
- const question = queryAncestors(reference, 'question');
19
- const displayNumber = question.getAttribute('display-number');
20
- return (React.createElement("li", { "data-list-number": formatQuestionDisplayNumber(displayNumber), key: `${displayNumber}${i}` },
21
- React.createElement(Reference, { element: reference, renderChildNodes: renderChildNodes })));
22
- })))) : null;
23
- }
24
- export default React.memo(References);
25
- //# sourceMappingURL=References.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"References.js","sourceRoot":"","sources":["../../src/components/References.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,sBAAsB,EAAsB,MAAM,2BAA2B,CAAA;AACtF,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AACvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,eAAe,CAAA;AAC3D,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,QAAQ,CAAA;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AACvD,OAAO,SAAS,MAAM,aAAa,CAAA;AACnC,OAAO,OAAO,MAAM,WAAW,CAAA;AAE/B,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,EAAE,CAAC,CAAA;AACnD,SAAS,UAAU,CAAC,MAA0B;IAC5C,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAC9C,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,kBAAkB,GAAG,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,MAAM,CAC3D,CAAC,SAAS,EAAE,EAAE,CAAC,cAAc,CAAC,SAAS,EAAE,mBAAmB,CAAC,IAAI,IAAI,CACtE,CAAA;IAED,OAAO,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CACrC,oBAAC,OAAO,uBAAkB,iBAAiB;QACzC,4BAAI,EAAE,EAAE,iBAAiB,IAAG,CAAC,CAAC,oBAAoB,CAAC,CAAM;QACzD,4BAAI,SAAS,EAAC,sCAAsC,IACjD,kBAAkB,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACvC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,EAAE,UAAU,CAAE,CAAA;YACvD,MAAM,aAAa,GAAG,QAAQ,CAAC,YAAY,CAAC,gBAAgB,CAAE,CAAA;YAC9D,OAAO,CACL,gDAAsB,2BAA2B,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,GAAG,aAAa,GAAG,CAAC,EAAE;gBAC3F,oBAAC,SAAS,IAAC,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,gBAAgB,GAAI,CAClE,CACN,CAAA;QACH,CAAC,CAAC,CACC,CACG,CACX,CAAC,CAAC,CAAC,IAAI,CAAA;AACV,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA"}
@@ -1,18 +0,0 @@
1
- import React from 'react';
2
- interface ResponsiveMediaContainerProps {
3
- bordered?: boolean;
4
- className?: string;
5
- children: React.ReactElement<any>;
6
- height: number;
7
- width: number;
8
- caption?: React.ReactNode[];
9
- captionId?: string;
10
- }
11
- /**
12
- * Wraps children into responsive container, which is used to prevent reflows as external media like images or videos
13
- * finish loading, see https://www.perpetual-beta.org/weblog/responsive-images-without-browser-reflow.html for more
14
- * information.
15
- */
16
- declare const ResponsiveMediaContainer: React.FunctionComponent<ResponsiveMediaContainerProps>;
17
- export default ResponsiveMediaContainer;
18
- //# sourceMappingURL=ResponsiveMediaContainer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ResponsiveMediaContainer.d.ts","sourceRoot":"","sources":["../../src/components/ResponsiveMediaContainer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,UAAU,6BAA6B;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,EAAE,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAA;IACjC,MAAM,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,EAAE,CAAA;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED;;;;GAIG;AACH,QAAA,MAAM,wBAAwB,EAAE,KAAK,CAAC,iBAAiB,CAAC,6BAA6B,CAsCpF,CAAA;AAED,eAAe,wBAAwB,CAAA"}
@@ -1,21 +0,0 @@
1
- import classNames from 'classnames';
2
- import React from 'react';
3
- const borderedPaddingAndBorderPx = 18;
4
- /**
5
- * Wraps children into responsive container, which is used to prevent reflows as external media like images or videos
6
- * finish loading, see https://www.perpetual-beta.org/weblog/responsive-images-without-browser-reflow.html for more
7
- * information.
8
- */
9
- const ResponsiveMediaContainer = ({ bordered = false, className, children, height, width, caption, captionId, }) => {
10
- const paddingBottom = `${(height / width) * 100}%`;
11
- const maxWidth = width + (bordered ? borderedPaddingAndBorderPx : 0);
12
- return (React.createElement("span", { className: classNames('responsive-media-container', { 'responsive-media-container--bordered': bordered }, className), style: {
13
- maxWidth,
14
- } },
15
- React.createElement("span", { className: "responsive-media-container__inner", style: {
16
- paddingBottom,
17
- } }, children),
18
- caption && (React.createElement("span", { className: "e-color-darkgrey e-block e-mrg-t-1 e-font-size-s e-light", id: captionId }, caption))));
19
- };
20
- export default ResponsiveMediaContainer;
21
- //# sourceMappingURL=ResponsiveMediaContainer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ResponsiveMediaContainer.js","sourceRoot":"","sources":["../../src/components/ResponsiveMediaContainer.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,0BAA0B,GAAG,EAAE,CAAA;AAYrC;;;;GAIG;AACH,MAAM,wBAAwB,GAA2D,CAAC,EACxF,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,EACR,MAAM,EACN,KAAK,EACL,OAAO,EACP,SAAS,GACV,EAAE,EAAE;IACH,MAAM,aAAa,GAAG,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC,GAAG,GAAG,GAAG,CAAA;IAClD,MAAM,QAAQ,GAAG,KAAK,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAEpE,OAAO,CACL,8BACE,SAAS,EAAE,UAAU,CACnB,4BAA4B,EAC5B,EAAE,sCAAsC,EAAE,QAAQ,EAAE,EACpD,SAAS,CACV,EACD,KAAK,EAAE;YACL,QAAQ;SACT;QAED,8BACE,SAAS,EAAC,mCAAmC,EAC7C,KAAK,EAAE;gBACL,aAAa;aACd,IAEA,QAAQ,CACJ;QACN,OAAO,IAAI,CACV,8BAAM,SAAS,EAAC,0DAA0D,EAAC,EAAE,EAAE,SAAS,IACrF,OAAO,CACH,CACR,CACI,CACR,CAAA;AACH,CAAC,CAAA;AAED,eAAe,wBAAwB,CAAA"}
@@ -1,12 +0,0 @@
1
- import React from 'react';
2
- import { RestrictedAudioId } from '..';
3
- declare function RestrictedAudioPlayer({ src, restrictedAudioId, duration, times, labelId, }: {
4
- src: string;
5
- restrictedAudioId: RestrictedAudioId;
6
- duration: number;
7
- times: number;
8
- labelId: string;
9
- }): JSX.Element;
10
- declare const _default: React.MemoExoticComponent<typeof RestrictedAudioPlayer>;
11
- export default _default;
12
- //# sourceMappingURL=RestrictedAudioPlayer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RestrictedAudioPlayer.d.ts","sourceRoot":"","sources":["../../src/components/RestrictedAudioPlayer.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,IAAI,CAAA;AAKtC,iBAAS,qBAAqB,CAAC,EAC7B,GAAG,EACH,iBAAiB,EACjB,QAAQ,EACR,KAAK,EACL,OAAO,GACR,EAAE;IACD,GAAG,EAAE,MAAM,CAAA;IACX,iBAAiB,EAAE,iBAAiB,CAAA;IACpC,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;CAChB,eAiCA;;AAED,wBAAgD"}
@@ -1,32 +0,0 @@
1
- import { faPlay } from '@fortawesome/free-solid-svg-icons';
2
- import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
3
- import classNames from 'classnames';
4
- import React from 'react';
5
- import { useDispatch, useSelector } from 'react-redux';
6
- import { useExamTranslation } from '../i18n';
7
- import { playAudio } from '../store/audio/actions';
8
- import { getAudioState, getDurationRemaining, getPlaybackTimesRemaining } from '../store/selectors';
9
- function RestrictedAudioPlayer({ src, restrictedAudioId, duration, times, labelId, }) {
10
- const audioState = useSelector(getAudioState(src, restrictedAudioId));
11
- const durationRemaining = useSelector(getDurationRemaining(src, restrictedAudioId));
12
- const playbackTimesRemaining = useSelector(getPlaybackTimesRemaining(restrictedAudioId, times));
13
- const { i18n, t } = useExamTranslation();
14
- const dispatch = useDispatch();
15
- const disabled = audioState !== 'stopped' || playbackTimesRemaining === 0;
16
- const remainingLabelId = `audio-remaining-${restrictedAudioId}`;
17
- return (React.createElement("div", { className: classNames('restricted-audio-player e-column e-column--narrow e-columns e-columns--inline e-columns--center-v e-pad-1', { 'restricted-audio-player--disabled': disabled }), lang: i18n.language },
18
- React.createElement("button", { className: classNames('restricted-audio-player__play e-column e-column--narrow', {
19
- 'restricted-audio-player__play--playing': audioState === 'playing',
20
- }), disabled: disabled, onClick: () => audioState === 'stopped' && dispatch(playAudio({ src, restrictedAudioId, duration })), "aria-describedby": [remainingLabelId, labelId].join(' '), "aria-label": t.raw('audio.play') }, audioState !== 'playing' && React.createElement(FontAwesomeIcon, { icon: faPlay, fixedWidth: true })),
21
- React.createElement("span", { className: "restricted-audio-player__duration e-column e-text-right", id: remainingLabelId }, formatDuration(durationRemaining != null ? durationRemaining : duration))));
22
- }
23
- export default React.memo(RestrictedAudioPlayer);
24
- function formatDuration(duration) {
25
- const minutes = Math.floor(duration / 60);
26
- const seconds = duration % 60;
27
- return padWithZeroes(minutes) + ':' + padWithZeroes(seconds);
28
- }
29
- function padWithZeroes(num) {
30
- return num.toString().padStart(2, '0');
31
- }
32
- //# sourceMappingURL=RestrictedAudioPlayer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RestrictedAudioPlayer.js","sourceRoot":"","sources":["../../src/components/RestrictedAudioPlayer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,mCAAmC,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAA;AAChE,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAEtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAClD,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAA;AAEnG,SAAS,qBAAqB,CAAC,EAC7B,GAAG,EACH,iBAAiB,EACjB,QAAQ,EACR,KAAK,EACL,OAAO,GAOR;IACC,MAAM,UAAU,GAAG,WAAW,CAAC,aAAa,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC,CAAA;IACrE,MAAM,iBAAiB,GAAG,WAAW,CAAC,oBAAoB,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC,CAAA;IACnF,MAAM,sBAAsB,GAAG,WAAW,CAAC,yBAAyB,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC,CAAA;IAC/F,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IACxC,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAA;IAC9B,MAAM,QAAQ,GAAG,UAAU,KAAK,SAAS,IAAI,sBAAsB,KAAK,CAAC,CAAA;IACzE,MAAM,gBAAgB,GAAG,mBAAmB,iBAAiB,EAAE,CAAA;IAE/D,OAAO,CACL,6BACE,SAAS,EAAE,UAAU,CACnB,2GAA2G,EAC3G,EAAE,mCAAmC,EAAE,QAAQ,EAAE,CAClD,EACD,IAAI,EAAE,IAAI,CAAC,QAAQ;QAEnB,gCACE,SAAS,EAAE,UAAU,CAAC,yDAAyD,EAAE;gBAC/E,wCAAwC,EAAE,UAAU,KAAK,SAAS;aACnE,CAAC,EACF,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,KAAK,SAAS,IAAI,QAAQ,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,iBAAiB,EAAE,QAAQ,EAAE,CAAC,CAAC,sBAClF,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,gBAC3C,CAAC,CAAC,GAAG,CAAC,YAAY,CAAC,IAE9B,UAAU,KAAK,SAAS,IAAI,oBAAC,eAAe,IAAC,IAAI,EAAE,MAAM,EAAE,UAAU,SAAG,CAClE;QACT,8BAAM,SAAS,EAAC,yDAAyD,EAAC,EAAE,EAAE,gBAAgB,IAC3F,cAAc,CAAC,iBAAiB,IAAI,IAAI,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,QAAQ,CAAC,CACpE,CACH,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;AAEhD,SAAS,cAAc,CAAC,QAAgB;IACtC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAA;IACzC,MAAM,OAAO,GAAG,QAAQ,GAAG,EAAE,CAAA;IAE7B,OAAO,aAAa,CAAC,OAAO,CAAC,GAAG,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,CAAA;AAC9D,CAAC;AAED,SAAS,aAAa,CAAC,GAAW;IAChC,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;AACxC,CAAC"}
@@ -1,33 +0,0 @@
1
- import { TOptions } from 'i18next';
2
- import React from 'react';
3
- import { RichTextAnswer as RichTextAnswerT } from '../types/ExamAnswer';
4
- import { CommonExamContext } from './CommonExamContext';
5
- export interface AnswerError {
6
- key: 'screenshot-too-big' | 'screenshot-byte-limit-reached' | 'screenshot-upload-failed';
7
- options?: TOptions;
8
- }
9
- interface Props {
10
- answer?: RichTextAnswerT;
11
- className?: string;
12
- questionId: number;
13
- onChange: (answerHTML: string, answerText: string) => void;
14
- onError: (error: AnswerError) => void;
15
- saveScreenshot: (screenshot: Blob) => Promise<string>;
16
- }
17
- export default class RichTextAnswer extends React.PureComponent<Props> {
18
- static contextType: React.Context<CommonExamContext>;
19
- context: React.ContextType<typeof CommonExamContext>;
20
- private ref;
21
- private lastHTML;
22
- constructor(props: Props);
23
- componentDidMount(): void;
24
- handleSaveError: (err: unknown) => void;
25
- handleChange: (data: {
26
- answerHTML: string;
27
- answerText: string;
28
- }) => void;
29
- componentDidUpdate(): void;
30
- render(): React.ReactNode;
31
- }
32
- export {};
33
- //# sourceMappingURL=RichTextAnswer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RichTextAnswer.d.ts","sourceRoot":"","sources":["../../src/components/RichTextAnswer.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAElC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,cAAc,IAAI,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,oBAAoB,GAAG,+BAA+B,GAAG,0BAA0B,CAAA;IACxF,OAAO,CAAC,EAAE,QAAQ,CAAA;CACnB;AAED,UAAU,KAAK;IACb,MAAM,CAAC,EAAE,eAAe,CAAA;IACxB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,UAAU,EAAE,MAAM,CAAA;IAClB,QAAQ,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,KAAK,IAAI,CAAA;IAC1D,OAAO,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAA;IACrC,cAAc,EAAE,CAAC,UAAU,EAAE,IAAI,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;CACtD;AAED,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;IACpE,MAAM,CAAC,WAAW,mCAAoB;IAC9B,OAAO,EAAE,KAAK,CAAC,WAAW,CAAC,OAAO,iBAAiB,CAAC,CAAA;IAC5D,OAAO,CAAC,GAAG,CAAiC;IAC5C,OAAO,CAAC,QAAQ,CAAQ;gBAEZ,KAAK,EAAE,KAAK;IAMxB,iBAAiB,IAAI,IAAI;IA0BzB,eAAe,QAAS,OAAO,KAAG,IAAI,CAarC;IAED,YAAY,SAAU;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,KAAG,IAAI,CAKtE;IAED,kBAAkB,IAAI,IAAI;IAS1B,MAAM,IAAI,KAAK,CAAC,SAAS;CAc1B"}
@@ -1,61 +0,0 @@
1
- import classNames from 'classnames';
2
- import * as _ from 'lodash-es';
3
- import React from 'react';
4
- import * as richTextEditor from 'rich-text-editor/dist/rich-text-editor';
5
- import { CommonExamContext } from './CommonExamContext';
6
- export default class RichTextAnswer extends React.PureComponent {
7
- constructor(props) {
8
- super(props);
9
- this.handleSaveError = (err) => {
10
- const key = (() => {
11
- switch (_.get(err, 'response.status')) {
12
- case 409:
13
- return 'screenshot-byte-limit-reached';
14
- case 413:
15
- return 'screenshot-too-big';
16
- default:
17
- return 'screenshot-upload-failed';
18
- }
19
- })();
20
- this.props.onError({ key });
21
- };
22
- this.handleChange = (data) => {
23
- const { onChange } = this.props;
24
- this.lastHTML = data.answerHTML;
25
- onChange(data.answerHTML, data.answerText);
26
- };
27
- this.ref = React.createRef();
28
- this.lastHTML = this.props.answer ? this.props.answer.value : '';
29
- }
30
- componentDidMount() {
31
- const { current } = this.ref;
32
- const { answer, saveScreenshot } = this.props;
33
- if (current) {
34
- if (answer) {
35
- current.innerHTML = answer.value;
36
- }
37
- richTextEditor.makeRichText(current, {
38
- locale: this.context.language.slice(0, 2).toUpperCase(),
39
- screenshot: {
40
- saver: ({ data, type }) => saveScreenshot(data instanceof Blob ? data : new Blob([data], { type })).catch((err) => {
41
- this.handleSaveError(err);
42
- throw err; // Rethrow error so rich-text-editor can handle it.
43
- }),
44
- },
45
- }, _.after(2, this.handleChange) /* TODO: Why does r-t-e send a change event in the beginning? */);
46
- }
47
- }
48
- componentDidUpdate() {
49
- const { current } = this.ref;
50
- // Don't update element unless value has changed from last known value to prevent cursor jumping
51
- if (current && this.props.answer && this.props.answer.value !== this.lastHTML) {
52
- current.innerHTML = this.lastHTML = this.props.answer.value;
53
- }
54
- }
55
- render() {
56
- const { className, questionId } = this.props;
57
- return (React.createElement("div", { ref: this.ref, className: classNames('text-answer text-answer--multi-line', className), "data-question-id": questionId, role: "textbox", "aria-multiline": "true", tabIndex: 0 }));
58
- }
59
- }
60
- RichTextAnswer.contextType = CommonExamContext;
61
- //# sourceMappingURL=RichTextAnswer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RichTextAnswer.js","sourceRoot":"","sources":["../../src/components/RichTextAnswer.tsx"],"names":[],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- declare function SaveIndicator(): JSX.Element | null;
3
- declare const _default: React.MemoExoticComponent<typeof SaveIndicator>;
4
- export default _default;
5
- //# sourceMappingURL=SaveIndicator.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SaveIndicator.d.ts","sourceRoot":"","sources":["../../src/components/SaveIndicator.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAMzB,iBAAS,aAAa,uBAarB;;AAED,wBAAwC"}