@digabi/exam-engine-core 16.4.4 → 16.4.7-alpha.0
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.
- package/dist/__tests__/tsconfig.tsbuildinfo +1 -1
- package/dist/components/AttachmentContext.d.ts +14 -0
- package/dist/components/AttachmentContext.d.ts.map +1 -0
- package/dist/components/AttachmentContext.js +12 -0
- package/dist/components/AttachmentContext.js.map +1 -0
- package/dist/components/AttachmentLink.d.ts +5 -0
- package/dist/components/AttachmentLink.d.ts.map +1 -0
- package/dist/components/AttachmentLink.js +28 -0
- package/dist/components/AttachmentLink.js.map +1 -0
- package/dist/components/AttachmentLinkAnchor.d.ts +7 -0
- package/dist/components/AttachmentLinkAnchor.d.ts.map +1 -0
- package/dist/components/AttachmentLinkAnchor.js +4 -0
- package/dist/components/AttachmentLinkAnchor.js.map +1 -0
- package/dist/components/AttachmentLinks.d.ts +5 -0
- package/dist/components/AttachmentLinks.d.ts.map +1 -0
- package/dist/components/AttachmentLinks.js +62 -0
- package/dist/components/AttachmentLinks.js.map +1 -0
- package/dist/components/Attachments.d.ts +6 -0
- package/dist/components/Attachments.d.ts.map +1 -0
- package/dist/components/Attachments.js +55 -0
- package/dist/components/Attachments.js.map +1 -0
- package/dist/components/AttachmentsAttachment.d.ts +5 -0
- package/dist/components/AttachmentsAttachment.d.ts.map +1 -0
- package/dist/components/AttachmentsAttachment.js +8 -0
- package/dist/components/AttachmentsAttachment.js.map +1 -0
- package/dist/components/AttachmentsAttachmentTitle.d.ts +6 -0
- package/dist/components/AttachmentsAttachmentTitle.d.ts.map +1 -0
- package/dist/components/AttachmentsAttachmentTitle.js +12 -0
- package/dist/components/AttachmentsAttachmentTitle.js.map +1 -0
- package/dist/components/AttachmentsExternalMaterial.d.ts +9 -0
- package/dist/components/AttachmentsExternalMaterial.d.ts.map +1 -0
- package/dist/components/AttachmentsExternalMaterial.js +40 -0
- package/dist/components/AttachmentsExternalMaterial.js.map +1 -0
- package/dist/components/AttachmentsQuestion.d.ts +5 -0
- package/dist/components/AttachmentsQuestion.d.ts.map +1 -0
- package/dist/components/AttachmentsQuestion.js +17 -0
- package/dist/components/AttachmentsQuestion.js.map +1 -0
- package/dist/components/AttachmentsQuestionTitle.d.ts +6 -0
- package/dist/components/AttachmentsQuestionTitle.d.ts.map +1 -0
- package/dist/components/AttachmentsQuestionTitle.js +13 -0
- package/dist/components/AttachmentsQuestionTitle.js.map +1 -0
- package/dist/components/Audio.d.ts +6 -0
- package/dist/components/Audio.d.ts.map +1 -0
- package/dist/components/Audio.js +31 -0
- package/dist/components/Audio.js.map +1 -0
- package/dist/components/AudioGroup.d.ts +6 -0
- package/dist/components/AudioGroup.d.ts.map +1 -0
- package/dist/components/AudioGroup.js +9 -0
- package/dist/components/AudioGroup.js.map +1 -0
- package/dist/components/AudioPlaybackError.d.ts +7 -0
- package/dist/components/AudioPlaybackError.d.ts.map +1 -0
- package/dist/components/AudioPlaybackError.js +13 -0
- package/dist/components/AudioPlaybackError.js.map +1 -0
- package/dist/components/AudioTest.d.ts +6 -0
- package/dist/components/AudioTest.d.ts.map +1 -0
- package/dist/components/AudioTest.js +29 -0
- package/dist/components/AudioTest.js.map +1 -0
- package/dist/components/ChoiceAnswer.d.ts +12 -0
- package/dist/components/ChoiceAnswer.d.ts.map +1 -0
- package/dist/components/ChoiceAnswer.js +62 -0
- package/dist/components/ChoiceAnswer.js.map +1 -0
- package/dist/components/CommonExamContext.d.ts +19 -0
- package/dist/components/CommonExamContext.d.ts.map +1 -0
- package/dist/components/CommonExamContext.js +25 -0
- package/dist/components/CommonExamContext.js.map +1 -0
- package/dist/components/DropdownAnswer.d.ts +12 -0
- package/dist/components/DropdownAnswer.d.ts.map +1 -0
- package/dist/components/DropdownAnswer.js +100 -0
- package/dist/components/DropdownAnswer.js.map +1 -0
- package/dist/components/ErrorIndicator.d.ts +4 -0
- package/dist/components/ErrorIndicator.d.ts.map +1 -0
- package/dist/components/ErrorIndicator.js +43 -0
- package/dist/components/ErrorIndicator.js.map +1 -0
- package/dist/components/Exam.d.ts +32 -0
- package/dist/components/Exam.d.ts.map +1 -0
- package/dist/components/Exam.js +103 -0
- package/dist/components/Exam.js.map +1 -0
- package/dist/components/ExamAttachment.d.ts +5 -0
- package/dist/components/ExamAttachment.d.ts.map +1 -0
- package/dist/components/ExamAttachment.js +8 -0
- package/dist/components/ExamAttachment.js.map +1 -0
- package/dist/components/ExamContext.d.ts +10 -0
- package/dist/components/ExamContext.d.ts.map +1 -0
- package/dist/components/ExamContext.js +11 -0
- package/dist/components/ExamContext.js.map +1 -0
- package/dist/components/ExamFooter.d.ts +6 -0
- package/dist/components/ExamFooter.d.ts.map +1 -0
- package/dist/components/ExamFooter.js +7 -0
- package/dist/components/ExamFooter.js.map +1 -0
- package/dist/components/ExamInstruction.d.ts +6 -0
- package/dist/components/ExamInstruction.d.ts.map +1 -0
- package/dist/components/ExamInstruction.js +6 -0
- package/dist/components/ExamInstruction.js.map +1 -0
- package/dist/components/ExamQuestion.d.ts +5 -0
- package/dist/components/ExamQuestion.d.ts.map +1 -0
- package/dist/components/ExamQuestion.js +16 -0
- package/dist/components/ExamQuestion.js.map +1 -0
- package/dist/components/ExamQuestionInstruction.d.ts +6 -0
- package/dist/components/ExamQuestionInstruction.d.ts.map +1 -0
- package/dist/components/ExamQuestionInstruction.js +6 -0
- package/dist/components/ExamQuestionInstruction.js.map +1 -0
- package/dist/components/ExamQuestionTitle.d.ts +5 -0
- package/dist/components/ExamQuestionTitle.d.ts.map +1 -0
- package/dist/components/ExamQuestionTitle.js +24 -0
- package/dist/components/ExamQuestionTitle.js.map +1 -0
- package/dist/components/ExamSection.d.ts +5 -0
- package/dist/components/ExamSection.d.ts.map +1 -0
- package/dist/components/ExamSection.js +31 -0
- package/dist/components/ExamSection.js.map +1 -0
- package/dist/components/ExamSectionTitle.d.ts +6 -0
- package/dist/components/ExamSectionTitle.d.ts.map +1 -0
- package/dist/components/ExamSectionTitle.js +22 -0
- package/dist/components/ExamSectionTitle.js.map +1 -0
- package/dist/components/ExternalMaterialList.d.ts +10 -0
- package/dist/components/ExternalMaterialList.d.ts.map +1 -0
- package/dist/components/ExternalMaterialList.js +33 -0
- package/dist/components/ExternalMaterialList.js.map +1 -0
- package/dist/components/File.d.ts +6 -0
- package/dist/components/File.d.ts.map +1 -0
- package/dist/components/File.js +15 -0
- package/dist/components/File.js.map +1 -0
- package/dist/components/Formula.d.ts +6 -0
- package/dist/components/Formula.d.ts.map +1 -0
- package/dist/components/Formula.js +13 -0
- package/dist/components/Formula.js.map +1 -0
- package/dist/components/Hints.d.ts +5 -0
- package/dist/components/Hints.d.ts.map +1 -0
- package/dist/components/Hints.js +30 -0
- package/dist/components/Hints.js.map +1 -0
- package/dist/components/Image.d.ts +6 -0
- package/dist/components/Image.d.ts.map +1 -0
- package/dist/components/Image.js +28 -0
- package/dist/components/Image.js.map +1 -0
- package/dist/components/ImageOverlay.d.ts +6 -0
- package/dist/components/ImageOverlay.d.ts.map +1 -0
- package/dist/components/ImageOverlay.js +44 -0
- package/dist/components/ImageOverlay.js.map +1 -0
- package/dist/components/ProgressBar.d.ts +7 -0
- package/dist/components/ProgressBar.d.ts.map +1 -0
- package/dist/components/ProgressBar.js +19 -0
- package/dist/components/ProgressBar.js.map +1 -0
- package/dist/components/QuestionContext.d.ts +14 -0
- package/dist/components/QuestionContext.d.ts.map +1 -0
- package/dist/components/QuestionContext.js +20 -0
- package/dist/components/QuestionContext.js.map +1 -0
- package/dist/components/Reference.d.ts +6 -0
- package/dist/components/Reference.d.ts.map +1 -0
- package/dist/components/Reference.js +71 -0
- package/dist/components/Reference.js.map +1 -0
- package/dist/components/References.d.ts +6 -0
- package/dist/components/References.d.ts.map +1 -0
- package/dist/components/References.js +25 -0
- package/dist/components/References.js.map +1 -0
- package/dist/components/ResponsiveMediaContainer.d.ts +18 -0
- package/dist/components/ResponsiveMediaContainer.d.ts.map +1 -0
- package/dist/components/ResponsiveMediaContainer.js +21 -0
- package/dist/components/ResponsiveMediaContainer.js.map +1 -0
- package/dist/components/RestrictedAudioPlayer.d.ts +12 -0
- package/dist/components/RestrictedAudioPlayer.d.ts.map +1 -0
- package/dist/components/RestrictedAudioPlayer.js +32 -0
- package/dist/components/RestrictedAudioPlayer.js.map +1 -0
- package/dist/components/RichTextAnswer.d.ts +33 -0
- package/dist/components/RichTextAnswer.d.ts.map +1 -0
- package/dist/components/RichTextAnswer.js +61 -0
- package/dist/components/RichTextAnswer.js.map +1 -0
- package/dist/components/SaveIndicator.d.ts +5 -0
- package/dist/components/SaveIndicator.d.ts.map +1 -0
- package/dist/components/SaveIndicator.js +16 -0
- package/dist/components/SaveIndicator.js.map +1 -0
- package/dist/components/Score.d.ts +8 -0
- package/dist/components/Score.d.ts.map +1 -0
- package/dist/components/Score.js +13 -0
- package/dist/components/Score.js.map +1 -0
- package/dist/components/Section.d.ts +4 -0
- package/dist/components/Section.d.ts.map +1 -0
- package/dist/components/Section.js +8 -0
- package/dist/components/Section.js.map +1 -0
- package/dist/components/SectionContext.d.ts +13 -0
- package/dist/components/SectionContext.d.ts.map +1 -0
- package/dist/components/SectionContext.js +21 -0
- package/dist/components/SectionContext.js.map +1 -0
- package/dist/components/SectionInstruction.d.ts +6 -0
- package/dist/components/SectionInstruction.d.ts.map +1 -0
- package/dist/components/SectionInstruction.js +6 -0
- package/dist/components/SectionInstruction.js.map +1 -0
- package/dist/components/TableOfContents.d.ts +13 -0
- package/dist/components/TableOfContents.d.ts.map +1 -0
- package/dist/components/TableOfContents.js +66 -0
- package/dist/components/TableOfContents.js.map +1 -0
- package/dist/components/TextAnswer.d.ts +6 -0
- package/dist/components/TextAnswer.d.ts.map +1 -0
- package/dist/components/TextAnswer.js +17 -0
- package/dist/components/TextAnswer.js.map +1 -0
- package/dist/components/TextAnswerInput.d.ts +36 -0
- package/dist/components/TextAnswerInput.d.ts.map +1 -0
- package/dist/components/TextAnswerInput.js +145 -0
- package/dist/components/TextAnswerInput.js.map +1 -0
- package/dist/components/Video.d.ts +6 -0
- package/dist/components/Video.d.ts.map +1 -0
- package/dist/components/Video.js +15 -0
- package/dist/components/Video.js.map +1 -0
- package/dist/components/exam/ChoiceAnswer.d.ts +2 -9
- package/dist/components/exam/ChoiceAnswer.d.ts.map +1 -1
- package/dist/components/exam/ChoiceAnswer.js +15 -20
- package/dist/components/exam/ChoiceAnswer.js.map +1 -1
- package/dist/components/exam/DropdownAnswer.d.ts +2 -9
- package/dist/components/exam/DropdownAnswer.d.ts.map +1 -1
- package/dist/components/exam/DropdownAnswer.js +8 -13
- package/dist/components/exam/DropdownAnswer.js.map +1 -1
- package/dist/components/exam/Hints.d.ts.map +1 -1
- package/dist/components/exam/Hints.js.map +1 -1
- package/dist/components/exam/Question.d.ts.map +1 -1
- package/dist/components/exam/Question.js.map +1 -1
- package/dist/components/exam/Section.d.ts.map +1 -1
- package/dist/components/exam/Section.js.map +1 -1
- package/dist/components/exam/TableOfContents.d.ts +13 -0
- package/dist/components/exam/TableOfContents.d.ts.map +1 -0
- package/dist/components/exam/TableOfContents.js +66 -0
- package/dist/components/exam/TableOfContents.js.map +1 -0
- package/dist/components/exam/TextAnswer.d.ts.map +1 -1
- package/dist/components/exam/TextAnswer.js +3 -13
- package/dist/components/exam/TextAnswer.js.map +1 -1
- package/dist/components/exam/internal/ErrorIndicator.d.ts.map +1 -1
- package/dist/components/exam/internal/ErrorIndicator.js.map +1 -1
- package/dist/components/exam/internal/TextAnswerInput.d.ts +1 -35
- package/dist/components/exam/internal/TextAnswerInput.d.ts.map +1 -1
- package/dist/components/exam/internal/TextAnswerInput.js +98 -129
- package/dist/components/exam/internal/TextAnswerInput.js.map +1 -1
- package/dist/components/grading-instruction/AnswerGradingInstruction.d.ts +5 -0
- package/dist/components/grading-instruction/AnswerGradingInstruction.d.ts.map +1 -0
- package/dist/components/grading-instruction/AnswerGradingInstruction.js +6 -0
- package/dist/components/grading-instruction/AnswerGradingInstruction.js.map +1 -0
- package/dist/components/grading-instruction/Audio.d.ts +5 -0
- package/dist/components/grading-instruction/Audio.d.ts.map +1 -0
- package/dist/components/grading-instruction/Audio.js +6 -0
- package/dist/components/grading-instruction/Audio.js.map +1 -0
- package/dist/components/grading-instruction/AudioTitle.d.ts +5 -0
- package/dist/components/grading-instruction/AudioTitle.d.ts.map +1 -0
- package/dist/components/grading-instruction/AudioTitle.js +10 -0
- package/dist/components/grading-instruction/AudioTitle.js.map +1 -0
- package/dist/components/grading-instruction/AutogradedAnswer.d.ts +5 -0
- package/dist/components/grading-instruction/AutogradedAnswer.d.ts.map +1 -0
- package/dist/components/grading-instruction/AutogradedAnswer.js +31 -0
- package/dist/components/grading-instruction/AutogradedAnswer.js.map +1 -0
- package/dist/components/grading-instruction/AutogradedAnswerOption.d.ts +5 -0
- package/dist/components/grading-instruction/AutogradedAnswerOption.d.ts.map +1 -0
- package/dist/components/grading-instruction/AutogradedAnswerOption.js +14 -0
- package/dist/components/grading-instruction/AutogradedAnswerOption.js.map +1 -0
- package/dist/components/grading-instruction/ExamGradingInstruction.d.ts +5 -0
- package/dist/components/grading-instruction/ExamGradingInstruction.d.ts.map +1 -0
- package/dist/components/grading-instruction/ExamGradingInstruction.js +6 -0
- package/dist/components/grading-instruction/ExamGradingInstruction.js.map +1 -0
- package/dist/components/grading-instruction/GradingInstruction.d.ts +5 -0
- package/dist/components/grading-instruction/GradingInstruction.d.ts.map +1 -0
- package/dist/components/grading-instruction/GradingInstruction.js +85 -0
- package/dist/components/grading-instruction/GradingInstruction.js.map +1 -0
- package/dist/components/grading-instruction/Question.d.ts +5 -0
- package/dist/components/grading-instruction/Question.d.ts.map +1 -0
- package/dist/components/grading-instruction/Question.js +12 -0
- package/dist/components/grading-instruction/Question.js.map +1 -0
- package/dist/components/grading-instruction/QuestionTitle.d.ts +5 -0
- package/dist/components/grading-instruction/QuestionTitle.d.ts.map +1 -0
- package/dist/components/grading-instruction/QuestionTitle.js +19 -0
- package/dist/components/grading-instruction/QuestionTitle.js.map +1 -0
- package/dist/components/grading-instruction/Section.d.ts +5 -0
- package/dist/components/grading-instruction/Section.d.ts.map +1 -0
- package/dist/components/grading-instruction/Section.js +10 -0
- package/dist/components/grading-instruction/Section.js.map +1 -0
- package/dist/components/grading-instruction/SectionTitle.d.ts +5 -0
- package/dist/components/grading-instruction/SectionTitle.d.ts.map +1 -0
- package/dist/components/grading-instruction/SectionTitle.js +16 -0
- package/dist/components/grading-instruction/SectionTitle.js.map +1 -0
- package/dist/components/grading-instructions/Audio.d.ts +5 -0
- package/dist/components/grading-instructions/Audio.d.ts.map +1 -0
- package/dist/components/grading-instructions/Audio.js +8 -0
- package/dist/components/grading-instructions/Audio.js.map +1 -0
- package/dist/components/grading-instructions/AudioTitle.d.ts +5 -0
- package/dist/components/grading-instructions/AudioTitle.d.ts.map +1 -0
- package/dist/components/grading-instructions/AudioTitle.js +11 -0
- package/dist/components/grading-instructions/AudioTitle.js.map +1 -0
- package/dist/components/results/AnnotationList.d.ts +5 -0
- package/dist/components/results/AnnotationList.d.ts.map +1 -0
- package/dist/components/results/AnnotationList.js +43 -0
- package/dist/components/results/AnnotationList.js.map +1 -0
- package/dist/components/results/GradingStructure.d.ts +5 -0
- package/dist/components/results/GradingStructure.d.ts.map +1 -0
- package/dist/components/results/GradingStructure.js +21 -0
- package/dist/components/results/GradingStructure.js.map +1 -0
- package/dist/components/results/Hvp.d.ts +15 -0
- package/dist/components/results/Hvp.d.ts.map +1 -0
- package/dist/components/results/Hvp.js +73 -0
- package/dist/components/results/Hvp.js.map +1 -0
- package/dist/components/results/HvpTextAnswer.d.ts +6 -0
- package/dist/components/results/HvpTextAnswer.d.ts.map +1 -0
- package/dist/components/results/HvpTextAnswer.js +51 -0
- package/dist/components/results/HvpTextAnswer.js.map +1 -0
- package/dist/components/results/ResultsChoiceAnswer.d.ts +6 -0
- package/dist/components/results/ResultsChoiceAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsChoiceAnswer.js +57 -0
- package/dist/components/results/ResultsChoiceAnswer.js.map +1 -0
- package/dist/components/results/ResultsContext.d.ts +18 -0
- package/dist/components/results/ResultsContext.d.ts.map +1 -0
- package/dist/components/results/ResultsContext.js +68 -0
- package/dist/components/results/ResultsContext.js.map +1 -0
- package/dist/components/results/ResultsDropdownAnswer.d.ts +6 -0
- package/dist/components/results/ResultsDropdownAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsDropdownAnswer.js +43 -0
- package/dist/components/results/ResultsDropdownAnswer.js.map +1 -0
- package/dist/components/results/ResultsExamQuestion.d.ts +5 -0
- package/dist/components/results/ResultsExamQuestion.d.ts.map +1 -0
- package/dist/components/results/ResultsExamQuestion.js +23 -0
- package/dist/components/results/ResultsExamQuestion.js.map +1 -0
- package/dist/components/results/ResultsExamQuestionAutoScore.d.ts +10 -0
- package/dist/components/results/ResultsExamQuestionAutoScore.d.ts.map +1 -0
- package/dist/components/results/ResultsExamQuestionAutoScore.js +17 -0
- package/dist/components/results/ResultsExamQuestionAutoScore.js.map +1 -0
- package/dist/components/results/ResultsExamQuestionManualScore.d.ts +12 -0
- package/dist/components/results/ResultsExamQuestionManualScore.d.ts.map +1 -0
- package/dist/components/results/ResultsExamQuestionManualScore.js +61 -0
- package/dist/components/results/ResultsExamQuestionManualScore.js.map +1 -0
- package/dist/components/results/ResultsExamQuestionScoresContainer.d.ts +10 -0
- package/dist/components/results/ResultsExamQuestionScoresContainer.d.ts.map +1 -0
- package/dist/components/results/ResultsExamQuestionScoresContainer.js +12 -0
- package/dist/components/results/ResultsExamQuestionScoresContainer.js.map +1 -0
- package/dist/components/results/ResultsExamQuestionTitle.d.ts +6 -0
- package/dist/components/results/ResultsExamQuestionTitle.d.ts.map +1 -0
- package/dist/components/results/ResultsExamQuestionTitle.js +21 -0
- package/dist/components/results/ResultsExamQuestionTitle.js.map +1 -0
- package/dist/components/results/ResultsExamSection.d.ts +5 -0
- package/dist/components/results/ResultsExamSection.d.ts.map +1 -0
- package/dist/components/results/ResultsExamSection.js +18 -0
- package/dist/components/results/ResultsExamSection.js.map +1 -0
- package/dist/components/results/ResultsMultiLineAnswer.d.ts +8 -0
- package/dist/components/results/ResultsMultiLineAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsMultiLineAnswer.js +19 -0
- package/dist/components/results/ResultsMultiLineAnswer.js.map +1 -0
- package/dist/components/results/ResultsScoredTextAnswer.d.ts +6 -0
- package/dist/components/results/ResultsScoredTextAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsScoredTextAnswer.js +22 -0
- package/dist/components/results/ResultsScoredTextAnswer.js.map +1 -0
- package/dist/components/results/ResultsSingleLineAnswer.d.ts +12 -0
- package/dist/components/results/ResultsSingleLineAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsSingleLineAnswer.js +23 -0
- package/dist/components/results/ResultsSingleLineAnswer.js.map +1 -0
- package/dist/components/results/ResultsTextAnswer.d.ts +6 -0
- package/dist/components/results/ResultsTextAnswer.d.ts.map +1 -0
- package/dist/components/results/ResultsTextAnswer.js +50 -0
- package/dist/components/results/ResultsTextAnswer.js.map +1 -0
- package/dist/components/results/helpers.d.ts +9 -0
- package/dist/components/results/helpers.d.ts.map +1 -0
- package/dist/components/results/helpers.js +11 -0
- package/dist/components/results/helpers.js.map +1 -0
- package/dist/components/withContext.d.ts +3 -0
- package/dist/components/withContext.d.ts.map +1 -0
- package/dist/components/withContext.js +12 -0
- package/dist/components/withContext.js.map +1 -0
- package/dist/main-bundle.js +9 -38
- package/dist/main.css +1 -1
- package/dist/store/index.d.ts +4 -0
- package/dist/store/index.d.ts.map +1 -1
- package/dist/store/index.js.map +1 -1
- package/package.json +11 -11
- package/dist/main-bundle.js.map +0 -1
@@ -0,0 +1,71 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Reference.js","sourceRoot":"","sources":["../../src/components/Reference.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,6 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,25 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,18 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,21 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,12 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,32 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,33 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,61 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"RichTextAnswer.js","sourceRoot":"","sources":["../../src/components/RichTextAnswer.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React from 'react';
|
3
|
+
import { useSelector } from 'react-redux';
|
4
|
+
import { useExamTranslation } from '../i18n';
|
5
|
+
import { getSaveState } from '../store/selectors';
|
6
|
+
function SaveIndicator() {
|
7
|
+
const state = useSelector(getSaveState);
|
8
|
+
const { t } = useExamTranslation();
|
9
|
+
if (state === 'initial') {
|
10
|
+
return null;
|
11
|
+
}
|
12
|
+
return (React.createElement("div", { className: "save-indicator e-pad-1 e-font-size-xs" },
|
13
|
+
React.createElement("span", { className: classNames('save-indicator-text', 'save-indicator-text--' + state) }, t('answer-saved'))));
|
14
|
+
}
|
15
|
+
export default React.memo(SaveIndicator);
|
16
|
+
//# sourceMappingURL=SaveIndicator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"SaveIndicator.js","sourceRoot":"","sources":["../../src/components/SaveIndicator.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,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAEjD,SAAS,aAAa;IACpB,MAAM,KAAK,GAAc,WAAW,CAAC,YAAY,CAAC,CAAA;IAClD,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAElC,IAAI,KAAK,KAAK,SAAS,EAAE;QACvB,OAAO,IAAI,CAAA;KACZ;IAED,OAAO,CACL,6BAAK,SAAS,EAAC,uCAAuC;QACpD,8BAAM,SAAS,EAAE,UAAU,CAAC,qBAAqB,EAAE,uBAAuB,GAAG,KAAK,CAAC,IAAG,CAAC,CAAC,cAAc,CAAC,CAAQ,CAC3G,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Score.d.ts","sourceRoot":"","sources":["../../src/components/Score.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,MAAM,WAAW,UAAU;IACzB,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,IAAI,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAA;IACnC,KAAK,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,KAAK,EAAE,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAerD,CAAA"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React from 'react';
|
3
|
+
import { useExamTranslation } from '../i18n';
|
4
|
+
export const Score = ({ id, size = 'small', score }) => {
|
5
|
+
const { t } = useExamTranslation();
|
6
|
+
const Tag = size === 'inline' ? 'sup' : 'span';
|
7
|
+
return (React.createElement(Tag, { className: classNames('e-score e-nowrap', {
|
8
|
+
'e-score--small e-font-size-m e-semibold': size === 'small',
|
9
|
+
'e-score--large e-font-size-l e-semibold': size === 'large',
|
10
|
+
'e-score--inline e-font-size-xs': size === 'inline',
|
11
|
+
}), id: id }, t('points', { count: score })));
|
12
|
+
};
|
13
|
+
//# sourceMappingURL=Score.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Score.js","sourceRoot":"","sources":["../../src/components/Score.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAQ5C,MAAM,CAAC,MAAM,KAAK,GAAwC,CAAC,EAAE,EAAE,EAAE,IAAI,GAAG,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE;IAC1F,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,GAAG,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAA;IAC9C,OAAO,CACL,oBAAC,GAAG,IACF,SAAS,EAAE,UAAU,CAAC,kBAAkB,EAAE;YACxC,yCAAyC,EAAE,IAAI,KAAK,OAAO;YAC3D,yCAAyC,EAAE,IAAI,KAAK,OAAO;YAC3D,gCAAgC,EAAE,IAAI,KAAK,QAAQ;SACpD,CAAC,EACF,EAAE,EAAE,EAAE,IAEL,CAAC,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAC1B,CACP,CAAA;AACH,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Section.d.ts","sourceRoot":"","sources":["../../src/components/Section.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,QAAA,MAAM,OAAO,EAAE,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,WAAW,CAAC,CAK7G,CAAA;AAED,eAAe,OAAO,CAAA"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React from 'react';
|
3
|
+
const Section = (props) => {
|
4
|
+
const className = classNames('e-section e-bg-color-off-white e-pad-6', props.className);
|
5
|
+
return React.createElement("section", Object.assign({}, { ...props, className }), props.children);
|
6
|
+
};
|
7
|
+
export default Section;
|
8
|
+
//# sourceMappingURL=Section.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Section.js","sourceRoot":"","sources":["../../src/components/Section.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,OAAO,GAAqG,CAChH,KAAK,EACL,EAAE;IACF,MAAM,SAAS,GAAG,UAAU,CAAC,wCAAwC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAA;IACvF,OAAO,iDAAa,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,QAAQ,CAAW,CAAA;AACzE,CAAC,CAAA;AAED,eAAe,OAAO,CAAA"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
export interface SectionContext {
|
4
|
+
casForbidden: boolean;
|
5
|
+
displayNumber: string;
|
6
|
+
maxAnswers?: number;
|
7
|
+
minAnswers?: number;
|
8
|
+
maxScore: number;
|
9
|
+
childQuestions: Element[];
|
10
|
+
}
|
11
|
+
export declare const SectionContext: React.Context<SectionContext>;
|
12
|
+
export declare const withSectionContext: (Component: React.ComponentType<ExamComponentProps>) => React.ComponentType<ExamComponentProps>;
|
13
|
+
//# sourceMappingURL=SectionContext.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"SectionContext.d.ts","sourceRoot":"","sources":["../../src/components/SectionContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAE9D,MAAM,WAAW,cAAc;IAC7B,YAAY,EAAE,OAAO,CAAA;IACrB,aAAa,EAAE,MAAM,CAAA;IACrB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,OAAO,EAAE,CAAA;CAC1B;AAED,eAAO,MAAM,cAAc,+BAA4D,CAAA;AAEvF,eAAO,MAAM,kBAAkB,iGAkB7B,CAAA"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { getBooleanAttribute, getNumericAttribute, mapChildElements } from '../dom-utils';
|
3
|
+
import { withContext } from './withContext';
|
4
|
+
export const SectionContext = React.createContext({});
|
5
|
+
export const withSectionContext = withContext(SectionContext, ({ element }) => {
|
6
|
+
const casForbidden = getBooleanAttribute(element, 'cas-forbidden');
|
7
|
+
const displayNumber = element.getAttribute('display-number');
|
8
|
+
const maxAnswers = getNumericAttribute(element, 'max-answers');
|
9
|
+
const minAnswers = getNumericAttribute(element, 'min-answers');
|
10
|
+
const maxScore = getNumericAttribute(element, 'max-score');
|
11
|
+
const childQuestions = mapChildElements(element, (childElement) => childElement).filter((parentNode) => parentNode.localName === 'question');
|
12
|
+
return {
|
13
|
+
casForbidden,
|
14
|
+
displayNumber,
|
15
|
+
maxAnswers,
|
16
|
+
minAnswers,
|
17
|
+
maxScore,
|
18
|
+
childQuestions,
|
19
|
+
};
|
20
|
+
});
|
21
|
+
//# sourceMappingURL=SectionContext.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"SectionContext.js","sourceRoot":"","sources":["../../src/components/SectionContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AACzF,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAY3C,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,CAAC,aAAa,CAAiB,EAAoB,CAAC,CAAA;AAEvF,MAAM,CAAC,MAAM,kBAAkB,GAAG,WAAW,CAAqC,cAAc,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IAChH,MAAM,YAAY,GAAG,mBAAmB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAA;IAClE,MAAM,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC,gBAAgB,CAAE,CAAA;IAC7D,MAAM,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAE,CAAA;IAC/D,MAAM,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAE,CAAA;IAC/D,MAAM,QAAQ,GAAG,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAE,CAAA;IAC3D,MAAM,cAAc,GAAG,gBAAgB,CAAC,OAAO,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,MAAM,CACrF,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,KAAK,UAAU,CACpD,CAAA;IAED,OAAO;QACL,YAAY;QACZ,aAAa;QACb,UAAU;QACV,UAAU;QACV,QAAQ;QACR,cAAc;KACf,CAAA;AACH,CAAC,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function SectionInstruction({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof SectionInstruction>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=SectionInstruction.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"SectionInstruction.d.ts","sourceRoot":"","sources":["../../src/components/SectionInstruction.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAE9D,iBAAS,kBAAkB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAE5E;;AAED,wBAA6C"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
function SectionInstruction({ element, renderChildNodes }) {
|
3
|
+
return React.createElement("div", { className: "e-mrg-b-2" }, renderChildNodes(element));
|
4
|
+
}
|
5
|
+
export default React.memo(SectionInstruction);
|
6
|
+
//# sourceMappingURL=SectionInstruction.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"SectionInstruction.js","sourceRoot":"","sources":["../../src/components/SectionInstruction.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,SAAS,kBAAkB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAsB;IAC3E,OAAO,6BAAK,SAAS,EAAC,WAAW,IAAE,gBAAgB,CAAC,OAAO,CAAC,CAAO,CAAA;AACrE,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAA"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
export interface TOCSectionTitleProps {
|
4
|
+
element: Element;
|
5
|
+
displayNumber: string;
|
6
|
+
maxAnswers?: number;
|
7
|
+
minAnswers?: number;
|
8
|
+
childQuestions: Element[];
|
9
|
+
}
|
10
|
+
declare function TableOfContents(_props: ExamComponentProps): JSX.Element;
|
11
|
+
declare const _default: React.MemoExoticComponent<typeof TableOfContents>;
|
12
|
+
export default _default;
|
13
|
+
//# sourceMappingURL=TableOfContents.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"TableOfContents.d.ts","sourceRoot":"","sources":["../../src/components/TableOfContents.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAA0B,kBAAkB,EAAiB,MAAM,2BAA2B,CAAA;AAkCrG,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,OAAO,CAAA;IAChB,aAAa,EAAE,MAAM,CAAA;IACrB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,cAAc,EAAE,OAAO,EAAE,CAAA;CAC1B;AA+DD,iBAAS,eAAe,CAAC,MAAM,EAAE,kBAAkB,eAgBlD;;AAED,wBAA0C"}
|
@@ -0,0 +1,66 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
import { createRenderChildNodes, RenderOptions } from '../createRenderChildNodes';
|
3
|
+
import { findChildElement, query, queryAncestors } from '../dom-utils';
|
4
|
+
import { useExamTranslation } from '../i18n';
|
5
|
+
import { tocSectionTitleId, tocTitleId } from '../ids';
|
6
|
+
import { url } from '../url';
|
7
|
+
import AnsweringInstructions from './AnsweringInstructions';
|
8
|
+
import { CommonExamContext } from './CommonExamContext';
|
9
|
+
import { QuestionContext, withQuestionContext } from './QuestionContext';
|
10
|
+
import { SectionContext, withSectionContext } from './SectionContext';
|
11
|
+
function TOCSection({ element }) {
|
12
|
+
const { maxAnswers, minAnswers, displayNumber, childQuestions } = useContext(SectionContext);
|
13
|
+
const sectionTitle = findChildElement(element, 'section-title');
|
14
|
+
return (React.createElement("li", null,
|
15
|
+
sectionTitle && (React.createElement(TOCSectionTitle, Object.assign({}, {
|
16
|
+
element: sectionTitle,
|
17
|
+
displayNumber,
|
18
|
+
maxAnswers,
|
19
|
+
minAnswers,
|
20
|
+
childQuestions,
|
21
|
+
}))),
|
22
|
+
React.createElement("ol", { className: "e-list-data e-pad-l-0", "aria-labelledby": sectionTitle && tocSectionTitleId(displayNumber) }, renderChildNodes(element, RenderOptions.SkipHTML))));
|
23
|
+
}
|
24
|
+
function TOCSectionTitle({ element, displayNumber, minAnswers, maxAnswers, childQuestions }) {
|
25
|
+
const { numberOfSections } = useContext(CommonExamContext);
|
26
|
+
const { t } = useExamTranslation();
|
27
|
+
return (React.createElement(React.Fragment, null,
|
28
|
+
React.createElement("header", { className: "e-semibold", id: tocSectionTitleId(displayNumber) }, element.hasChildNodes() && (React.createElement(React.Fragment, null,
|
29
|
+
numberOfSections > 1 && t('section', { displayNumber }),
|
30
|
+
" ",
|
31
|
+
renderChildNodes(element)))),
|
32
|
+
maxAnswers != null && (React.createElement("div", null,
|
33
|
+
React.createElement(AnsweringInstructions, Object.assign({}, { maxAnswers, minAnswers, childQuestions, type: 'toc-section' }))))));
|
34
|
+
}
|
35
|
+
function TOCQuestion({ element }) {
|
36
|
+
const { attachmentsURL } = useContext(CommonExamContext);
|
37
|
+
const { level, displayNumber, maxScore } = useContext(QuestionContext);
|
38
|
+
const { t } = useExamTranslation();
|
39
|
+
const externalMaterial = query(element, 'external-material');
|
40
|
+
const questionTitle = findChildElement(element, 'question-title');
|
41
|
+
return level === 0 ? (React.createElement("li", { "data-list-number": displayNumber + '.' },
|
42
|
+
React.createElement("div", { className: "e-columns" },
|
43
|
+
questionTitle && (React.createElement("span", { className: "e-column" },
|
44
|
+
React.createElement("a", { href: url('', { hash: displayNumber }) }, renderChildNodes(questionTitle)))),
|
45
|
+
externalMaterial && (React.createElement("span", { className: "e-column e-column--narrow" },
|
46
|
+
React.createElement("a", { href: url(attachmentsURL, {
|
47
|
+
hash: queryAncestors(externalMaterial, 'question').getAttribute('display-number'),
|
48
|
+
}), target: "attachments" }, t('material')))),
|
49
|
+
React.createElement("span", { className: "e-column e-column--narrow table-of-contents--score-column" }, t('points', { count: maxScore }))))) : null;
|
50
|
+
}
|
51
|
+
const renderChildNodes = createRenderChildNodes({
|
52
|
+
section: withSectionContext(TOCSection),
|
53
|
+
question: withQuestionContext(TOCQuestion),
|
54
|
+
});
|
55
|
+
function TableOfContents(_props) {
|
56
|
+
const { root, maxScore } = useContext(CommonExamContext);
|
57
|
+
const { t } = useExamTranslation();
|
58
|
+
return (React.createElement("nav", { className: "table-of-contents e-mrg-b-6", "aria-labelledby": tocTitleId },
|
59
|
+
React.createElement("h2", { id: tocTitleId }, t('toc-heading')),
|
60
|
+
React.createElement("ol", { className: "e-list-plain e-pad-l-0" }, renderChildNodes(root)),
|
61
|
+
React.createElement("div", { className: "e-columns" },
|
62
|
+
React.createElement("strong", { className: "e-column" }, t('exam-total')),
|
63
|
+
React.createElement("strong", { className: "e-column e-column--narrow table-of-contents--score-column" }, t('points', { count: maxScore })))));
|
64
|
+
}
|
65
|
+
export default React.memo(TableOfContents);
|
66
|
+
//# sourceMappingURL=TableOfContents.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"TableOfContents.js","sourceRoot":"","sources":["../../src/components/TableOfContents.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function TextAnswer(props: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof TextAnswer>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=TextAnswer.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"TextAnswer.d.ts","sourceRoot":"","sources":["../../src/components/TextAnswer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAG9D,iBAAS,UAAU,CAAC,KAAK,EAAE,kBAAkB,eAe5C;;AAED,wBAAqC"}
|