@cuemath/leap 2.8.31-hg2 → 2.8.31-hg4
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/trial-session/comps/trial-circle-game/trial-circle-game.js +73 -78
- package/dist/features/trial-session/comps/trial-circle-game/trial-circle-game.js.map +1 -1
- package/dist/features/trial-session/hooks/use-trial-session-navigation.js +104 -98
- package/dist/features/trial-session/hooks/use-trial-session-navigation.js.map +1 -1
- package/package.json +1 -1
@@ -1,39 +1,38 @@
|
|
1
|
-
import { jsxs as
|
2
|
-
import { memo as
|
1
|
+
import { jsxs as c, Fragment as J, jsx as a } from "react/jsx-runtime";
|
2
|
+
import { memo as K, useRef as Q, useState as X, useMemo as p, useCallback as m, useEffect as ee } from "react";
|
3
3
|
import { getTimeStrInFormatHMS as re } from "../../../../helpers/date-time.js";
|
4
4
|
import { useWebViewGames as te } from "../../../circle-games/games/web-view/hooks/use-webview-games.js";
|
5
5
|
import { WebView as ae } from "../../../circle-games/games/web-view/web-view.js";
|
6
|
-
import
|
7
|
-
import
|
8
|
-
import
|
6
|
+
import v from "../../../ui/layout/flex-view.js";
|
7
|
+
import h from "../../../ui/separator/separator.js";
|
8
|
+
import d from "../../../ui/text/text.js";
|
9
9
|
import { useTrialSessionContext as ie } from "../../context/use-trial-session-context.js";
|
10
|
-
import { TrialPageId as
|
10
|
+
import { TrialPageId as T } from "../../trial-session-constants.js";
|
11
11
|
import { TrialCircleGameLaunchScreen as oe } from "./trial-circle-game-launch-screen/trial-circle-game-launch-screen.js";
|
12
|
-
import { GameContainer as ne, GameWrapper as le, GameLaunchOverlay as
|
12
|
+
import { GameContainer as ne, GameWrapper as le, GameLaunchOverlay as se } from "./trial-circle-game-styled.js";
|
13
13
|
import { ProjectType as e } from "../../../circle-games/games/web-view/enums/project-type-enum.js";
|
14
|
-
|
15
|
-
|
16
|
-
[
|
17
|
-
[
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
isCircleSkillCompleted: p = !1,
|
14
|
+
const ce = {
|
15
|
+
[T.CIRCLE_GAME]: e.GAME,
|
16
|
+
[T.CIRCLE_PUZZLE]: e.PUZZLE,
|
17
|
+
[T.CIRCLE_SKILL]: e.LESSON
|
18
|
+
}, ye = K(() => {
|
19
|
+
const { slideConfig: w, trialGameUrl: Z, circleGames: b, formData: j, handleInfoMessage: A, updateSlideConfig: t } = ie(), {
|
20
|
+
showCircleGameScreen: S = !0,
|
21
|
+
isCircleGamePlayed: u = !1,
|
22
|
+
isCirclePuzzleSolved: s = !1,
|
23
|
+
isCircleSkillCompleted: f = !1,
|
25
24
|
accuracyStr: E = "",
|
26
25
|
totalTimeTaken: C = 0,
|
27
26
|
matchmakingId: G
|
28
|
-
} =
|
29
|
-
[e.GAME]:
|
30
|
-
[e.PUZZLE]:
|
31
|
-
[e.LESSON]:
|
32
|
-
}), [
|
27
|
+
} = j || {}, L = Q(null), { playGame: y } = te({ webViewRef: L }), [$, g] = X(!0), { header: U, id: k } = w, r = ce[k], { circleConfig: M, playerDetails: O } = b, { games: l, puzzles: n, lessons: i } = M ?? {}, I = p(() => ({
|
28
|
+
[e.GAME]: u,
|
29
|
+
[e.PUZZLE]: s,
|
30
|
+
[e.LESSON]: f
|
31
|
+
}), [u, s, f]), P = p(() => {
|
33
32
|
const o = {
|
34
|
-
[e.GAME]:
|
35
|
-
[e.PUZZLE]:
|
36
|
-
[e.LESSON]:
|
33
|
+
[e.GAME]: u ? l.game_card : l.tutorial,
|
34
|
+
[e.PUZZLE]: s ? n.game_card : n.tutorial,
|
35
|
+
[e.LESSON]: f ? i.game_card : i.tutorial
|
37
36
|
};
|
38
37
|
return r ? o[r] : "";
|
39
38
|
}, [
|
@@ -44,16 +43,16 @@ const me = {
|
|
44
43
|
n.tutorial,
|
45
44
|
i.game_card,
|
46
45
|
i.tutorial,
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
]),
|
51
|
-
id:
|
52
|
-
username:
|
53
|
-
grade:
|
54
|
-
avatar:
|
55
|
-
playerType:
|
56
|
-
},
|
46
|
+
u,
|
47
|
+
s,
|
48
|
+
f
|
49
|
+
]), W = p(() => r === e.PUZZLE && s ? "You've solved it!" : "", [r, s]), { circle_username: x, userId: D, grade: H, user_avatar: N, playerType: _ } = O ?? {}, R = {
|
50
|
+
id: D,
|
51
|
+
username: x,
|
52
|
+
grade: H,
|
53
|
+
avatar: N,
|
54
|
+
playerType: _
|
55
|
+
}, z = p(() => {
|
57
56
|
const o = {
|
58
57
|
joinByRoomId: G,
|
59
58
|
enableCloseButton: !1,
|
@@ -81,13 +80,13 @@ const me = {
|
|
81
80
|
targetQuestions: i.target_questions,
|
82
81
|
projectType: e.LESSON
|
83
82
|
};
|
84
|
-
}, [l, n, i, r, G]),
|
83
|
+
}, [l, n, i, r, G]), F = m(() => {
|
85
84
|
g(!1);
|
86
|
-
}, []),
|
85
|
+
}, []), B = m(() => {
|
87
86
|
g(!0), t({ matchmakingId: void 0 }), r === e.GAME ? t({ showCircleGameScreen: !0 }) : r === e.PUZZLE ? t({ showCircleGameScreen: !0 }) : r === e.LESSON && t({ showCircleGameScreen: !0 });
|
88
|
-
}, [t, r]),
|
87
|
+
}, [t, r]), V = m(() => {
|
89
88
|
t({ showCircleGameScreen: !1, accuracyStr: "", totalTimeTaken: 0 });
|
90
|
-
}, [t]),
|
89
|
+
}, [t]), q = m(
|
91
90
|
(o) => {
|
92
91
|
g(!0), t({ matchmakingId: void 0 }), r === e.LESSON ? t({
|
93
92
|
accuracyStr: o.value,
|
@@ -97,62 +96,58 @@ const me = {
|
|
97
96
|
}) : r === e.GAME ? t({ isCircleGamePlayed: !0, showCircleGameScreen: !0 }) : r === e.PUZZLE && t({ isCirclePuzzleSolved: !0, showCircleGameScreen: !0 });
|
98
97
|
},
|
99
98
|
[t, r]
|
100
|
-
),
|
101
|
-
/* @__PURE__ */
|
102
|
-
/* @__PURE__ */ a(
|
103
|
-
/* @__PURE__ */ a(
|
104
|
-
/* @__PURE__ */ a(
|
99
|
+
), Y = m(() => E && C ? /* @__PURE__ */ c(J, { children: [
|
100
|
+
/* @__PURE__ */ c(v, { $flexDirection: "row", children: [
|
101
|
+
/* @__PURE__ */ a(d, { $renderAs: "ab2", $color: "WHITE", children: "Finished in" }),
|
102
|
+
/* @__PURE__ */ a(h, { width: 5 }),
|
103
|
+
/* @__PURE__ */ a(d, { $renderAs: "ab2-bold", $color: "WHITE", children: re(C) })
|
105
104
|
] }),
|
106
|
-
/* @__PURE__ */ a(
|
107
|
-
/* @__PURE__ */
|
108
|
-
/* @__PURE__ */ a(
|
109
|
-
/* @__PURE__ */ a(
|
110
|
-
/* @__PURE__ */ a(
|
105
|
+
/* @__PURE__ */ a(h, { height: 20 }),
|
106
|
+
/* @__PURE__ */ c(v, { $flexDirection: "row", children: [
|
107
|
+
/* @__PURE__ */ a(d, { $renderAs: "ab2", $color: "WHITE", children: "Accuracy:" }),
|
108
|
+
/* @__PURE__ */ a(h, { width: 5 }),
|
109
|
+
/* @__PURE__ */ a(d, { $renderAs: "ab2-bold", $color: "WHITE", children: E })
|
111
110
|
] })
|
112
111
|
] }) : null, [E, C]);
|
113
|
-
return
|
114
|
-
|
115
|
-
}, [
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
/* @__PURE__ */ a(S, { height: 16 }),
|
121
|
-
/* @__PURE__ */ a(u, { $renderAs: "ah3-bold", $color: "WHITE_T_87", $align: "center", $marginBottom: 16, children: U }),
|
122
|
-
/* @__PURE__ */ m(le, { children: [
|
123
|
-
s && /* @__PURE__ */ a(ce, { children: /* @__PURE__ */ a(
|
112
|
+
return ee(() => {
|
113
|
+
S || y();
|
114
|
+
}, [S, y]), /* @__PURE__ */ c(ne, { children: [
|
115
|
+
/* @__PURE__ */ a(h, { height: 16 }),
|
116
|
+
/* @__PURE__ */ a(d, { $renderAs: "ah3-bold", $color: "WHITE_T_87", $align: "center", $marginBottom: 16, children: U }),
|
117
|
+
/* @__PURE__ */ c(le, { children: [
|
118
|
+
S && /* @__PURE__ */ a(se, { children: /* @__PURE__ */ a(
|
124
119
|
oe,
|
125
120
|
{
|
126
|
-
assetUrl:
|
127
|
-
assetUrlType:
|
128
|
-
descriptionHeader:
|
129
|
-
playerType:
|
121
|
+
assetUrl: P,
|
122
|
+
assetUrlType: P.endsWith("mp4") ? "video" : "lottie",
|
123
|
+
descriptionHeader: W,
|
124
|
+
playerType: _,
|
130
125
|
isLoading: $,
|
131
|
-
isGamePlayed: (r &&
|
132
|
-
onPlay:
|
133
|
-
custEle: r === e.LESSON ?
|
134
|
-
celebrationText: r &&
|
126
|
+
isGamePlayed: (r && I[r]) ?? !1,
|
127
|
+
onPlay: V,
|
128
|
+
custEle: r === e.LESSON ? Y() : void 0,
|
129
|
+
celebrationText: r && I[r] ? "WELL DONE!" : ""
|
135
130
|
}
|
136
131
|
) }),
|
137
132
|
G && /* @__PURE__ */ a(
|
138
133
|
ae,
|
139
134
|
{
|
140
|
-
ref:
|
135
|
+
ref: L,
|
141
136
|
height: "100%",
|
142
137
|
width: "100%",
|
143
|
-
baseUrl:
|
144
|
-
playerDetails:
|
145
|
-
projectDetails:
|
146
|
-
onGameLoad:
|
147
|
-
onBack:
|
148
|
-
handleInfoMessage:
|
149
|
-
onGamePlayFinish:
|
138
|
+
baseUrl: Z,
|
139
|
+
playerDetails: R,
|
140
|
+
projectDetails: z,
|
141
|
+
onGameLoad: F,
|
142
|
+
onBack: B,
|
143
|
+
handleInfoMessage: A,
|
144
|
+
onGamePlayFinish: q
|
150
145
|
}
|
151
146
|
)
|
152
147
|
] })
|
153
148
|
] });
|
154
149
|
});
|
155
150
|
export {
|
156
|
-
|
151
|
+
ye as default
|
157
152
|
};
|
158
153
|
//# sourceMappingURL=trial-circle-game.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"trial-circle-game.js","sources":["../../../../../src/features/trial-session/comps/trial-circle-game/trial-circle-game.tsx"],"sourcesContent":["import type { GameId, LessonId, PuzzleId } from '../../../circle-games/games/web-view/enums';\nimport type {\n ILessonWebGameProps,\n IMultiplayerWebGameProps,\n IPlayer,\n IPlayerStats,\n IPuzzleWebGameProps,\n} from '../../../circle-games/games/web-view/web-view-types';\n\nimport { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport { getTimeStrInFormatHMS } from '../../../../helpers/date-time';\nimport { ProjectType } from '../../../circle-games/games/web-view/enums';\nimport { useWebViewGames } from '../../../circle-games/games/web-view/hooks/use-webview-games';\nimport { WebView } from '../../../circle-games/games/web-view/web-view';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { useTrialSessionContext } from '../../context/use-trial-session-context';\nimport { TrialPageId } from '../../trial-session-constants';\nimport { TrialCircleGameLaunchScreen } from './trial-circle-game-launch-screen/trial-circle-game-launch-screen';\nimport * as Styled from './trial-circle-game-styled';\n\nconst PROJECT_TYPE_MAP: Partial<Record<TrialPageId, ProjectType>> = {\n [TrialPageId.CIRCLE_GAME]: ProjectType.GAME,\n [TrialPageId.CIRCLE_PUZZLE]: ProjectType.PUZZLE,\n [TrialPageId.CIRCLE_SKILL]: ProjectType.LESSON,\n};\n\nconst TrialCircleGame = memo(() => {\n const { slideConfig, trialGameUrl, circleGames, formData, handleInfoMessage, updateSlideConfig } =\n useTrialSessionContext();\n const {\n showCircleGameScreen = true,\n isCircleGamePlayed = false,\n isCirclePuzzleSolved = false,\n isCircleSkillCompleted = false,\n accuracyStr = '',\n totalTimeTaken = 0,\n matchmakingId,\n } = formData || {};\n const webViewRef = useRef<HTMLIFrameElement>(null);\n const { playGame } = useWebViewGames({ webViewRef });\n const [isLoading, setIsLoading] = useState(true);\n\n const { header, id } = slideConfig;\n const projectType = PROJECT_TYPE_MAP[id];\n const { circleConfig, playerDetails } = circleGames;\n const { games, puzzles, lessons } = circleConfig ?? {};\n\n const isPlayed = useMemo(() => {\n const playedStats: Record<ProjectType, boolean> = {\n [ProjectType.GAME]: isCircleGamePlayed,\n [ProjectType.PUZZLE]: isCirclePuzzleSolved,\n [ProjectType.LESSON]: isCircleSkillCompleted,\n };\n\n return playedStats;\n }, [isCircleGamePlayed, isCirclePuzzleSolved, isCircleSkillCompleted]);\n\n const assetUrl = useMemo(() => {\n const url: Record<ProjectType, string> = {\n [ProjectType.GAME]: isCircleGamePlayed ? games.game_card : games.tutorial,\n [ProjectType.PUZZLE]: isCirclePuzzleSolved ? puzzles.game_card : puzzles.tutorial,\n [ProjectType.LESSON]: isCircleSkillCompleted ? lessons.game_card : lessons.tutorial,\n };\n\n return projectType ? url[projectType] : '';\n }, [\n projectType,\n games.game_card,\n games.tutorial,\n puzzles.game_card,\n puzzles.tutorial,\n lessons.game_card,\n lessons.tutorial,\n isCircleGamePlayed,\n isCirclePuzzleSolved,\n isCircleSkillCompleted,\n ]);\n\n const descriptionHeader = useMemo(() => {\n if (projectType === ProjectType.PUZZLE && isCirclePuzzleSolved) {\n return \"You've solved it!\";\n }\n\n return '';\n }, [projectType, isCirclePuzzleSolved]);\n\n const { circle_username, userId, grade, user_avatar, playerType } = playerDetails ?? {};\n\n const playerData: IPlayer = {\n id: userId,\n username: circle_username,\n grade: grade,\n avatar: user_avatar,\n playerType,\n };\n\n const projectDetails = useMemo(() => {\n const commonConfig = {\n joinByRoomId: matchmakingId,\n enableCloseButton: false,\n enablePlayerTurnIndicators: true,\n enableSync: true,\n };\n\n if (projectType === ProjectType.GAME) {\n return {\n ...commonConfig,\n projectId: games.project_id as GameId,\n variant: games.variant,\n projectType: ProjectType.GAME,\n } as IMultiplayerWebGameProps;\n }\n\n if (projectType === ProjectType.PUZZLE) {\n return {\n ...commonConfig,\n projectId: puzzles.project_id as PuzzleId,\n variant: puzzles.variant,\n question: puzzles.question,\n askHintPermission: false,\n projectType: ProjectType.PUZZLE,\n } as IPuzzleWebGameProps;\n }\n\n return {\n ...commonConfig,\n projectId: lessons.project_id as LessonId,\n variant: lessons.variant,\n miniGameIdentifier: lessons.mini_game_identifier,\n sessionId: lessons.session_id,\n targetQuestions: lessons.target_questions,\n projectType: ProjectType.LESSON,\n } as ILessonWebGameProps;\n\n // return commonConfig;\n }, [games, puzzles, lessons, projectType, matchmakingId]);\n\n const onGameLoad = useCallback(() => {\n setIsLoading(false);\n }, []);\n\n const handleBack = useCallback(() => {\n setIsLoading(true);\n updateSlideConfig({ matchmakingId: undefined });\n if (projectType === ProjectType.GAME) {\n updateSlideConfig({ showCircleGameScreen: true });\n } else if (projectType === ProjectType.PUZZLE) {\n updateSlideConfig({ showCircleGameScreen: true });\n } else if (projectType === ProjectType.LESSON) {\n updateSlideConfig({ showCircleGameScreen: true });\n }\n }, [updateSlideConfig, projectType]);\n\n const onPlay = useCallback(() => {\n updateSlideConfig({ showCircleGameScreen: false, accuracyStr: '', totalTimeTaken: 0 });\n }, [updateSlideConfig]);\n\n const handleGameFinish = useCallback(\n (playerStats: IPlayerStats) => {\n setIsLoading(true);\n updateSlideConfig({ matchmakingId: undefined });\n if (projectType === ProjectType.LESSON) {\n updateSlideConfig({\n accuracyStr: playerStats.value,\n totalTimeTaken: playerStats.timeSpent,\n isCircleSkillCompleted: true,\n showCircleGameScreen: true,\n });\n } else if (projectType === ProjectType.GAME) {\n updateSlideConfig({ isCircleGamePlayed: true, showCircleGameScreen: true });\n } else if (projectType === ProjectType.PUZZLE) {\n updateSlideConfig({ isCirclePuzzleSolved: true, showCircleGameScreen: true });\n }\n },\n [updateSlideConfig, projectType],\n );\n\n const getCustEle = useCallback(() => {\n if (accuracyStr && totalTimeTaken) {\n return (\n <>\n <FlexView $flexDirection=\"row\">\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n Finished in\n </Text>\n <Separator width={5} />\n <Text $renderAs=\"ab2-bold\" $color=\"WHITE\">\n {getTimeStrInFormatHMS(totalTimeTaken)}\n </Text>\n </FlexView>\n <Separator height={20} />\n <FlexView $flexDirection=\"row\">\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n Accuracy:\n </Text>\n <Separator width={5} />\n <Text $renderAs=\"ab2-bold\" $color=\"WHITE\">\n {accuracyStr}\n </Text>\n </FlexView>\n </>\n );\n }\n\n return null;\n }, [accuracyStr, totalTimeTaken]);\n\n useEffect(() => {\n if (!showCircleGameScreen) {\n playGame();\n }\n }, [showCircleGameScreen, playGame]);\n\n useEffect(() => {\n updateSlideConfig({ showCircleGameScreen: true });\n }, [updateSlideConfig]);\n\n useEffect(() => {\n if (showCircleGameScreen) {\n updateSlideConfig({ matchmakingId: uuidv4() });\n }\n\n return () => {\n updateSlideConfig({ matchmakingId: undefined });\n };\n }, [showCircleGameScreen, updateSlideConfig]);\n\n return (\n <Styled.GameContainer>\n <Separator height={16} />\n <Text $renderAs=\"ah3-bold\" $color=\"WHITE_T_87\" $align=\"center\" $marginBottom={16}>\n {header}\n </Text>\n <Styled.GameWrapper>\n {showCircleGameScreen && (\n <Styled.GameLaunchOverlay>\n <TrialCircleGameLaunchScreen\n assetUrl={assetUrl}\n assetUrlType={assetUrl.endsWith('mp4') ? 'video' : 'lottie'}\n descriptionHeader={descriptionHeader}\n playerType={playerType}\n isLoading={isLoading}\n isGamePlayed={(projectType && isPlayed[projectType]) ?? false}\n onPlay={onPlay}\n custEle={projectType === ProjectType.LESSON ? getCustEle() : undefined}\n celebrationText={projectType && isPlayed[projectType] ? 'WELL DONE!' : ''}\n />\n </Styled.GameLaunchOverlay>\n )}\n {matchmakingId && (\n <WebView\n ref={webViewRef}\n height=\"100%\"\n width=\"100%\"\n baseUrl={trialGameUrl}\n playerDetails={playerData}\n projectDetails={projectDetails}\n onGameLoad={onGameLoad}\n onBack={handleBack}\n handleInfoMessage={handleInfoMessage}\n onGamePlayFinish={handleGameFinish}\n />\n )}\n </Styled.GameWrapper>\n </Styled.GameContainer>\n );\n});\n\nexport default TrialCircleGame;\n"],"names":["PROJECT_TYPE_MAP","TrialPageId","ProjectType","TrialCircleGame","memo","slideConfig","trialGameUrl","circleGames","formData","handleInfoMessage","updateSlideConfig","useTrialSessionContext","showCircleGameScreen","isCircleGamePlayed","isCirclePuzzleSolved","isCircleSkillCompleted","accuracyStr","totalTimeTaken","matchmakingId","webViewRef","useRef","playGame","useWebViewGames","isLoading","setIsLoading","useState","header","id","projectType","circleConfig","playerDetails","games","puzzles","lessons","isPlayed","useMemo","assetUrl","url","descriptionHeader","circle_username","userId","grade","user_avatar","playerType","playerData","projectDetails","commonConfig","onGameLoad","useCallback","handleBack","onPlay","handleGameFinish","playerStats","getCustEle","jsxs","Fragment","FlexView","jsx","Text","Separator","getTimeStrInFormatHMS","useEffect","uuidv4","Styled.GameContainer","Styled.GameWrapper","Styled.GameLaunchOverlay","TrialCircleGameLaunchScreen","WebView"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"trial-circle-game.js","sources":["../../../../../src/features/trial-session/comps/trial-circle-game/trial-circle-game.tsx"],"sourcesContent":["import type { GameId, LessonId, PuzzleId } from '../../../circle-games/games/web-view/enums';\nimport type {\n ILessonWebGameProps,\n IMultiplayerWebGameProps,\n IPlayer,\n IPlayerStats,\n IPuzzleWebGameProps,\n} from '../../../circle-games/games/web-view/web-view-types';\n\nimport { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { getTimeStrInFormatHMS } from '../../../../helpers/date-time';\nimport { ProjectType } from '../../../circle-games/games/web-view/enums';\nimport { useWebViewGames } from '../../../circle-games/games/web-view/hooks/use-webview-games';\nimport { WebView } from '../../../circle-games/games/web-view/web-view';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { useTrialSessionContext } from '../../context/use-trial-session-context';\nimport { TrialPageId } from '../../trial-session-constants';\nimport { TrialCircleGameLaunchScreen } from './trial-circle-game-launch-screen/trial-circle-game-launch-screen';\nimport * as Styled from './trial-circle-game-styled';\n\nconst PROJECT_TYPE_MAP: Partial<Record<TrialPageId, ProjectType>> = {\n [TrialPageId.CIRCLE_GAME]: ProjectType.GAME,\n [TrialPageId.CIRCLE_PUZZLE]: ProjectType.PUZZLE,\n [TrialPageId.CIRCLE_SKILL]: ProjectType.LESSON,\n};\n\nconst TrialCircleGame = memo(() => {\n const { slideConfig, trialGameUrl, circleGames, formData, handleInfoMessage, updateSlideConfig } =\n useTrialSessionContext();\n const {\n showCircleGameScreen = true,\n isCircleGamePlayed = false,\n isCirclePuzzleSolved = false,\n isCircleSkillCompleted = false,\n accuracyStr = '',\n totalTimeTaken = 0,\n matchmakingId,\n } = formData || {};\n const webViewRef = useRef<HTMLIFrameElement>(null);\n const { playGame } = useWebViewGames({ webViewRef });\n const [isLoading, setIsLoading] = useState(true);\n\n const { header, id } = slideConfig;\n const projectType = PROJECT_TYPE_MAP[id];\n const { circleConfig, playerDetails } = circleGames;\n const { games, puzzles, lessons } = circleConfig ?? {};\n\n const isPlayed = useMemo(() => {\n const playedStats: Record<ProjectType, boolean> = {\n [ProjectType.GAME]: isCircleGamePlayed,\n [ProjectType.PUZZLE]: isCirclePuzzleSolved,\n [ProjectType.LESSON]: isCircleSkillCompleted,\n };\n\n return playedStats;\n }, [isCircleGamePlayed, isCirclePuzzleSolved, isCircleSkillCompleted]);\n\n const assetUrl = useMemo(() => {\n const url: Record<ProjectType, string> = {\n [ProjectType.GAME]: isCircleGamePlayed ? games.game_card : games.tutorial,\n [ProjectType.PUZZLE]: isCirclePuzzleSolved ? puzzles.game_card : puzzles.tutorial,\n [ProjectType.LESSON]: isCircleSkillCompleted ? lessons.game_card : lessons.tutorial,\n };\n\n return projectType ? url[projectType] : '';\n }, [\n projectType,\n games.game_card,\n games.tutorial,\n puzzles.game_card,\n puzzles.tutorial,\n lessons.game_card,\n lessons.tutorial,\n isCircleGamePlayed,\n isCirclePuzzleSolved,\n isCircleSkillCompleted,\n ]);\n\n const descriptionHeader = useMemo(() => {\n if (projectType === ProjectType.PUZZLE && isCirclePuzzleSolved) {\n return \"You've solved it!\";\n }\n\n return '';\n }, [projectType, isCirclePuzzleSolved]);\n\n const { circle_username, userId, grade, user_avatar, playerType } = playerDetails ?? {};\n\n const playerData: IPlayer = {\n id: userId,\n username: circle_username,\n grade: grade,\n avatar: user_avatar,\n playerType,\n };\n\n const projectDetails = useMemo(() => {\n const commonConfig = {\n joinByRoomId: matchmakingId,\n enableCloseButton: false,\n enablePlayerTurnIndicators: true,\n enableSync: true,\n };\n\n if (projectType === ProjectType.GAME) {\n return {\n ...commonConfig,\n projectId: games.project_id as GameId,\n variant: games.variant,\n projectType: ProjectType.GAME,\n } as IMultiplayerWebGameProps;\n }\n\n if (projectType === ProjectType.PUZZLE) {\n return {\n ...commonConfig,\n projectId: puzzles.project_id as PuzzleId,\n variant: puzzles.variant,\n question: puzzles.question,\n askHintPermission: false,\n projectType: ProjectType.PUZZLE,\n } as IPuzzleWebGameProps;\n }\n\n return {\n ...commonConfig,\n projectId: lessons.project_id as LessonId,\n variant: lessons.variant,\n miniGameIdentifier: lessons.mini_game_identifier,\n sessionId: lessons.session_id,\n targetQuestions: lessons.target_questions,\n projectType: ProjectType.LESSON,\n } as ILessonWebGameProps;\n\n // return commonConfig;\n }, [games, puzzles, lessons, projectType, matchmakingId]);\n\n const onGameLoad = useCallback(() => {\n setIsLoading(false);\n }, []);\n\n const handleBack = useCallback(() => {\n setIsLoading(true);\n updateSlideConfig({ matchmakingId: undefined });\n if (projectType === ProjectType.GAME) {\n updateSlideConfig({ showCircleGameScreen: true });\n } else if (projectType === ProjectType.PUZZLE) {\n updateSlideConfig({ showCircleGameScreen: true });\n } else if (projectType === ProjectType.LESSON) {\n updateSlideConfig({ showCircleGameScreen: true });\n }\n }, [updateSlideConfig, projectType]);\n\n const onPlay = useCallback(() => {\n updateSlideConfig({ showCircleGameScreen: false, accuracyStr: '', totalTimeTaken: 0 });\n }, [updateSlideConfig]);\n\n const handleGameFinish = useCallback(\n (playerStats: IPlayerStats) => {\n setIsLoading(true);\n updateSlideConfig({ matchmakingId: undefined });\n if (projectType === ProjectType.LESSON) {\n updateSlideConfig({\n accuracyStr: playerStats.value,\n totalTimeTaken: playerStats.timeSpent,\n isCircleSkillCompleted: true,\n showCircleGameScreen: true,\n });\n } else if (projectType === ProjectType.GAME) {\n updateSlideConfig({ isCircleGamePlayed: true, showCircleGameScreen: true });\n } else if (projectType === ProjectType.PUZZLE) {\n updateSlideConfig({ isCirclePuzzleSolved: true, showCircleGameScreen: true });\n }\n },\n [updateSlideConfig, projectType],\n );\n\n const getCustEle = useCallback(() => {\n if (accuracyStr && totalTimeTaken) {\n return (\n <>\n <FlexView $flexDirection=\"row\">\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n Finished in\n </Text>\n <Separator width={5} />\n <Text $renderAs=\"ab2-bold\" $color=\"WHITE\">\n {getTimeStrInFormatHMS(totalTimeTaken)}\n </Text>\n </FlexView>\n <Separator height={20} />\n <FlexView $flexDirection=\"row\">\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n Accuracy:\n </Text>\n <Separator width={5} />\n <Text $renderAs=\"ab2-bold\" $color=\"WHITE\">\n {accuracyStr}\n </Text>\n </FlexView>\n </>\n );\n }\n\n return null;\n }, [accuracyStr, totalTimeTaken]);\n\n useEffect(() => {\n if (!showCircleGameScreen) {\n playGame();\n }\n }, [showCircleGameScreen, playGame]);\n\n return (\n <Styled.GameContainer>\n <Separator height={16} />\n <Text $renderAs=\"ah3-bold\" $color=\"WHITE_T_87\" $align=\"center\" $marginBottom={16}>\n {header}\n </Text>\n <Styled.GameWrapper>\n {showCircleGameScreen && (\n <Styled.GameLaunchOverlay>\n <TrialCircleGameLaunchScreen\n assetUrl={assetUrl}\n assetUrlType={assetUrl.endsWith('mp4') ? 'video' : 'lottie'}\n descriptionHeader={descriptionHeader}\n playerType={playerType}\n isLoading={isLoading}\n isGamePlayed={(projectType && isPlayed[projectType]) ?? false}\n onPlay={onPlay}\n custEle={projectType === ProjectType.LESSON ? getCustEle() : undefined}\n celebrationText={projectType && isPlayed[projectType] ? 'WELL DONE!' : ''}\n />\n </Styled.GameLaunchOverlay>\n )}\n {matchmakingId && (\n <WebView\n ref={webViewRef}\n height=\"100%\"\n width=\"100%\"\n baseUrl={trialGameUrl}\n playerDetails={playerData}\n projectDetails={projectDetails}\n onGameLoad={onGameLoad}\n onBack={handleBack}\n handleInfoMessage={handleInfoMessage}\n onGamePlayFinish={handleGameFinish}\n />\n )}\n </Styled.GameWrapper>\n </Styled.GameContainer>\n );\n});\n\nexport default TrialCircleGame;\n"],"names":["PROJECT_TYPE_MAP","TrialPageId","ProjectType","TrialCircleGame","memo","slideConfig","trialGameUrl","circleGames","formData","handleInfoMessage","updateSlideConfig","useTrialSessionContext","showCircleGameScreen","isCircleGamePlayed","isCirclePuzzleSolved","isCircleSkillCompleted","accuracyStr","totalTimeTaken","matchmakingId","webViewRef","useRef","playGame","useWebViewGames","isLoading","setIsLoading","useState","header","id","projectType","circleConfig","playerDetails","games","puzzles","lessons","isPlayed","useMemo","assetUrl","url","descriptionHeader","circle_username","userId","grade","user_avatar","playerType","playerData","projectDetails","commonConfig","onGameLoad","useCallback","handleBack","onPlay","handleGameFinish","playerStats","getCustEle","jsxs","Fragment","FlexView","jsx","Text","Separator","getTimeStrInFormatHMS","useEffect","Styled.GameContainer","Styled.GameWrapper","Styled.GameLaunchOverlay","TrialCircleGameLaunchScreen","WebView"],"mappings":"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"}
|
@@ -1,168 +1,174 @@
|
|
1
|
-
import { useCallback as
|
2
|
-
import { COURSE_STREAMS as
|
3
|
-
import { useMilestoneBulkPost as
|
4
|
-
import { usePostStudentPreferences as
|
5
|
-
import { usePatchStudentInformation as
|
6
|
-
import { usePatchTrialHome as
|
7
|
-
import { useTrialSessionContext as
|
8
|
-
import { getFormattedPreferences as
|
9
|
-
import { DEFAULT_BUTTON_STATE as
|
10
|
-
|
1
|
+
import { useCallback as l, useEffect as W } from "react";
|
2
|
+
import { COURSE_STREAMS as V } from "../../milestone/constants.js";
|
3
|
+
import { useMilestoneBulkPost as j } from "../../milestone/create/api/milestone-bulk.js";
|
4
|
+
import { usePostStudentPreferences as q } from "../api/course-stream.js";
|
5
|
+
import { usePatchStudentInformation as J } from "../api/student-information.js";
|
6
|
+
import { usePatchTrialHome as Q } from "../api/trial-home.js";
|
7
|
+
import { useTrialSessionContext as X } from "../context/use-trial-session-context.js";
|
8
|
+
import { getFormattedPreferences as Y, getFormattedStudentPersonalizedPreference as $ } from "../helper.js";
|
9
|
+
import { DEFAULT_BUTTON_STATE as _, TrialPageId as e } from "../trial-session-constants.js";
|
10
|
+
import z from "../../../node_modules/uuid/dist/esm-browser/v4.js";
|
11
|
+
const de = () => {
|
11
12
|
const {
|
12
13
|
updateSlideConfig: s,
|
13
14
|
slideConfig: B,
|
14
|
-
formData:
|
15
|
+
formData: H,
|
15
16
|
updateButtonState: a,
|
16
17
|
teacherId: d,
|
17
18
|
studentId: n,
|
18
|
-
milestoneConfig:
|
19
|
+
milestoneConfig: P,
|
19
20
|
onTrialInformationUpdate: h,
|
20
|
-
trialHomeData:
|
21
|
-
worksheetNavigationPanel:
|
22
|
-
} =
|
23
|
-
name:
|
24
|
-
grade:
|
25
|
-
goals:
|
26
|
-
curriculum:
|
27
|
-
studentTimezone:
|
28
|
-
preferences:
|
21
|
+
trialHomeData: x,
|
22
|
+
worksheetNavigationPanel: I
|
23
|
+
} = X(), { nextPage: w, id: r } = B || {}, { demo_info: Z } = x, { stream: N } = Z, { pageId: i } = w || {}, {
|
24
|
+
name: u,
|
25
|
+
grade: p,
|
26
|
+
goals: C,
|
27
|
+
curriculum: E,
|
28
|
+
studentTimezone: g,
|
29
|
+
preferences: T = [],
|
29
30
|
personalizedLevel: A = [],
|
30
|
-
personalizedFocus:
|
31
|
-
personalizedBehaviors:
|
32
|
-
} =
|
31
|
+
personalizedFocus: R = [],
|
32
|
+
personalizedBehaviors: O = []
|
33
|
+
} = H || {}, c = l(() => {
|
33
34
|
a("both", {
|
34
35
|
left: { isDisabled: !0, isLoading: !1 },
|
35
36
|
right: { isDisabled: !0, isLoading: !0 }
|
36
37
|
});
|
37
|
-
}, [a]), S = (
|
38
|
-
|
39
|
-
|
38
|
+
}, [a]), S = (o) => {
|
39
|
+
if (!o) {
|
40
|
+
const t = {};
|
41
|
+
(i === e.CIRCLE_GAME || i === e.CIRCLE_PUZZLE || i === e.CIRCLE_SKILL) && (t.matchmakingId = z(), t.showCircleGameScreen = !0), s({ id: i, ...t });
|
42
|
+
}
|
43
|
+
a("both", _), (r === e.STUDENT_INFORMATION || r === e.SCHOOL_GOALS) && (h == null || h());
|
44
|
+
}, { patch: b } = Q({ onComplete: S }), { patch: v } = J({
|
40
45
|
onComplete: S
|
41
|
-
}), { post: k } =
|
46
|
+
}), { post: k } = j({
|
42
47
|
onComplete: S
|
43
|
-
}), { post:
|
48
|
+
}), { post: D } = q({
|
44
49
|
onComplete: S
|
45
|
-
}),
|
46
|
-
const [
|
47
|
-
first_name:
|
48
|
-
last_name:
|
49
|
-
grade:
|
50
|
-
board:
|
50
|
+
}), G = l(() => {
|
51
|
+
const [o, t] = (u == null ? void 0 : u.split(" ")) || [], m = {
|
52
|
+
first_name: o,
|
53
|
+
last_name: t,
|
54
|
+
grade: p,
|
55
|
+
board: E,
|
51
56
|
demo_type: "TRIAL_V3",
|
52
57
|
teacher_id: d
|
53
58
|
};
|
54
|
-
|
55
|
-
}, [p, u,
|
56
|
-
const
|
57
|
-
if (
|
58
|
-
const
|
59
|
+
c(), v(n, m);
|
60
|
+
}, [E, p, u, v, n, d, c]), M = l(() => {
|
61
|
+
const o = Y(T, g);
|
62
|
+
if (o.length > 0) {
|
63
|
+
const t = {
|
59
64
|
trial_details: {
|
60
|
-
selected_regular_slots:
|
65
|
+
selected_regular_slots: o
|
61
66
|
}
|
62
67
|
};
|
63
|
-
|
68
|
+
c(), b("trial-v3-patch", {
|
64
69
|
action: "UPDATE_DEMO",
|
65
|
-
action_data:
|
70
|
+
action_data: t,
|
66
71
|
teacher_id: d,
|
67
72
|
student_id: n
|
68
73
|
});
|
69
74
|
} else
|
70
|
-
s({ id:
|
75
|
+
s({ id: i }), a("both", _);
|
71
76
|
}, [
|
72
|
-
|
73
|
-
|
74
|
-
|
77
|
+
T,
|
78
|
+
g,
|
79
|
+
c,
|
75
80
|
b,
|
76
81
|
d,
|
77
82
|
n,
|
78
83
|
s,
|
79
|
-
|
84
|
+
i,
|
80
85
|
a
|
81
|
-
]),
|
82
|
-
const
|
83
|
-
course_stream:
|
84
|
-
grade:
|
86
|
+
]), U = l(() => {
|
87
|
+
const o = {
|
88
|
+
course_stream: N,
|
89
|
+
grade: p,
|
85
90
|
teacher_id: d,
|
86
|
-
board:
|
87
|
-
goals:
|
91
|
+
board: E,
|
92
|
+
goals: C
|
88
93
|
};
|
89
|
-
|
94
|
+
c(), k(o, {
|
90
95
|
studentId: n
|
91
96
|
});
|
92
97
|
}, [
|
98
|
+
E,
|
99
|
+
c,
|
100
|
+
C,
|
93
101
|
p,
|
94
|
-
i,
|
95
|
-
g,
|
96
|
-
u,
|
97
102
|
k,
|
98
|
-
|
103
|
+
N,
|
99
104
|
n,
|
100
105
|
d
|
101
|
-
]),
|
102
|
-
const
|
106
|
+
]), F = l(() => {
|
107
|
+
const t = { preferences: $(P, [
|
103
108
|
...A,
|
104
|
-
...
|
105
|
-
...
|
106
|
-
]) },
|
107
|
-
|
109
|
+
...R,
|
110
|
+
...O
|
111
|
+
]) }, m = { stream: V.MATH, studentId: n };
|
112
|
+
c(), D(t, m);
|
108
113
|
}, [
|
109
|
-
|
110
|
-
|
111
|
-
R,
|
114
|
+
c,
|
115
|
+
P,
|
112
116
|
O,
|
117
|
+
R,
|
113
118
|
A,
|
114
|
-
|
119
|
+
D,
|
115
120
|
n
|
116
|
-
]),
|
117
|
-
(
|
121
|
+
]), L = l(
|
122
|
+
(o, t) => {
|
118
123
|
if (!s) return;
|
119
|
-
const
|
120
|
-
if (e === "prev" && (s({
|
121
|
-
id:
|
122
|
-
...
|
123
|
-
...
|
124
|
+
const m = r === e.STUDENT_PROFILE, K = r === e.LEARNING_PLAN, f = {};
|
125
|
+
if ((t === e.CIRCLE_GAME || t === e.CIRCLE_PUZZLE || t === e.CIRCLE_SKILL) && (f.matchmakingId = z(), f.showCircleGameScreen = !0), o === "prev" && (s({
|
126
|
+
id: t,
|
127
|
+
...m && { studentProfile: void 0 },
|
128
|
+
...K && {
|
124
129
|
chapterId: void 0
|
125
|
-
}
|
126
|
-
|
130
|
+
},
|
131
|
+
...f
|
132
|
+
}), a("both", _)), o === "next")
|
127
133
|
switch (r) {
|
128
|
-
case
|
129
|
-
case
|
130
|
-
|
134
|
+
case e.STUDENT_INFORMATION:
|
135
|
+
case e.SCHOOL_GOALS:
|
136
|
+
G();
|
137
|
+
break;
|
138
|
+
case e.LEARNING_WORKSHEET:
|
139
|
+
U();
|
131
140
|
break;
|
132
|
-
case
|
141
|
+
case e.CLASS_PREFERENCE:
|
133
142
|
M();
|
134
143
|
break;
|
135
|
-
case
|
144
|
+
case e.LEARNING_LEVEL:
|
145
|
+
case e.STUDENT_PERSONALIZATION:
|
136
146
|
F();
|
137
147
|
break;
|
138
|
-
case
|
139
|
-
|
140
|
-
z();
|
141
|
-
break;
|
142
|
-
case t.LEARNING_PLAN:
|
143
|
-
s({ id: o, chapterId: void 0 });
|
148
|
+
case e.LEARNING_PLAN:
|
149
|
+
s({ id: t, chapterId: void 0, ...f });
|
144
150
|
break;
|
145
151
|
default:
|
146
|
-
s({ id:
|
152
|
+
s({ id: t, ...f }), a("both", _);
|
147
153
|
}
|
148
154
|
},
|
149
155
|
[
|
150
156
|
s,
|
151
157
|
r,
|
152
158
|
a,
|
153
|
-
|
159
|
+
G,
|
160
|
+
U,
|
154
161
|
M,
|
155
|
-
F
|
156
|
-
z
|
162
|
+
F
|
157
163
|
]
|
158
|
-
), y =
|
159
|
-
!
|
160
|
-
}, [r,
|
164
|
+
), y = l(() => {
|
165
|
+
!I && r === e.LEARNING_WORKSHEET && L("next", i);
|
166
|
+
}, [r, L, i, I]);
|
161
167
|
return W(() => {
|
162
168
|
y();
|
163
|
-
}, [
|
169
|
+
}, [I]), { handleNavigation: L };
|
164
170
|
};
|
165
171
|
export {
|
166
|
-
|
172
|
+
de as useTrialSessionNavigation
|
167
173
|
};
|
168
174
|
//# sourceMappingURL=use-trial-session-navigation.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"use-trial-session-navigation.js","sources":["../../../../src/features/trial-session/hooks/use-trial-session-navigation.ts"],"sourcesContent":["import { useCallback, useEffect } from 'react';\n\nimport { COURSE_STREAMS } from '../../milestone/constants';\nimport { useMilestoneBulkPost } from '../../milestone/create/api/milestone-bulk';\nimport { usePostStudentPreferences } from '../api/course-stream';\nimport { usePatchStudentInformation } from '../api/student-information';\nimport { usePatchTrialHome } from '../api/trial-home';\nimport { useTrialSessionContext } from '../context/use-trial-session-context';\nimport { getFormattedPreferences, getFormattedStudentPersonalizedPreference } from '../helper';\nimport { DEFAULT_BUTTON_STATE, TrialPageId } from '../trial-session-constants';\n\nconst useTrialSessionNavigation = () => {\n const {\n updateSlideConfig,\n slideConfig,\n formData,\n updateButtonState,\n teacherId,\n studentId,\n milestoneConfig,\n onTrialInformationUpdate,\n trialHomeData,\n worksheetNavigationPanel,\n } = useTrialSessionContext();\n const { nextPage, id: currentPageId } = slideConfig || {};\n const { demo_info: demoInfo } = trialHomeData;\n const { stream } = demoInfo;\n const { pageId: nextPageId } = nextPage || {};\n const {\n name,\n grade,\n goals,\n curriculum,\n studentTimezone,\n preferences = [],\n personalizedLevel = [],\n personalizedFocus = [],\n personalizedBehaviors = [],\n } = formData || {};\n\n const disableNavButtons = useCallback(() => {\n updateButtonState('both', {\n left: { isDisabled: true, isLoading: false },\n right: { isDisabled: true, isLoading: true },\n });\n }, [updateButtonState]);\n\n const onAcknowledge = (errorMessage: string | null) => {\n if (!errorMessage) {\n updateSlideConfig({ id: nextPageId });\n }\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n\n if (\n currentPageId === TrialPageId.STUDENT_INFORMATION ||\n currentPageId === TrialPageId.SCHOOL_GOALS\n ) {\n //TODO: remove TrialPageId.STUDENT_INFORMATION\n onTrialInformationUpdate?.();\n }\n };\n\n // API specifications\n const { patch: patchTrialSession } = usePatchTrialHome({ onComplete: onAcknowledge });\n const { patch: patchStudentInformation } = usePatchStudentInformation({\n onComplete: onAcknowledge,\n });\n const { post: postMilestoneBulk } = useMilestoneBulkPost({\n onComplete: onAcknowledge,\n });\n const { post: postStudentPreferences } = usePostStudentPreferences({\n onComplete: onAcknowledge,\n });\n\n // Function to call API and updates states\n const handleStudentInformation = useCallback(() => {\n const [firstName, lastName] = name?.split(' ') || [];\n const payload = {\n first_name: firstName,\n last_name: lastName,\n grade,\n board: curriculum,\n demo_type: 'TRIAL_V3',\n teacher_id: teacherId,\n };\n\n disableNavButtons();\n patchStudentInformation(studentId, payload);\n }, [curriculum, grade, name, patchStudentInformation, studentId, teacherId, disableNavButtons]);\n\n const handleClassPreferences = useCallback(() => {\n const selectedRegularSlots = getFormattedPreferences(preferences, studentTimezone);\n\n if (selectedRegularSlots.length > 0) {\n const actionData = {\n trial_details: {\n selected_regular_slots: selectedRegularSlots,\n },\n };\n\n disableNavButtons();\n patchTrialSession('trial-v3-patch', {\n action: 'UPDATE_DEMO',\n action_data: actionData,\n teacher_id: teacherId,\n student_id: studentId,\n });\n } else {\n updateSlideConfig({ id: nextPageId });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n }, [\n preferences,\n studentTimezone,\n disableNavButtons,\n patchTrialSession,\n teacherId,\n studentId,\n updateSlideConfig,\n nextPageId,\n updateButtonState,\n ]);\n\n const handleMileStoneBulkPost = useCallback(() => {\n const payload = {\n course_stream: stream,\n grade,\n teacher_id: teacherId,\n board: curriculum,\n goals,\n };\n\n disableNavButtons();\n postMilestoneBulk(payload, {\n studentId,\n });\n }, [\n curriculum,\n disableNavButtons,\n goals,\n grade,\n postMilestoneBulk,\n stream,\n studentId,\n teacherId,\n ]);\n\n const handleStudentPreferencesPatch = useCallback(() => {\n const personalizedPreferences = getFormattedStudentPersonalizedPreference(milestoneConfig, [\n ...personalizedLevel,\n ...personalizedFocus,\n ...personalizedBehaviors,\n ]);\n\n const payload = { preferences: personalizedPreferences };\n const meta = { stream: COURSE_STREAMS.MATH, studentId };\n\n disableNavButtons();\n postStudentPreferences(payload, meta);\n }, [\n disableNavButtons,\n milestoneConfig,\n personalizedBehaviors,\n personalizedFocus,\n personalizedLevel,\n postStudentPreferences,\n studentId,\n ]);\n\n // Navigation logic\n const handleNavigation = useCallback(\n (dir: string, id?: string) => {\n if (!updateSlideConfig) return;\n\n const isStudentProfilePage = currentPageId === TrialPageId.STUDENT_PROFILE;\n const isLearningPlanSlide = currentPageId === TrialPageId.LEARNING_PLAN;\n\n if (dir === 'prev') {\n updateSlideConfig({\n id,\n ...(isStudentProfilePage && { studentProfile: undefined }),\n ...(isLearningPlanSlide && {\n chapterId: undefined,\n }),\n });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n\n if (dir === 'next') {\n switch (currentPageId) {\n //TODO: remove STUDENT_INFORMATION\n case TrialPageId.STUDENT_INFORMATION:\n case TrialPageId.SCHOOL_GOALS:\n handleStudentInformation();\n break;\n case TrialPageId.LEARNING_WORKSHEET:\n handleMileStoneBulkPost();\n break;\n case TrialPageId.CLASS_PREFERENCE:\n handleClassPreferences();\n break;\n case TrialPageId.LEARNING_LEVEL:\n case TrialPageId.STUDENT_PERSONALIZATION:\n handleStudentPreferencesPatch();\n break;\n case TrialPageId.LEARNING_PLAN:\n updateSlideConfig({ id, chapterId: undefined });\n break;\n default: {\n updateSlideConfig({ id });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n }\n }\n },\n [\n updateSlideConfig,\n currentPageId,\n updateButtonState,\n handleStudentInformation,\n handleMileStoneBulkPost,\n handleClassPreferences,\n handleStudentPreferencesPatch,\n ],\n );\n\n const sessionWorksheetNavigation = useCallback(() => {\n if (!worksheetNavigationPanel && currentPageId === TrialPageId.LEARNING_WORKSHEET) {\n handleNavigation('next', nextPageId);\n }\n }, [currentPageId, handleNavigation, nextPageId, worksheetNavigationPanel]);\n\n useEffect(() => {\n sessionWorksheetNavigation();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [worksheetNavigationPanel]);\n\n return { handleNavigation };\n};\n\nexport { useTrialSessionNavigation };\n"],"names":["useTrialSessionNavigation","updateSlideConfig","slideConfig","formData","updateButtonState","teacherId","studentId","milestoneConfig","onTrialInformationUpdate","trialHomeData","worksheetNavigationPanel","useTrialSessionContext","nextPage","currentPageId","demoInfo","stream","nextPageId","name","grade","goals","curriculum","studentTimezone","preferences","personalizedLevel","personalizedFocus","personalizedBehaviors","disableNavButtons","useCallback","onAcknowledge","errorMessage","DEFAULT_BUTTON_STATE","TrialPageId","patchTrialSession","usePatchTrialHome","patchStudentInformation","usePatchStudentInformation","postMilestoneBulk","useMilestoneBulkPost","postStudentPreferences","usePostStudentPreferences","handleStudentInformation","firstName","lastName","payload","handleClassPreferences","selectedRegularSlots","getFormattedPreferences","actionData","handleMileStoneBulkPost","handleStudentPreferencesPatch","getFormattedStudentPersonalizedPreference","meta","COURSE_STREAMS","handleNavigation","dir","id","isStudentProfilePage","isLearningPlanSlide","sessionWorksheetNavigation","useEffect"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"use-trial-session-navigation.js","sources":["../../../../src/features/trial-session/hooks/use-trial-session-navigation.ts"],"sourcesContent":["import type { ITrialSessionFormFields } from '../trial-session-types';\n\nimport { useCallback, useEffect } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport { COURSE_STREAMS } from '../../milestone/constants';\nimport { useMilestoneBulkPost } from '../../milestone/create/api/milestone-bulk';\nimport { usePostStudentPreferences } from '../api/course-stream';\nimport { usePatchStudentInformation } from '../api/student-information';\nimport { usePatchTrialHome } from '../api/trial-home';\nimport { useTrialSessionContext } from '../context/use-trial-session-context';\nimport { getFormattedPreferences, getFormattedStudentPersonalizedPreference } from '../helper';\nimport { DEFAULT_BUTTON_STATE, TrialPageId } from '../trial-session-constants';\n\nconst useTrialSessionNavigation = () => {\n const {\n updateSlideConfig,\n slideConfig,\n formData,\n updateButtonState,\n teacherId,\n studentId,\n milestoneConfig,\n onTrialInformationUpdate,\n trialHomeData,\n worksheetNavigationPanel,\n } = useTrialSessionContext();\n const { nextPage, id: currentPageId } = slideConfig || {};\n const { demo_info: demoInfo } = trialHomeData;\n const { stream } = demoInfo;\n const { pageId: nextPageId } = nextPage || {};\n const {\n name,\n grade,\n goals,\n curriculum,\n studentTimezone,\n preferences = [],\n personalizedLevel = [],\n personalizedFocus = [],\n personalizedBehaviors = [],\n } = formData || {};\n\n const disableNavButtons = useCallback(() => {\n updateButtonState('both', {\n left: { isDisabled: true, isLoading: false },\n right: { isDisabled: true, isLoading: true },\n });\n }, [updateButtonState]);\n\n const onAcknowledge = (errorMessage: string | null) => {\n if (!errorMessage) {\n const overrides: Partial<ITrialSessionFormFields> = {};\n\n if (\n nextPageId === TrialPageId.CIRCLE_GAME ||\n nextPageId === TrialPageId.CIRCLE_PUZZLE ||\n nextPageId === TrialPageId.CIRCLE_SKILL\n ) {\n overrides.matchmakingId = uuidv4();\n overrides.showCircleGameScreen = true;\n }\n\n updateSlideConfig({ id: nextPageId, ...overrides });\n }\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n\n if (\n currentPageId === TrialPageId.STUDENT_INFORMATION ||\n currentPageId === TrialPageId.SCHOOL_GOALS\n ) {\n //TODO: remove TrialPageId.STUDENT_INFORMATION\n onTrialInformationUpdate?.();\n }\n };\n\n // API specifications\n const { patch: patchTrialSession } = usePatchTrialHome({ onComplete: onAcknowledge });\n const { patch: patchStudentInformation } = usePatchStudentInformation({\n onComplete: onAcknowledge,\n });\n const { post: postMilestoneBulk } = useMilestoneBulkPost({\n onComplete: onAcknowledge,\n });\n const { post: postStudentPreferences } = usePostStudentPreferences({\n onComplete: onAcknowledge,\n });\n\n // Function to call API and updates states\n const handleStudentInformation = useCallback(() => {\n const [firstName, lastName] = name?.split(' ') || [];\n const payload = {\n first_name: firstName,\n last_name: lastName,\n grade,\n board: curriculum,\n demo_type: 'TRIAL_V3',\n teacher_id: teacherId,\n };\n\n disableNavButtons();\n patchStudentInformation(studentId, payload);\n }, [curriculum, grade, name, patchStudentInformation, studentId, teacherId, disableNavButtons]);\n\n const handleClassPreferences = useCallback(() => {\n const selectedRegularSlots = getFormattedPreferences(preferences, studentTimezone);\n\n if (selectedRegularSlots.length > 0) {\n const actionData = {\n trial_details: {\n selected_regular_slots: selectedRegularSlots,\n },\n };\n\n disableNavButtons();\n patchTrialSession('trial-v3-patch', {\n action: 'UPDATE_DEMO',\n action_data: actionData,\n teacher_id: teacherId,\n student_id: studentId,\n });\n } else {\n updateSlideConfig({ id: nextPageId });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n }, [\n preferences,\n studentTimezone,\n disableNavButtons,\n patchTrialSession,\n teacherId,\n studentId,\n updateSlideConfig,\n nextPageId,\n updateButtonState,\n ]);\n\n const handleMileStoneBulkPost = useCallback(() => {\n const payload = {\n course_stream: stream,\n grade,\n teacher_id: teacherId,\n board: curriculum,\n goals,\n };\n\n disableNavButtons();\n postMilestoneBulk(payload, {\n studentId,\n });\n }, [\n curriculum,\n disableNavButtons,\n goals,\n grade,\n postMilestoneBulk,\n stream,\n studentId,\n teacherId,\n ]);\n\n const handleStudentPreferencesPatch = useCallback(() => {\n const personalizedPreferences = getFormattedStudentPersonalizedPreference(milestoneConfig, [\n ...personalizedLevel,\n ...personalizedFocus,\n ...personalizedBehaviors,\n ]);\n\n const payload = { preferences: personalizedPreferences };\n const meta = { stream: COURSE_STREAMS.MATH, studentId };\n\n disableNavButtons();\n postStudentPreferences(payload, meta);\n }, [\n disableNavButtons,\n milestoneConfig,\n personalizedBehaviors,\n personalizedFocus,\n personalizedLevel,\n postStudentPreferences,\n studentId,\n ]);\n\n // Navigation logic\n const handleNavigation = useCallback(\n (dir: string, id?: string) => {\n if (!updateSlideConfig) return;\n\n const isStudentProfilePage = currentPageId === TrialPageId.STUDENT_PROFILE;\n const isLearningPlanSlide = currentPageId === TrialPageId.LEARNING_PLAN;\n const overrides: Partial<ITrialSessionFormFields> = {};\n\n if (\n id === TrialPageId.CIRCLE_GAME ||\n id === TrialPageId.CIRCLE_PUZZLE ||\n id === TrialPageId.CIRCLE_SKILL\n ) {\n overrides.matchmakingId = uuidv4();\n overrides.showCircleGameScreen = true;\n }\n\n if (dir === 'prev') {\n updateSlideConfig({\n id,\n ...(isStudentProfilePage && { studentProfile: undefined }),\n ...(isLearningPlanSlide && {\n chapterId: undefined,\n }),\n ...overrides,\n });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n\n if (dir === 'next') {\n switch (currentPageId) {\n //TODO: remove STUDENT_INFORMATION\n case TrialPageId.STUDENT_INFORMATION:\n case TrialPageId.SCHOOL_GOALS:\n handleStudentInformation();\n break;\n case TrialPageId.LEARNING_WORKSHEET:\n handleMileStoneBulkPost();\n break;\n case TrialPageId.CLASS_PREFERENCE:\n handleClassPreferences();\n break;\n case TrialPageId.LEARNING_LEVEL:\n case TrialPageId.STUDENT_PERSONALIZATION:\n handleStudentPreferencesPatch();\n break;\n case TrialPageId.LEARNING_PLAN:\n updateSlideConfig({ id, chapterId: undefined, ...overrides });\n break;\n default: {\n updateSlideConfig({ id, ...overrides });\n updateButtonState('both', DEFAULT_BUTTON_STATE);\n }\n }\n }\n },\n [\n updateSlideConfig,\n currentPageId,\n updateButtonState,\n handleStudentInformation,\n handleMileStoneBulkPost,\n handleClassPreferences,\n handleStudentPreferencesPatch,\n ],\n );\n\n const sessionWorksheetNavigation = useCallback(() => {\n if (!worksheetNavigationPanel && currentPageId === TrialPageId.LEARNING_WORKSHEET) {\n handleNavigation('next', nextPageId);\n }\n }, [currentPageId, handleNavigation, nextPageId, worksheetNavigationPanel]);\n\n useEffect(() => {\n sessionWorksheetNavigation();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [worksheetNavigationPanel]);\n\n return { handleNavigation };\n};\n\nexport { useTrialSessionNavigation };\n"],"names":["useTrialSessionNavigation","updateSlideConfig","slideConfig","formData","updateButtonState","teacherId","studentId","milestoneConfig","onTrialInformationUpdate","trialHomeData","worksheetNavigationPanel","useTrialSessionContext","nextPage","currentPageId","demoInfo","stream","nextPageId","name","grade","goals","curriculum","studentTimezone","preferences","personalizedLevel","personalizedFocus","personalizedBehaviors","disableNavButtons","useCallback","onAcknowledge","errorMessage","overrides","TrialPageId","uuidv4","DEFAULT_BUTTON_STATE","patchTrialSession","usePatchTrialHome","patchStudentInformation","usePatchStudentInformation","postMilestoneBulk","useMilestoneBulkPost","postStudentPreferences","usePostStudentPreferences","handleStudentInformation","firstName","lastName","payload","handleClassPreferences","selectedRegularSlots","getFormattedPreferences","actionData","handleMileStoneBulkPost","handleStudentPreferencesPatch","getFormattedStudentPersonalizedPreference","meta","COURSE_STREAMS","handleNavigation","dir","id","isStudentProfilePage","isLearningPlanSlide","sessionWorksheetNavigation","useEffect"],"mappings":"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"}
|