@cuemath/leap 3.3.11-link.0 → 3.3.11-link.2
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.
|
@@ -1,154 +1,148 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import { memo as
|
|
3
|
-
import { PREFERENCE_CATEGORY as
|
|
4
|
-
import { getGradesFromConfig as
|
|
1
|
+
import { jsx as h, jsxs as ne } from "react/jsx-runtime";
|
|
2
|
+
import { memo as re, useState as oe, useMemo as P, useCallback as L, useEffect as S } from "react";
|
|
3
|
+
import { PREFERENCE_CATEGORY as H } from "../milestone/constants.js";
|
|
4
|
+
import { getGradesFromConfig as se } from "../milestone/create/milestone-create-helpers.js";
|
|
5
5
|
import ae from "../ui/layout/flex-view.js";
|
|
6
|
-
import { PREFERENCE_CODE_MAP as
|
|
7
|
-
import
|
|
8
|
-
import { getPreferenceCodesByCategory as
|
|
9
|
-
import { useButtonStateForLeftPanel as
|
|
10
|
-
import
|
|
11
|
-
import
|
|
12
|
-
const
|
|
6
|
+
import { PREFERENCE_CODE_MAP as ie } from "./comps/student-feedback/student-feedback-constants.js";
|
|
7
|
+
import le from "./context/trial-session-context.js";
|
|
8
|
+
import { getPreferenceCodesByCategory as U } from "./helper.js";
|
|
9
|
+
import { useButtonStateForLeftPanel as ce } from "./hooks/use-left-panel-button-state.js";
|
|
10
|
+
import de from "./left-panel/index.js";
|
|
11
|
+
import me from "./right-panel/index.js";
|
|
12
|
+
const Te = re((q) => {
|
|
13
13
|
const {
|
|
14
|
-
countryCode:
|
|
15
|
-
userType:
|
|
16
|
-
teacherPanel:
|
|
17
|
-
studentPanel:
|
|
18
|
-
trialGameUrl:
|
|
19
|
-
formData:
|
|
20
|
-
height:
|
|
21
|
-
trialHomeData:
|
|
22
|
-
milestoneConfig:
|
|
23
|
-
onFormDataChange:
|
|
24
|
-
worksheet:
|
|
25
|
-
studentId:
|
|
26
|
-
teacherId:
|
|
27
|
-
classStartedOn:
|
|
28
|
-
worksheetNavigationPanel:
|
|
29
|
-
questionsRatingPanel:
|
|
30
|
-
studentAbsentInClass:
|
|
31
|
-
openEndClassModal:
|
|
32
|
-
onTrialInformationUpdate:
|
|
33
|
-
onStudentTimezoneUpdate:
|
|
34
|
-
handleInfoMessage:
|
|
35
|
-
onRemoveOptionalSlides:
|
|
36
|
-
classDuration:
|
|
37
|
-
studentTimezone:
|
|
38
|
-
classTimeAlertConfig:
|
|
39
|
-
} =
|
|
40
|
-
() =>
|
|
41
|
-
[
|
|
42
|
-
),
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
), o = s(
|
|
46
|
-
() => J(f, q.POSITION, !0),
|
|
47
|
-
[f]
|
|
48
|
-
), $ = s(() => {
|
|
49
|
-
const t = {
|
|
50
|
-
circleConfig: n.circle_trial_game_config,
|
|
14
|
+
countryCode: I,
|
|
15
|
+
userType: o,
|
|
16
|
+
teacherPanel: D,
|
|
17
|
+
studentPanel: T,
|
|
18
|
+
trialGameUrl: _,
|
|
19
|
+
formData: s,
|
|
20
|
+
height: J = "100vh",
|
|
21
|
+
trialHomeData: e,
|
|
22
|
+
milestoneConfig: a,
|
|
23
|
+
onFormDataChange: f,
|
|
24
|
+
worksheet: R,
|
|
25
|
+
studentId: i,
|
|
26
|
+
teacherId: l,
|
|
27
|
+
classStartedOn: v,
|
|
28
|
+
worksheetNavigationPanel: y,
|
|
29
|
+
questionsRatingPanel: x,
|
|
30
|
+
studentAbsentInClass: O,
|
|
31
|
+
openEndClassModal: F,
|
|
32
|
+
onTrialInformationUpdate: G,
|
|
33
|
+
onStudentTimezoneUpdate: u,
|
|
34
|
+
handleInfoMessage: N,
|
|
35
|
+
onRemoveOptionalSlides: b,
|
|
36
|
+
classDuration: j,
|
|
37
|
+
studentTimezone: c,
|
|
38
|
+
classTimeAlertConfig: w
|
|
39
|
+
} = q, t = o === "TEACHER", { pages: p = [] } = e, [r, Y] = oe(s), g = t ? r : s, C = g == null ? void 0 : g.id, A = P(
|
|
40
|
+
() => p.find((n) => n.id === C) ?? p[0],
|
|
41
|
+
[C, p]
|
|
42
|
+
), M = P(() => {
|
|
43
|
+
const n = {
|
|
44
|
+
circleConfig: e.circle_trial_game_config,
|
|
51
45
|
playerDetails: {
|
|
52
|
-
userId:
|
|
53
|
-
circle_username:
|
|
54
|
-
user_avatar:
|
|
55
|
-
playerType:
|
|
56
|
-
countryCode:
|
|
46
|
+
userId: t ? l : i,
|
|
47
|
+
circle_username: e[t ? "teacher" : "student"].circle_username,
|
|
48
|
+
user_avatar: e[t ? "teacher" : "student"].user_avatar,
|
|
49
|
+
playerType: o,
|
|
50
|
+
countryCode: I
|
|
57
51
|
}
|
|
58
52
|
};
|
|
59
|
-
return
|
|
60
|
-
}, [
|
|
61
|
-
|
|
62
|
-
}, []), { buttonState:
|
|
53
|
+
return o === "STUDENT" && (n.playerDetails.grade = e.student.grade), n;
|
|
54
|
+
}, [I, t, i, l, e, o]), d = L((n) => {
|
|
55
|
+
Y((m) => m ? { ...m, ...n } : n);
|
|
56
|
+
}, []), { buttonState: B, updateButtonState: V } = ce(), K = P(
|
|
63
57
|
() => ({
|
|
64
|
-
teacherPanel:
|
|
65
|
-
studentPanel:
|
|
66
|
-
isTeacher:
|
|
67
|
-
slideConfig:
|
|
68
|
-
milestoneConfig:
|
|
69
|
-
formData:
|
|
70
|
-
updateSlideConfig:
|
|
71
|
-
worksheet:
|
|
72
|
-
buttonState:
|
|
73
|
-
updateButtonState:
|
|
74
|
-
studentId:
|
|
75
|
-
teacherId:
|
|
76
|
-
classStartedOn:
|
|
77
|
-
trialHomeData:
|
|
78
|
-
worksheetNavigationPanel:
|
|
79
|
-
questionsRatingPanel:
|
|
80
|
-
onTrialInformationUpdate:
|
|
81
|
-
openEndClassModal:
|
|
82
|
-
studentAbsentInClass:
|
|
83
|
-
circleGames:
|
|
84
|
-
trialGameUrl:
|
|
85
|
-
handleInfoMessage:
|
|
86
|
-
onRemoveOptionalSlides:
|
|
87
|
-
classDuration:
|
|
88
|
-
classTimeAlertConfig:
|
|
58
|
+
teacherPanel: D,
|
|
59
|
+
studentPanel: T,
|
|
60
|
+
isTeacher: t,
|
|
61
|
+
slideConfig: A,
|
|
62
|
+
milestoneConfig: a,
|
|
63
|
+
formData: t ? r : s,
|
|
64
|
+
updateSlideConfig: d,
|
|
65
|
+
worksheet: R,
|
|
66
|
+
buttonState: B,
|
|
67
|
+
updateButtonState: V,
|
|
68
|
+
studentId: i,
|
|
69
|
+
teacherId: l,
|
|
70
|
+
classStartedOn: v,
|
|
71
|
+
trialHomeData: e,
|
|
72
|
+
worksheetNavigationPanel: y,
|
|
73
|
+
questionsRatingPanel: x,
|
|
74
|
+
onTrialInformationUpdate: G,
|
|
75
|
+
openEndClassModal: F,
|
|
76
|
+
studentAbsentInClass: O,
|
|
77
|
+
circleGames: M,
|
|
78
|
+
trialGameUrl: _,
|
|
79
|
+
handleInfoMessage: N,
|
|
80
|
+
onRemoveOptionalSlides: b,
|
|
81
|
+
classDuration: j,
|
|
82
|
+
classTimeAlertConfig: w
|
|
89
83
|
}),
|
|
90
84
|
[
|
|
85
|
+
D,
|
|
91
86
|
T,
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
B,
|
|
95
|
-
c,
|
|
96
|
-
r,
|
|
97
|
-
l,
|
|
87
|
+
t,
|
|
88
|
+
A,
|
|
98
89
|
a,
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
z,
|
|
90
|
+
r,
|
|
91
|
+
s,
|
|
102
92
|
d,
|
|
103
|
-
m,
|
|
104
93
|
R,
|
|
105
|
-
|
|
94
|
+
B,
|
|
95
|
+
V,
|
|
96
|
+
i,
|
|
97
|
+
l,
|
|
98
|
+
v,
|
|
99
|
+
e,
|
|
100
|
+
y,
|
|
106
101
|
x,
|
|
107
|
-
O,
|
|
108
|
-
N,
|
|
109
102
|
G,
|
|
110
103
|
F,
|
|
111
|
-
|
|
112
|
-
|
|
104
|
+
O,
|
|
105
|
+
M,
|
|
106
|
+
_,
|
|
107
|
+
N,
|
|
113
108
|
b,
|
|
114
109
|
j,
|
|
115
|
-
w
|
|
116
|
-
A
|
|
110
|
+
w
|
|
117
111
|
]
|
|
118
112
|
);
|
|
119
|
-
|
|
120
|
-
r &&
|
|
121
|
-
}, [
|
|
122
|
-
|
|
123
|
-
}, [
|
|
124
|
-
const
|
|
125
|
-
() =>
|
|
126
|
-
|
|
113
|
+
S(() => {
|
|
114
|
+
r && f && f(r);
|
|
115
|
+
}, [f, r]), S(() => {
|
|
116
|
+
c || u == null || u();
|
|
117
|
+
}, [C]);
|
|
118
|
+
const $ = L(
|
|
119
|
+
(n) => {
|
|
120
|
+
const { student: m, intel_student: Q } = n, { student_preference: W } = Q || {}, { preferences: k = [] } = W || {}, { name: X, grade: z } = m || {}, Z = !!se(a).find(
|
|
121
|
+
(te) => te.id === z
|
|
122
|
+
), ee = U(k, H.OBJECTIVES), E = U(
|
|
123
|
+
k,
|
|
124
|
+
H.POSITION,
|
|
125
|
+
!0
|
|
126
|
+
);
|
|
127
|
+
d({
|
|
128
|
+
studentTimezone: c,
|
|
129
|
+
name: X,
|
|
130
|
+
grade: Z ? z : "",
|
|
131
|
+
personalizedObjectives: ee,
|
|
132
|
+
personalizedPosition: E,
|
|
133
|
+
personalizedLevel: E[0] ? [ie[E[0]]] : []
|
|
134
|
+
});
|
|
135
|
+
},
|
|
136
|
+
[a, c, d]
|
|
127
137
|
);
|
|
128
|
-
return
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
});
|
|
134
|
-
}, [
|
|
135
|
-
M,
|
|
136
|
-
u,
|
|
137
|
-
a,
|
|
138
|
-
E,
|
|
139
|
-
L
|
|
140
|
-
]), g(() => {
|
|
141
|
-
e && a({
|
|
142
|
-
personalizedObjectives: V,
|
|
143
|
-
personalizedPosition: o,
|
|
144
|
-
personalizedLevel: o != null && o[0] ? [se[o[0]]] : []
|
|
145
|
-
});
|
|
146
|
-
}, [e, V, o, a]), /* @__PURE__ */ I(ie.Provider, { value: Z, children: /* @__PURE__ */ ee(ae, { $height: Y, $flexDirection: "row", $justifyContent: "center", $alignItems: "center", children: [
|
|
147
|
-
/* @__PURE__ */ I(ce, {}),
|
|
148
|
-
/* @__PURE__ */ I(de, {})
|
|
138
|
+
return S(() => {
|
|
139
|
+
t && e && $(e);
|
|
140
|
+
}, [c, $, e, t]), /* @__PURE__ */ h(le.Provider, { value: K, children: /* @__PURE__ */ ne(ae, { $height: J, $flexDirection: "row", $justifyContent: "center", $alignItems: "center", children: [
|
|
141
|
+
/* @__PURE__ */ h(de, {}),
|
|
142
|
+
/* @__PURE__ */ h(me, {})
|
|
149
143
|
] }) });
|
|
150
144
|
});
|
|
151
145
|
export {
|
|
152
|
-
|
|
146
|
+
Te as default
|
|
153
147
|
};
|
|
154
148
|
//# sourceMappingURL=trial-session-view.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"trial-session-view.js","sources":["../../../src/features/trial-session/trial-session-view.tsx"],"sourcesContent":["import type { ITrialCircleGameParams } from './comps/trial-circle-game/trial-circle-game-types';\nimport type {\n ITrialSessionContext,\n ITrialSessionViewProps,\n ITrialSessionFormFields,\n} from './trial-session-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { PREFERENCE_CATEGORY } from '../milestone/constants';\nimport { getGradesFromConfig } from '../milestone/create/milestone-create-helpers';\nimport FlexView from '../ui/layout/flex-view';\nimport { PREFERENCE_CODE_MAP } from './comps/student-feedback/student-feedback-constants';\nimport TrialSessionContext from './context/trial-session-context';\nimport { getPreferenceCodesByCategory } from './helper';\nimport { useButtonStateForLeftPanel } from './hooks/use-left-panel-button-state';\nimport LeftPanel from './left-panel';\nimport RightPanel from './right-panel';\n\nconst TrialSessionView: FC<ITrialSessionViewProps> = memo(props => {\n const {\n countryCode,\n userType,\n teacherPanel,\n studentPanel,\n trialGameUrl,\n formData: formDataProps,\n height = '100vh',\n trialHomeData,\n milestoneConfig,\n onFormDataChange,\n worksheet,\n studentId,\n teacherId,\n classStartedOn,\n worksheetNavigationPanel,\n questionsRatingPanel,\n studentAbsentInClass,\n openEndClassModal,\n onTrialInformationUpdate,\n onStudentTimezoneUpdate,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n studentTimezone,\n classTimeAlertConfig,\n } = props;\n const isTeacher = userType === 'TEACHER';\n const { pages: slides = [], student, intel_student: intelStudent } = trialHomeData;\n const { student_preference: studentPreference } = intelStudent || {};\n const { preferences = [] } = studentPreference || {};\n const { name: studentName, grade: studentGrade } = student || {};\n\n const [formData, setFormData] = useState<ITrialSessionFormFields | undefined>(formDataProps);\n const formDataToUse = isTeacher ? formData : formDataProps;\n const currentSlideId = formDataToUse?.id;\n\n const currentSlideConfig = useMemo(\n () => slides.find(config => config.id === currentSlideId) ?? slides[0]!,\n [currentSlideId, slides],\n );\n\n const objectives = useMemo(\n () => getPreferenceCodesByCategory(preferences, PREFERENCE_CATEGORY.OBJECTIVES),\n [preferences],\n );\n\n const positions = useMemo(\n () => getPreferenceCodesByCategory(preferences, PREFERENCE_CATEGORY.POSITION, true),\n [preferences],\n );\n\n const circleGames = useMemo(() => {\n const data = {\n circleConfig: trialHomeData.circle_trial_game_config,\n playerDetails: {\n userId: isTeacher ? teacherId : studentId,\n circle_username: trialHomeData[isTeacher ? 'teacher' : 'student'].circle_username,\n user_avatar: trialHomeData[isTeacher ? 'teacher' : 'student'].user_avatar,\n playerType: userType,\n countryCode: countryCode,\n },\n } as ITrialCircleGameParams;\n\n if (userType === 'STUDENT') {\n data.playerDetails.grade = trialHomeData.student.grade;\n }\n\n return data;\n }, [countryCode, isTeacher, studentId, teacherId, trialHomeData, userType]);\n\n const updateSlideConfig = useCallback((config: Partial<ITrialSessionFormFields>) => {\n setFormData(previousProps => {\n if (!previousProps) return config as ITrialSessionFormFields;\n\n return { ...previousProps, ...config };\n });\n }, []);\n const { buttonState, updateButtonState } = useButtonStateForLeftPanel();\n\n const contextValue = useMemo<ITrialSessionContext>(\n () => ({\n teacherPanel,\n studentPanel,\n isTeacher,\n slideConfig: currentSlideConfig,\n milestoneConfig,\n formData: isTeacher ? formData : formDataProps,\n updateSlideConfig,\n worksheet,\n buttonState,\n updateButtonState,\n studentId,\n teacherId,\n classStartedOn,\n trialHomeData,\n worksheetNavigationPanel,\n questionsRatingPanel,\n onTrialInformationUpdate,\n openEndClassModal,\n studentAbsentInClass,\n circleGames,\n trialGameUrl,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n classTimeAlertConfig,\n }),\n [\n teacherPanel,\n studentPanel,\n isTeacher,\n currentSlideConfig,\n milestoneConfig,\n formData,\n formDataProps,\n updateSlideConfig,\n worksheet,\n buttonState,\n updateButtonState,\n studentId,\n teacherId,\n classStartedOn,\n trialHomeData,\n worksheetNavigationPanel,\n questionsRatingPanel,\n onTrialInformationUpdate,\n openEndClassModal,\n studentAbsentInClass,\n circleGames,\n trialGameUrl,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n classTimeAlertConfig,\n ],\n );\n\n useEffect(() => {\n if (formData && onFormDataChange) {\n onFormDataChange(formData);\n }\n }, [onFormDataChange, formData]);\n\n useEffect(() => {\n if (!studentTimezone) onStudentTimezoneUpdate?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [currentSlideId]);\n\n const IsGradeExistInMilestoneConfig = useMemo(\n () => !!getGradesFromConfig(milestoneConfig).find(element => element.id === studentGrade),\n [milestoneConfig, studentGrade],\n );\n\n useEffect(() => {\n updateSlideConfig({\n studentTimezone,\n name: studentName,\n grade: IsGradeExistInMilestoneConfig ? studentGrade : '',\n });\n }, [\n studentName,\n studentGrade,\n updateSlideConfig,\n studentTimezone,\n IsGradeExistInMilestoneConfig,\n ]);\n\n useEffect(() => {\n if (isTeacher) {\n updateSlideConfig({\n personalizedObjectives: objectives,\n personalizedPosition: positions,\n personalizedLevel: positions?.[0]\n ? [PREFERENCE_CODE_MAP[positions[0] as keyof typeof PREFERENCE_CODE_MAP]]\n : [],\n });\n }\n }, [isTeacher, objectives, positions, updateSlideConfig]);\n\n return (\n <TrialSessionContext.Provider value={contextValue}>\n <FlexView $height={height} $flexDirection=\"row\" $justifyContent=\"center\" $alignItems=\"center\">\n <LeftPanel />\n <RightPanel />\n </FlexView>\n </TrialSessionContext.Provider>\n );\n});\n\nexport default TrialSessionView;\n"],"names":["TrialSessionView","memo","props","countryCode","userType","teacherPanel","studentPanel","trialGameUrl","formDataProps","height","trialHomeData","milestoneConfig","onFormDataChange","worksheet","studentId","teacherId","classStartedOn","worksheetNavigationPanel","questionsRatingPanel","studentAbsentInClass","openEndClassModal","onTrialInformationUpdate","onStudentTimezoneUpdate","handleInfoMessage","onRemoveOptionalSlides","classDuration","studentTimezone","classTimeAlertConfig","isTeacher","slides","student","intelStudent","studentPreference","preferences","studentName","studentGrade","formData","setFormData","useState","formDataToUse","currentSlideId","currentSlideConfig","useMemo","config","objectives","getPreferenceCodesByCategory","PREFERENCE_CATEGORY","positions","circleGames","data","updateSlideConfig","useCallback","previousProps","buttonState","updateButtonState","useButtonStateForLeftPanel","contextValue","useEffect","IsGradeExistInMilestoneConfig","getGradesFromConfig","element","PREFERENCE_CODE_MAP","jsx","TrialSessionContext","jsxs","FlexView","LeftPanel","RightPanel"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"trial-session-view.js","sources":["../../../src/features/trial-session/trial-session-view.tsx"],"sourcesContent":["import type { ITrialCircleGameParams } from './comps/trial-circle-game/trial-circle-game-types';\nimport type {\n ITrialSessionContext,\n ITrialSessionViewProps,\n ITrialSessionFormFields,\n ITrialHomeData,\n} from './trial-session-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { PREFERENCE_CATEGORY } from '../milestone/constants';\nimport { getGradesFromConfig } from '../milestone/create/milestone-create-helpers';\nimport FlexView from '../ui/layout/flex-view';\nimport { PREFERENCE_CODE_MAP } from './comps/student-feedback/student-feedback-constants';\nimport TrialSessionContext from './context/trial-session-context';\nimport { getPreferenceCodesByCategory } from './helper';\nimport { useButtonStateForLeftPanel } from './hooks/use-left-panel-button-state';\nimport LeftPanel from './left-panel';\nimport RightPanel from './right-panel';\n\nconst TrialSessionView: FC<ITrialSessionViewProps> = memo(props => {\n const {\n countryCode,\n userType,\n teacherPanel,\n studentPanel,\n trialGameUrl,\n formData: formDataProps,\n height = '100vh',\n trialHomeData,\n milestoneConfig,\n onFormDataChange,\n worksheet,\n studentId,\n teacherId,\n classStartedOn,\n worksheetNavigationPanel,\n questionsRatingPanel,\n studentAbsentInClass,\n openEndClassModal,\n onTrialInformationUpdate,\n onStudentTimezoneUpdate,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n studentTimezone,\n classTimeAlertConfig,\n } = props;\n const isTeacher = userType === 'TEACHER';\n const { pages: slides = [] } = trialHomeData;\n\n const [formData, setFormData] = useState<ITrialSessionFormFields | undefined>(formDataProps);\n const formDataToUse = isTeacher ? formData : formDataProps;\n const currentSlideId = formDataToUse?.id;\n\n const currentSlideConfig = useMemo(\n () => slides.find(config => config.id === currentSlideId) ?? slides[0]!,\n [currentSlideId, slides],\n );\n\n const circleGames = useMemo(() => {\n const data = {\n circleConfig: trialHomeData.circle_trial_game_config,\n playerDetails: {\n userId: isTeacher ? teacherId : studentId,\n circle_username: trialHomeData[isTeacher ? 'teacher' : 'student'].circle_username,\n user_avatar: trialHomeData[isTeacher ? 'teacher' : 'student'].user_avatar,\n playerType: userType,\n countryCode: countryCode,\n },\n } as ITrialCircleGameParams;\n\n if (userType === 'STUDENT') {\n data.playerDetails.grade = trialHomeData.student.grade;\n }\n\n return data;\n }, [countryCode, isTeacher, studentId, teacherId, trialHomeData, userType]);\n\n const updateSlideConfig = useCallback((config: Partial<ITrialSessionFormFields>) => {\n setFormData(previousProps => {\n if (!previousProps) return config as ITrialSessionFormFields;\n\n return { ...previousProps, ...config };\n });\n }, []);\n const { buttonState, updateButtonState } = useButtonStateForLeftPanel();\n\n const contextValue = useMemo<ITrialSessionContext>(\n () => ({\n teacherPanel,\n studentPanel,\n isTeacher,\n slideConfig: currentSlideConfig,\n milestoneConfig,\n formData: isTeacher ? formData : formDataProps,\n updateSlideConfig,\n worksheet,\n buttonState,\n updateButtonState,\n studentId,\n teacherId,\n classStartedOn,\n trialHomeData,\n worksheetNavigationPanel,\n questionsRatingPanel,\n onTrialInformationUpdate,\n openEndClassModal,\n studentAbsentInClass,\n circleGames,\n trialGameUrl,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n classTimeAlertConfig,\n }),\n [\n teacherPanel,\n studentPanel,\n isTeacher,\n currentSlideConfig,\n milestoneConfig,\n formData,\n formDataProps,\n updateSlideConfig,\n worksheet,\n buttonState,\n updateButtonState,\n studentId,\n teacherId,\n classStartedOn,\n trialHomeData,\n worksheetNavigationPanel,\n questionsRatingPanel,\n onTrialInformationUpdate,\n openEndClassModal,\n studentAbsentInClass,\n circleGames,\n trialGameUrl,\n handleInfoMessage,\n onRemoveOptionalSlides,\n classDuration,\n classTimeAlertConfig,\n ],\n );\n\n useEffect(() => {\n if (formData && onFormDataChange) {\n onFormDataChange(formData);\n }\n }, [onFormDataChange, formData]);\n\n useEffect(() => {\n if (!studentTimezone) onStudentTimezoneUpdate?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [currentSlideId]);\n\n const onRenderUpdateSlideConfig = useCallback(\n (homeData: ITrialHomeData) => {\n const { student, intel_student: intelStudent } = homeData;\n const { student_preference: studentPreference } = intelStudent || {};\n const { preferences = [] } = studentPreference || {};\n const { name: studentName, grade: studentGrade } = student || {};\n\n const IsGradeExistInMilestoneConfig = !!getGradesFromConfig(milestoneConfig).find(\n element => element.id === studentGrade,\n );\n\n const objectives = getPreferenceCodesByCategory(preferences, PREFERENCE_CATEGORY.OBJECTIVES);\n const position = getPreferenceCodesByCategory(\n preferences,\n PREFERENCE_CATEGORY.POSITION,\n true,\n );\n\n updateSlideConfig({\n studentTimezone,\n name: studentName,\n grade: IsGradeExistInMilestoneConfig ? studentGrade : '',\n personalizedObjectives: objectives,\n personalizedPosition: position,\n personalizedLevel: position[0]\n ? [PREFERENCE_CODE_MAP[position[0] as keyof typeof PREFERENCE_CODE_MAP]]\n : [],\n });\n },\n [milestoneConfig, studentTimezone, updateSlideConfig],\n );\n\n useEffect(() => {\n if (isTeacher && trialHomeData) {\n onRenderUpdateSlideConfig(trialHomeData);\n }\n }, [studentTimezone, onRenderUpdateSlideConfig, trialHomeData, isTeacher]);\n\n return (\n <TrialSessionContext.Provider value={contextValue}>\n <FlexView $height={height} $flexDirection=\"row\" $justifyContent=\"center\" $alignItems=\"center\">\n <LeftPanel />\n <RightPanel />\n </FlexView>\n </TrialSessionContext.Provider>\n );\n});\n\nexport default TrialSessionView;\n"],"names":["TrialSessionView","memo","props","countryCode","userType","teacherPanel","studentPanel","trialGameUrl","formDataProps","height","trialHomeData","milestoneConfig","onFormDataChange","worksheet","studentId","teacherId","classStartedOn","worksheetNavigationPanel","questionsRatingPanel","studentAbsentInClass","openEndClassModal","onTrialInformationUpdate","onStudentTimezoneUpdate","handleInfoMessage","onRemoveOptionalSlides","classDuration","studentTimezone","classTimeAlertConfig","isTeacher","slides","formData","setFormData","useState","formDataToUse","currentSlideId","currentSlideConfig","useMemo","config","circleGames","data","updateSlideConfig","useCallback","previousProps","buttonState","updateButtonState","useButtonStateForLeftPanel","contextValue","useEffect","onRenderUpdateSlideConfig","homeData","student","intelStudent","studentPreference","preferences","studentName","studentGrade","IsGradeExistInMilestoneConfig","getGradesFromConfig","element","objectives","getPreferenceCodesByCategory","PREFERENCE_CATEGORY","position","PREFERENCE_CODE_MAP","jsx","TrialSessionContext","jsxs","FlexView","LeftPanel","RightPanel"],"mappings":"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"}
|