@digabi/exam-engine-core 22.0.0 → 22.0.1-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/context/CommonExamContext.d.ts +1 -0
- package/dist/components/context/CommonExamContext.d.ts.map +1 -1
- package/dist/components/context/CommonExamContext.js +3 -0
- package/dist/components/context/CommonExamContext.js.map +1 -1
- package/dist/components/context/GradingInstructionContext.d.ts +12 -4
- package/dist/components/context/GradingInstructionContext.d.ts.map +1 -1
- package/dist/components/context/GradingInstructionContext.js.map +1 -1
- package/dist/components/grading-instructions/AnswerGradingInstruction.d.ts.map +1 -1
- package/dist/components/grading-instructions/AnswerGradingInstruction.js +7 -2
- package/dist/components/grading-instructions/AnswerGradingInstruction.js.map +1 -1
- package/dist/components/grading-instructions/EditableGradingInstruction.js +6 -5
- package/dist/components/grading-instructions/EditableGradingInstruction.js.map +1 -1
- package/dist/components/grading-instructions/ExamGradingInstruction.d.ts.map +1 -1
- package/dist/components/grading-instructions/ExamGradingInstruction.js +7 -2
- package/dist/components/grading-instructions/ExamGradingInstruction.js.map +1 -1
- package/dist/components/grading-instructions/GradingInstructionProvider.d.ts +1 -1
- package/dist/components/grading-instructions/GradingInstructionProvider.d.ts.map +1 -1
- package/dist/components/grading-instructions/GradingInstructionProvider.js +4 -5
- package/dist/components/grading-instructions/GradingInstructionProvider.js.map +1 -1
- package/dist/components/grading-instructions/GradingInstructions.d.ts +2 -1
- package/dist/components/grading-instructions/GradingInstructions.d.ts.map +1 -1
- package/dist/components/grading-instructions/GradingInstructions.js +18 -15
- package/dist/components/grading-instructions/GradingInstructions.js.map +1 -1
- package/dist/main-bundle.js +1 -1
- package/package.json +2 -2
- package/dist/components/context/AnnotationContext.d.ts +0 -8
- package/dist/components/context/AnnotationContext.d.ts.map +0 -1
- package/dist/components/context/AnnotationContext.js +0 -3
- package/dist/components/context/AnnotationContext.js.map +0 -1
- package/dist/components/exam/ExamineExam.d.ts +0 -5
- package/dist/components/exam/ExamineExam.d.ts.map +0 -1
- package/dist/components/exam/ExamineExam.js +0 -20
- package/dist/components/exam/ExamineExam.js.map +0 -1
- package/dist/components/exam/FinishExam.d.ts +0 -5
- package/dist/components/exam/FinishExam.d.ts.map +0 -1
- package/dist/components/exam/FinishExam.js +0 -17
- package/dist/components/exam/FinishExam.js.map +0 -1
- package/dist/components/grading/reactAnnotation.d.ts +0 -4
- package/dist/components/grading/reactAnnotation.d.ts.map +0 -1
- package/dist/components/grading/reactAnnotation.js +0 -54
- package/dist/components/grading/reactAnnotation.js.map +0 -1
- package/dist/components/results/isExamFinishPageHook.d.ts +0 -2
- package/dist/components/results/isExamFinishPageHook.d.ts.map +0 -1
- package/dist/components/results/isExamFinishPageHook.js +0 -7
- package/dist/components/results/isExamFinishPageHook.js.map +0 -1
- package/dist/components/shared/CreateAnnotationPopup.d.ts +0 -6
- package/dist/components/shared/CreateAnnotationPopup.d.ts.map +0 -1
- package/dist/components/shared/CreateAnnotationPopup.js +0 -11
- package/dist/components/shared/CreateAnnotationPopup.js.map +0 -1
- package/dist/store/listenerMiddleware.d.ts +0 -89
- package/dist/store/listenerMiddleware.d.ts.map +0 -1
- package/dist/store/listenerMiddleware.js +0 -6
- package/dist/store/listenerMiddleware.js.map +0 -1
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@digabi/exam-engine-core",
|
3
|
-
"version": "22.0.
|
3
|
+
"version": "22.0.1-alpha.1",
|
4
4
|
"main": "dist/main-bundle.js",
|
5
5
|
"types": "dist/index.d.ts",
|
6
6
|
"author": "Matriculation Examination Board, Finland",
|
@@ -58,5 +58,5 @@
|
|
58
58
|
"webpack-bundle-analyzer": "^4.1.0",
|
59
59
|
"webpack-cli": "^5.0.2"
|
60
60
|
},
|
61
|
-
"gitHead": "
|
61
|
+
"gitHead": "0d98fd0ca8fa12468afe5afb429c832df4e3c56b"
|
62
62
|
}
|
@@ -1,8 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { TextAnnotation } from '../../types/Score';
|
3
|
-
export interface AnnotationContext {
|
4
|
-
annotations: Record<string, TextAnnotation>;
|
5
|
-
onClickAnnotation: (a: TextAnnotation) => void;
|
6
|
-
}
|
7
|
-
export declare const AnnotationContext: React.Context<AnnotationContext>;
|
8
|
-
//# sourceMappingURL=AnnotationContext.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"AnnotationContext.d.ts","sourceRoot":"","sources":["../../../src/components/context/AnnotationContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAElD,MAAM,WAAW,iBAAiB;IAChC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;IAC3C,iBAAiB,EAAE,CAAC,CAAC,EAAE,cAAc,KAAK,IAAI,CAAA;CAC/C;AAED,eAAO,MAAM,iBAAiB,kCAA+C,CAAA"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"AnnotationContext.js","sourceRoot":"","sources":["../../../src/components/context/AnnotationContext.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAQzB,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,aAAa,CAAC,EAAuB,CAAC,CAAA"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ExamineExam.d.ts","sourceRoot":"","sources":["../../../src/components/exam/ExamineExam.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAKzC,iBAAS,WAAW,sBA4BnB;;AAED,wBAAsC"}
|
@@ -1,20 +0,0 @@
|
|
1
|
-
import React, { useContext } from 'react';
|
2
|
-
import { useExamTranslation } from '../../i18n';
|
3
|
-
import { ExamContext } from '../context/ExamContext';
|
4
|
-
function ExamineExam() {
|
5
|
-
const { examServerApi } = useContext(ExamContext);
|
6
|
-
const { examineExam } = examServerApi;
|
7
|
-
const { t } = useExamTranslation();
|
8
|
-
const goToInspectAnswers = () => {
|
9
|
-
if (!examineExam) {
|
10
|
-
return;
|
11
|
-
}
|
12
|
-
examineExam();
|
13
|
-
window.scrollTo(0, 0);
|
14
|
-
};
|
15
|
-
return (React.createElement("div", { className: "e-examine-exam" },
|
16
|
-
React.createElement("button", { className: "e-button", id: "examineExam", onClick: goToInspectAnswers, "aria-describedby": "examineExamInstructions" }, t('examine-exam.examine')),
|
17
|
-
React.createElement("div", { className: "e-examine-exam-instructions", id: "examineExamInstructions" }, t('examine-exam.instructions'))));
|
18
|
-
}
|
19
|
-
export default React.memo(ExamineExam);
|
20
|
-
//# sourceMappingURL=ExamineExam.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"ExamineExam.js","sourceRoot":"","sources":["../../../src/components/exam/ExamineExam.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAA;AAGpD,SAAS,WAAW;IAClB,MAAM,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC,WAAW,CAAC,CAAA;IACjD,MAAM,EAAE,WAAW,EAAE,GAAkB,aAAa,CAAA;IACpD,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAElC,MAAM,kBAAkB,GAAG,GAAG,EAAE;QAC9B,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAM;QACR,CAAC;QACD,WAAW,EAAE,CAAA;QACb,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IACvB,CAAC,CAAA;IAED,OAAO,CACL,6BAAK,SAAS,EAAC,gBAAgB;QAC7B,gCACE,SAAS,EAAC,UAAU,EACpB,EAAE,EAAC,aAAa,EAChB,OAAO,EAAE,kBAAkB,sBACV,yBAAyB,IAEzC,CAAC,CAAC,sBAAsB,CAAC,CACnB;QACT,6BAAK,SAAS,EAAC,6BAA6B,EAAC,EAAE,EAAC,yBAAyB,IACtE,CAAC,CAAC,2BAA2B,CAAC,CAC3B,CACF,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"FinishExam.d.ts","sourceRoot":"","sources":["../../../src/components/exam/FinishExam.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AAIzC,iBAAS,UAAU,sBAoBlB;;AAED,wBAAqC"}
|
@@ -1,17 +0,0 @@
|
|
1
|
-
import React, { useContext } from 'react';
|
2
|
-
import { useExamTranslation } from '../../i18n';
|
3
|
-
import { ExamContext } from '../context/ExamContext';
|
4
|
-
function FinishExam() {
|
5
|
-
const { examServerApi } = useContext(ExamContext);
|
6
|
-
const { finishExam } = examServerApi;
|
7
|
-
const { t } = useExamTranslation();
|
8
|
-
const goToInspectAnswers = () => {
|
9
|
-
finishExam();
|
10
|
-
window.scrollTo(0, 0);
|
11
|
-
};
|
12
|
-
return (React.createElement("div", { className: "e-finish-exam" },
|
13
|
-
React.createElement("button", { id: "finishExam", onClick: goToInspectAnswers, "aria-describedby": "finishExamInstructions" }, t('finish-exam.finish')),
|
14
|
-
React.createElement("div", { className: "e-finish-exam-instructions", id: "finishExamInstructions" }, t('finish-exam.instructions'))));
|
15
|
-
}
|
16
|
-
export default React.memo(FinishExam);
|
17
|
-
//# sourceMappingURL=FinishExam.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"FinishExam.js","sourceRoot":"","sources":["../../../src/components/exam/FinishExam.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAA;AAEpD,SAAS,UAAU;IACjB,MAAM,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC,WAAW,CAAC,CAAA;IACjD,MAAM,EAAE,UAAU,EAAE,GAAG,aAAa,CAAA;IACpC,MAAM,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,CAAA;IAElC,MAAM,kBAAkB,GAAG,GAAG,EAAE;QAC9B,UAAU,EAAE,CAAA;QACZ,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IACvB,CAAC,CAAA;IAED,OAAO,CACL,6BAAK,SAAS,EAAC,eAAe;QAC5B,gCAAQ,EAAE,EAAC,YAAY,EAAC,OAAO,EAAE,kBAAkB,sBAAmB,wBAAwB,IAC3F,CAAC,CAAC,oBAAoB,CAAC,CACjB;QACT,6BAAK,SAAS,EAAC,4BAA4B,EAAC,EAAE,EAAC,wBAAwB,IACpE,CAAC,CAAC,0BAA0B,CAAC,CAC1B,CACF,CACP,CAAA;AACH,CAAC;AAED,eAAe,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"reactAnnotation.d.ts","sourceRoot":"","sources":["../../../src/components/grading/reactAnnotation.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,wBAAgB,wBAAwB,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,EAAE,eAAe,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,IAAI,QAwB9F;AAED,wBAAgB,2BAA2B,IAAI,OAAO,CAoCrD"}
|
@@ -1,54 +0,0 @@
|
|
1
|
-
import { textAnnotationFromRange } from './editAnnotations';
|
2
|
-
export function onMouseDownForAnnotation(e, mouseUpCallback) {
|
3
|
-
function onWindowMouseUpAfterAnswerMouseDown(e) {
|
4
|
-
const target = e.target;
|
5
|
-
window.removeEventListener('mouseup', onWindowMouseUpAfterAnswerMouseDown);
|
6
|
-
// Text annotation
|
7
|
-
const selection = window.getSelection();
|
8
|
-
if (selection && hasTextSelectedInAnswerText()) {
|
9
|
-
const range = selection.getRangeAt(0);
|
10
|
-
const position = textAnnotationFromRange(target, range);
|
11
|
-
if (!position) {
|
12
|
-
return;
|
13
|
-
}
|
14
|
-
const selectedText = selection.toString();
|
15
|
-
mouseUpCallback({ ...position, selectedText, range: selection.getRangeAt(0) });
|
16
|
-
}
|
17
|
-
}
|
18
|
-
const isReadOnly = false;
|
19
|
-
// Do annotations only with left mouse buttons and when permitted
|
20
|
-
if (isReadOnly || e.button !== 0) {
|
21
|
-
return;
|
22
|
-
}
|
23
|
-
window.addEventListener('mouseup', onWindowMouseUpAfterAnswerMouseDown);
|
24
|
-
}
|
25
|
-
export function hasTextSelectedInAnswerText() {
|
26
|
-
const selection = window.getSelection();
|
27
|
-
return (selection !== null &&
|
28
|
-
selectionInAnswerText(selection) &&
|
29
|
-
(isRangeSelection(selection) || textSelectedInRange(selection)));
|
30
|
-
function selectionInAnswerText(sel) {
|
31
|
-
if (sel.type === 'None' || sel.type === 'Caret' || sel.rangeCount === 0) {
|
32
|
-
return false;
|
33
|
-
}
|
34
|
-
const startContainer = sel.getRangeAt(0).startContainer;
|
35
|
-
const endContainer = sel.getRangeAt(0).endContainer;
|
36
|
-
const startParent = startContainer.parentElement;
|
37
|
-
const endParent = endContainer.parentElement;
|
38
|
-
return sel.rangeCount > 0 && startParent === endParent;
|
39
|
-
}
|
40
|
-
function isRangeSelection(sel) {
|
41
|
-
return (sel === null || sel === void 0 ? void 0 : sel.type) === 'Range';
|
42
|
-
}
|
43
|
-
function textSelectedInRange(sel) {
|
44
|
-
const range = sel.getRangeAt(0);
|
45
|
-
return (!!sel.rangeCount &&
|
46
|
-
(range.toString().length > 0 ||
|
47
|
-
isParentContainer(range.startContainer) ||
|
48
|
-
isParentContainer(range.endContainer)));
|
49
|
-
}
|
50
|
-
function isParentContainer(container) {
|
51
|
-
return container.classList.contains('answer');
|
52
|
-
}
|
53
|
-
}
|
54
|
-
//# sourceMappingURL=reactAnnotation.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"reactAnnotation.js","sourceRoot":"","sources":["../../../src/components/grading/reactAnnotation.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAA;AAG3D,MAAM,UAAU,wBAAwB,CAAC,CAAmB,EAAE,eAAiC;IAC7F,SAAS,mCAAmC,CAAC,CAAa;QACxD,MAAM,MAAM,GAAG,CAAC,CAAC,MAAqB,CAAA;QACtC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,mCAAmC,CAAC,CAAA;QAE1E,kBAAkB;QAClB,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,SAAS,IAAI,2BAA2B,EAAE,EAAE,CAAC;YAC/C,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;YACrC,MAAM,QAAQ,GAAG,uBAAuB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAA;YACvD,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,OAAM;YACR,CAAC;YACD,MAAM,YAAY,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAA;YACzC,eAAe,CAAC,EAAE,GAAG,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;QAChF,CAAC;IACH,CAAC;IAED,MAAM,UAAU,GAAG,KAAK,CAAA;IACxB,iEAAiE;IACjE,IAAI,UAAU,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,OAAM;IACR,CAAC;IACD,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,mCAAmC,CAAC,CAAA;AACzE,CAAC;AAED,MAAM,UAAU,2BAA2B;IACzC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAA;IACvC,OAAO,CACL,SAAS,KAAK,IAAI;QAClB,qBAAqB,CAAC,SAAS,CAAC;QAChC,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAChE,CAAA;IAED,SAAS,qBAAqB,CAAC,GAAc;QAC3C,IAAI,GAAG,CAAC,IAAI,KAAK,MAAM,IAAI,GAAG,CAAC,IAAI,KAAK,OAAO,IAAI,GAAG,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;YACxE,OAAO,KAAK,CAAA;QACd,CAAC;QACD,MAAM,cAAc,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,cAAc,CAAA;QACvD,MAAM,YAAY,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,YAAY,CAAA;QACnD,MAAM,WAAW,GAAG,cAAc,CAAC,aAAa,CAAA;QAChD,MAAM,SAAS,GAAG,YAAY,CAAC,aAAa,CAAA;QAC5C,OAAO,GAAG,CAAC,UAAU,GAAG,CAAC,IAAI,WAAW,KAAK,SAAS,CAAA;IACxD,CAAC;IAED,SAAS,gBAAgB,CAAC,GAAc;QACtC,OAAO,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,IAAI,MAAK,OAAO,CAAA;IAC9B,CAAC;IAED,SAAS,mBAAmB,CAAC,GAAc;QACzC,MAAM,KAAK,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;QAC/B,OAAO,CACL,CAAC,CAAC,GAAG,CAAC,UAAU;YAChB,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,MAAM,GAAG,CAAC;gBAC1B,iBAAiB,CAAC,KAAK,CAAC,cAAyB,CAAC;gBAClD,iBAAiB,CAAC,KAAK,CAAC,YAAuB,CAAC,CAAC,CACpD,CAAA;IACH,CAAC;IAED,SAAS,iBAAiB,CAAC,SAAkB;QAC3C,OAAO,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;IAC/C,CAAC;AACH,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"isExamFinishPageHook.d.ts","sourceRoot":"","sources":["../../../src/components/results/isExamFinishPageHook.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,2BAA2B,eAGvC,CAAA"}
|
@@ -1,7 +0,0 @@
|
|
1
|
-
import { useContext } from 'react';
|
2
|
-
import { ResultsContext } from '../context/ResultsContext';
|
3
|
-
export const useIsStudentsFinishExamPage = () => {
|
4
|
-
const { gradingStructure } = useContext(ResultsContext);
|
5
|
-
return gradingStructure === undefined;
|
6
|
-
};
|
7
|
-
//# sourceMappingURL=isExamFinishPageHook.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"isExamFinishPageHook.js","sourceRoot":"","sources":["../../../src/components/results/isExamFinishPageHook.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAE1D,MAAM,CAAC,MAAM,2BAA2B,GAAG,GAAG,EAAE;IAC9C,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IACvD,OAAO,gBAAgB,KAAK,SAAS,CAAA;AACvC,CAAC,CAAA"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"CreateAnnotationPopup.d.ts","sourceRoot":"","sources":["../../../src/components/shared/CreateAnnotationPopup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAEvC,wBAAgB,qBAAqB,CAAC,EACpC,aAAa,EACb,WAAW,EACZ,EAAE;IACD,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACtC,WAAW,EAAE,MAAM,IAAI,CAAA;CACxB,qBAyBA"}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
import React, { useState } from 'react';
|
2
|
-
export function CreateAnnotationPopup({ updateComment, closeEditor }) {
|
3
|
-
const [comment, setComment] = useState('');
|
4
|
-
return (React.createElement("span", { className: "annotation-popup", style: { position: 'absolute' } },
|
5
|
-
React.createElement("textarea", { className: "comment-content", role: "textbox", "aria-multiline": "true", onChange: e => setComment(e.target.value), value: comment, autoFocus: true }),
|
6
|
-
React.createElement("span", { className: "comment-button-area" },
|
7
|
-
React.createElement("span", null,
|
8
|
-
React.createElement("button", { onClick: () => updateComment(comment), disabled: comment.trim().length === 0 }, "Vastaa"),
|
9
|
-
React.createElement("button", { className: "text-button", onClick: () => closeEditor() }, "Peru")))));
|
10
|
-
}
|
11
|
-
//# sourceMappingURL=CreateAnnotationPopup.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"CreateAnnotationPopup.js","sourceRoot":"","sources":["../../../src/components/shared/CreateAnnotationPopup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,MAAM,UAAU,qBAAqB,CAAC,EACpC,aAAa,EACb,WAAW,EAIZ;IACC,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAA;IAElD,OAAO,CACL,8BAAM,SAAS,EAAC,kBAAkB,EAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE;QAChE,kCACE,SAAS,EAAC,iBAAiB,EAC3B,IAAI,EAAC,SAAS,oBACC,MAAM,EACrB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EACzC,KAAK,EAAE,OAAO,EACd,SAAS,EAAE,IAAI,GACf;QACF,8BAAM,SAAS,EAAC,qBAAqB;YACnC;gBACE,gCAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,aAE3E;gBACT,gCAAQ,SAAS,EAAC,aAAa,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,EAAE,WAEnD,CACJ,CACF,CACF,CACR,CAAA;AACH,CAAC"}
|
@@ -1,89 +0,0 @@
|
|
1
|
-
export declare const listenerMiddleware: import("@reduxjs/toolkit").ListenerMiddlewareInstance<unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
2
|
-
export declare const startListening: {
|
3
|
-
<MiddlewareActionType extends import("redux").UnknownAction, ListenerPredicateType extends (action: import("redux").UnknownAction, currentState: unknown, originalState: unknown) => action is MiddlewareActionType>(options: {
|
4
|
-
actionCreator?: never;
|
5
|
-
type?: never;
|
6
|
-
matcher?: never;
|
7
|
-
predicate: ListenerPredicateType;
|
8
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<ListenerPredicateType extends (action: import("redux").UnknownAction, currentState: any, originalState: any) => action is infer ActionType extends import("redux").Action ? ActionType : never, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
9
|
-
}): import("@reduxjs/toolkit").UnsubscribeListener;
|
10
|
-
<ActionCreatorType extends {
|
11
|
-
(...args: any[]): import("redux").Action<any>;
|
12
|
-
type: any;
|
13
|
-
} & {
|
14
|
-
match: (v: any) => v is any;
|
15
|
-
}>(options: {
|
16
|
-
actionCreator: ActionCreatorType;
|
17
|
-
type?: never;
|
18
|
-
matcher?: never;
|
19
|
-
predicate?: never;
|
20
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<ReturnType<ActionCreatorType>, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
21
|
-
}): import("@reduxjs/toolkit").UnsubscribeListener;
|
22
|
-
<T extends string>(options: {
|
23
|
-
actionCreator?: never;
|
24
|
-
type: T;
|
25
|
-
matcher?: never;
|
26
|
-
predicate?: never;
|
27
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<import("redux").Action<T>, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
28
|
-
}): import("@reduxjs/toolkit").UnsubscribeListener;
|
29
|
-
<MatchFunctionType extends (v: any) => v is import("redux").UnknownAction>(options: {
|
30
|
-
actionCreator?: never;
|
31
|
-
type?: never;
|
32
|
-
matcher: MatchFunctionType;
|
33
|
-
predicate?: never;
|
34
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<MatchFunctionType extends (x: any, ...args: any[]) => x is infer T ? T : never, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
35
|
-
}): import("@reduxjs/toolkit").UnsubscribeListener;
|
36
|
-
<ListenerPredicateType extends import("@reduxjs/toolkit").AnyListenerPredicate<unknown>>(options: {
|
37
|
-
actionCreator?: never;
|
38
|
-
type?: never;
|
39
|
-
matcher?: never;
|
40
|
-
predicate: ListenerPredicateType;
|
41
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<import("redux").UnknownAction, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
42
|
-
}): import("@reduxjs/toolkit").UnsubscribeListener;
|
43
|
-
} & {
|
44
|
-
withTypes: <OverrideStateType extends unknown, OverrideDispatchType extends import("redux").Dispatch = import("redux-thunk").ThunkDispatch<OverrideStateType, unknown, import("redux").UnknownAction>, OverrideExtraArgument = unknown>() => import("@reduxjs/toolkit").TypedStartListening<OverrideStateType, OverrideDispatchType, OverrideExtraArgument>;
|
45
|
-
}, stopListening: {
|
46
|
-
<MiddlewareActionType extends import("redux").UnknownAction, ListenerPredicateType extends (action: import("redux").UnknownAction, currentState: unknown, originalState: unknown) => action is MiddlewareActionType>(options: {
|
47
|
-
actionCreator?: never;
|
48
|
-
type?: never;
|
49
|
-
matcher?: never;
|
50
|
-
predicate: ListenerPredicateType;
|
51
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<ListenerPredicateType extends (action: import("redux").UnknownAction, currentState: any, originalState: any) => action is infer ActionType extends import("redux").Action ? ActionType : never, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
52
|
-
} & import("@reduxjs/toolkit").UnsubscribeListenerOptions): boolean;
|
53
|
-
<ActionCreatorType extends {
|
54
|
-
(...args: any[]): import("redux").Action<any>;
|
55
|
-
type: any;
|
56
|
-
} & {
|
57
|
-
match: (v: any) => v is any;
|
58
|
-
}>(options: {
|
59
|
-
actionCreator: ActionCreatorType;
|
60
|
-
type?: never;
|
61
|
-
matcher?: never;
|
62
|
-
predicate?: never;
|
63
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<ReturnType<ActionCreatorType>, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
64
|
-
} & import("@reduxjs/toolkit").UnsubscribeListenerOptions): boolean;
|
65
|
-
<T extends string>(options: {
|
66
|
-
actionCreator?: never;
|
67
|
-
type: T;
|
68
|
-
matcher?: never;
|
69
|
-
predicate?: never;
|
70
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<import("redux").Action<T>, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
71
|
-
} & import("@reduxjs/toolkit").UnsubscribeListenerOptions): boolean;
|
72
|
-
<MatchFunctionType extends (v: any) => v is import("redux").UnknownAction>(options: {
|
73
|
-
actionCreator?: never;
|
74
|
-
type?: never;
|
75
|
-
matcher: MatchFunctionType;
|
76
|
-
predicate?: never;
|
77
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<MatchFunctionType extends (x: any, ...args: any[]) => x is infer T ? T : never, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
78
|
-
} & import("@reduxjs/toolkit").UnsubscribeListenerOptions): boolean;
|
79
|
-
<ListenerPredicateType extends import("@reduxjs/toolkit").AnyListenerPredicate<unknown>>(options: {
|
80
|
-
actionCreator?: never;
|
81
|
-
type?: never;
|
82
|
-
matcher?: never;
|
83
|
-
predicate: ListenerPredicateType;
|
84
|
-
effect: import("@reduxjs/toolkit").ListenerEffect<import("redux").UnknownAction, unknown, import("redux-thunk").ThunkDispatch<unknown, unknown, import("redux").UnknownAction>, unknown>;
|
85
|
-
} & import("@reduxjs/toolkit").UnsubscribeListenerOptions): boolean;
|
86
|
-
} & {
|
87
|
-
withTypes: <OverrideStateType extends unknown, OverrideDispatchType extends import("redux").Dispatch = import("redux-thunk").ThunkDispatch<OverrideStateType, unknown, import("redux").UnknownAction>, OverrideExtraArgument = unknown>() => import("@reduxjs/toolkit").TypedStopListening<OverrideStateType, OverrideDispatchType, OverrideExtraArgument>;
|
88
|
-
};
|
89
|
-
//# sourceMappingURL=listenerMiddleware.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"listenerMiddleware.d.ts","sourceRoot":"","sources":["../../src/store/listenerMiddleware.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,kBAAkB,+JAA6B,CAAA;AAE5D,eAAO,MAAQ,cAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAAE,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAuB,CAAA"}
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { createListenerMiddleware } from '@reduxjs/toolkit';
|
2
|
-
// Best to define this in a separate file, to avoid importing
|
3
|
-
// from the store file into the rest of the codebase
|
4
|
-
export const listenerMiddleware = createListenerMiddleware();
|
5
|
-
export const { startListening, stopListening } = listenerMiddleware;
|
6
|
-
//# sourceMappingURL=listenerMiddleware.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"listenerMiddleware.js","sourceRoot":"","sources":["../../src/store/listenerMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAA;AAE3D,6DAA6D;AAC7D,oDAAoD;AACpD,MAAM,CAAC,MAAM,kBAAkB,GAAG,wBAAwB,EAAE,CAAA;AAE5D,MAAM,CAAC,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,GAAG,kBAAkB,CAAA"}
|