@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,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function QuestionInstruction({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof QuestionInstruction>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=ExamQuestionInstruction.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamQuestionInstruction.d.ts","sourceRoot":"","sources":["../../src/components/ExamQuestionInstruction.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAE9D,iBAAS,mBAAmB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAE7E;;AAED,wBAA8C"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
function QuestionInstruction({ element, renderChildNodes }) {
|
3
|
+
return React.createElement("div", { className: "exam-question-instruction e-mrg-b-2" }, renderChildNodes(element));
|
4
|
+
}
|
5
|
+
export default React.memo(QuestionInstruction);
|
6
|
+
//# sourceMappingURL=ExamQuestionInstruction.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamQuestionInstruction.js","sourceRoot":"","sources":["../../src/components/ExamQuestionInstruction.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,SAAS,mBAAmB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAsB;IAC5E,OAAO,6BAAK,SAAS,EAAC,qCAAqC,IAAE,gBAAgB,CAAC,OAAO,CAAC,CAAO,CAAA;AAC/F,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamQuestionTitle.d.ts","sourceRoot":"","sources":["../../src/components/ExamQuestionTitle.tsx"],"names":[],"mappings":"AACA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAKzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;;AA6B9D,wBAA4C"}
|
@@ -0,0 +1,24 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React, { useContext } from 'react';
|
3
|
+
import AnsweringInstructions from './AnsweringInstructions';
|
4
|
+
import NotificationIcon from './NotificationIcon';
|
5
|
+
import { QuestionContext } from './QuestionContext';
|
6
|
+
import { Score } from './Score';
|
7
|
+
import { formatQuestionDisplayNumber } from '../formatting';
|
8
|
+
const ExamQuestionTitle = ({ element, renderChildNodes }) => {
|
9
|
+
const { displayNumber, maxScore, level, maxAnswers, childQuestions } = useContext(QuestionContext);
|
10
|
+
const Tag = `h${Math.min(3 + level, 6)}`;
|
11
|
+
return (React.createElement(React.Fragment, null,
|
12
|
+
React.createElement(Tag, { className: classNames('exam-question-title', { 'e-normal e-font-size-m': level > 0 }) },
|
13
|
+
React.createElement("strong", { className: classNames('exam-question-title__display-number', {
|
14
|
+
'exam-question-title__display-number--indented': level > 0,
|
15
|
+
}) }, formatQuestionDisplayNumber(displayNumber) + ' '),
|
16
|
+
renderChildNodes(element),
|
17
|
+
" ",
|
18
|
+
React.createElement(Score, { score: maxScore, size: level === 0 ? 'large' : 'small' })),
|
19
|
+
maxAnswers != null && childQuestions.length > 0 && (React.createElement("p", { className: "e-italic" },
|
20
|
+
React.createElement(NotificationIcon, null),
|
21
|
+
React.createElement(AnsweringInstructions, Object.assign({}, { maxAnswers, childQuestions, type: 'question' }))))));
|
22
|
+
};
|
23
|
+
export default React.memo(ExamQuestionTitle);
|
24
|
+
//# sourceMappingURL=ExamQuestionTitle.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamQuestionTitle.js","sourceRoot":"","sources":["../../src/components/ExamQuestionTitle.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,qBAAqB,MAAM,yBAAyB,CAAA;AAC3D,OAAO,gBAAgB,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAA;AAE/B,OAAO,EAAE,2BAA2B,EAAE,MAAM,eAAe,CAAA;AAE3D,MAAM,iBAAiB,GAAgD,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,EAAE;IACvG,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,eAAe,CAAC,CAAA;IAClG,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,EAA+B,CAAA;IAErE,OAAO,CACL;QACE,oBAAC,GAAG,IAAC,SAAS,EAAE,UAAU,CAAC,qBAAqB,EAAE,EAAE,wBAAwB,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC;YACxF,gCACE,SAAS,EAAE,UAAU,CAAC,qCAAqC,EAAE;oBAC3D,+CAA+C,EAAE,KAAK,GAAG,CAAC;iBAC3D,CAAC,IAED,2BAA2B,CAAC,aAAa,CAAC,GAAG,GAAG,CAC1C;YACR,gBAAgB,CAAC,OAAO,CAAC;;YAAE,oBAAC,KAAK,IAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,GAAI,CACzF;QACL,UAAU,IAAI,IAAI,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,IAAI,CAClD,2BAAG,SAAS,EAAC,UAAU;YACrB,oBAAC,gBAAgB,OAAG;YACpB,oBAAC,qBAAqB,oBAAK,EAAE,UAAU,EAAE,cAAc,EAAE,IAAI,EAAE,UAAU,EAAE,EAAI,CAC7E,CACL,CACA,CACJ,CAAA;AACH,CAAC,CAAA;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamSection.d.ts","sourceRoot":"","sources":["../../src/components/ExamSection.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;;AAyD9D,wBAA0D"}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
import { shallowEqual, useDispatch, useSelector } from 'react-redux';
|
3
|
+
import { useExamTranslation } from '../i18n';
|
4
|
+
import { sectionTitleId } from '../ids';
|
5
|
+
import { allowCas, allowCasCancelled } from '../store/cas/actions';
|
6
|
+
import { ExamContext } from './ExamContext';
|
7
|
+
import ProgressBar from './ProgressBar';
|
8
|
+
import Section from './Section';
|
9
|
+
import { SectionContext, withSectionContext } from './SectionContext';
|
10
|
+
function ExamSection({ element, renderChildNodes }) {
|
11
|
+
const casState = useSelector((state) => state.cas, shallowEqual);
|
12
|
+
const { casForbidden, displayNumber } = useContext(SectionContext);
|
13
|
+
return (React.createElement(Section, { className: "exam-section", "aria-labelledby": sectionTitleId(displayNumber) },
|
14
|
+
renderChildNodes(element),
|
15
|
+
casForbidden && React.createElement(CasControls, Object.assign({}, casState))));
|
16
|
+
}
|
17
|
+
function CasControls(props) {
|
18
|
+
const dispatch = useDispatch();
|
19
|
+
const { t } = useExamTranslation();
|
20
|
+
const { casCountdownDuration } = useContext(ExamContext);
|
21
|
+
return (React.createElement("div", { className: "e-cas-controls" }, props.casStatus === 'forbidden' ? (React.createElement("div", { className: "e-text-center" },
|
22
|
+
React.createElement("hr", { className: "e-exam-separator" }),
|
23
|
+
React.createElement("p", null, t('cas.forbidden.infoText')),
|
24
|
+
React.createElement("button", { className: "e-button", id: "allow-cas", onClick: () => dispatch(allowCas(casCountdownDuration)) }, t('cas.forbidden.buttonText')))) : props.casStatus === 'allowing' ? (React.createElement("div", { className: "e-text-center", ref: (e) => e != null && casCountdownDuration === props.durationRemaining && e.scrollIntoView() },
|
25
|
+
React.createElement("hr", { className: "e-exam-separator" }),
|
26
|
+
React.createElement("p", null, t('cas.allowing.infoText')),
|
27
|
+
React.createElement(ProgressBar, { className: "e-mrg-b-2", duration: casCountdownDuration }),
|
28
|
+
React.createElement("button", { className: "e-button", id: "allow-cas-cancelled", onClick: () => dispatch(allowCasCancelled()) }, t('cas.allowing.buttonText', { count: props.durationRemaining })))) : (React.createElement("div", { className: "notification e-text-left e-mrg-b-0" }, t('cas.allowed.infoText')))));
|
29
|
+
}
|
30
|
+
export default React.memo(withSectionContext(ExamSection));
|
31
|
+
//# sourceMappingURL=ExamSection.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamSection.js","sourceRoot":"","sources":["../../src/components/ExamSection.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAEpE,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAA;AAEvC,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AAElE,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAC3C,OAAO,WAAW,MAAM,eAAe,CAAA;AACvC,OAAO,OAAO,MAAM,WAAW,CAAA;AAC/B,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAErE,SAAS,WAAW,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAsB;IACpE,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,KAAe,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,YAAY,CAAC,CAAA;IAC1E,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAElE,OAAO,CACL,oBAAC,OAAO,IAAC,SAAS,EAAC,cAAc,qBAAkB,cAAc,CAAC,aAAa,CAAC;QAC7E,gBAAgB,CAAC,OAAO,CAAC;QACzB,YAAY,IAAI,oBAAC,WAAW,oBAAK,QAAQ,EAAI,CACtC,CACX,CAAA;AACH,CAAC;AAED,SAAS,WAAW,CAAC,KAAe;IAClC,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAA;IAC9B,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,EAAE,oBAAoB,EAAE,GAAG,UAAU,CAAC,WAAW,CAAC,CAAA;IAExD,OAAO,CACL,6BAAK,SAAS,EAAC,gBAAgB,IAC5B,KAAK,CAAC,SAAS,KAAK,WAAW,CAAC,CAAC,CAAC,CACjC,6BAAK,SAAS,EAAC,eAAe;QAC5B,4BAAI,SAAS,EAAC,kBAAkB,GAAG;QACnC,+BAAI,CAAC,CAAC,wBAAwB,CAAC,CAAK;QACpC,gCAAQ,SAAS,EAAC,UAAU,EAAC,EAAE,EAAC,WAAW,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,IAChG,CAAC,CAAC,0BAA0B,CAAC,CACvB,CACL,CACP,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,CACnC,6BACE,SAAS,EAAC,eAAe,EACzB,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,oBAAoB,KAAK,KAAK,CAAC,iBAAiB,IAAI,CAAC,CAAC,cAAc,EAAE;QAE/F,4BAAI,SAAS,EAAC,kBAAkB,GAAG;QACnC,+BAAI,CAAC,CAAC,uBAAuB,CAAC,CAAK;QACnC,oBAAC,WAAW,IAAC,SAAS,EAAC,WAAW,EAAC,QAAQ,EAAE,oBAAoB,GAAI;QACrE,gCAAQ,SAAS,EAAC,UAAU,EAAC,EAAE,EAAC,qBAAqB,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,IAC/F,CAAC,CAAC,yBAAyB,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,iBAAiB,EAAE,CAAC,CAC1D,CACL,CACP,CAAC,CAAC,CAAC,CACF,6BAAK,SAAS,EAAC,oCAAoC,IAAE,CAAC,CAAC,sBAAsB,CAAC,CAAO,CACtF,CACG,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function ExamSectionTitle({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof ExamSectionTitle>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=ExamSectionTitle.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamSectionTitle.d.ts","sourceRoot":"","sources":["../../src/components/ExamSectionTitle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAQ9D,iBAAS,gBAAgB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAoB1E;;AAED,wBAA2C"}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
import { useExamTranslation } from '../i18n';
|
3
|
+
import { sectionTitleId } from '../ids';
|
4
|
+
import AnsweringInstructions from './AnsweringInstructions';
|
5
|
+
import { CommonExamContext } from './CommonExamContext';
|
6
|
+
import NotificationIcon from './NotificationIcon';
|
7
|
+
import { SectionContext } from './SectionContext';
|
8
|
+
function ExamSectionTitle({ element, renderChildNodes }) {
|
9
|
+
const { numberOfSections } = useContext(CommonExamContext);
|
10
|
+
const { displayNumber, minAnswers, maxAnswers, childQuestions } = useContext(SectionContext);
|
11
|
+
const { t } = useExamTranslation();
|
12
|
+
return (React.createElement(React.Fragment, null,
|
13
|
+
element.hasChildNodes() && (React.createElement("h2", { className: "exam-section-title", id: sectionTitleId(displayNumber) },
|
14
|
+
numberOfSections > 1 && t('section', { displayNumber }),
|
15
|
+
" ",
|
16
|
+
renderChildNodes(element))),
|
17
|
+
maxAnswers != null && (React.createElement("span", { className: "notification notification--inline" },
|
18
|
+
React.createElement(NotificationIcon, null),
|
19
|
+
React.createElement(AnsweringInstructions, Object.assign({}, { maxAnswers, minAnswers, childQuestions, type: 'section' }))))));
|
20
|
+
}
|
21
|
+
export default React.memo(ExamSectionTitle);
|
22
|
+
//# sourceMappingURL=ExamSectionTitle.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExamSectionTitle.js","sourceRoot":"","sources":["../../src/components/ExamSectionTitle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAA;AACvC,OAAO,qBAAqB,MAAM,yBAAyB,CAAA;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AACvD,OAAO,gBAAgB,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,SAAS,gBAAgB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAsB;IACzE,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAC1D,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAC5F,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAElC,OAAO,CACL;QACG,OAAO,CAAC,aAAa,EAAE,IAAI,CAC1B,4BAAI,SAAS,EAAC,oBAAoB,EAAC,EAAE,EAAE,cAAc,CAAC,aAAa,CAAC;YACjE,gBAAgB,GAAG,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,aAAa,EAAE,CAAC;;YAAG,gBAAgB,CAAC,OAAO,CAAC,CACjF,CACN;QACA,UAAU,IAAI,IAAI,IAAI,CACrB,8BAAM,SAAS,EAAC,mCAAmC;YACjD,oBAAC,gBAAgB,OAAG;YACpB,oBAAC,qBAAqB,oBAAK,EAAE,UAAU,EAAE,UAAU,EAAE,cAAc,EAAE,IAAI,EAAE,SAAS,EAAE,EAAI,CACrF,CACR,CACA,CACJ,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA"}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
interface ExternalMaterialListProps extends ExamComponentProps {
|
4
|
+
forceRender?: boolean;
|
5
|
+
showTitle?: boolean;
|
6
|
+
}
|
7
|
+
declare function ExternalMaterialList({ element, showTitle, forceRender }: ExternalMaterialListProps): JSX.Element | null;
|
8
|
+
declare const _default: React.MemoExoticComponent<typeof ExternalMaterialList>;
|
9
|
+
export default _default;
|
10
|
+
//# sourceMappingURL=ExternalMaterialList.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExternalMaterialList.d.ts","sourceRoot":"","sources":["../../src/components/ExternalMaterialList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,EAA0B,kBAAkB,EAAiB,MAAM,2BAA2B,CAAA;AAkCrG,UAAU,yBAA0B,SAAQ,kBAAkB;IAC5D,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAED,iBAAS,oBAAoB,CAAC,EAAE,OAAO,EAAE,SAAgB,EAAE,WAAmB,EAAE,EAAE,yBAAyB,sBAoB1G;;AAED,wBAA+C"}
|
@@ -0,0 +1,33 @@
|
|
1
|
+
import React, { useContext } from 'react';
|
2
|
+
import { createRenderChildNodes, RenderOptions } from '../createRenderChildNodes';
|
3
|
+
import { queryAncestors } from '../dom-utils';
|
4
|
+
import { useExamTranslation } from '../i18n';
|
5
|
+
import { externalMaterialListTitleId } from '../ids';
|
6
|
+
import { url } from '../url';
|
7
|
+
import { AttachmentContext, withAttachmentContext } from './AttachmentContext';
|
8
|
+
import { CommonExamContext } from './CommonExamContext';
|
9
|
+
const renderChildNodes = createRenderChildNodes({
|
10
|
+
attachment: withAttachmentContext(Attachment),
|
11
|
+
'attachment-title': AttachmentTitle,
|
12
|
+
});
|
13
|
+
function Attachment({ element }) {
|
14
|
+
const { displayNumber } = useContext(AttachmentContext);
|
15
|
+
return (React.createElement("li", { "data-list-number": displayNumber, "aria-label": displayNumber }, renderChildNodes(element, RenderOptions.SkipHTML)));
|
16
|
+
}
|
17
|
+
function AttachmentTitle({ element }) {
|
18
|
+
const { attachmentsURL } = useContext(CommonExamContext);
|
19
|
+
const { displayNumber } = useContext(AttachmentContext);
|
20
|
+
return (React.createElement("a", { href: url(attachmentsURL, { hash: displayNumber }), className: "exam-attachment-title", target: "attachments" }, renderChildNodes(element)));
|
21
|
+
}
|
22
|
+
function ExternalMaterialList({ element, showTitle = true, forceRender = false }) {
|
23
|
+
if (queryAncestors(element, 'question') == null && !forceRender) {
|
24
|
+
return null;
|
25
|
+
}
|
26
|
+
const { t } = useExamTranslation();
|
27
|
+
const id = externalMaterialListTitleId(element);
|
28
|
+
return (React.createElement("div", { className: "external-material-list e-mrg-b-4" },
|
29
|
+
showTitle && (React.createElement("div", { className: "e-font-size-l e-semibold", id: id }, t('external-material-title'))),
|
30
|
+
React.createElement("ol", { className: "e-list-data e-pad-l-0 e-mrg-0", "aria-labelledby": id }, renderChildNodes(element))));
|
31
|
+
}
|
32
|
+
export default React.memo(ExternalMaterialList);
|
33
|
+
//# sourceMappingURL=ExternalMaterialList.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ExternalMaterialList.js","sourceRoot":"","sources":["../../src/components/ExternalMaterialList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,sBAAsB,EAAsB,aAAa,EAAE,MAAM,2BAA2B,CAAA;AACrG,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,2BAA2B,EAAE,MAAM,QAAQ,CAAA;AACpD,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAA;AAC5B,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA;AAC9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD,MAAM,gBAAgB,GAAG,sBAAsB,CAAC;IAC9C,UAAU,EAAE,qBAAqB,CAAC,UAAU,CAAC;IAC7C,kBAAkB,EAAE,eAAe;CACpC,CAAC,CAAA;AAEF,SAAS,UAAU,CAAC,EAAE,OAAO,EAAsB;IACjD,MAAM,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAEvD,OAAO,CACL,gDAAsB,aAAa,gBAAc,aAAc,IAC5D,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,QAAQ,CAAC,CAC/C,CACN,CAAA;AACH,CAAC;AAED,SAAS,eAAe,CAAC,EAAE,OAAO,EAAsB;IACtD,MAAM,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IACxD,MAAM,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAEvD,OAAO,CACL,2BAAG,IAAI,EAAE,GAAG,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,aAAc,EAAE,CAAC,EAAE,SAAS,EAAC,uBAAuB,EAAC,MAAM,EAAC,aAAa,IAC3G,gBAAgB,CAAC,OAAO,CAAC,CACxB,CACL,CAAA;AACH,CAAC;AAOD,SAAS,oBAAoB,CAAC,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI,EAAE,WAAW,GAAG,KAAK,EAA6B;IACzG,IAAI,cAAc,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,EAAE;QAC/D,OAAO,IAAI,CAAA;KACZ;IAED,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,EAAE,GAAG,2BAA2B,CAAC,OAAO,CAAC,CAAA;IAE/C,OAAO,CACL,6BAAK,SAAS,EAAC,kCAAkC;QAC9C,SAAS,IAAI,CACZ,6BAAK,SAAS,EAAC,0BAA0B,EAAC,EAAE,EAAE,EAAE,IAC7C,CAAC,CAAC,yBAAyB,CAAC,CACzB,CACP;QACD,4BAAI,SAAS,EAAC,+BAA+B,qBAAkB,EAAE,IAC9D,gBAAgB,CAAC,OAAO,CAAC,CACvB,CACD,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function File({ element, className, renderChildNodes }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof File>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=File.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"File.d.ts","sourceRoot":"","sources":["../../src/components/File.tsx"],"names":[],"mappings":"AACA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAE9D,iBAAS,IAAI,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAgBzE;;AAED,wBAA+B"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React, { useContext } from 'react';
|
3
|
+
import { CommonExamContext } from './CommonExamContext';
|
4
|
+
function File({ element, className, renderChildNodes }) {
|
5
|
+
const src = element.getAttribute('src');
|
6
|
+
const hasDescription = element.hasChildNodes();
|
7
|
+
const { resolveAttachment } = useContext(CommonExamContext);
|
8
|
+
return (React.createElement("a", { className: classNames('file e-nowrap', className), href: resolveAttachment(src), download: true }, hasDescription ? (React.createElement(React.Fragment, null,
|
9
|
+
renderChildNodes(element),
|
10
|
+
" (",
|
11
|
+
src,
|
12
|
+
")")) : (src)));
|
13
|
+
}
|
14
|
+
export default React.memo(File);
|
15
|
+
//# sourceMappingURL=File.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"File.js","sourceRoot":"","sources":["../../src/components/File.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAGvD,SAAS,IAAI,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAsB;IACxE,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,CAAC,KAAK,CAAE,CAAA;IACxC,MAAM,cAAc,GAAG,OAAO,CAAC,aAAa,EAAE,CAAA;IAC9C,MAAM,EAAE,iBAAiB,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAE3D,OAAO,CACL,2BAAG,SAAS,EAAE,UAAU,CAAC,eAAe,EAAE,SAAS,CAAC,EAAE,IAAI,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE,QAAQ,UACzF,cAAc,CAAC,CAAC,CAAC,CAChB;QACG,gBAAgB,CAAC,OAAO,CAAC;;QAAI,GAAG;YAChC,CACJ,CAAC,CAAC,CAAC,CACF,GAAG,CACJ,CACC,CACL,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../createRenderChildNodes';
|
3
|
+
declare function Formula({ element, className }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof Formula>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=Formula.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Formula.d.ts","sourceRoot":"","sources":["../../src/components/Formula.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAG9D,iBAAS,OAAO,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,kBAAkB,eAe1D;;AAED,wBAAkC"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React from 'react';
|
3
|
+
import { getAttribute } from '../dom-utils';
|
4
|
+
function Formula({ element, className }) {
|
5
|
+
const svg = getAttribute(element, 'svg');
|
6
|
+
const assistiveTitle = getAttribute(element, 'assistive-title');
|
7
|
+
const isDisplayFormula = getAttribute(element, 'mode') === 'display';
|
8
|
+
return (React.createElement(React.Fragment, null,
|
9
|
+
React.createElement("span", { className: classNames('e-formula', { 'e-block': isDisplayFormula }, className), dangerouslySetInnerHTML: { __html: svg }, "aria-hidden": "true" }),
|
10
|
+
React.createElement("span", { className: "e-screen-reader-only" }, assistiveTitle || element.textContent)));
|
11
|
+
}
|
12
|
+
export default React.memo(Formula);
|
13
|
+
//# sourceMappingURL=Formula.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Formula.js","sourceRoot":"","sources":["../../src/components/Formula.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAE3C,SAAS,OAAO,CAAC,EAAE,OAAO,EAAE,SAAS,EAAsB;IACzD,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,EAAE,KAAK,CAAE,CAAA;IACzC,MAAM,cAAc,GAAG,YAAY,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,SAAS,CAAA;IAEpE,OAAO,CACL;QACE,8BACE,SAAS,EAAE,UAAU,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE,SAAS,CAAC,EAC9E,uBAAuB,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,iBAC5B,MAAM,GAClB;QACF,8BAAM,SAAS,EAAC,sBAAsB,IAAE,cAAc,IAAI,OAAO,CAAC,WAAW,CAAQ,CACpF,CACJ,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Hints.d.ts","sourceRoot":"","sources":["../../src/components/Hints.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,kBAAkB,EAAoB,MAAM,2BAA2B,CAAA;AAMhF,QAAA,MAAM,KAAK,EAAE,KAAK,CAAC,iBAAiB,CAAC,kBAAkB,CAmBtD,CAAA;AAiCD,eAAe,KAAK,CAAA"}
|
@@ -0,0 +1,30 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,6 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,28 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,6 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,44 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ImageOverlay.js","sourceRoot":"","sources":["../../src/components/ImageOverlay.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,19 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,14 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,20 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|
@@ -0,0 +1,6 @@
|
|
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
|
@@ -0,0 +1 @@
|
|
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"}
|