@cuemath/leap 3.5.48 → 3.5.49
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/features/cue-canvas/cue-canvas.js +26 -24
- package/dist/features/cue-canvas/cue-canvas.js.map +1 -1
- package/dist/features/cue-canvas/hooks/use-height-extender.js +36 -28
- package/dist/features/cue-canvas/hooks/use-height-extender.js.map +1 -1
- package/dist/features/worksheet/constants/events.js +2 -1
- package/dist/features/worksheet/constants/events.js.map +1 -1
- package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question.js +33 -32
- package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import { memo as
|
|
3
|
-
import
|
|
4
|
-
import { CueCanvasCore as
|
|
5
|
-
import { getCanvasConfig as
|
|
6
|
-
import { CueCanvasWrapper as
|
|
7
|
-
import
|
|
8
|
-
import { useCueCanvasActions as
|
|
9
|
-
import
|
|
10
|
-
import
|
|
11
|
-
const
|
|
1
|
+
import { jsx as k } from "react/jsx-runtime";
|
|
2
|
+
import { memo as I, useRef as x, useCallback as P, useEffect as n } from "react";
|
|
3
|
+
import W from "../worksheet/learnosity-preloader/use-is-learnosity-loaded.js";
|
|
4
|
+
import { CueCanvasCore as q } from "./cue-canvas-core.js";
|
|
5
|
+
import { getCanvasConfig as y, getCanvasSettings as z } from "./cue-canvas-helpers.js";
|
|
6
|
+
import { CueCanvasWrapper as A } from "./cue-cavas-styled.js";
|
|
7
|
+
import B from "./hooks/use-config-updater.js";
|
|
8
|
+
import { useCueCanvasActions as F } from "./hooks/use-cue-canvas-actions.js";
|
|
9
|
+
import G from "./hooks/use-height-extender.js";
|
|
10
|
+
import J from "./hooks/use-upload-helper.js";
|
|
11
|
+
const K = I(function({
|
|
12
12
|
canvasId: i,
|
|
13
13
|
width: u,
|
|
14
14
|
height: o,
|
|
@@ -23,19 +23,21 @@ const J = k(function({
|
|
|
23
23
|
userType: s,
|
|
24
24
|
renderAs: e = "canvas",
|
|
25
25
|
canvasConfig: U,
|
|
26
|
-
updateCanvasConfig: H
|
|
26
|
+
updateCanvasConfig: H,
|
|
27
|
+
loggerRef: L
|
|
27
28
|
}) {
|
|
28
|
-
const f = x(null), { setActiveInstance: c, setActiveTool: w } =
|
|
29
|
+
const f = x(null), { setActiveInstance: c, setActiveTool: w } = F(), R = J({ userId: g, renderAs: e, userType: s }), { scriptStatus: d } = W(), t = x(null), V = P(
|
|
29
30
|
(m) => {
|
|
30
31
|
w(m);
|
|
31
32
|
},
|
|
32
33
|
[w]
|
|
33
34
|
);
|
|
34
|
-
return
|
|
35
|
+
return G({
|
|
35
36
|
canvasElementRef: f,
|
|
36
37
|
cueCanvasRef: t,
|
|
37
|
-
canScribble: r
|
|
38
|
-
|
|
38
|
+
canScribble: r,
|
|
39
|
+
loggerRef: L
|
|
40
|
+
}), B(U, e), n(() => {
|
|
39
41
|
r && t.current && (t.current.resetViewPort(), c(t.current));
|
|
40
42
|
}, [r, c]), n(() => {
|
|
41
43
|
a && t.current && t.current.update(a);
|
|
@@ -43,12 +45,12 @@ const J = k(function({
|
|
|
43
45
|
o && t.current && t.current.resetViewPort();
|
|
44
46
|
}, [o, u]), n(() => {
|
|
45
47
|
if (C && $ && !t.current && d === "loaded") {
|
|
46
|
-
const m =
|
|
48
|
+
const m = y(u, o, e, s), j = z(e, s), v = new q({
|
|
47
49
|
onPublish: p,
|
|
48
50
|
onSubscribe: l,
|
|
49
|
-
onUpdateActiveTool:
|
|
51
|
+
onUpdateActiveTool: V,
|
|
50
52
|
onUpdateHeight: E,
|
|
51
|
-
uploadImageToS3:
|
|
53
|
+
uploadImageToS3: R,
|
|
52
54
|
height: o,
|
|
53
55
|
userId: g,
|
|
54
56
|
canvasId: i,
|
|
@@ -60,15 +62,15 @@ const J = k(function({
|
|
|
60
62
|
await v.create({
|
|
61
63
|
canvasElementRef: f,
|
|
62
64
|
canvasConfig: m,
|
|
63
|
-
canvasSetting:
|
|
65
|
+
canvasSetting: j,
|
|
64
66
|
initialData: a
|
|
65
67
|
}), t.current = v, r && c(v);
|
|
66
68
|
})();
|
|
67
69
|
}
|
|
68
70
|
}, [p, l, c, C, $, d]), n(() => () => {
|
|
69
71
|
t.current && (t.current.destroy(), t.current = null);
|
|
70
|
-
}, []), /* @__PURE__ */
|
|
71
|
-
|
|
72
|
+
}, []), /* @__PURE__ */ k(
|
|
73
|
+
A,
|
|
72
74
|
{
|
|
73
75
|
id: e === "whiteboard" ? "canvasContainer" : i,
|
|
74
76
|
ref: f,
|
|
@@ -79,8 +81,8 @@ const J = k(function({
|
|
|
79
81
|
$renderAs: e
|
|
80
82
|
}
|
|
81
83
|
);
|
|
82
|
-
}),
|
|
84
|
+
}), b = K;
|
|
83
85
|
export {
|
|
84
|
-
|
|
86
|
+
b as default
|
|
85
87
|
};
|
|
86
88
|
//# sourceMappingURL=cue-canvas.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cue-canvas.js","sources":["../../../src/features/cue-canvas/cue-canvas.tsx"],"sourcesContent":["import { memo, useCallback, useEffect, useRef, type FC } from 'react';\n\nimport useIsLearnosityLoaded from '../worksheet/learnosity-preloader/use-is-learnosity-loaded';\nimport { CueCanvasCore } from './cue-canvas-core';\nimport { getCanvasConfig, getCanvasSettings } from './cue-canvas-helpers';\nimport { CueCanvasWrapper } from './cue-cavas-styled';\nimport useConfigUpdater from './hooks/use-config-updater';\nimport { useCueCanvasActions } from './hooks/use-cue-canvas-actions';\nimport useHeightExtender from './hooks/use-height-extender';\nimport useUploadHelper from './hooks/use-upload-helper';\nimport type { ICueCanvas, TCueCanvasTool } from './types/cue-canvas';\n\nconst CueCanvas: FC<ICueCanvas> = memo(function CueCanvas({\n canvasId,\n width,\n height,\n canRender,\n onUpdateHeight,\n initialData,\n onPublish,\n onSubscribe,\n userId,\n appended,\n canScribble,\n userType,\n renderAs = 'canvas',\n canvasConfig,\n updateCanvasConfig,\n}) {\n const canvasElementRef = useRef<HTMLDivElement>(null) as React.RefObject<HTMLDivElement>;\n const { setActiveInstance: setActiveCueCanvas, setActiveTool } = useCueCanvasActions();\n const uploadImageToS3 = useUploadHelper({ userId, renderAs, userType });\n const { scriptStatus } = useIsLearnosityLoaded(); // This hook checks if the Polypad script is loaded + (additional scripts)\n\n const cueCanvasRef = useRef<CueCanvasCore | null>(null);\n\n const onUpdateActiveTool = useCallback(\n (tool: TCueCanvasTool) => {\n setActiveTool(tool);\n },\n [setActiveTool],\n );\n\n useHeightExtender({\n canvasElementRef,\n cueCanvasRef,\n canScribble,\n });\n useConfigUpdater(canvasConfig, renderAs);\n\n useEffect(() => {\n if (canScribble && cueCanvasRef.current) {\n cueCanvasRef.current.resetViewPort();\n\n setActiveCueCanvas(cueCanvasRef.current);\n }\n }, [canScribble, setActiveCueCanvas]);\n\n useEffect(() => {\n if (initialData && cueCanvasRef.current) {\n cueCanvasRef.current.update(initialData);\n }\n }, [initialData]);\n\n useEffect(() => {\n if (height && cueCanvasRef.current) {\n cueCanvasRef.current.resetViewPort();\n }\n }, [height, width]);\n\n useEffect(() => {\n if (canRender && appended && !cueCanvasRef.current && scriptStatus === 'loaded') {\n const canvasCreateConfig = getCanvasConfig(width, height, renderAs, userType);\n const canvasSetting = getCanvasSettings(renderAs, userType);\n const cueCanvasCore = new CueCanvasCore({\n onPublish,\n onSubscribe,\n onUpdateActiveTool,\n onUpdateHeight,\n uploadImageToS3,\n height,\n userId,\n canvasId,\n userType,\n renderAs,\n updateCanvasConfig,\n });\n\n const createCueCanvas = async () => {\n await cueCanvasCore.create({\n canvasElementRef,\n canvasConfig: canvasCreateConfig,\n canvasSetting,\n initialData,\n });\n cueCanvasRef.current = cueCanvasCore;\n\n if (canScribble) {\n setActiveCueCanvas(cueCanvasCore);\n }\n };\n\n createCueCanvas();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [onPublish, onSubscribe, setActiveCueCanvas, canRender, appended, scriptStatus]);\n\n useEffect(() => {\n return () => {\n if (cueCanvasRef.current) {\n cueCanvasRef.current.destroy();\n cueCanvasRef.current = null;\n }\n };\n }, []);\n\n return (\n <CueCanvasWrapper\n id={renderAs === 'whiteboard' ? 'canvasContainer' : canvasId}\n ref={canvasElementRef}\n $width={width}\n $height={height}\n $canScribble={canScribble}\n $canRender={canRender}\n $renderAs={renderAs}\n />\n );\n});\n\nexport default CueCanvas;\n"],"names":["CueCanvas","memo","canvasId","width","height","canRender","onUpdateHeight","initialData","onPublish","onSubscribe","userId","appended","canScribble","userType","renderAs","canvasConfig","updateCanvasConfig","canvasElementRef","useRef","setActiveCueCanvas","setActiveTool","useCueCanvasActions","uploadImageToS3","useUploadHelper","scriptStatus","useIsLearnosityLoaded","cueCanvasRef","onUpdateActiveTool","useCallback","tool","useHeightExtender","useConfigUpdater","useEffect","canvasCreateConfig","getCanvasConfig","canvasSetting","getCanvasSettings","cueCanvasCore","CueCanvasCore","jsx","CueCanvasWrapper","CueCanvas$1"],"mappings":";;;;;;;;;;AAYA,MAAMA,IAA4BC,EAAK,SAAmB;AAAA,EACxD,UAAAC;AAAA,EACA,OAAAC;AAAA,EACA,QAAAC;AAAA,EACA,WAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,WAAAC;AAAA,EACA,aAAAC;AAAA,EACA,QAAAC;AAAA,EACA,UAAAC;AAAA,EACA,aAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,cAAAC;AAAA,EACA,oBAAAC;AACF,GAAG;AACK,QAAAC,IAAmBC,EAAuB,IAAI,GAC9C,EAAE,mBAAmBC,GAAoB,eAAAC,MAAkBC,EAAoB,GAC/EC,IAAkBC,EAAgB,EAAE,
|
|
1
|
+
{"version":3,"file":"cue-canvas.js","sources":["../../../src/features/cue-canvas/cue-canvas.tsx"],"sourcesContent":["import { memo, useCallback, useEffect, useRef, type FC } from 'react';\n\nimport useIsLearnosityLoaded from '../worksheet/learnosity-preloader/use-is-learnosity-loaded';\nimport { CueCanvasCore } from './cue-canvas-core';\nimport { getCanvasConfig, getCanvasSettings } from './cue-canvas-helpers';\nimport { CueCanvasWrapper } from './cue-cavas-styled';\nimport useConfigUpdater from './hooks/use-config-updater';\nimport { useCueCanvasActions } from './hooks/use-cue-canvas-actions';\nimport useHeightExtender from './hooks/use-height-extender';\nimport useUploadHelper from './hooks/use-upload-helper';\nimport type { ICueCanvas, TCueCanvasTool } from './types/cue-canvas';\n\nconst CueCanvas: FC<ICueCanvas> = memo(function CueCanvas({\n canvasId,\n width,\n height,\n canRender,\n onUpdateHeight,\n initialData,\n onPublish,\n onSubscribe,\n userId,\n appended,\n canScribble,\n userType,\n renderAs = 'canvas',\n canvasConfig,\n updateCanvasConfig,\n loggerRef,\n}) {\n const canvasElementRef = useRef<HTMLDivElement>(null) as React.RefObject<HTMLDivElement>;\n const { setActiveInstance: setActiveCueCanvas, setActiveTool } = useCueCanvasActions();\n const uploadImageToS3 = useUploadHelper({ userId, renderAs, userType });\n const { scriptStatus } = useIsLearnosityLoaded(); // This hook checks if the Polypad script is loaded + (additional scripts)\n\n const cueCanvasRef = useRef<CueCanvasCore | null>(null);\n\n const onUpdateActiveTool = useCallback(\n (tool: TCueCanvasTool) => {\n setActiveTool(tool);\n },\n [setActiveTool],\n );\n\n useHeightExtender({\n canvasElementRef,\n cueCanvasRef,\n canScribble,\n loggerRef,\n });\n useConfigUpdater(canvasConfig, renderAs);\n\n useEffect(() => {\n if (canScribble && cueCanvasRef.current) {\n cueCanvasRef.current.resetViewPort();\n\n setActiveCueCanvas(cueCanvasRef.current);\n }\n }, [canScribble, setActiveCueCanvas]);\n\n useEffect(() => {\n if (initialData && cueCanvasRef.current) {\n cueCanvasRef.current.update(initialData);\n }\n }, [initialData]);\n\n useEffect(() => {\n if (height && cueCanvasRef.current) {\n cueCanvasRef.current.resetViewPort();\n }\n }, [height, width]);\n\n useEffect(() => {\n if (canRender && appended && !cueCanvasRef.current && scriptStatus === 'loaded') {\n const canvasCreateConfig = getCanvasConfig(width, height, renderAs, userType);\n const canvasSetting = getCanvasSettings(renderAs, userType);\n const cueCanvasCore = new CueCanvasCore({\n onPublish,\n onSubscribe,\n onUpdateActiveTool,\n onUpdateHeight,\n uploadImageToS3,\n height,\n userId,\n canvasId,\n userType,\n renderAs,\n updateCanvasConfig,\n });\n\n const createCueCanvas = async () => {\n await cueCanvasCore.create({\n canvasElementRef,\n canvasConfig: canvasCreateConfig,\n canvasSetting,\n initialData,\n });\n cueCanvasRef.current = cueCanvasCore;\n\n if (canScribble) {\n setActiveCueCanvas(cueCanvasCore);\n }\n };\n\n createCueCanvas();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [onPublish, onSubscribe, setActiveCueCanvas, canRender, appended, scriptStatus]);\n\n useEffect(() => {\n return () => {\n if (cueCanvasRef.current) {\n cueCanvasRef.current.destroy();\n cueCanvasRef.current = null;\n }\n };\n }, []);\n\n return (\n <CueCanvasWrapper\n id={renderAs === 'whiteboard' ? 'canvasContainer' : canvasId}\n ref={canvasElementRef}\n $width={width}\n $height={height}\n $canScribble={canScribble}\n $canRender={canRender}\n $renderAs={renderAs}\n />\n );\n});\n\nexport default CueCanvas;\n"],"names":["CueCanvas","memo","canvasId","width","height","canRender","onUpdateHeight","initialData","onPublish","onSubscribe","userId","appended","canScribble","userType","renderAs","canvasConfig","updateCanvasConfig","loggerRef","canvasElementRef","useRef","setActiveCueCanvas","setActiveTool","useCueCanvasActions","uploadImageToS3","useUploadHelper","scriptStatus","useIsLearnosityLoaded","cueCanvasRef","onUpdateActiveTool","useCallback","tool","useHeightExtender","useConfigUpdater","useEffect","canvasCreateConfig","getCanvasConfig","canvasSetting","getCanvasSettings","cueCanvasCore","CueCanvasCore","jsx","CueCanvasWrapper","CueCanvas$1"],"mappings":";;;;;;;;;;AAYA,MAAMA,IAA4BC,EAAK,SAAmB;AAAA,EACxD,UAAAC;AAAA,EACA,OAAAC;AAAA,EACA,QAAAC;AAAA,EACA,WAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,WAAAC;AAAA,EACA,aAAAC;AAAA,EACA,QAAAC;AAAA,EACA,UAAAC;AAAA,EACA,aAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC,IAAW;AAAA,EACX,cAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,WAAAC;AACF,GAAG;AACK,QAAAC,IAAmBC,EAAuB,IAAI,GAC9C,EAAE,mBAAmBC,GAAoB,eAAAC,MAAkBC,EAAoB,GAC/EC,IAAkBC,EAAgB,EAAE,QAAAd,GAAQ,UAAAI,GAAU,UAAAD,GAAU,GAChE,EAAE,cAAAY,MAAiBC,KAEnBC,IAAeR,EAA6B,IAAI,GAEhDS,IAAqBC;AAAA,IACzB,CAACC,MAAyB;AACxB,MAAAT,EAAcS,CAAI;AAAA,IACpB;AAAA,IACA,CAACT,CAAa;AAAA,EAAA;AAGE,SAAAU,EAAA;AAAA,IAChB,kBAAAb;AAAA,IACA,cAAAS;AAAA,IACA,aAAAf;AAAA,IACA,WAAAK;AAAA,EAAA,CACD,GACDe,EAAiBjB,GAAcD,CAAQ,GAEvCmB,EAAU,MAAM;AACV,IAAArB,KAAee,EAAa,YAC9BA,EAAa,QAAQ,iBAErBP,EAAmBO,EAAa,OAAO;AAAA,EACzC,GACC,CAACf,GAAaQ,CAAkB,CAAC,GAEpCa,EAAU,MAAM;AACV,IAAA1B,KAAeoB,EAAa,WACjBA,EAAA,QAAQ,OAAOpB,CAAW;AAAA,EACzC,GACC,CAACA,CAAW,CAAC,GAEhB0B,EAAU,MAAM;AACV,IAAA7B,KAAUuB,EAAa,WACzBA,EAAa,QAAQ;EACvB,GACC,CAACvB,GAAQD,CAAK,CAAC,GAElB8B,EAAU,MAAM;AACd,QAAI5B,KAAaM,KAAY,CAACgB,EAAa,WAAWF,MAAiB,UAAU;AAC/E,YAAMS,IAAqBC,EAAgBhC,GAAOC,GAAQU,GAAUD,CAAQ,GACtEuB,IAAgBC,EAAkBvB,GAAUD,CAAQ,GACpDyB,IAAgB,IAAIC,EAAc;AAAA,QACtC,WAAA/B;AAAA,QACA,aAAAC;AAAA,QACA,oBAAAmB;AAAA,QACA,gBAAAtB;AAAA,QACA,iBAAAiB;AAAA,QACA,QAAAnB;AAAA,QACA,QAAAM;AAAA,QACA,UAAAR;AAAA,QACA,UAAAW;AAAA,QACA,UAAAC;AAAA,QACA,oBAAAE;AAAA,MAAA,CACD;AAgBe,OAdQ,YAAY;AAClC,cAAMsB,EAAc,OAAO;AAAA,UACzB,kBAAApB;AAAA,UACA,cAAcgB;AAAA,UACd,eAAAE;AAAA,UACA,aAAA7B;AAAA,QAAA,CACD,GACDoB,EAAa,UAAUW,GAEnB1B,KACFQ,EAAmBkB,CAAa;AAAA,MAClC;IAIJ;AAAA,EAAA,GAEC,CAAC9B,GAAWC,GAAaW,GAAoBf,GAAWM,GAAUc,CAAY,CAAC,GAElFQ,EAAU,MACD,MAAM;AACX,IAAIN,EAAa,YACfA,EAAa,QAAQ,WACrBA,EAAa,UAAU;AAAA,EACzB,GAED,CAAE,CAAA,GAGH,gBAAAa;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,IAAI3B,MAAa,eAAe,oBAAoBZ;AAAA,MACpD,KAAKgB;AAAA,MACL,QAAQf;AAAA,MACR,SAASC;AAAA,MACT,cAAcQ;AAAA,MACd,YAAYP;AAAA,MACZ,WAAWS;AAAA,IAAA;AAAA,EAAA;AAGjB,CAAC,GAED4B,IAAe1C;"}
|
|
@@ -1,45 +1,53 @@
|
|
|
1
|
-
import { useRef as
|
|
2
|
-
import { useCueCanvasActions as
|
|
3
|
-
|
|
1
|
+
import { useRef as L, useCallback as p, useEffect as v } from "react";
|
|
2
|
+
import { useCueCanvasActions as w } from "./use-cue-canvas-actions.js";
|
|
3
|
+
import D from "../../worksheet/constants/events.js";
|
|
4
|
+
const A = ({
|
|
4
5
|
canvasElementRef: e,
|
|
5
|
-
cueCanvasRef:
|
|
6
|
-
canScribble:
|
|
6
|
+
cueCanvasRef: n,
|
|
7
|
+
canScribble: h,
|
|
8
|
+
loggerRef: o
|
|
7
9
|
}) => {
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
}, []),
|
|
11
|
-
var t;
|
|
12
|
-
if (e.current && o.current) {
|
|
13
|
-
o.current = !1;
|
|
14
|
-
const h = e.current.getBoundingClientRect().height + 200;
|
|
15
|
-
(t = r == null ? void 0 : r.current) == null || t.updateHeight(h);
|
|
16
|
-
}
|
|
17
|
-
n.current = !1;
|
|
18
|
-
}, [e, r]), c = d(
|
|
10
|
+
const i = L(!1), u = L(!1), { isWritingToolActive: E } = w(), c = p(() => {
|
|
11
|
+
i.current = !0;
|
|
12
|
+
}, []), s = p(
|
|
19
13
|
(t) => {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
t.
|
|
14
|
+
var r;
|
|
15
|
+
if (o == null || o.current(D.STROKE_ADDED, {
|
|
16
|
+
source: t.pointerType || "unknown",
|
|
17
|
+
mode: "cuecanvas"
|
|
18
|
+
}), e.current && u.current) {
|
|
19
|
+
u.current = !1;
|
|
20
|
+
const l = e.current.getBoundingClientRect().height + 200;
|
|
21
|
+
(r = n == null ? void 0 : n.current) == null || r.updateHeight(l);
|
|
22
|
+
}
|
|
23
|
+
i.current = !1;
|
|
24
|
+
},
|
|
25
|
+
[e, n, o]
|
|
26
|
+
), d = p(
|
|
27
|
+
(t) => {
|
|
28
|
+
if (i.current && e.current) {
|
|
29
|
+
const r = e.current.getBoundingClientRect();
|
|
30
|
+
t.clientY - r.top >= r.height - 200 && (u.current = !0);
|
|
23
31
|
}
|
|
24
32
|
},
|
|
25
33
|
[e]
|
|
26
34
|
);
|
|
27
|
-
|
|
35
|
+
v(() => {
|
|
28
36
|
const t = e.current;
|
|
29
|
-
if (
|
|
30
|
-
return t.addEventListener("pointerdown",
|
|
31
|
-
t.removeEventListener("pointerdown",
|
|
37
|
+
if (h && t && E)
|
|
38
|
+
return t.addEventListener("pointerdown", c), t.addEventListener("pointerup", s), t.addEventListener("pointermove", d), () => {
|
|
39
|
+
t.removeEventListener("pointerdown", c), t.removeEventListener("pointerup", s), t.removeEventListener("pointermove", d);
|
|
32
40
|
};
|
|
33
41
|
}, [
|
|
34
42
|
e,
|
|
35
|
-
i,
|
|
36
43
|
c,
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
44
|
+
d,
|
|
45
|
+
s,
|
|
46
|
+
h,
|
|
47
|
+
E
|
|
40
48
|
]);
|
|
41
49
|
};
|
|
42
50
|
export {
|
|
43
|
-
|
|
51
|
+
A as default
|
|
44
52
|
};
|
|
45
53
|
//# sourceMappingURL=use-height-extender.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-height-extender.js","sources":["../../../../src/features/cue-canvas/hooks/use-height-extender.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from 'react';\n\nimport type { CueCanvasCore } from '../cue-canvas-core';\nimport { useCueCanvasActions } from './use-cue-canvas-actions';\n\ninterface IUseHeightIncreaseProps {\n canvasElementRef: React.RefObject<HTMLElement | null>;\n cueCanvasRef: React.RefObject<CueCanvasCore | null> | undefined;\n canScribble: boolean;\n}\n\nconst useHeightExtender = ({\n canvasElementRef,\n cueCanvasRef,\n canScribble,\n}: IUseHeightIncreaseProps) => {\n const isScribblingRef = useRef<boolean>(false);\n const shouldIncreaseHeightRef = useRef<boolean>(false);\n const { isWritingToolActive } = useCueCanvasActions();\n\n const handlePointerDown = useCallback(() => {\n isScribblingRef.current = true;\n }, []);\n\n const handlePointerUp = useCallback(() => {\n
|
|
1
|
+
{"version":3,"file":"use-height-extender.js","sources":["../../../../src/features/cue-canvas/hooks/use-height-extender.ts"],"sourcesContent":["import { useCallback, useEffect, useRef } from 'react';\n\nimport type { CueCanvasCore } from '../cue-canvas-core';\nimport { useCueCanvasActions } from './use-cue-canvas-actions';\nimport EVENTS from '../../worksheet/constants/events';\n\ninterface IUseHeightIncreaseProps {\n canvasElementRef: React.RefObject<HTMLElement | null>;\n cueCanvasRef: React.RefObject<CueCanvasCore | null> | undefined;\n canScribble: boolean;\n loggerRef?: React.RefObject<(eventName: string, eventPayload?: Record<string, unknown>) => void>;\n}\n\nconst useHeightExtender = ({\n canvasElementRef,\n cueCanvasRef,\n canScribble,\n loggerRef,\n}: IUseHeightIncreaseProps) => {\n const isScribblingRef = useRef<boolean>(false);\n const shouldIncreaseHeightRef = useRef<boolean>(false);\n const { isWritingToolActive } = useCueCanvasActions();\n\n const handlePointerDown = useCallback(() => {\n isScribblingRef.current = true;\n }, []);\n\n const handlePointerUp = useCallback(\n (e: PointerEvent) => {\n loggerRef?.current(EVENTS.STROKE_ADDED, {\n source: e.pointerType || 'unknown',\n mode: 'cuecanvas',\n });\n if (canvasElementRef.current && shouldIncreaseHeightRef.current) {\n shouldIncreaseHeightRef.current = false;\n\n const rect = canvasElementRef.current.getBoundingClientRect();\n const updatedHeight = rect.height + 200;\n\n cueCanvasRef?.current?.updateHeight(updatedHeight);\n }\n\n isScribblingRef.current = false;\n },\n [canvasElementRef, cueCanvasRef, loggerRef],\n );\n\n const handlePointerMove = useCallback(\n (event: MouseEvent) => {\n if (isScribblingRef.current && canvasElementRef.current) {\n const rect = canvasElementRef.current.getBoundingClientRect();\n const y = event.clientY - rect.top;\n\n if (y >= rect.height - 200) {\n shouldIncreaseHeightRef.current = true;\n }\n }\n },\n [canvasElementRef],\n );\n\n useEffect(() => {\n const canvasEle = canvasElementRef.current;\n\n if (canScribble && canvasEle && isWritingToolActive) {\n canvasEle.addEventListener('pointerdown', handlePointerDown);\n canvasEle.addEventListener('pointerup', handlePointerUp);\n canvasEle.addEventListener('pointermove', handlePointerMove);\n\n return () => {\n canvasEle.removeEventListener('pointerdown', handlePointerDown);\n canvasEle.removeEventListener('pointerup', handlePointerUp);\n canvasEle.removeEventListener('pointermove', handlePointerMove);\n };\n }\n }, [\n canvasElementRef,\n handlePointerDown,\n handlePointerMove,\n handlePointerUp,\n canScribble,\n isWritingToolActive,\n ]);\n};\n\nexport default useHeightExtender;\n"],"names":["useHeightExtender","canvasElementRef","cueCanvasRef","canScribble","loggerRef","isScribblingRef","useRef","shouldIncreaseHeightRef","isWritingToolActive","useCueCanvasActions","handlePointerDown","useCallback","handlePointerUp","e","EVENTS","updatedHeight","_a","handlePointerMove","event","rect","useEffect","canvasEle"],"mappings":";;;AAaA,MAAMA,IAAoB,CAAC;AAAA,EACzB,kBAAAC;AAAA,EACA,cAAAC;AAAA,EACA,aAAAC;AAAA,EACA,WAAAC;AACF,MAA+B;AACvB,QAAAC,IAAkBC,EAAgB,EAAK,GACvCC,IAA0BD,EAAgB,EAAK,GAC/C,EAAE,qBAAAE,MAAwBC,KAE1BC,IAAoBC,EAAY,MAAM;AAC1C,IAAAN,EAAgB,UAAU;AAAA,EAC5B,GAAG,CAAE,CAAA,GAECO,IAAkBD;AAAA,IACtB,CAACE,MAAoB;;AAKf,UAJOT,KAAA,QAAAA,EAAA,QAAQU,EAAO,cAAc;AAAA,QACtC,QAAQD,EAAE,eAAe;AAAA,QACzB,MAAM;AAAA,MAAA,IAEJZ,EAAiB,WAAWM,EAAwB,SAAS;AAC/D,QAAAA,EAAwB,UAAU;AAG5B,cAAAQ,IADOd,EAAiB,QAAQ,sBAAsB,EACjC,SAAS;AAEtB,SAAAe,IAAAd,KAAA,gBAAAA,EAAA,YAAA,QAAAc,EAAS,aAAaD;AAAA,MACtC;AAEA,MAAAV,EAAgB,UAAU;AAAA,IAC5B;AAAA,IACA,CAACJ,GAAkBC,GAAcE,CAAS;AAAA,EAAA,GAGtCa,IAAoBN;AAAA,IACxB,CAACO,MAAsB;AACjB,UAAAb,EAAgB,WAAWJ,EAAiB,SAAS;AACjD,cAAAkB,IAAOlB,EAAiB,QAAQ,sBAAsB;AAGxD,QAFMiB,EAAM,UAAUC,EAAK,OAEtBA,EAAK,SAAS,QACrBZ,EAAwB,UAAU;AAAA,MAEtC;AAAA,IACF;AAAA,IACA,CAACN,CAAgB;AAAA,EAAA;AAGnB,EAAAmB,EAAU,MAAM;AACd,UAAMC,IAAYpB,EAAiB;AAE/B,QAAAE,KAAekB,KAAab;AACpB,aAAAa,EAAA,iBAAiB,eAAeX,CAAiB,GACjDW,EAAA,iBAAiB,aAAaT,CAAe,GAC7CS,EAAA,iBAAiB,eAAeJ,CAAiB,GAEpD,MAAM;AACD,QAAAI,EAAA,oBAAoB,eAAeX,CAAiB,GACpDW,EAAA,oBAAoB,aAAaT,CAAe,GAChDS,EAAA,oBAAoB,eAAeJ,CAAiB;AAAA,MAAA;AAAA,EAElE,GACC;AAAA,IACDhB;AAAA,IACAS;AAAA,IACAO;AAAA,IACAL;AAAA,IACAT;AAAA,IACAK;AAAA,EAAA,CACD;AACH;"}
|
|
@@ -33,7 +33,8 @@ const _ = {
|
|
|
33
33
|
WORKSHEET_V3_SCRIBBLE_TOGGLE: "worksheet_v3_scribble_toggled",
|
|
34
34
|
WORKSHEET_V3_HINT_SEEN: "worksheet_v3_hint_seen",
|
|
35
35
|
WORKSHEET_V3_SOLUTION_SEEN: "worksheet_v3_solution_seen",
|
|
36
|
-
WORKSHEET_V3_GREATER_WIDTH_ELEMENT: "worksheet_v3_greater_width_element"
|
|
36
|
+
WORKSHEET_V3_GREATER_WIDTH_ELEMENT: "worksheet_v3_greater_width_element",
|
|
37
|
+
STROKE_ADDED: "stroke_added"
|
|
37
38
|
};
|
|
38
39
|
export {
|
|
39
40
|
_ as default
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"events.js","sources":["../../../../src/features/worksheet/constants/events.ts"],"sourcesContent":["const EVENTS = {\n WORKSHEET_V3_SCRIPT_LOADING: 'worksheet_v3_script_loading',\n WORKSHEET_V3_SCRIPT_LOADED: 'worksheet_v3_script_loaded',\n WORKSHEET_V3_SCRIPT_FAILED: 'worksheet_v3_script_failed',\n\n WORKSHEET_V3_SCRIPT_FALLBACK_LOADING: 'worksheet_v3_script_fallback_loading',\n WORKSHEET_V3_SCRIPT_FALLBACK_LOADED: 'worksheet_v3_script_fallback_loaded',\n WORKSHEET_V3_SCRIPT_FALLBACK_FAILED: 'worksheet_v3_script_fallback_failed',\n\n WORKSHEET_V3_SCRIPT_READY: 'worksheet_v3_script_ready',\n\n WORKSHEET_V3_ITEMS_LOADING: 'worksheet_v3_items_loading',\n WORKSHEET_V3_ITEMS_LOADED: 'worksheet_v3_items_loaded',\n WORKSHEET_V3_ITEMS_FAILED: 'worksheet_v3_items_failed',\n\n WORKSHEET_V3_ATTEMPT_RESPONSES_LOADING: 'worksheet_v3_attempt_responses_loading',\n WORKSHEET_V3_ATTEMPT_RESPONSES_LOADED: 'worksheet_v3_attempt_responses_loaded',\n WORKSHEET_V3_ATTEMPT_RESPONSES_FAILED: 'worksheet_v3_attempt_responses_failed',\n\n WORKSHHEET_V3_LEANROSITY_INITIALIZING: 'worksheet_v3_learnosity_initializing',\n WORKSHEET_V3_LEARNOSITY_INITIALIZED: 'worksheet_v3_learnosity_initialized',\n WORKSHEET_V3_LEARNOSITY_FAILED: 'worksheet_v3_learnosity_failed',\n\n WORKSHEET_V3_READY: 'worksheet_v3_ready',\n\n WORKSHEET_V3_QUESTION_APPENDING_QUEUED: 'worksheet_v3_question_appending_queued',\n WORKSHEET_V3_QUESTION_APPENDING: 'worksheet_v3_question_appending',\n WORKSHEET_V3_QUESTION_APPENDED: 'worksheet_v3_question_appended',\n\n WORKSHEET_V3_FIRST_QUESTION_APPENDED: 'worksheet_v3_first_question_appended',\n\n WORKSHEET_V3_QUESTION_MISSING_VALIDATION: 'worksheet_v3_question_missing_validation',\n MATHJAX_COMPILE_ERROR: 'mathjax_compile_error',\n MATHJAX_TYPESET_ERROR: 'mathjax_typeset_error',\n MATHJAX_FORMAT_ERROR: 'mathjax_format_error',\n\n MATHJAX_SCRIPT_LOADING: 'mathjax_script_loading',\n MATHJAX_SCRIPT_LOADED: 'mathjax_script_loaded',\n MATHJAX_SCRIPT_FAILED: 'mathjax_script_failed',\n\n POLYPAD_SCRIPT_LOADING: 'polypad_script_loading',\n POLYPAD_SCRIPT_LOADED: 'polypad_script_loaded',\n POLYPAD_SCRIPT_FAILED: 'polypad_script_failed',\n\n WORKSHEET_V3_SCRIBBLE_TOGGLE: 'worksheet_v3_scribble_toggled',\n WORKSHEET_V3_HINT_SEEN: 'worksheet_v3_hint_seen',\n WORKSHEET_V3_SOLUTION_SEEN: 'worksheet_v3_solution_seen',\n WORKSHEET_V3_GREATER_WIDTH_ELEMENT: 'worksheet_v3_greater_width_element',\n};\n\nexport default EVENTS;\n"],"names":["EVENTS"],"mappings":"AAAA,MAAMA,IAAS;AAAA,EACb,6BAA6B;AAAA,EAC7B,4BAA4B;AAAA,EAC5B,4BAA4B;AAAA,EAE5B,sCAAsC;AAAA,EACtC,qCAAqC;AAAA,EACrC,qCAAqC;AAAA,EAErC,2BAA2B;AAAA,EAE3B,4BAA4B;AAAA,EAC5B,2BAA2B;AAAA,EAC3B,2BAA2B;AAAA,EAE3B,wCAAwC;AAAA,EACxC,uCAAuC;AAAA,EACvC,uCAAuC;AAAA,EAEvC,uCAAuC;AAAA,EACvC,qCAAqC;AAAA,EACrC,gCAAgC;AAAA,EAEhC,oBAAoB;AAAA,EAEpB,wCAAwC;AAAA,EACxC,iCAAiC;AAAA,EACjC,gCAAgC;AAAA,EAEhC,sCAAsC;AAAA,EAEtC,0CAA0C;AAAA,EAC1C,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EACvB,sBAAsB;AAAA,EAEtB,wBAAwB;AAAA,EACxB,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EAEvB,wBAAwB;AAAA,EACxB,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EAEvB,8BAA8B;AAAA,EAC9B,wBAAwB;AAAA,EACxB,4BAA4B;AAAA,EAC5B,oCAAoC;
|
|
1
|
+
{"version":3,"file":"events.js","sources":["../../../../src/features/worksheet/constants/events.ts"],"sourcesContent":["const EVENTS = {\n WORKSHEET_V3_SCRIPT_LOADING: 'worksheet_v3_script_loading',\n WORKSHEET_V3_SCRIPT_LOADED: 'worksheet_v3_script_loaded',\n WORKSHEET_V3_SCRIPT_FAILED: 'worksheet_v3_script_failed',\n\n WORKSHEET_V3_SCRIPT_FALLBACK_LOADING: 'worksheet_v3_script_fallback_loading',\n WORKSHEET_V3_SCRIPT_FALLBACK_LOADED: 'worksheet_v3_script_fallback_loaded',\n WORKSHEET_V3_SCRIPT_FALLBACK_FAILED: 'worksheet_v3_script_fallback_failed',\n\n WORKSHEET_V3_SCRIPT_READY: 'worksheet_v3_script_ready',\n\n WORKSHEET_V3_ITEMS_LOADING: 'worksheet_v3_items_loading',\n WORKSHEET_V3_ITEMS_LOADED: 'worksheet_v3_items_loaded',\n WORKSHEET_V3_ITEMS_FAILED: 'worksheet_v3_items_failed',\n\n WORKSHEET_V3_ATTEMPT_RESPONSES_LOADING: 'worksheet_v3_attempt_responses_loading',\n WORKSHEET_V3_ATTEMPT_RESPONSES_LOADED: 'worksheet_v3_attempt_responses_loaded',\n WORKSHEET_V3_ATTEMPT_RESPONSES_FAILED: 'worksheet_v3_attempt_responses_failed',\n\n WORKSHHEET_V3_LEANROSITY_INITIALIZING: 'worksheet_v3_learnosity_initializing',\n WORKSHEET_V3_LEARNOSITY_INITIALIZED: 'worksheet_v3_learnosity_initialized',\n WORKSHEET_V3_LEARNOSITY_FAILED: 'worksheet_v3_learnosity_failed',\n\n WORKSHEET_V3_READY: 'worksheet_v3_ready',\n\n WORKSHEET_V3_QUESTION_APPENDING_QUEUED: 'worksheet_v3_question_appending_queued',\n WORKSHEET_V3_QUESTION_APPENDING: 'worksheet_v3_question_appending',\n WORKSHEET_V3_QUESTION_APPENDED: 'worksheet_v3_question_appended',\n\n WORKSHEET_V3_FIRST_QUESTION_APPENDED: 'worksheet_v3_first_question_appended',\n\n WORKSHEET_V3_QUESTION_MISSING_VALIDATION: 'worksheet_v3_question_missing_validation',\n MATHJAX_COMPILE_ERROR: 'mathjax_compile_error',\n MATHJAX_TYPESET_ERROR: 'mathjax_typeset_error',\n MATHJAX_FORMAT_ERROR: 'mathjax_format_error',\n\n MATHJAX_SCRIPT_LOADING: 'mathjax_script_loading',\n MATHJAX_SCRIPT_LOADED: 'mathjax_script_loaded',\n MATHJAX_SCRIPT_FAILED: 'mathjax_script_failed',\n\n POLYPAD_SCRIPT_LOADING: 'polypad_script_loading',\n POLYPAD_SCRIPT_LOADED: 'polypad_script_loaded',\n POLYPAD_SCRIPT_FAILED: 'polypad_script_failed',\n\n WORKSHEET_V3_SCRIBBLE_TOGGLE: 'worksheet_v3_scribble_toggled',\n WORKSHEET_V3_HINT_SEEN: 'worksheet_v3_hint_seen',\n WORKSHEET_V3_SOLUTION_SEEN: 'worksheet_v3_solution_seen',\n WORKSHEET_V3_GREATER_WIDTH_ELEMENT: 'worksheet_v3_greater_width_element',\n STROKE_ADDED: 'stroke_added',\n};\n\nexport default EVENTS;\n"],"names":["EVENTS"],"mappings":"AAAA,MAAMA,IAAS;AAAA,EACb,6BAA6B;AAAA,EAC7B,4BAA4B;AAAA,EAC5B,4BAA4B;AAAA,EAE5B,sCAAsC;AAAA,EACtC,qCAAqC;AAAA,EACrC,qCAAqC;AAAA,EAErC,2BAA2B;AAAA,EAE3B,4BAA4B;AAAA,EAC5B,2BAA2B;AAAA,EAC3B,2BAA2B;AAAA,EAE3B,wCAAwC;AAAA,EACxC,uCAAuC;AAAA,EACvC,uCAAuC;AAAA,EAEvC,uCAAuC;AAAA,EACvC,qCAAqC;AAAA,EACrC,gCAAgC;AAAA,EAEhC,oBAAoB;AAAA,EAEpB,wCAAwC;AAAA,EACxC,iCAAiC;AAAA,EACjC,gCAAgC;AAAA,EAEhC,sCAAsC;AAAA,EAEtC,0CAA0C;AAAA,EAC1C,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EACvB,sBAAsB;AAAA,EAEtB,wBAAwB;AAAA,EACxB,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EAEvB,wBAAwB;AAAA,EACxB,uBAAuB;AAAA,EACvB,uBAAuB;AAAA,EAEvB,8BAA8B;AAAA,EAC9B,wBAAwB;AAAA,EACxB,4BAA4B;AAAA,EAC5B,oCAAoC;AAAA,EACpC,cAAc;AAChB;"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { jsxs as
|
|
1
|
+
import { jsxs as W, jsx as o, Fragment as Le } from "react/jsx-runtime";
|
|
2
2
|
import { memo as Ae, useMemo as g, useState as O, useRef as z, useCallback as Be, useEffect as R, useLayoutEffect as Ne } from "react";
|
|
3
3
|
import { IMAGES as Oe } from "../../../../assets/images/images.js";
|
|
4
4
|
import ze from "../../../cue-canvas/cue-canvas.js";
|
|
@@ -22,7 +22,7 @@ const Tt = Ae(function({
|
|
|
22
22
|
response: t,
|
|
23
23
|
nextQuestionId: Re,
|
|
24
24
|
isActive: v,
|
|
25
|
-
isHidden:
|
|
25
|
+
isHidden: x,
|
|
26
26
|
canRender: j,
|
|
27
27
|
appended: s,
|
|
28
28
|
intersectionObserver: F
|
|
@@ -38,7 +38,7 @@ const Tt = Ae(function({
|
|
|
38
38
|
learnosity: $,
|
|
39
39
|
onPublishStrokes: V,
|
|
40
40
|
onReceiveStrokes: X,
|
|
41
|
-
initialStrokesData:
|
|
41
|
+
initialStrokesData: T,
|
|
42
42
|
onPublishMouseMove: G,
|
|
43
43
|
onSubscribeMouseMove: Y,
|
|
44
44
|
canResolveDoubt: we,
|
|
@@ -46,7 +46,7 @@ const Tt = Ae(function({
|
|
|
46
46
|
userId: He,
|
|
47
47
|
studentId: Me,
|
|
48
48
|
subjectiveProps: Z,
|
|
49
|
-
loggerRef:
|
|
49
|
+
loggerRef: w,
|
|
50
50
|
isScribblingEnabled: J
|
|
51
51
|
} = dt((e) => ({
|
|
52
52
|
behavior: e.behavior,
|
|
@@ -69,10 +69,10 @@ const Tt = Ae(function({
|
|
|
69
69
|
subjectiveProps: e.subjectiveProps,
|
|
70
70
|
loggerRef: e.loggerRef,
|
|
71
71
|
isScribblingEnabled: e.scribblingEnabled
|
|
72
|
-
})), { background: q = "paper" } = U,
|
|
72
|
+
})), { background: q = "paper" } = U, C = g(
|
|
73
73
|
() => q === "paper" ? Ke(r) : void 0,
|
|
74
74
|
[q, r]
|
|
75
|
-
), [
|
|
75
|
+
), [H, Ie] = O(), [ee, We] = O(), {
|
|
76
76
|
validation: te,
|
|
77
77
|
review: k,
|
|
78
78
|
maximumAttempts: Q,
|
|
@@ -90,19 +90,19 @@ const Tt = Ae(function({
|
|
|
90
90
|
question_number: le,
|
|
91
91
|
item_number: de,
|
|
92
92
|
item_display_number: me
|
|
93
|
-
} = r,
|
|
93
|
+
} = r, M = m === "overview", l = Ve(ae), f = ae === "SystemIntro", L = l || f, he = t == null ? void 0 : t.responseEdited, ke = g(() => {
|
|
94
94
|
const e = [];
|
|
95
|
-
return he && c === "TEACHER" && e.push("attempting"), s || e.push("hidden"), p === "hotspot" && e.push("correct-answers-hidden"), s && D && p === "clozetext" && (!l || c === "STUDENT" ? e.push("response-hidden") : e.push("response-code-hidden")),
|
|
95
|
+
return he && c === "TEACHER" && e.push("attempting"), s || e.push("hidden"), p === "hotspot" && e.push("correct-answers-hidden"), s && D && p === "clozetext" && (!l || c === "STUDENT" ? e.push("response-hidden") : e.push("response-code-hidden")), M && e.push("lesson-overview"), l && e.push("concept-intro"), f && e.push("system-intro"), e.join(" ");
|
|
96
96
|
}, [
|
|
97
97
|
s,
|
|
98
98
|
l,
|
|
99
|
-
|
|
99
|
+
M,
|
|
100
100
|
f,
|
|
101
101
|
p,
|
|
102
102
|
he,
|
|
103
103
|
D,
|
|
104
104
|
c
|
|
105
|
-
]), A = z({}), fe = (t == null ? void 0 : t.hintsUsed) ?? 0,
|
|
105
|
+
]), A = z({}), fe = (t == null ? void 0 : t.hintsUsed) ?? 0, I = z(null), B = z(null), N = g(() => h == null ? void 0 : h.slice(0, fe), [h, fe]), pe = g(() => c === "TEACHER" || E ? !0 : !t || !t.response || t.responseEdited ? !1 : te, [t, c, te, E]), be = g(() => {
|
|
106
106
|
if (c === "TEACHER") return !0;
|
|
107
107
|
if (k) {
|
|
108
108
|
const { attemptsHistory: e } = t ?? {};
|
|
@@ -119,7 +119,7 @@ const Tt = Ae(function({
|
|
|
119
119
|
We(e);
|
|
120
120
|
}, []);
|
|
121
121
|
return R(() => {
|
|
122
|
-
|
|
122
|
+
I.current && F.observe(I.current);
|
|
123
123
|
}, [F]), R(() => {
|
|
124
124
|
if (s && (r.type === "clozeassociation" || r.type === "association" || r.type === "clozeformula")) {
|
|
125
125
|
const e = document.querySelectorAll(
|
|
@@ -142,14 +142,14 @@ const Tt = Ae(function({
|
|
|
142
142
|
}
|
|
143
143
|
}, [s, $, i, k, be, c, pe]), R(() => {
|
|
144
144
|
const e = B.current;
|
|
145
|
-
if (s && e &&
|
|
145
|
+
if (s && e && w.current && A.current[i] === void 0 && !l && !f) {
|
|
146
146
|
const a = e.clientWidth, n = e.querySelectorAll("*");
|
|
147
147
|
for (let u = 0; u < n.length; u++) {
|
|
148
148
|
const d = n[u];
|
|
149
149
|
if (d != null && d.closest(".resize-sensor"))
|
|
150
150
|
continue;
|
|
151
151
|
if (((d == null ? void 0 : d.clientWidth) ?? 0) > a) {
|
|
152
|
-
A.current[i] = !0,
|
|
152
|
+
A.current[i] = !0, w.current(Fe.WORKSHEET_V3_GREATER_WIDTH_ELEMENT, {
|
|
153
153
|
item_reference: ue,
|
|
154
154
|
widget_reference: ce,
|
|
155
155
|
question_type: p,
|
|
@@ -170,13 +170,13 @@ const Tt = Ae(function({
|
|
|
170
170
|
me,
|
|
171
171
|
de,
|
|
172
172
|
ue,
|
|
173
|
-
|
|
173
|
+
w,
|
|
174
174
|
p,
|
|
175
175
|
le,
|
|
176
176
|
i,
|
|
177
177
|
ce
|
|
178
178
|
]), R(() => {
|
|
179
|
-
const e =
|
|
179
|
+
const e = I.current, a = (n) => {
|
|
180
180
|
const u = n.querySelector(".lrn_response_wrapper");
|
|
181
181
|
if (L || !u)
|
|
182
182
|
return 0;
|
|
@@ -198,17 +198,17 @@ const Tt = Ae(function({
|
|
|
198
198
|
return Math.abs(ve - n) > 4 ? ve : n;
|
|
199
199
|
}), $.renderMath("mathjax");
|
|
200
200
|
}), Ne(() => {
|
|
201
|
-
!re && !
|
|
202
|
-
}, [
|
|
201
|
+
!re && !x && Xe(i);
|
|
202
|
+
}, [x, re, i, ne]), /* @__PURE__ */ W(
|
|
203
203
|
it,
|
|
204
204
|
{
|
|
205
205
|
"data-response-id": i,
|
|
206
206
|
className: `widget-${i}`,
|
|
207
|
-
ref:
|
|
207
|
+
ref: I,
|
|
208
208
|
$topOffset: ne,
|
|
209
209
|
$flexDirection: S ? "row" : "column",
|
|
210
210
|
$alignItems: S ? "flex-start" : "center",
|
|
211
|
-
$hidden:
|
|
211
|
+
$hidden: x,
|
|
212
212
|
$marginBottom: Ue,
|
|
213
213
|
children: [
|
|
214
214
|
S && /* @__PURE__ */ o(
|
|
@@ -219,14 +219,14 @@ const Tt = Ae(function({
|
|
|
219
219
|
}
|
|
220
220
|
}
|
|
221
221
|
),
|
|
222
|
-
/* @__PURE__ */
|
|
222
|
+
/* @__PURE__ */ W(
|
|
223
223
|
rt,
|
|
224
224
|
{
|
|
225
225
|
ref: B,
|
|
226
226
|
$width: S ? "50%" : `${K}px`,
|
|
227
|
-
$minHeight:
|
|
227
|
+
$minHeight: H ? Math.max(H - 72, ee ?? 0) : xe,
|
|
228
228
|
$isActive: v,
|
|
229
|
-
$paperColor:
|
|
229
|
+
$paperColor: C,
|
|
230
230
|
$opacity: v ? 1 : 0.2,
|
|
231
231
|
$imageHue: se,
|
|
232
232
|
children: [
|
|
@@ -239,29 +239,29 @@ const Tt = Ae(function({
|
|
|
239
239
|
responseId: i
|
|
240
240
|
}
|
|
241
241
|
),
|
|
242
|
-
/* @__PURE__ */
|
|
242
|
+
/* @__PURE__ */ W(
|
|
243
243
|
st,
|
|
244
244
|
{
|
|
245
245
|
className: ke,
|
|
246
246
|
$dropzoneMinWidth: ge.width,
|
|
247
247
|
$dropzoneMinHeight: ge.height,
|
|
248
248
|
children: [
|
|
249
|
-
Te && !(
|
|
249
|
+
Te && !(M || l || f) && /* @__PURE__ */ o(
|
|
250
250
|
Ge,
|
|
251
251
|
{
|
|
252
252
|
question: r,
|
|
253
253
|
response: t,
|
|
254
254
|
behavior: _,
|
|
255
|
-
paperColor:
|
|
255
|
+
paperColor: C,
|
|
256
256
|
actionbarHeight: $e,
|
|
257
257
|
canResolveDoubt: we,
|
|
258
258
|
onResolveDoubt: Ce,
|
|
259
259
|
worksheetCompleted: E
|
|
260
260
|
}
|
|
261
261
|
),
|
|
262
|
-
|
|
263
|
-
l &&
|
|
264
|
-
f ? /* @__PURE__ */
|
|
262
|
+
M && /* @__PURE__ */ o(at, { src: Oe.LESSON_OVERVIEW_BANNER }),
|
|
263
|
+
l && C && /* @__PURE__ */ o(Ze, { paperColor: C }),
|
|
264
|
+
f ? /* @__PURE__ */ W(Le, { children: [
|
|
265
265
|
m === "practice-basic" && /* @__PURE__ */ o(et, {}),
|
|
266
266
|
m === "practice-regular" && /* @__PURE__ */ o(ot, {}),
|
|
267
267
|
m === "exit-ticket" && /* @__PURE__ */ o(tt, {}),
|
|
@@ -282,7 +282,7 @@ const Tt = Ae(function({
|
|
|
282
282
|
isPuzzle: Q === -2
|
|
283
283
|
}
|
|
284
284
|
),
|
|
285
|
-
!L && !!_.canvasEnabled && V && X &&
|
|
285
|
+
!L && !!_.canvasEnabled && V && X && H !== void 0 && /* @__PURE__ */ o(ct, { $canScribble: J, children: /* @__PURE__ */ o(
|
|
286
286
|
ze,
|
|
287
287
|
{
|
|
288
288
|
canRender: j,
|
|
@@ -290,13 +290,14 @@ const Tt = Ae(function({
|
|
|
290
290
|
appended: s,
|
|
291
291
|
canvasId: i,
|
|
292
292
|
width: K,
|
|
293
|
-
height: Math.max(
|
|
293
|
+
height: Math.max(H, ee ?? 0),
|
|
294
294
|
onUpdateHeight: Pe,
|
|
295
295
|
onPublish: V,
|
|
296
296
|
onSubscribe: X,
|
|
297
297
|
userId: He,
|
|
298
|
-
initialData:
|
|
299
|
-
userType: c
|
|
298
|
+
initialData: T == null ? void 0 : T[i],
|
|
299
|
+
userType: c,
|
|
300
|
+
loggerRef: w
|
|
300
301
|
}
|
|
301
302
|
) }),
|
|
302
303
|
!L && N && N.length > 0 && /* @__PURE__ */ o(
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worksheet-question.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-question/worksheet-question.tsx"],"sourcesContent":["import {\n memo,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n type FC,\n} from 'react';\n\nimport { IMAGES } from '../../../../assets/images/images';\nimport CueCanvas from '../../../cue-canvas/cue-canvas';\nimport Pointer from '../../../pointer-sync/pointer';\nimport FlexView from '../../../ui/layout/flex-view';\nimport EVENTS from '../../constants/events';\nimport { LEARNOSITY_KEYBOARD_HEIGHT, QUESTIONS_GAP } from '../constants';\nimport {\n getPaperColorByQuestion,\n isConceptIntroWidget,\n scrollToQuestion,\n} from '../worksheet-helpers';\nimport QuestionHeader from './header/header';\nimport LearnosityQuestion from './learnosity-question';\nimport QuestionBackdrop from './question-backdrop/question-backdrop';\nimport SubjectiveQuestionReview from './subjective-review';\nimport AdvancedPracticeIntro from './system-intros/advanced-practice-intro';\nimport BasicPracticeIntro from './system-intros/basic-practice-intro';\nimport ExitTicketIntro from './system-intros/exit-ticket-intro';\nimport RegularPracticeIntro from './system-intros/regular-practice-intro';\nimport * as Styled from './worksheet-question-styled';\nimport type { IWorksheetQuestionProps } from './worksheet-question-types';\nimport { useWorksheetStore } from '../hooks/use-worksheet-store';\n\nconst WorksheetQuestion: FC<IWorksheetQuestionProps> = memo(function WorksheetQuestion({\n question,\n response,\n nextQuestionId,\n isActive,\n isHidden,\n canRender,\n appended,\n intersectionObserver,\n}) {\n const {\n behavior,\n layout,\n userType,\n responses,\n maxQuestionWidth,\n actionbarHeight,\n worksheetCompleted,\n learnosity,\n onPublishStrokes,\n onReceiveStrokes,\n initialStrokesData,\n onPublishMouseMove,\n onSubscribeMouseMove,\n canResolveDoubt,\n onResolveDoubt,\n userId,\n studentId,\n subjectiveProps,\n loggerRef,\n isScribblingEnabled,\n } = useWorksheetStore(store => ({\n behavior: store.behavior,\n layout: store.layout,\n userType: store.userType,\n responses: store.responses,\n maxQuestionWidth: store.maxQuestionWidth,\n actionbarHeight: store.actionbarHeight,\n worksheetCompleted: store.worksheetCompleted,\n learnosity: store.learnosity,\n onPublishStrokes: store.onPublishStrokes,\n onReceiveStrokes: store.onReceiveStrokes,\n initialStrokesData: store.initialStrokesData,\n onPublishMouseMove: store.onPublishMouseMove,\n onSubscribeMouseMove: store.onSubscribeMouseMove,\n canResolveDoubt: store.canResolveDoubt,\n onResolveDoubt: store.onResolveDoubt,\n userId: store.userId,\n studentId: store.studentId,\n subjectiveProps: store.subjectiveProps,\n loggerRef: store.loggerRef,\n isScribblingEnabled: store.scribblingEnabled,\n }));\n const { background = 'paper' } = layout;\n const paperColor = useMemo(\n () => (background === 'paper' ? getPaperColorByQuestion(question) : undefined),\n [background, question],\n );\n const [questionHeight, setQuestionHeight] = useState<number | undefined>();\n const [canvasHeight, setCanvasHeight] = useState<number | undefined>();\n const {\n validation,\n review,\n maximumAttempts,\n canExceedAttempts,\n teacherValidationEnabled,\n solutionHidden,\n } = behavior;\n const { minQuestionHeight, topOffset, questionsScrollable, renderQuestionHeader, imageHue } =\n layout;\n const {\n type: questionType,\n response_id: responseId,\n stimulus_review,\n item_type,\n instructor_stimulus,\n metadata: { hints: hintsAvailable, solution, widget_reference },\n item_reference,\n question_number,\n item_number,\n item_display_number,\n } = question;\n const isLessonOverview = item_type === 'overview';\n const isConceptIntro = isConceptIntroWidget(instructor_stimulus);\n const isSystemIntro = instructor_stimulus === 'SystemIntro';\n const isIntro = isConceptIntro || isSystemIntro;\n const responseEdited = response?.responseEdited;\n const wrapperClasses = useMemo(() => {\n const classes = [];\n\n if (responseEdited && userType === 'TEACHER') {\n classes.push('attempting');\n }\n\n if (!appended) {\n classes.push('hidden');\n }\n\n if (questionType === 'hotspot') {\n classes.push('correct-answers-hidden');\n }\n\n if (appended && teacherValidationEnabled && questionType === 'clozetext') {\n if (!isConceptIntro || userType === 'STUDENT') {\n classes.push('response-hidden');\n } else {\n classes.push('response-code-hidden');\n }\n }\n\n if (isLessonOverview) {\n classes.push('lesson-overview');\n }\n\n if (isConceptIntro) {\n classes.push('concept-intro');\n }\n\n if (isSystemIntro) {\n classes.push('system-intro');\n }\n\n return classes.join(' ');\n }, [\n appended,\n isConceptIntro,\n isLessonOverview,\n isSystemIntro,\n questionType,\n responseEdited,\n teacherValidationEnabled,\n userType,\n ]);\n const overflowDetectedRef = useRef<Record<string, boolean>>({});\n const hintsUsed = response?.hintsUsed ?? 0;\n const questionRef = useRef<HTMLDivElement>(null);\n const pointerContainerRef = useRef<HTMLDivElement>(null);\n const hints = useMemo(() => hintsAvailable?.slice(0, hintsUsed), [hintsAvailable, hintsUsed]);\n const validateResponse = useMemo(() => {\n if (userType === 'TEACHER') return true;\n\n if (worksheetCompleted) return true;\n\n if (!response) return false;\n\n if (!response.response) return false;\n\n if (response.responseEdited) return false;\n\n return validation;\n }, [response, userType, validation, worksheetCompleted]);\n\n const showCorrectAnswers = useMemo(() => {\n if (userType === 'TEACHER') return true;\n\n if (review) {\n const { attemptsHistory } = response ?? {};\n const maximumAttemptsReached = (attemptsHistory?.length ?? 0) >= maximumAttempts;\n\n return maximumAttemptsReached && !canExceedAttempts;\n }\n\n return false;\n }, [canExceedAttempts, maximumAttempts, response, review, userType]);\n\n const showSolution = useMemo(\n () => solution && worksheetCompleted && !solutionHidden,\n [solutionHidden, solution, worksheetCompleted],\n );\n\n const [dropZoneDimensions, setDropZoneDimensions] = useState({\n width: 0,\n height: 0,\n });\n\n const onUpdateHeight = useCallback((height: number) => {\n setCanvasHeight(height);\n }, []);\n\n useEffect(() => {\n if (questionRef.current) {\n intersectionObserver.observe(questionRef.current);\n }\n }, [intersectionObserver]);\n\n useEffect(() => {\n if (\n appended &&\n (question.type === 'clozeassociation' ||\n question.type === 'association' ||\n question.type === 'clozeformula')\n ) {\n const draggableElements = document.querySelectorAll(\n `.widget-${question.response_id} .lrn_draggable`,\n );\n\n let minWidth = 0;\n let minHeight = 0;\n\n draggableElements.forEach(draggableElement => {\n minWidth = Math.max(minWidth, draggableElement.clientWidth + 33);\n minHeight = Math.max(minHeight, draggableElement.clientHeight + 1);\n });\n\n setDropZoneDimensions({\n width: question.type !== 'association' ? minWidth : 0,\n height: minHeight,\n });\n }\n }, [appended, question.response_id, question.type]);\n\n useEffect(() => {\n if (appended && validateResponse) {\n const learnosityQuestion = learnosity.question(responseId);\n\n if (learnosityQuestion) {\n learnosityQuestion.validate({\n showCorrectAnswers,\n });\n }\n }\n }, [appended, learnosity, responseId, review, showCorrectAnswers, userType, validateResponse]);\n\n useEffect(() => {\n const $questionEl = pointerContainerRef.current;\n\n if (\n appended &&\n $questionEl &&\n loggerRef.current &&\n overflowDetectedRef.current[responseId] === undefined &&\n !isConceptIntro &&\n !isSystemIntro\n ) {\n const parentWidth = $questionEl.clientWidth;\n const nestedElements = $questionEl.querySelectorAll('*');\n\n for (let i = 0; i < nestedElements.length; i++) {\n const element = nestedElements[i];\n\n if (element?.closest('.resize-sensor')) {\n continue;\n }\n\n const elementWidth = element?.clientWidth ?? 0;\n\n if (elementWidth > parentWidth) {\n overflowDetectedRef.current[responseId] = true;\n loggerRef.current(EVENTS.WORKSHEET_V3_GREATER_WIDTH_ELEMENT, {\n item_reference,\n widget_reference,\n question_type: questionType,\n question_number,\n responseId,\n item_number,\n item_display_number,\n });\n break;\n }\n }\n\n overflowDetectedRef.current[responseId] = false;\n }\n }, [\n appended,\n isConceptIntro,\n isSystemIntro,\n item_display_number,\n item_number,\n item_reference,\n loggerRef,\n questionType,\n question_number,\n responseId,\n widget_reference,\n ]);\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useEffect(() => {\n const $questionEl = questionRef.current;\n\n const getExtraSpaceNeedForFloatingKeyboard = (questionEl: HTMLDivElement) => {\n const $responseWrapper = questionEl.querySelector('.lrn_response_wrapper');\n\n if (isIntro || !$responseWrapper) {\n return 0;\n }\n\n const questionBottom = questionEl.getBoundingClientRect().bottom;\n const responseWrapperBottom = $responseWrapper.getBoundingClientRect().bottom;\n const spaceFromResponseToBottom = Math.abs(questionBottom - responseWrapperBottom);\n\n if (spaceFromResponseToBottom < LEARNOSITY_KEYBOARD_HEIGHT) {\n return LEARNOSITY_KEYBOARD_HEIGHT - spaceFromResponseToBottom;\n }\n\n return 0;\n };\n\n if (appended && $questionEl) {\n setQuestionHeight(qHeight => {\n const hasFloatingKeyboard = question.ui_style?.type === 'floating-keyboard';\n const v3CodeHidden = teacherValidationEnabled && questionType === 'clozetext';\n const hasKeyboard = hasFloatingKeyboard && !v3CodeHidden;\n const height = $questionEl.clientHeight;\n\n if (height === 0) {\n return qHeight;\n }\n\n // If the question has a floating keyboard, we need to add the height of the keyboard to the question height\n if (!qHeight) {\n return Math.ceil(\n height + (hasKeyboard ? getExtraSpaceNeedForFloatingKeyboard($questionEl) : 0),\n );\n }\n\n const newQuestionHeight = Math.ceil(\n height + (hasKeyboard ? getExtraSpaceNeedForFloatingKeyboard($questionEl) : 0),\n );\n\n if (Math.abs(newQuestionHeight - qHeight) > 4) {\n return newQuestionHeight;\n }\n\n return qHeight;\n });\n }\n\n learnosity.renderMath('mathjax');\n });\n\n useLayoutEffect(() => {\n if (!questionsScrollable && !isHidden) {\n scrollToQuestion(responseId);\n }\n }, [isHidden, questionsScrollable, responseId, topOffset]);\n\n return (\n <Styled.QuestionContainerWrapper\n data-response-id={responseId}\n className={`widget-${responseId}`}\n ref={questionRef}\n $topOffset={topOffset}\n $flexDirection={stimulus_review ? 'row' : 'column'}\n $alignItems={stimulus_review ? 'flex-start' : 'center'}\n $hidden={isHidden}\n $marginBottom={QUESTIONS_GAP}\n >\n {stimulus_review && (\n <Styled.StimulusReview\n dangerouslySetInnerHTML={{\n __html: stimulus_review,\n }}\n />\n )}\n <Styled.QuestionContainer\n ref={pointerContainerRef}\n $width={stimulus_review ? '50%' : `${maxQuestionWidth}px`}\n $minHeight={\n questionHeight ? Math.max(questionHeight - 72, canvasHeight ?? 0) : minQuestionHeight\n }\n $isActive={isActive}\n $paperColor={paperColor}\n $opacity={isActive ? 1 : 0.2}\n $imageHue={imageHue}\n >\n {isActive && !!onPublishMouseMove && !!onSubscribeMouseMove && !!behavior.canvasEnabled && (\n <Pointer\n containerRef={pointerContainerRef}\n onPublish={onPublishMouseMove}\n onSubscribe={onSubscribeMouseMove}\n responseId={responseId}\n />\n )}\n <Styled.QuestionWrapper\n className={wrapperClasses}\n $dropzoneMinWidth={dropZoneDimensions.width}\n $dropzoneMinHeight={dropZoneDimensions.height}\n >\n {renderQuestionHeader && !(isLessonOverview || isConceptIntro || isSystemIntro) && (\n <QuestionHeader\n question={question}\n response={response}\n behavior={behavior}\n paperColor={paperColor}\n actionbarHeight={actionbarHeight}\n canResolveDoubt={canResolveDoubt}\n onResolveDoubt={onResolveDoubt}\n worksheetCompleted={worksheetCompleted}\n />\n )}\n {isLessonOverview && <Styled.LessonOverviewBanner src={IMAGES.LESSON_OVERVIEW_BANNER} />}\n {isConceptIntro && paperColor && <QuestionBackdrop paperColor={paperColor} />}\n {isSystemIntro ? (\n <>\n {item_type === 'practice-basic' && <BasicPracticeIntro />}\n {item_type === 'practice-regular' && <RegularPracticeIntro />}\n {item_type === 'exit-ticket' && <ExitTicketIntro />}\n {item_type?.startsWith('advanced-') && <AdvancedPracticeIntro />}\n </>\n ) : undefined}\n <LearnosityQuestion\n appended={appended}\n question={question}\n response={response?.response}\n canRender={canRender || isActive}\n learnosity={learnosity}\n canForceAppend={userType === 'TEACHER'}\n isConceptIntro={isConceptIntro}\n simState={response?.simState}\n imageHue={imageHue}\n isPuzzle={maximumAttempts === -2}\n />\n\n {!isIntro &&\n !!behavior.canvasEnabled &&\n onPublishStrokes &&\n onReceiveStrokes &&\n questionHeight !== undefined && (\n <Styled.CueCanvasWrapper $canScribble={isScribblingEnabled}>\n <CueCanvas\n canRender={canRender}\n canScribble={isScribblingEnabled && isActive}\n appended={appended}\n canvasId={responseId}\n width={maxQuestionWidth}\n height={Math.max(questionHeight, canvasHeight ?? 0)}\n onUpdateHeight={onUpdateHeight}\n onPublish={onPublishStrokes}\n onSubscribe={onReceiveStrokes}\n userId={userId}\n initialData={initialStrokesData?.[responseId]}\n userType={userType}\n />\n </Styled.CueCanvasWrapper>\n )}\n {!isIntro && hints && hints.length > 0 && (\n <FlexView\n $background=\"BLUE_1\"\n $gutterX={1}\n $gapX={0.5}\n $borderRadiusX={0}\n $borderColor=\"BLUE_2\"\n >\n {hints.map((hint, index) => (\n <Styled.Hint\n key={hint}\n dangerouslySetInnerHTML={{\n __html: `<span style=\"color: #DA5107; font-weight: 600;\">Hint${\n (hintsAvailable?.length ?? 0) > 1 ? ` ${index + 1}` : ''\n }:</span> ${hint}`,\n }}\n />\n ))}\n </FlexView>\n )}\n {showSolution && (\n <FlexView\n $background=\"YELLOW_1\"\n $gutterX={1}\n $gapX={0.875}\n $borderRadiusX={0}\n $borderColor=\"YELLOW_2\"\n >\n <Styled.Solution\n dangerouslySetInnerHTML={{\n __html: `<div style=\"color: #DA5107; font-weight: 600;\">Solution:</div>${solution}`,\n }}\n />\n </FlexView>\n )}\n {!!subjectiveProps && (\n <SubjectiveQuestionReview\n responses={responses}\n response={response}\n nextQuestionId={nextQuestionId}\n responseId={responseId}\n studentId={studentId}\n {...subjectiveProps}\n />\n )}\n </Styled.QuestionWrapper>\n </Styled.QuestionContainer>\n </Styled.QuestionContainerWrapper>\n );\n});\n\nexport default WorksheetQuestion;\n"],"names":["WorksheetQuestion","memo","question","response","nextQuestionId","isActive","isHidden","canRender","appended","intersectionObserver","behavior","layout","userType","responses","maxQuestionWidth","actionbarHeight","worksheetCompleted","learnosity","onPublishStrokes","onReceiveStrokes","initialStrokesData","onPublishMouseMove","onSubscribeMouseMove","canResolveDoubt","onResolveDoubt","userId","studentId","subjectiveProps","loggerRef","isScribblingEnabled","useWorksheetStore","store","background","paperColor","useMemo","getPaperColorByQuestion","questionHeight","setQuestionHeight","useState","canvasHeight","setCanvasHeight","validation","review","maximumAttempts","canExceedAttempts","teacherValidationEnabled","solutionHidden","minQuestionHeight","topOffset","questionsScrollable","renderQuestionHeader","imageHue","questionType","responseId","stimulus_review","item_type","instructor_stimulus","hintsAvailable","solution","widget_reference","item_reference","question_number","item_number","item_display_number","isLessonOverview","isConceptIntro","isConceptIntroWidget","isSystemIntro","isIntro","responseEdited","wrapperClasses","classes","overflowDetectedRef","useRef","hintsUsed","questionRef","pointerContainerRef","hints","validateResponse","showCorrectAnswers","attemptsHistory","showSolution","dropZoneDimensions","setDropZoneDimensions","onUpdateHeight","useCallback","height","useEffect","draggableElements","minWidth","minHeight","draggableElement","learnosityQuestion","$questionEl","parentWidth","nestedElements","i","element","EVENTS","getExtraSpaceNeedForFloatingKeyboard","questionEl","$responseWrapper","questionBottom","responseWrapperBottom","spaceFromResponseToBottom","LEARNOSITY_KEYBOARD_HEIGHT","qHeight","hasKeyboard","_a","newQuestionHeight","useLayoutEffect","scrollToQuestion","jsxs","Styled.QuestionContainerWrapper","QUESTIONS_GAP","jsx","Styled.StimulusReview","Styled.QuestionContainer","Pointer","Styled.QuestionWrapper","QuestionHeader","Styled.LessonOverviewBanner","IMAGES","QuestionBackdrop","Fragment","BasicPracticeIntro","RegularPracticeIntro","ExitTicketIntro","AdvancedPracticeIntro","LearnosityQuestion","Styled.CueCanvasWrapper","CueCanvas","FlexView","hint","index","Styled.Hint","Styled.Solution","SubjectiveQuestionReview"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"worksheet-question.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-question/worksheet-question.tsx"],"sourcesContent":["import {\n memo,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n type FC,\n} from 'react';\n\nimport { IMAGES } from '../../../../assets/images/images';\nimport CueCanvas from '../../../cue-canvas/cue-canvas';\nimport Pointer from '../../../pointer-sync/pointer';\nimport FlexView from '../../../ui/layout/flex-view';\nimport EVENTS from '../../constants/events';\nimport { LEARNOSITY_KEYBOARD_HEIGHT, QUESTIONS_GAP } from '../constants';\nimport {\n getPaperColorByQuestion,\n isConceptIntroWidget,\n scrollToQuestion,\n} from '../worksheet-helpers';\nimport QuestionHeader from './header/header';\nimport LearnosityQuestion from './learnosity-question';\nimport QuestionBackdrop from './question-backdrop/question-backdrop';\nimport SubjectiveQuestionReview from './subjective-review';\nimport AdvancedPracticeIntro from './system-intros/advanced-practice-intro';\nimport BasicPracticeIntro from './system-intros/basic-practice-intro';\nimport ExitTicketIntro from './system-intros/exit-ticket-intro';\nimport RegularPracticeIntro from './system-intros/regular-practice-intro';\nimport * as Styled from './worksheet-question-styled';\nimport type { IWorksheetQuestionProps } from './worksheet-question-types';\nimport { useWorksheetStore } from '../hooks/use-worksheet-store';\n\nconst WorksheetQuestion: FC<IWorksheetQuestionProps> = memo(function WorksheetQuestion({\n question,\n response,\n nextQuestionId,\n isActive,\n isHidden,\n canRender,\n appended,\n intersectionObserver,\n}) {\n const {\n behavior,\n layout,\n userType,\n responses,\n maxQuestionWidth,\n actionbarHeight,\n worksheetCompleted,\n learnosity,\n onPublishStrokes,\n onReceiveStrokes,\n initialStrokesData,\n onPublishMouseMove,\n onSubscribeMouseMove,\n canResolveDoubt,\n onResolveDoubt,\n userId,\n studentId,\n subjectiveProps,\n loggerRef,\n isScribblingEnabled,\n } = useWorksheetStore(store => ({\n behavior: store.behavior,\n layout: store.layout,\n userType: store.userType,\n responses: store.responses,\n maxQuestionWidth: store.maxQuestionWidth,\n actionbarHeight: store.actionbarHeight,\n worksheetCompleted: store.worksheetCompleted,\n learnosity: store.learnosity,\n onPublishStrokes: store.onPublishStrokes,\n onReceiveStrokes: store.onReceiveStrokes,\n initialStrokesData: store.initialStrokesData,\n onPublishMouseMove: store.onPublishMouseMove,\n onSubscribeMouseMove: store.onSubscribeMouseMove,\n canResolveDoubt: store.canResolveDoubt,\n onResolveDoubt: store.onResolveDoubt,\n userId: store.userId,\n studentId: store.studentId,\n subjectiveProps: store.subjectiveProps,\n loggerRef: store.loggerRef,\n isScribblingEnabled: store.scribblingEnabled,\n }));\n const { background = 'paper' } = layout;\n const paperColor = useMemo(\n () => (background === 'paper' ? getPaperColorByQuestion(question) : undefined),\n [background, question],\n );\n const [questionHeight, setQuestionHeight] = useState<number | undefined>();\n const [canvasHeight, setCanvasHeight] = useState<number | undefined>();\n const {\n validation,\n review,\n maximumAttempts,\n canExceedAttempts,\n teacherValidationEnabled,\n solutionHidden,\n } = behavior;\n const { minQuestionHeight, topOffset, questionsScrollable, renderQuestionHeader, imageHue } =\n layout;\n const {\n type: questionType,\n response_id: responseId,\n stimulus_review,\n item_type,\n instructor_stimulus,\n metadata: { hints: hintsAvailable, solution, widget_reference },\n item_reference,\n question_number,\n item_number,\n item_display_number,\n } = question;\n const isLessonOverview = item_type === 'overview';\n const isConceptIntro = isConceptIntroWidget(instructor_stimulus);\n const isSystemIntro = instructor_stimulus === 'SystemIntro';\n const isIntro = isConceptIntro || isSystemIntro;\n const responseEdited = response?.responseEdited;\n const wrapperClasses = useMemo(() => {\n const classes = [];\n\n if (responseEdited && userType === 'TEACHER') {\n classes.push('attempting');\n }\n\n if (!appended) {\n classes.push('hidden');\n }\n\n if (questionType === 'hotspot') {\n classes.push('correct-answers-hidden');\n }\n\n if (appended && teacherValidationEnabled && questionType === 'clozetext') {\n if (!isConceptIntro || userType === 'STUDENT') {\n classes.push('response-hidden');\n } else {\n classes.push('response-code-hidden');\n }\n }\n\n if (isLessonOverview) {\n classes.push('lesson-overview');\n }\n\n if (isConceptIntro) {\n classes.push('concept-intro');\n }\n\n if (isSystemIntro) {\n classes.push('system-intro');\n }\n\n return classes.join(' ');\n }, [\n appended,\n isConceptIntro,\n isLessonOverview,\n isSystemIntro,\n questionType,\n responseEdited,\n teacherValidationEnabled,\n userType,\n ]);\n const overflowDetectedRef = useRef<Record<string, boolean>>({});\n const hintsUsed = response?.hintsUsed ?? 0;\n const questionRef = useRef<HTMLDivElement>(null);\n const pointerContainerRef = useRef<HTMLDivElement>(null);\n const hints = useMemo(() => hintsAvailable?.slice(0, hintsUsed), [hintsAvailable, hintsUsed]);\n const validateResponse = useMemo(() => {\n if (userType === 'TEACHER') return true;\n\n if (worksheetCompleted) return true;\n\n if (!response) return false;\n\n if (!response.response) return false;\n\n if (response.responseEdited) return false;\n\n return validation;\n }, [response, userType, validation, worksheetCompleted]);\n\n const showCorrectAnswers = useMemo(() => {\n if (userType === 'TEACHER') return true;\n\n if (review) {\n const { attemptsHistory } = response ?? {};\n const maximumAttemptsReached = (attemptsHistory?.length ?? 0) >= maximumAttempts;\n\n return maximumAttemptsReached && !canExceedAttempts;\n }\n\n return false;\n }, [canExceedAttempts, maximumAttempts, response, review, userType]);\n\n const showSolution = useMemo(\n () => solution && worksheetCompleted && !solutionHidden,\n [solutionHidden, solution, worksheetCompleted],\n );\n\n const [dropZoneDimensions, setDropZoneDimensions] = useState({\n width: 0,\n height: 0,\n });\n\n const onUpdateHeight = useCallback((height: number) => {\n setCanvasHeight(height);\n }, []);\n\n useEffect(() => {\n if (questionRef.current) {\n intersectionObserver.observe(questionRef.current);\n }\n }, [intersectionObserver]);\n\n useEffect(() => {\n if (\n appended &&\n (question.type === 'clozeassociation' ||\n question.type === 'association' ||\n question.type === 'clozeformula')\n ) {\n const draggableElements = document.querySelectorAll(\n `.widget-${question.response_id} .lrn_draggable`,\n );\n\n let minWidth = 0;\n let minHeight = 0;\n\n draggableElements.forEach(draggableElement => {\n minWidth = Math.max(minWidth, draggableElement.clientWidth + 33);\n minHeight = Math.max(minHeight, draggableElement.clientHeight + 1);\n });\n\n setDropZoneDimensions({\n width: question.type !== 'association' ? minWidth : 0,\n height: minHeight,\n });\n }\n }, [appended, question.response_id, question.type]);\n\n useEffect(() => {\n if (appended && validateResponse) {\n const learnosityQuestion = learnosity.question(responseId);\n\n if (learnosityQuestion) {\n learnosityQuestion.validate({\n showCorrectAnswers,\n });\n }\n }\n }, [appended, learnosity, responseId, review, showCorrectAnswers, userType, validateResponse]);\n\n useEffect(() => {\n const $questionEl = pointerContainerRef.current;\n\n if (\n appended &&\n $questionEl &&\n loggerRef.current &&\n overflowDetectedRef.current[responseId] === undefined &&\n !isConceptIntro &&\n !isSystemIntro\n ) {\n const parentWidth = $questionEl.clientWidth;\n const nestedElements = $questionEl.querySelectorAll('*');\n\n for (let i = 0; i < nestedElements.length; i++) {\n const element = nestedElements[i];\n\n if (element?.closest('.resize-sensor')) {\n continue;\n }\n\n const elementWidth = element?.clientWidth ?? 0;\n\n if (elementWidth > parentWidth) {\n overflowDetectedRef.current[responseId] = true;\n loggerRef.current(EVENTS.WORKSHEET_V3_GREATER_WIDTH_ELEMENT, {\n item_reference,\n widget_reference,\n question_type: questionType,\n question_number,\n responseId,\n item_number,\n item_display_number,\n });\n break;\n }\n }\n\n overflowDetectedRef.current[responseId] = false;\n }\n }, [\n appended,\n isConceptIntro,\n isSystemIntro,\n item_display_number,\n item_number,\n item_reference,\n loggerRef,\n questionType,\n question_number,\n responseId,\n widget_reference,\n ]);\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n useEffect(() => {\n const $questionEl = questionRef.current;\n\n const getExtraSpaceNeedForFloatingKeyboard = (questionEl: HTMLDivElement) => {\n const $responseWrapper = questionEl.querySelector('.lrn_response_wrapper');\n\n if (isIntro || !$responseWrapper) {\n return 0;\n }\n\n const questionBottom = questionEl.getBoundingClientRect().bottom;\n const responseWrapperBottom = $responseWrapper.getBoundingClientRect().bottom;\n const spaceFromResponseToBottom = Math.abs(questionBottom - responseWrapperBottom);\n\n if (spaceFromResponseToBottom < LEARNOSITY_KEYBOARD_HEIGHT) {\n return LEARNOSITY_KEYBOARD_HEIGHT - spaceFromResponseToBottom;\n }\n\n return 0;\n };\n\n if (appended && $questionEl) {\n setQuestionHeight(qHeight => {\n const hasFloatingKeyboard = question.ui_style?.type === 'floating-keyboard';\n const v3CodeHidden = teacherValidationEnabled && questionType === 'clozetext';\n const hasKeyboard = hasFloatingKeyboard && !v3CodeHidden;\n const height = $questionEl.clientHeight;\n\n if (height === 0) {\n return qHeight;\n }\n\n // If the question has a floating keyboard, we need to add the height of the keyboard to the question height\n if (!qHeight) {\n return Math.ceil(\n height + (hasKeyboard ? getExtraSpaceNeedForFloatingKeyboard($questionEl) : 0),\n );\n }\n\n const newQuestionHeight = Math.ceil(\n height + (hasKeyboard ? getExtraSpaceNeedForFloatingKeyboard($questionEl) : 0),\n );\n\n if (Math.abs(newQuestionHeight - qHeight) > 4) {\n return newQuestionHeight;\n }\n\n return qHeight;\n });\n }\n\n learnosity.renderMath('mathjax');\n });\n\n useLayoutEffect(() => {\n if (!questionsScrollable && !isHidden) {\n scrollToQuestion(responseId);\n }\n }, [isHidden, questionsScrollable, responseId, topOffset]);\n\n return (\n <Styled.QuestionContainerWrapper\n data-response-id={responseId}\n className={`widget-${responseId}`}\n ref={questionRef}\n $topOffset={topOffset}\n $flexDirection={stimulus_review ? 'row' : 'column'}\n $alignItems={stimulus_review ? 'flex-start' : 'center'}\n $hidden={isHidden}\n $marginBottom={QUESTIONS_GAP}\n >\n {stimulus_review && (\n <Styled.StimulusReview\n dangerouslySetInnerHTML={{\n __html: stimulus_review,\n }}\n />\n )}\n <Styled.QuestionContainer\n ref={pointerContainerRef}\n $width={stimulus_review ? '50%' : `${maxQuestionWidth}px`}\n $minHeight={\n questionHeight ? Math.max(questionHeight - 72, canvasHeight ?? 0) : minQuestionHeight\n }\n $isActive={isActive}\n $paperColor={paperColor}\n $opacity={isActive ? 1 : 0.2}\n $imageHue={imageHue}\n >\n {isActive && !!onPublishMouseMove && !!onSubscribeMouseMove && !!behavior.canvasEnabled && (\n <Pointer\n containerRef={pointerContainerRef}\n onPublish={onPublishMouseMove}\n onSubscribe={onSubscribeMouseMove}\n responseId={responseId}\n />\n )}\n <Styled.QuestionWrapper\n className={wrapperClasses}\n $dropzoneMinWidth={dropZoneDimensions.width}\n $dropzoneMinHeight={dropZoneDimensions.height}\n >\n {renderQuestionHeader && !(isLessonOverview || isConceptIntro || isSystemIntro) && (\n <QuestionHeader\n question={question}\n response={response}\n behavior={behavior}\n paperColor={paperColor}\n actionbarHeight={actionbarHeight}\n canResolveDoubt={canResolveDoubt}\n onResolveDoubt={onResolveDoubt}\n worksheetCompleted={worksheetCompleted}\n />\n )}\n {isLessonOverview && <Styled.LessonOverviewBanner src={IMAGES.LESSON_OVERVIEW_BANNER} />}\n {isConceptIntro && paperColor && <QuestionBackdrop paperColor={paperColor} />}\n {isSystemIntro ? (\n <>\n {item_type === 'practice-basic' && <BasicPracticeIntro />}\n {item_type === 'practice-regular' && <RegularPracticeIntro />}\n {item_type === 'exit-ticket' && <ExitTicketIntro />}\n {item_type?.startsWith('advanced-') && <AdvancedPracticeIntro />}\n </>\n ) : undefined}\n <LearnosityQuestion\n appended={appended}\n question={question}\n response={response?.response}\n canRender={canRender || isActive}\n learnosity={learnosity}\n canForceAppend={userType === 'TEACHER'}\n isConceptIntro={isConceptIntro}\n simState={response?.simState}\n imageHue={imageHue}\n isPuzzle={maximumAttempts === -2}\n />\n\n {!isIntro &&\n !!behavior.canvasEnabled &&\n onPublishStrokes &&\n onReceiveStrokes &&\n questionHeight !== undefined && (\n <Styled.CueCanvasWrapper $canScribble={isScribblingEnabled}>\n <CueCanvas\n canRender={canRender}\n canScribble={isScribblingEnabled && isActive}\n appended={appended}\n canvasId={responseId}\n width={maxQuestionWidth}\n height={Math.max(questionHeight, canvasHeight ?? 0)}\n onUpdateHeight={onUpdateHeight}\n onPublish={onPublishStrokes}\n onSubscribe={onReceiveStrokes}\n userId={userId}\n initialData={initialStrokesData?.[responseId]}\n userType={userType}\n loggerRef={loggerRef}\n />\n </Styled.CueCanvasWrapper>\n )}\n {!isIntro && hints && hints.length > 0 && (\n <FlexView\n $background=\"BLUE_1\"\n $gutterX={1}\n $gapX={0.5}\n $borderRadiusX={0}\n $borderColor=\"BLUE_2\"\n >\n {hints.map((hint, index) => (\n <Styled.Hint\n key={hint}\n dangerouslySetInnerHTML={{\n __html: `<span style=\"color: #DA5107; font-weight: 600;\">Hint${\n (hintsAvailable?.length ?? 0) > 1 ? ` ${index + 1}` : ''\n }:</span> ${hint}`,\n }}\n />\n ))}\n </FlexView>\n )}\n {showSolution && (\n <FlexView\n $background=\"YELLOW_1\"\n $gutterX={1}\n $gapX={0.875}\n $borderRadiusX={0}\n $borderColor=\"YELLOW_2\"\n >\n <Styled.Solution\n dangerouslySetInnerHTML={{\n __html: `<div style=\"color: #DA5107; font-weight: 600;\">Solution:</div>${solution}`,\n }}\n />\n </FlexView>\n )}\n {!!subjectiveProps && (\n <SubjectiveQuestionReview\n responses={responses}\n response={response}\n nextQuestionId={nextQuestionId}\n responseId={responseId}\n studentId={studentId}\n {...subjectiveProps}\n />\n )}\n </Styled.QuestionWrapper>\n </Styled.QuestionContainer>\n </Styled.QuestionContainerWrapper>\n );\n});\n\nexport default WorksheetQuestion;\n"],"names":["WorksheetQuestion","memo","question","response","nextQuestionId","isActive","isHidden","canRender","appended","intersectionObserver","behavior","layout","userType","responses","maxQuestionWidth","actionbarHeight","worksheetCompleted","learnosity","onPublishStrokes","onReceiveStrokes","initialStrokesData","onPublishMouseMove","onSubscribeMouseMove","canResolveDoubt","onResolveDoubt","userId","studentId","subjectiveProps","loggerRef","isScribblingEnabled","useWorksheetStore","store","background","paperColor","useMemo","getPaperColorByQuestion","questionHeight","setQuestionHeight","useState","canvasHeight","setCanvasHeight","validation","review","maximumAttempts","canExceedAttempts","teacherValidationEnabled","solutionHidden","minQuestionHeight","topOffset","questionsScrollable","renderQuestionHeader","imageHue","questionType","responseId","stimulus_review","item_type","instructor_stimulus","hintsAvailable","solution","widget_reference","item_reference","question_number","item_number","item_display_number","isLessonOverview","isConceptIntro","isConceptIntroWidget","isSystemIntro","isIntro","responseEdited","wrapperClasses","classes","overflowDetectedRef","useRef","hintsUsed","questionRef","pointerContainerRef","hints","validateResponse","showCorrectAnswers","attemptsHistory","showSolution","dropZoneDimensions","setDropZoneDimensions","onUpdateHeight","useCallback","height","useEffect","draggableElements","minWidth","minHeight","draggableElement","learnosityQuestion","$questionEl","parentWidth","nestedElements","i","element","EVENTS","getExtraSpaceNeedForFloatingKeyboard","questionEl","$responseWrapper","questionBottom","responseWrapperBottom","spaceFromResponseToBottom","LEARNOSITY_KEYBOARD_HEIGHT","qHeight","hasKeyboard","_a","newQuestionHeight","useLayoutEffect","scrollToQuestion","jsxs","Styled.QuestionContainerWrapper","QUESTIONS_GAP","jsx","Styled.StimulusReview","Styled.QuestionContainer","Pointer","Styled.QuestionWrapper","QuestionHeader","Styled.LessonOverviewBanner","IMAGES","QuestionBackdrop","Fragment","BasicPracticeIntro","RegularPracticeIntro","ExitTicketIntro","AdvancedPracticeIntro","LearnosityQuestion","Styled.CueCanvasWrapper","CueCanvas","FlexView","hint","index","Styled.Hint","Styled.Solution","SubjectiveQuestionReview"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1584,6 +1584,7 @@ declare interface ICueCanvas {
|
|
|
1584
1584
|
onSubscribe?: TSubscribe;
|
|
1585
1585
|
canvasConfig?: ICanvasUpdateConfig | null;
|
|
1586
1586
|
updateCanvasConfig?: TUpdateCanvasConfig;
|
|
1587
|
+
loggerRef?: React.RefObject<(eventName: string, eventPayload?: Record<string, unknown>) => void>;
|
|
1587
1588
|
}
|
|
1588
1589
|
|
|
1589
1590
|
declare interface ICueCanvasCallbackProps {
|