@digabi/exam-engine-core 19.0.2 → 19.0.4-alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/__tests__/tsconfig.tsbuildinfo +1 -1
- package/dist/components/grading/AnnotationPopup.d.ts +11 -0
- package/dist/components/grading/AnnotationPopup.d.ts.map +1 -0
- package/dist/components/grading/AnnotationPopup.js +20 -0
- package/dist/components/grading/AnnotationPopup.js.map +1 -0
- package/dist/components/grading/AnswerWithAnnotations.d.ts +11 -0
- package/dist/components/grading/AnswerWithAnnotations.d.ts.map +1 -0
- package/dist/components/grading/AnswerWithAnnotations.js +15 -0
- package/dist/components/grading/AnswerWithAnnotations.js.map +1 -0
- package/dist/components/grading/ChoiceAnswer.d.ts +6 -0
- package/dist/components/grading/ChoiceAnswer.d.ts.map +1 -0
- package/dist/components/grading/ChoiceAnswer.js +57 -0
- package/dist/components/grading/ChoiceAnswer.js.map +1 -0
- package/dist/components/grading/DropdownAnswer.d.ts +6 -0
- package/dist/components/grading/DropdownAnswer.d.ts.map +1 -0
- package/dist/components/grading/DropdownAnswer.js +43 -0
- package/dist/components/grading/DropdownAnswer.js.map +1 -0
- package/dist/components/grading/Grading.d.ts +4 -0
- package/dist/components/grading/Grading.d.ts.map +1 -0
- package/dist/components/grading/Grading.js +81 -0
- package/dist/components/grading/Grading.js.map +1 -0
- package/dist/components/grading/GradingAnswer.d.ts +17 -0
- package/dist/components/grading/GradingAnswer.d.ts.map +1 -0
- package/dist/components/grading/GradingAnswer.js +179 -0
- package/dist/components/grading/GradingAnswer.js.map +1 -0
- package/dist/components/grading/MultiLineAnswer.d.ts +14 -0
- package/dist/components/grading/MultiLineAnswer.d.ts.map +1 -0
- package/dist/components/grading/MultiLineAnswer.js +61 -0
- package/dist/components/grading/MultiLineAnswer.js.map +1 -0
- package/dist/components/grading/Question.d.ts +5 -0
- package/dist/components/grading/Question.d.ts.map +1 -0
- package/dist/components/grading/Question.js +23 -0
- package/dist/components/grading/Question.js.map +1 -0
- package/dist/components/grading/QuestionTitle.d.ts +6 -0
- package/dist/components/grading/QuestionTitle.d.ts.map +1 -0
- package/dist/components/grading/QuestionTitle.js +21 -0
- package/dist/components/grading/QuestionTitle.js.map +1 -0
- package/dist/components/grading/Results.d.ts +15 -0
- package/dist/components/grading/Results.d.ts.map +1 -0
- package/dist/components/grading/Results.js +77 -0
- package/dist/components/grading/Results.js.map +1 -0
- package/dist/components/grading/ScoredTextAnswer.d.ts +6 -0
- package/dist/components/grading/ScoredTextAnswer.d.ts.map +1 -0
- package/dist/components/grading/ScoredTextAnswer.js +22 -0
- package/dist/components/grading/ScoredTextAnswer.js.map +1 -0
- package/dist/components/grading/Section.d.ts +5 -0
- package/dist/components/grading/Section.d.ts.map +1 -0
- package/dist/components/grading/Section.js +18 -0
- package/dist/components/grading/Section.js.map +1 -0
- package/dist/components/grading/SingleLineAnswer.d.ts +12 -0
- package/dist/components/grading/SingleLineAnswer.d.ts.map +1 -0
- package/dist/components/grading/SingleLineAnswer.js +23 -0
- package/dist/components/grading/SingleLineAnswer.js.map +1 -0
- package/dist/components/grading/TextAnswer.d.ts +7 -0
- package/dist/components/grading/TextAnswer.d.ts.map +1 -0
- package/dist/components/grading/TextAnswer.js +53 -0
- package/dist/components/grading/TextAnswer.js.map +1 -0
- package/dist/components/grading/editAnnotations.d.ts +27 -0
- package/dist/components/grading/editAnnotations.d.ts.map +1 -0
- package/dist/components/grading/editAnnotations.js +170 -0
- package/dist/components/grading/editAnnotations.js.map +1 -0
- package/dist/components/grading/internal/AnnotationList.d.ts +5 -0
- package/dist/components/grading/internal/AnnotationList.d.ts.map +1 -0
- package/dist/components/grading/internal/AnnotationList.js +43 -0
- package/dist/components/grading/internal/AnnotationList.js.map +1 -0
- package/dist/components/grading/internal/QuestionAutoScore.d.ts +10 -0
- package/dist/components/grading/internal/QuestionAutoScore.d.ts.map +1 -0
- package/dist/components/grading/internal/QuestionAutoScore.js +17 -0
- package/dist/components/grading/internal/QuestionAutoScore.js.map +1 -0
- package/dist/components/grading/internal/QuestionManualScore.d.ts +12 -0
- package/dist/components/grading/internal/QuestionManualScore.d.ts.map +1 -0
- package/dist/components/grading/internal/QuestionManualScore.js +61 -0
- package/dist/components/grading/internal/QuestionManualScore.js.map +1 -0
- package/dist/components/grading/internal/QuestionScoresContainer.d.ts +10 -0
- package/dist/components/grading/internal/QuestionScoresContainer.d.ts.map +1 -0
- package/dist/components/grading/internal/QuestionScoresContainer.js +12 -0
- package/dist/components/grading/internal/QuestionScoresContainer.js.map +1 -0
- package/dist/components/results/Results2.d.ts +15 -0
- package/dist/components/results/Results2.d.ts.map +1 -0
- package/dist/components/results/Results2.js +79 -0
- package/dist/components/results/Results2.js.map +1 -0
- package/dist/components/results/internal/AnnotationList.js +1 -1
- package/dist/components/results/internal/AnnotationList.js.map +1 -1
- package/dist/editAnnotations.d.ts +2 -0
- package/dist/editAnnotations.d.ts.map +1 -0
- package/dist/editAnnotations.js +8 -0
- package/dist/editAnnotations.js.map +1 -0
- package/dist/editAnnotationsOld.d.ts +3 -0
- package/dist/editAnnotationsOld.d.ts.map +1 -0
- package/dist/editAnnotationsOld.js +340 -0
- package/dist/editAnnotationsOld.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/main-bundle.js +1 -1
- package/dist/main.css +1 -1
- package/dist/renderAnnotations.d.ts +5 -1
- package/dist/renderAnnotations.d.ts.map +1 -1
- package/dist/renderAnnotations.js +52 -36
- package/dist/renderAnnotations.js.map +1 -1
- package/package.json +2 -2
@@ -0,0 +1,11 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
export declare const AnnotationPopup: React.FunctionComponent<{
|
3
|
+
setMessage: (message: string) => void;
|
4
|
+
message: string;
|
5
|
+
popupVisible: boolean;
|
6
|
+
position: {
|
7
|
+
left: number;
|
8
|
+
top: number;
|
9
|
+
};
|
10
|
+
}>;
|
11
|
+
//# sourceMappingURL=AnnotationPopup.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"AnnotationPopup.d.ts","sourceRoot":"","sources":["../../../src/components/grading/AnnotationPopup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAA;AAE1D,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC;IACpD,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACrC,OAAO,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,OAAO,CAAA;IACrB,QAAQ,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAA;CACxC,CAuCA,CAAA"}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import React, { useEffect, useRef, useState } from 'react';
|
2
|
+
export const AnnotationPopup = ({ setMessage, message, popupVisible, position }) => {
|
3
|
+
const popupRef = useRef(null);
|
4
|
+
const [field, setField] = useState('');
|
5
|
+
useEffect(() => {
|
6
|
+
setField(message);
|
7
|
+
}, [message]);
|
8
|
+
return popupVisible ? (React.createElement("div", { style: {
|
9
|
+
display: popupVisible ? 'block' : 'none',
|
10
|
+
position: 'absolute',
|
11
|
+
left: position.left,
|
12
|
+
top: position.top,
|
13
|
+
}, className: "popup", ref: popupRef },
|
14
|
+
React.createElement("div", { className: "popup add-annotation-popup" },
|
15
|
+
React.createElement("form", { onSubmit: (e) => e.preventDefault() },
|
16
|
+
React.createElement("input", { onChange: (e) => setField(e.target.value), value: field, className: "add-annotation-text", type: "text", autoFocus: true }),
|
17
|
+
React.createElement("i", { className: "fa fa-comment" }),
|
18
|
+
React.createElement("button", { type: "submit", "data-i18n": "arpa.annotate", onClick: () => setMessage(field) }, "Merkitse"))))) : (React.createElement(React.Fragment, null));
|
19
|
+
};
|
20
|
+
//# sourceMappingURL=AnnotationPopup.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"AnnotationPopup.js","sourceRoot":"","sources":["../../../src/components/grading/AnnotationPopup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE1D,MAAM,CAAC,MAAM,eAAe,GAKvB,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE;IACvD,MAAM,QAAQ,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAE7C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAA;IAE9C,SAAS,CAAC,GAAG,EAAE;QACb,QAAQ,CAAC,OAAO,CAAC,CAAA;IACnB,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,OAAO,YAAY,CAAC,CAAC,CAAC,CACpB,6BACE,KAAK,EAAE;YACL,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;YACxC,QAAQ,EAAE,UAAU;YACpB,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,GAAG,EAAE,QAAQ,CAAC,GAAG;SAClB,EACD,SAAS,EAAC,OAAO,EACjB,GAAG,EAAE,QAAQ;QAEb,6BAAK,SAAS,EAAC,4BAA4B;YACzC,8BAAM,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE;gBACvC,+BACE,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EACzC,KAAK,EAAE,KAAK,EACZ,SAAS,EAAC,qBAAqB,EAC/B,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,IAAI,GACf;gBACF,2BAAG,SAAS,EAAC,eAAe,GAAK;gBACjC,gCAAQ,IAAI,EAAC,QAAQ,eAAW,eAAe,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,eAEvE,CACJ,CACH,CACF,CACP,CAAC,CAAC,CAAC,CACF,yCAAK,CACN,CAAA;AACH,CAAC,CAAA"}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { Annotation } from '../..';
|
3
|
+
export declare const AnswerWithAnnotations: React.FunctionComponent<{
|
4
|
+
type: 'richText' | 'text';
|
5
|
+
value?: string;
|
6
|
+
annotations: {
|
7
|
+
pregrading: Annotation[];
|
8
|
+
censoring: Annotation[];
|
9
|
+
};
|
10
|
+
}>;
|
11
|
+
//# sourceMappingURL=AnswerWithAnnotations.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"AnswerWithAnnotations.d.ts","sourceRoot":"","sources":["../../../src/components/grading/AnswerWithAnnotations.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkC,MAAM,OAAO,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAIlC,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,iBAAiB,CAAC;IAC1D,IAAI,EAAE,UAAU,GAAG,MAAM,CAAA;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,WAAW,EAAE;QAAE,UAAU,EAAE,UAAU,EAAE,CAAC;QAAC,SAAS,EAAE,UAAU,EAAE,CAAA;KAAE,CAAA;CACnE,CAmBA,CAAA"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import React, { useLayoutEffect, useRef } from 'react';
|
2
|
+
import { renderAnnotations } from '../../renderAnnotations';
|
3
|
+
export const AnswerWithAnnotations = ({ type, annotations, value }) => {
|
4
|
+
const answerRef = useRef(null);
|
5
|
+
useLayoutEffect(() => {
|
6
|
+
console.log('LAYOUT', annotations.censoring.length);
|
7
|
+
if (answerRef.current) {
|
8
|
+
answerRef.current.innerHTML = value || '';
|
9
|
+
renderAnnotations(answerRef.current, annotations.pregrading, annotations.censoring);
|
10
|
+
}
|
11
|
+
});
|
12
|
+
return type === 'richText' ? (React.createElement("div", { ref: answerRef })) : (React.createElement("span", { className: "text-answer text-answer--single-line" },
|
13
|
+
React.createElement("span", { className: "e-inline-block", ref: answerRef }, value)));
|
14
|
+
};
|
15
|
+
//# sourceMappingURL=AnswerWithAnnotations.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"AnswerWithAnnotations.js","sourceRoot":"","sources":["../../../src/components/grading/AnswerWithAnnotations.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAG3D,MAAM,CAAC,MAAM,qBAAqB,GAI7B,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,EAAE;IACpC,MAAM,SAAS,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAE9C,eAAe,CAAC,GAAG,EAAE;QACnB,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;QACnD,IAAI,SAAS,CAAC,OAAO,EAAE;YACrB,SAAS,CAAC,OAAO,CAAC,SAAS,GAAG,KAAK,IAAI,EAAE,CAAA;YACzC,iBAAiB,CAAC,SAAS,CAAC,OAAO,EAAE,WAAW,CAAC,UAAU,EAAE,WAAW,CAAC,SAAS,CAAC,CAAA;SACpF;IACH,CAAC,CAAC,CAAA;IACF,OAAO,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,CAC3B,6BAAK,GAAG,EAAE,SAAS,GAAI,CACxB,CAAC,CAAC,CAAC,CACF,8BAAM,SAAS,EAAC,sCAAsC;QACpD,8BAAM,SAAS,EAAC,gBAAgB,EAAC,GAAG,EAAE,SAAS,IAC5C,KAAK,CACD,CACF,CACR,CAAA;AACH,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../../createRenderChildNodes';
|
3
|
+
declare function ChoiceAnswer({ element, renderChildNodes }: ExamComponentProps): JSX.Element;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof ChoiceAnswer>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=ChoiceAnswer.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ChoiceAnswer.d.ts","sourceRoot":"","sources":["../../../src/components/grading/ChoiceAnswer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAA;AAuEjE,iBAAS,YAAY,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,eAyCtE;;AAED,wBAAuC"}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React, { useContext } from 'react';
|
3
|
+
import { getNumericAttribute, mapChildElements, query } from '../../dom-utils';
|
4
|
+
import { useExamTranslation } from '../../i18n';
|
5
|
+
import { ScreenReaderOnly } from '../ScreenReaderOnly';
|
6
|
+
import { findMultiChoiceFromGradingStructure, ResultsContext } from '../context/ResultsContext';
|
7
|
+
import ResultsExamQuestionAutoScore from './internal/QuestionAutoScore';
|
8
|
+
function ChoiceAnswerOption({ renderChildNodes, selected, element, questionId, direction, isCorrect, }) {
|
9
|
+
const { t } = useExamTranslation();
|
10
|
+
const className = element.getAttribute('class');
|
11
|
+
const optionId = element.getAttribute('option-id');
|
12
|
+
const content = (React.createElement("div", { className: classNames('e-choice-answer-option e-column', className, {
|
13
|
+
'e-choice-answer-option--selected': selected,
|
14
|
+
}) }, renderChildNodes(element)));
|
15
|
+
const Content = ({ narrow = false }) => (React.createElement(React.Fragment, null,
|
16
|
+
React.createElement("input", { type: "radio", className: classNames('e-radio-button', { 'e-column e-column--narrow': narrow }), name: String(questionId), value: optionId, checked: selected, readOnly: true }),
|
17
|
+
content,
|
18
|
+
isCorrect && React.createElement(ScreenReaderOnly, null, t('screen-reader.correct-answer'))));
|
19
|
+
return direction === 'vertical' ? (React.createElement("div", { className: "e-mrg-b-1" },
|
20
|
+
React.createElement("label", { className: classNames('e-columns', {
|
21
|
+
'e-correct-answer-left': isCorrect,
|
22
|
+
'e-columns--inline': query(element, ['image', 'video']) == null /* Force full width for options containing responsive media */,
|
23
|
+
}) },
|
24
|
+
React.createElement(Content, { narrow: true })))) : (React.createElement("div", { className: "e-column e-mrg-b-1" },
|
25
|
+
React.createElement("label", { className: classNames('e-block e-text-center', { 'e-correct-answer-bottom': isCorrect }) },
|
26
|
+
React.createElement(Content, null))));
|
27
|
+
}
|
28
|
+
function ChoiceAnswer({ element, renderChildNodes }) {
|
29
|
+
const { answersByQuestionId, gradingStructure } = useContext(ResultsContext);
|
30
|
+
const questionId = getNumericAttribute(element, 'question-id');
|
31
|
+
const answer = answersByQuestionId[questionId];
|
32
|
+
const direction = element.getAttribute('direction') || 'vertical';
|
33
|
+
const className = element.getAttribute('class');
|
34
|
+
const choice = findMultiChoiceFromGradingStructure(gradingStructure, questionId);
|
35
|
+
const scoreValue = answer && choice.options.find((option) => option.id === Number(answer.value)).score;
|
36
|
+
const maxScore = getNumericAttribute(element, 'max-score');
|
37
|
+
return (React.createElement(React.Fragment, null,
|
38
|
+
scoreValue !== undefined && React.createElement(ResultsExamQuestionAutoScore, { score: scoreValue, maxScore: maxScore }),
|
39
|
+
React.createElement("div", { className: classNames('e-choice-answer', className, {
|
40
|
+
'e-columns': direction === 'horizontal',
|
41
|
+
}) }, mapChildElements(element, (childElement) => {
|
42
|
+
const optionId = getNumericAttribute(childElement, 'option-id');
|
43
|
+
const selected = answer != null && Number(answer.value) === optionId;
|
44
|
+
const grading = choice.options.find((option) => option.id === optionId);
|
45
|
+
return (React.createElement(ChoiceAnswerOption, { ...{
|
46
|
+
element: childElement,
|
47
|
+
renderChildNodes,
|
48
|
+
questionId,
|
49
|
+
key: optionId,
|
50
|
+
direction,
|
51
|
+
selected,
|
52
|
+
isCorrect: grading.correct,
|
53
|
+
} }));
|
54
|
+
}))));
|
55
|
+
}
|
56
|
+
export default React.memo(ChoiceAnswer);
|
57
|
+
//# sourceMappingURL=ChoiceAnswer.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ChoiceAnswer.js","sourceRoot":"","sources":["../../../src/components/grading/ChoiceAnswer.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAGzC,OAAO,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAC9E,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AACtD,OAAO,EAAE,mCAAmC,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC/F,OAAO,4BAA4B,MAAM,8BAA8B,CAAA;AASvE,SAAS,kBAAkB,CAAC,EAC1B,gBAAgB,EAChB,QAAQ,EACR,OAAO,EACP,UAAU,EACV,SAAS,EACT,SAAS,GACe;IACxB,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAClC,MAAM,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;IAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,YAAY,CAAC,WAAW,CAAE,CAAA;IAEnD,MAAM,OAAO,GAAG,CACd,6BACE,SAAS,EAAE,UAAU,CAAC,iCAAiC,EAAE,SAAS,EAAE;YAClE,kCAAkC,EAAE,QAAQ;SAC7C,CAAC,IAED,gBAAgB,CAAC,OAAO,CAAC,CACtB,CACP,CAAA;IACD,MAAM,OAAO,GAAkD,CAAC,EAAE,MAAM,GAAG,KAAK,EAAE,EAAE,EAAE,CAAC,CACrF;QACE,+BACE,IAAI,EAAC,OAAO,EACZ,SAAS,EAAE,UAAU,CAAC,gBAAgB,EAAE,EAAE,2BAA2B,EAAE,MAAM,EAAE,CAAC,EAChF,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,EACxB,KAAK,EAAE,QAAQ,EACf,OAAO,EAAE,QAAQ,EACjB,QAAQ,SACR;QACD,OAAO;QACP,SAAS,IAAI,oBAAC,gBAAgB,QAAE,CAAC,CAAC,8BAA8B,CAAC,CAAoB,CACrF,CACJ,CAAA;IAED,OAAO,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,CAChC,6BAAK,SAAS,EAAC,WAAW;QACxB,+BACE,SAAS,EAAE,UAAU,CAAC,WAAW,EAAE;gBACjC,uBAAuB,EAAE,SAAS;gBAClC,mBAAmB,EACjB,KAAK,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,8DAA8D;aAC5G,CAAC;YAEF,oBAAC,OAAO,IAAC,MAAM,SAAG,CACZ,CACJ,CACP,CAAC,CAAC,CAAC,CACF,6BAAK,SAAS,EAAC,oBAAoB;QACjC,+BAAO,SAAS,EAAE,UAAU,CAAC,uBAAuB,EAAE,EAAE,yBAAyB,EAAE,SAAS,EAAE,CAAC;YAC7F,oBAAC,OAAO,OAAG,CACL,CACJ,CACP,CAAA;AACH,CAAC;AAED,SAAS,YAAY,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAsB;IACrE,MAAM,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAC5E,MAAM,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAE,CAAA;IAC/D,MAAM,MAAM,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAA;IAE9C,MAAM,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,UAAU,CAAA;IACjE,MAAM,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;IAE/C,MAAM,MAAM,GAAG,mCAAmC,CAAC,gBAAgB,EAAE,UAAU,CAAE,CAAA;IACjF,MAAM,UAAU,GAAG,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAE,CAAC,KAAK,CAAA;IACvG,MAAM,QAAQ,GAAG,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAA;IAE1D,OAAO,CACL;QACG,UAAU,KAAK,SAAS,IAAI,oBAAC,4BAA4B,IAAC,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,GAAI;QACpG,6BACE,SAAS,EAAE,UAAU,CAAC,iBAAiB,EAAE,SAAS,EAAE;gBAClD,WAAW,EAAE,SAAS,KAAK,YAAY;aACxC,CAAC,IAED,gBAAgB,CAAC,OAAO,EAAE,CAAC,YAAY,EAAE,EAAE;YAC1C,MAAM,QAAQ,GAAG,mBAAmB,CAAC,YAAY,EAAE,WAAW,CAAE,CAAA;YAChE,MAAM,QAAQ,GAAG,MAAM,IAAI,IAAI,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,QAAQ,CAAA;YACpE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,QAAQ,CAAE,CAAA;YACxE,OAAO,CACL,oBAAC,kBAAkB,OACb;oBACF,OAAO,EAAE,YAAY;oBACrB,gBAAgB;oBAChB,UAAU;oBACV,GAAG,EAAE,QAAQ;oBACb,SAAS;oBACT,QAAQ;oBACR,SAAS,EAAE,OAAO,CAAC,OAAO;iBAC3B,GACD,CACH,CAAA;QACH,CAAC,CAAC,CACE,CACL,CACJ,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { ExamComponentProps } from '../../createRenderChildNodes';
|
3
|
+
declare function DropdownAnswer({ element, renderChildNodes }: ExamComponentProps): JSX.Element | null;
|
4
|
+
declare const _default: React.MemoExoticComponent<typeof DropdownAnswer>;
|
5
|
+
export default _default;
|
6
|
+
//# sourceMappingURL=DropdownAnswer.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"DropdownAnswer.d.ts","sourceRoot":"","sources":["../../../src/components/grading/DropdownAnswer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAA;AASjE,iBAAS,cAAc,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,EAAE,kBAAkB,sBA2DxE;;AAED,wBAAyC"}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import classNames from 'classnames';
|
2
|
+
import React, { useContext } from 'react';
|
3
|
+
import { findChildElement, getNumericAttribute } from '../../dom-utils';
|
4
|
+
import { useExamTranslation } from '../../i18n';
|
5
|
+
import { shortDisplayNumber } from '../../shortDisplayNumber';
|
6
|
+
import { QuestionContext } from '../context/QuestionContext';
|
7
|
+
import { ScreenReaderOnly } from '../ScreenReaderOnly';
|
8
|
+
import { findMultiChoiceFromGradingStructure, ResultsContext } from '../context/ResultsContext';
|
9
|
+
import ResultsExamQuestionAutoScore from './internal/QuestionAutoScore';
|
10
|
+
function DropdownAnswer({ element, renderChildNodes }) {
|
11
|
+
const { t } = useExamTranslation();
|
12
|
+
const { answersByQuestionId, gradingStructure } = useContext(ResultsContext);
|
13
|
+
const { answers } = useContext(QuestionContext);
|
14
|
+
const questionId = getNumericAttribute(element, 'question-id');
|
15
|
+
const answer = answersByQuestionId[questionId];
|
16
|
+
const selectedOption = findChildElement(element, (childElement) => (answer === null || answer === void 0 ? void 0 : answer.value) === childElement.getAttribute('option-id'));
|
17
|
+
const choice = findMultiChoiceFromGradingStructure(gradingStructure, questionId);
|
18
|
+
if (selectedOption) {
|
19
|
+
const correctIds = choice.options.filter((o) => o.correct).map((o) => o.id);
|
20
|
+
const correctOptions = Array.from(element.children).filter((childElement) => correctIds.includes(getNumericAttribute(childElement, 'option-id')));
|
21
|
+
const isAnswerCorrect = correctIds.includes(getNumericAttribute(selectedOption, 'option-id'));
|
22
|
+
const displayNumber = shortDisplayNumber(element.getAttribute('display-number'));
|
23
|
+
const scoreValue = answer && choice.options.find((option) => option.id === Number(answer.value)).score;
|
24
|
+
const maxScore = getNumericAttribute(element, 'max-score');
|
25
|
+
return (React.createElement(React.Fragment, null,
|
26
|
+
answers.length > 1 && React.createElement("sup", null, displayNumber),
|
27
|
+
React.createElement("span", { className: classNames('e-dropdown-answer__answered', {
|
28
|
+
'e-dropdown-answer__answered--correct': isAnswerCorrect,
|
29
|
+
'e-dropdown-answer__answered--wrong': !isAnswerCorrect,
|
30
|
+
}) },
|
31
|
+
React.createElement(ScreenReaderOnly, null, t('screen-reader.answer-begin')),
|
32
|
+
renderChildNodes(selectedOption),
|
33
|
+
React.createElement(ScreenReaderOnly, null, t('screen-reader.answer-end')),
|
34
|
+
isAnswerCorrect && React.createElement(ScreenReaderOnly, null, t('screen-reader.correct-answer'))),
|
35
|
+
!isAnswerCorrect && (React.createElement("span", { className: "e-dropdown-answer__correct", "aria-hidden": true }, correctOptions.map((correctOption, i) => (React.createElement(React.Fragment, { key: i },
|
36
|
+
renderChildNodes(correctOption),
|
37
|
+
i < correctOptions.length - 1 && ', '))))),
|
38
|
+
scoreValue != null && (React.createElement(ResultsExamQuestionAutoScore, { score: scoreValue, maxScore: maxScore, displayNumber: displayNumber }))));
|
39
|
+
}
|
40
|
+
return null;
|
41
|
+
}
|
42
|
+
export default React.memo(DropdownAnswer);
|
43
|
+
//# sourceMappingURL=DropdownAnswer.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"DropdownAnswer.js","sourceRoot":"","sources":["../../../src/components/grading/DropdownAnswer.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Grading.d.ts","sourceRoot":"","sources":["../../../src/components/grading/Grading.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkD,MAAM,OAAO,CAAA;;AAmHtE,wBAA6E"}
|
@@ -0,0 +1,81 @@
|
|
1
|
+
import React, { useContext, useEffect, useRef, useState } from 'react';
|
2
|
+
import { I18nextProvider } from 'react-i18next';
|
3
|
+
import { changeLanguage, initI18n } from '../../i18n';
|
4
|
+
import { useCached } from '../../useCached';
|
5
|
+
import { withCommonExamContext } from '../context/CommonExamContext';
|
6
|
+
import { ResultsContext, withResultsContext } from '../context/ResultsContext';
|
7
|
+
import { GradingAnswer } from './GradingAnswer';
|
8
|
+
function Grading() {
|
9
|
+
const { answersByQuestionId } = useContext(ResultsContext);
|
10
|
+
const i18n = useCached(() => initI18n('FI-fi'));
|
11
|
+
useEffect(changeLanguage(i18n, 'FI-fi'));
|
12
|
+
const answerIds = Object.keys(answersByQuestionId).map(Number);
|
13
|
+
if (answerIds.length === 0) {
|
14
|
+
return React.createElement("div", null, "No answers");
|
15
|
+
}
|
16
|
+
const [answerId, setAnswerId] = useState(answerIds[0]);
|
17
|
+
const annotationsStorage = useRef(Object.fromEntries(answerIds.map((id) => [
|
18
|
+
id,
|
19
|
+
{
|
20
|
+
pregrading: [
|
21
|
+
{
|
22
|
+
startIndex: 2,
|
23
|
+
length: 5,
|
24
|
+
message: '+1',
|
25
|
+
},
|
26
|
+
{
|
27
|
+
x: 0.07434944237918215,
|
28
|
+
y: 0.8599562363238512,
|
29
|
+
type: 'rect',
|
30
|
+
width: 0.16604708798017348,
|
31
|
+
height: 0.03063457330415753,
|
32
|
+
message: '+2',
|
33
|
+
attachmentIndex: 0,
|
34
|
+
},
|
35
|
+
{
|
36
|
+
x1: 0.4035532994923858,
|
37
|
+
x2: 0.5621827411167513,
|
38
|
+
y1: 0.957983193277311,
|
39
|
+
y2: 0.957983193277311,
|
40
|
+
type: 'line',
|
41
|
+
message: 'trk, +1',
|
42
|
+
attachmentIndex: 0,
|
43
|
+
},
|
44
|
+
],
|
45
|
+
censoring: [],
|
46
|
+
},
|
47
|
+
])));
|
48
|
+
const [annotations, setAnnotations] = useState({
|
49
|
+
pregrading: [],
|
50
|
+
censoring: [],
|
51
|
+
});
|
52
|
+
useEffect(() => {
|
53
|
+
setAnnotations(annotationsStorage.current[answerId]);
|
54
|
+
});
|
55
|
+
const { type: answerType, value } = answersByQuestionId[answerId];
|
56
|
+
if (answerType === 'choice') {
|
57
|
+
return React.createElement("div", null, "choice answer");
|
58
|
+
}
|
59
|
+
function selectQuestion(e, id) {
|
60
|
+
e.preventDefault();
|
61
|
+
setAnswerId(id);
|
62
|
+
setAnnotations(annotationsStorage.current[id]);
|
63
|
+
}
|
64
|
+
function saveAnnotations(annotations) {
|
65
|
+
annotationsStorage.current[answerId] = annotations;
|
66
|
+
setAnnotations({ ...annotationsStorage.current[answerId] });
|
67
|
+
}
|
68
|
+
return (React.createElement(I18nextProvider, { i18n: i18n },
|
69
|
+
React.createElement("main", { className: "e-exam" },
|
70
|
+
React.createElement("div", { className: "grading-navi" }, answerIds.map((id) => id === answerId ? (React.createElement("span", { key: id, className: "grading-navi-item" }, answersByQuestionId[id].displayNumber)) : (React.createElement("a", { className: "grading-navi-item", href: "", onClick: (e) => selectQuestion(e, id), key: id }, answersByQuestionId[id].displayNumber)))),
|
71
|
+
React.createElement(GradingAnswer, { ...{
|
72
|
+
isReadOnly: false,
|
73
|
+
answerType,
|
74
|
+
gradingRole: 'censoring',
|
75
|
+
value,
|
76
|
+
annotations,
|
77
|
+
saveAnnotations,
|
78
|
+
} }))));
|
79
|
+
}
|
80
|
+
export default React.memo(withResultsContext(withCommonExamContext(Grading)));
|
81
|
+
//# sourceMappingURL=Grading.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Grading.js","sourceRoot":"","sources":["../../../src/components/grading/Grading.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
/// <reference types="react" />
|
2
|
+
import { Annotation } from '../..';
|
3
|
+
type Annotations = {
|
4
|
+
pregrading: Annotation[];
|
5
|
+
censoring: Annotation[];
|
6
|
+
};
|
7
|
+
type GradingType = 'pregrading' | 'censoring';
|
8
|
+
export declare function GradingAnswer({ isReadOnly, answerType, gradingRole, annotations, saveAnnotations, value, }: {
|
9
|
+
isReadOnly: boolean;
|
10
|
+
answerType: 'richText' | 'text';
|
11
|
+
gradingRole: GradingType;
|
12
|
+
value: string;
|
13
|
+
annotations: Annotations;
|
14
|
+
saveAnnotations: (annotations: Annotations) => void;
|
15
|
+
}): JSX.Element;
|
16
|
+
export {};
|
17
|
+
//# sourceMappingURL=GradingAnswer.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"GradingAnswer.d.ts","sourceRoot":"","sources":["../../../src/components/grading/GradingAnswer.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAkBlC,KAAK,WAAW,GAAG;IAAE,UAAU,EAAE,UAAU,EAAE,CAAC;IAAC,SAAS,EAAE,UAAU,EAAE,CAAA;CAAE,CAAA;AAOxE,KAAK,WAAW,GAAG,YAAY,GAAG,WAAW,CAAA;AAE7C,wBAAgB,aAAa,CAAC,EAC5B,UAAU,EACV,UAAU,EACV,WAAW,EACX,WAAW,EACX,eAAe,EACf,KAAK,GACN,EAAE;IACD,UAAU,EAAE,OAAO,CAAA;IACnB,UAAU,EAAE,UAAU,GAAG,MAAM,CAAA;IAC/B,WAAW,EAAE,WAAW,CAAA;IACxB,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,WAAW,CAAA;IACxB,eAAe,EAAE,CAAC,WAAW,EAAE,WAAW,KAAK,IAAI,CAAA;CACpD,eA6NA"}
|
@@ -0,0 +1,179 @@
|
|
1
|
+
import React, { useLayoutEffect, useRef } from 'react';
|
2
|
+
import { annotationFromMousePosition, hasTextSelectedInAnswerText, imageAnnotationMouseDownInfo, mergeAnnotation, popupPosition, selectionHasNothingToUnderline, textAnnotationFromRange, } from './editAnnotations';
|
3
|
+
import { renderAnnotations, renderImageAnnotationByImage, updateImageAnnotationMarkSize, wrapAllImages, } from '../../renderAnnotations';
|
4
|
+
function preventDefaults(e) {
|
5
|
+
e.preventDefault();
|
6
|
+
e.stopPropagation();
|
7
|
+
}
|
8
|
+
export function GradingAnswer({ isReadOnly, answerType, gradingRole, annotations, saveAnnotations, value, }) {
|
9
|
+
const answerRef = useRef(null);
|
10
|
+
const popupRef = useRef(null);
|
11
|
+
const messageRef = useRef(null);
|
12
|
+
const tooltipRef = useRef(null);
|
13
|
+
let newAnnotationObject;
|
14
|
+
// let isMouseDown = false
|
15
|
+
let latestSavedAnnotations;
|
16
|
+
let mouseDownInfo;
|
17
|
+
let newImageAnnotationMark;
|
18
|
+
let imageAtHand;
|
19
|
+
let isPopupVisible = false;
|
20
|
+
let fadeTooltipOut;
|
21
|
+
let annotationDataForTooltip;
|
22
|
+
useLayoutEffect(() => {
|
23
|
+
if (answerRef.current) {
|
24
|
+
latestSavedAnnotations = annotations;
|
25
|
+
tooltipRef.current.style.display = 'none';
|
26
|
+
popupRef.current.style.display = 'none';
|
27
|
+
renderAnswerWithAnnotations(latestSavedAnnotations);
|
28
|
+
}
|
29
|
+
});
|
30
|
+
function removeAnnotation(e) {
|
31
|
+
e.preventDefault();
|
32
|
+
closeTooltip();
|
33
|
+
latestSavedAnnotations[annotationDataForTooltip.type].splice(annotationDataForTooltip.index, 1);
|
34
|
+
annotationDataForTooltip = undefined;
|
35
|
+
saveAnnotations(latestSavedAnnotations);
|
36
|
+
}
|
37
|
+
return (React.createElement("div", { className: "e-grading-answer-wrapper" },
|
38
|
+
React.createElement("div", { className: "answer e-grading-answer e-line-height-l e-pad-l-2 e-mrg-b-1", ref: answerRef, onKeyUp: (e) => onKeyUp(e), onMouseDown: (e) => onMouseDown(e), onMouseOver: (e) => onMouseOver(e) }),
|
39
|
+
React.createElement("form", { style: { display: 'none', position: 'absolute' }, ref: popupRef, className: "e-grading-answer-popup e-grading-answer-add-annotation", onSubmit: (e) => onSubmit(e) },
|
40
|
+
React.createElement("input", { name: "message", className: "e-grading-answer-add-annotation-text", type: "text", ref: messageRef }),
|
41
|
+
React.createElement("button", { className: "e-grading-answer-add-annotation-button", type: "submit", "data-i18n": "arpa.annotate" }, "Merkitse")),
|
42
|
+
React.createElement("div", { style: { display: 'none' }, ref: tooltipRef, className: "e-grading-answer-tooltip e-grading-answer-popup", onMouseOver: onMouseOverTooltip, onMouseOut: closeTooltip },
|
43
|
+
React.createElement("span", { className: "e-grading-answer-tooltip-label" }, "tooltip text"),
|
44
|
+
React.createElement("button", { onClick: (e) => removeAnnotation(e), className: "e-grading-answer-tooltip-remove" }, "\u00D7"))));
|
45
|
+
function closeTooltip() {
|
46
|
+
fadeTooltipOut = setTimeout(() => {
|
47
|
+
tooltipRef.current.style.display = 'none';
|
48
|
+
}, 400);
|
49
|
+
}
|
50
|
+
function onMouseOverTooltip() {
|
51
|
+
clearTimeout(fadeTooltipOut);
|
52
|
+
}
|
53
|
+
function onMouseOut(e) {
|
54
|
+
const target = e.target;
|
55
|
+
if (target.tagName === 'MARK') {
|
56
|
+
clearTimeout(fadeTooltipOut);
|
57
|
+
closeTooltip();
|
58
|
+
}
|
59
|
+
answerRef.current.removeEventListener('mouseout', onMouseOut);
|
60
|
+
}
|
61
|
+
function showTooltip(target) {
|
62
|
+
clearTimeout(fadeTooltipOut);
|
63
|
+
const tooltip = tooltipRef.current;
|
64
|
+
const type = target.dataset.type;
|
65
|
+
tooltip.querySelector('.e-grading-answer-tooltip-remove').style.display =
|
66
|
+
isReadOnly || type !== gradingRole ? 'none' : 'initial';
|
67
|
+
const rect = target.getBoundingClientRect();
|
68
|
+
Object.assign(tooltip.style, popupPosition(rect, answerRef.current), { display: 'block' });
|
69
|
+
tooltip.querySelector('.e-grading-answer-tooltip-label').textContent = target.dataset.message || '–';
|
70
|
+
annotationDataForTooltip = { index: Number(target.dataset.listIndex), type };
|
71
|
+
answerRef.current.addEventListener('mouseout', onMouseOut);
|
72
|
+
}
|
73
|
+
function onMouseOver(e) {
|
74
|
+
const target = e.target;
|
75
|
+
if (target.tagName === 'MARK' &&
|
76
|
+
!isPopupVisible &&
|
77
|
+
(!hasTextSelectedInAnswerText() || isReadOnly) &&
|
78
|
+
!newImageAnnotationMark) {
|
79
|
+
showTooltip(target);
|
80
|
+
}
|
81
|
+
}
|
82
|
+
function showAnnotationPopup(rect) {
|
83
|
+
Object.assign(popupRef.current.style, popupPosition(rect, answerRef.current), {
|
84
|
+
display: 'block',
|
85
|
+
});
|
86
|
+
const inputElement = messageRef.current;
|
87
|
+
inputElement.value = '';
|
88
|
+
inputElement.focus();
|
89
|
+
isPopupVisible = true;
|
90
|
+
}
|
91
|
+
function closePopupAndRefresh() {
|
92
|
+
newAnnotationObject = undefined;
|
93
|
+
newImageAnnotationMark = undefined;
|
94
|
+
imageAtHand = undefined;
|
95
|
+
isPopupVisible = false;
|
96
|
+
popupRef.current.style.display = 'none';
|
97
|
+
renderAnswerWithAnnotations(latestSavedAnnotations);
|
98
|
+
}
|
99
|
+
function onMouseDown(e) {
|
100
|
+
var _a;
|
101
|
+
if (isReadOnly) {
|
102
|
+
return;
|
103
|
+
}
|
104
|
+
window.addEventListener('mouseup', onWindowMouseUp);
|
105
|
+
if (e.button !== 0) {
|
106
|
+
return;
|
107
|
+
}
|
108
|
+
const target = e.target;
|
109
|
+
imageAtHand = ((_a = target.closest('.e-annotation-wrapper')) === null || _a === void 0 ? void 0 : _a.querySelector('img')) || undefined;
|
110
|
+
if (!imageAtHand) {
|
111
|
+
return;
|
112
|
+
}
|
113
|
+
imageAtHand.addEventListener('dragstart', preventDefaults);
|
114
|
+
mouseDownInfo = imageAnnotationMouseDownInfo(e, imageAtHand);
|
115
|
+
window.addEventListener('mousemove', onMouseMoveForImageAnnotation);
|
116
|
+
}
|
117
|
+
function onWindowMouseUp(e) {
|
118
|
+
imageAtHand === null || imageAtHand === void 0 ? void 0 : imageAtHand.removeEventListener('dragstart', preventDefaults);
|
119
|
+
window.removeEventListener('mousemove', onMouseMoveForImageAnnotation);
|
120
|
+
window.removeEventListener('mouseup', onWindowMouseUp);
|
121
|
+
if (isPopupVisible && e.target.closest('.popup') === null) {
|
122
|
+
closePopupAndRefresh();
|
123
|
+
return;
|
124
|
+
}
|
125
|
+
if (newImageAnnotationMark) {
|
126
|
+
showAnnotationPopup(newImageAnnotationMark === null || newImageAnnotationMark === void 0 ? void 0 : newImageAnnotationMark.getBoundingClientRect());
|
127
|
+
return;
|
128
|
+
}
|
129
|
+
const selection = window.getSelection();
|
130
|
+
if (selection && answerRef.current !== null && hasTextSelectedInAnswerText()) {
|
131
|
+
const range = selection.getRangeAt(0);
|
132
|
+
if (selectionHasNothingToUnderline(range)) {
|
133
|
+
return;
|
134
|
+
}
|
135
|
+
const position = textAnnotationFromRange(answerRef.current, range);
|
136
|
+
newAnnotationObject = { ...position, type: 'text', message: '' };
|
137
|
+
showAnnotationPopup(range.getBoundingClientRect());
|
138
|
+
const newAnnotations = { ...latestSavedAnnotations };
|
139
|
+
newAnnotations[gradingRole] = mergeAnnotation(answerRef.current, newAnnotationObject, latestSavedAnnotations[gradingRole]);
|
140
|
+
renderAnswerWithAnnotations(newAnnotations);
|
141
|
+
}
|
142
|
+
}
|
143
|
+
function onMouseMoveForImageAnnotation(e) {
|
144
|
+
preventDefaults(e);
|
145
|
+
newAnnotationObject = annotationFromMousePosition(e, mouseDownInfo);
|
146
|
+
if (newImageAnnotationMark) {
|
147
|
+
updateImageAnnotationMarkSize(newImageAnnotationMark, newAnnotationObject);
|
148
|
+
}
|
149
|
+
else {
|
150
|
+
newImageAnnotationMark = renderImageAnnotationByImage(imageAtHand, '', newAnnotationObject, gradingRole, 999);
|
151
|
+
}
|
152
|
+
}
|
153
|
+
function renderAnswerWithAnnotations(annotations) {
|
154
|
+
const container = answerRef.current;
|
155
|
+
if (answerType === 'richText') {
|
156
|
+
container.innerHTML = value;
|
157
|
+
}
|
158
|
+
else {
|
159
|
+
container.textContent = value;
|
160
|
+
}
|
161
|
+
wrapAllImages(container);
|
162
|
+
renderAnnotations(container, annotations.pregrading, annotations.censoring);
|
163
|
+
//TODO make titles optional for annotation rendering
|
164
|
+
container.querySelectorAll('mark').forEach((mark) => mark.removeAttribute('title'));
|
165
|
+
}
|
166
|
+
function onSubmit(e) {
|
167
|
+
e.preventDefault();
|
168
|
+
const message = messageRef.current.value;
|
169
|
+
latestSavedAnnotations[gradingRole] = mergeAnnotation(answerRef.current, { ...newAnnotationObject, message }, latestSavedAnnotations[gradingRole] || []);
|
170
|
+
popupRef.current.style.display = 'none';
|
171
|
+
saveAnnotations(latestSavedAnnotations);
|
172
|
+
}
|
173
|
+
function onKeyUp(e) {
|
174
|
+
if (e.key === 'Escape' && newAnnotationObject) {
|
175
|
+
closePopupAndRefresh();
|
176
|
+
}
|
177
|
+
}
|
178
|
+
}
|
179
|
+
//# sourceMappingURL=GradingAnswer.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"GradingAnswer.js","sourceRoot":"","sources":["../../../src/components/grading/GradingAnswer.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { Score } from '../..';
|
3
|
+
export declare const MultiLineAnswer: React.FunctionComponent<{
|
4
|
+
type: 'rich-text' | 'single-line';
|
5
|
+
value?: string;
|
6
|
+
score?: Score;
|
7
|
+
}>;
|
8
|
+
export declare function calculatePosition(answerTextNode: HTMLDivElement, range: Range): {
|
9
|
+
startIndex: number;
|
10
|
+
length: number;
|
11
|
+
};
|
12
|
+
export declare function toNodeLength(node: Node): number | undefined;
|
13
|
+
export declare function allNodesUnder(el: Node, documentObject?: Document): Node[];
|
14
|
+
//# sourceMappingURL=MultiLineAnswer.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"MultiLineAnswer.d.ts","sourceRoot":"","sources":["../../../src/components/grading/MultiLineAnswer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkC,MAAM,OAAO,CAAA;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAA;AAM7B,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC;IACpD,IAAI,EAAE,WAAW,GAAG,aAAa,CAAA;IACjC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,CAAC,EAAE,KAAK,CAAA;CACd,CAwCA,CAAA;AAED,wBAAgB,iBAAiB,CAAC,cAAc,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK;;;EAgB7E;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,IAAI,sBAEtC;AAED,wBAAgB,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,cAAc,WAAW,GAAG,IAAI,EAAE,CAQzE"}
|
@@ -0,0 +1,61 @@
|
|
1
|
+
import React, { useLayoutEffect, useRef } from 'react';
|
2
|
+
import { useExamTranslation } from '../../i18n';
|
3
|
+
import { renderAnnotations } from '../../renderAnnotations';
|
4
|
+
import { ScreenReaderOnly } from '../ScreenReaderOnly';
|
5
|
+
import * as _ from 'lodash-es';
|
6
|
+
export const MultiLineAnswer = ({ type, score, value }) => {
|
7
|
+
const { t } = useExamTranslation();
|
8
|
+
const answerRef = useRef(null);
|
9
|
+
useLayoutEffect(() => {
|
10
|
+
var _a, _b, _c, _d;
|
11
|
+
if (answerRef.current) {
|
12
|
+
renderAnnotations(answerRef.current, (_b = (_a = score === null || score === void 0 ? void 0 : score.pregrading) === null || _a === void 0 ? void 0 : _a.annotations) !== null && _b !== void 0 ? _b : [], (_d = (_c = score === null || score === void 0 ? void 0 : score.censoring) === null || _c === void 0 ? void 0 : _c.annotations) !== null && _d !== void 0 ? _d : []);
|
13
|
+
document.addEventListener('selectionchange', onSelect);
|
14
|
+
console.log('annotations rendered2');
|
15
|
+
}
|
16
|
+
});
|
17
|
+
function onSelect(e) {
|
18
|
+
console.log(e);
|
19
|
+
const selection = window.getSelection();
|
20
|
+
if (selection && answerRef.current !== null) {
|
21
|
+
const range = selection.getRangeAt(0);
|
22
|
+
const position = calculatePosition(answerRef.current, range);
|
23
|
+
console.log(position, '\n=== position');
|
24
|
+
}
|
25
|
+
}
|
26
|
+
return type === 'rich-text' ? (React.createElement("div", { className: "e-multiline-results-text-answer e-line-height-l e-pad-l-2 e-mrg-b-1" },
|
27
|
+
React.createElement(ScreenReaderOnly, null, t('screen-reader.answer-begin')),
|
28
|
+
type === 'rich-text' ? (React.createElement("div", { dangerouslySetInnerHTML: { __html: value || '' }, ref: answerRef })) : (React.createElement("div", { className: "e-pre-wrap", ref: answerRef }, value)))) : (React.createElement("span", { className: "text-answer text-answer--single-line" },
|
29
|
+
React.createElement(ScreenReaderOnly, null, t('screen-reader.answer-begin')),
|
30
|
+
React.createElement("span", { className: "e-inline-block", ref: answerRef }, value)));
|
31
|
+
};
|
32
|
+
export function calculatePosition(answerTextNode, range) {
|
33
|
+
const answerNodes = allNodesUnder(answerTextNode);
|
34
|
+
const charactersBefore = charactersBeforeContainer(range.startContainer, range.startOffset);
|
35
|
+
const charactersUntilEnd = charactersBeforeContainer(range.endContainer, range.endOffset);
|
36
|
+
return {
|
37
|
+
startIndex: charactersBefore,
|
38
|
+
length: charactersUntilEnd - charactersBefore,
|
39
|
+
};
|
40
|
+
function charactersBeforeContainer(rangeContainer, offset) {
|
41
|
+
const containerIsTag = rangeContainer === answerTextNode;
|
42
|
+
const container = containerIsTag ? rangeContainer.childNodes[offset] : rangeContainer;
|
43
|
+
const offsetInside = containerIsTag ? 0 : offset;
|
44
|
+
const nodesBeforeContainer = _.takeWhile(answerNodes, (node) => node !== container);
|
45
|
+
return offsetInside + _.sum(nodesBeforeContainer.map(toNodeLength));
|
46
|
+
}
|
47
|
+
}
|
48
|
+
export function toNodeLength(node) {
|
49
|
+
var _a;
|
50
|
+
return node.nodeType === Node.TEXT_NODE ? (_a = node.textContent) === null || _a === void 0 ? void 0 : _a.length : node.nodeName === 'IMG' ? 1 : 0;
|
51
|
+
}
|
52
|
+
export function allNodesUnder(el, documentObject = document) {
|
53
|
+
let n = null;
|
54
|
+
const a = [];
|
55
|
+
const walk = documentObject.createTreeWalker(el, NodeFilter.SHOW_ALL, null);
|
56
|
+
while ((n = walk.nextNode())) {
|
57
|
+
a.push(n);
|
58
|
+
}
|
59
|
+
return a;
|
60
|
+
}
|
61
|
+
//# sourceMappingURL=MultiLineAnswer.js.map
|