@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 I, jsxs as ee } from "react/jsx-runtime";
2
- import { memo as te, useState as ne, useMemo as s, useCallback as re, useEffect as g } from "react";
3
- import { PREFERENCE_CATEGORY as q } from "../milestone/constants.js";
4
- import { getGradesFromConfig as oe } from "../milestone/create/milestone-create-helpers.js";
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 se } from "./comps/student-feedback/student-feedback-constants.js";
7
- import ie from "./context/trial-session-context.js";
8
- import { getPreferenceCodesByCategory as J } from "./helper.js";
9
- import { useButtonStateForLeftPanel as le } from "./hooks/use-left-panel-button-state.js";
10
- import ce from "./left-panel/index.js";
11
- import de from "./right-panel/index.js";
12
- const De = te((U) => {
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: D,
15
- userType: i,
16
- teacherPanel: T,
17
- studentPanel: _,
18
- trialGameUrl: v,
19
- formData: l,
20
- height: Y = "100vh",
21
- trialHomeData: n,
22
- milestoneConfig: c,
23
- onFormDataChange: p,
24
- worksheet: y,
25
- studentId: d,
26
- teacherId: m,
27
- classStartedOn: R,
28
- worksheetNavigationPanel: x,
29
- questionsRatingPanel: O,
30
- studentAbsentInClass: F,
31
- openEndClassModal: G,
32
- onTrialInformationUpdate: N,
33
- onStudentTimezoneUpdate: C,
34
- handleInfoMessage: b,
35
- onRemoveOptionalSlides: j,
36
- classDuration: w,
37
- studentTimezone: E,
38
- classTimeAlertConfig: A
39
- } = U, e = i === "TEACHER", { pages: h = [], student: K, intel_student: Q } = n, { student_preference: W } = Q || {}, { preferences: f = [] } = W || {}, { name: M, grade: u } = K || {}, [r, X] = ne(l), P = e ? r : l, S = P == null ? void 0 : P.id, B = s(
40
- () => h.find((t) => t.id === S) ?? h[0],
41
- [S, h]
42
- ), V = s(
43
- () => J(f, q.OBJECTIVES),
44
- [f]
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: e ? m : d,
53
- circle_username: n[e ? "teacher" : "student"].circle_username,
54
- user_avatar: n[e ? "teacher" : "student"].user_avatar,
55
- playerType: i,
56
- countryCode: D
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 i === "STUDENT" && (t.playerDetails.grade = n.student.grade), t;
60
- }, [D, e, d, m, n, i]), a = re((t) => {
61
- X((H) => H ? { ...H, ...t } : t);
62
- }, []), { buttonState: k, updateButtonState: z } = le(), Z = s(
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: T,
65
- studentPanel: _,
66
- isTeacher: e,
67
- slideConfig: B,
68
- milestoneConfig: c,
69
- formData: e ? r : l,
70
- updateSlideConfig: a,
71
- worksheet: y,
72
- buttonState: k,
73
- updateButtonState: z,
74
- studentId: d,
75
- teacherId: m,
76
- classStartedOn: R,
77
- trialHomeData: n,
78
- worksheetNavigationPanel: x,
79
- questionsRatingPanel: O,
80
- onTrialInformationUpdate: N,
81
- openEndClassModal: G,
82
- studentAbsentInClass: F,
83
- circleGames: $,
84
- trialGameUrl: v,
85
- handleInfoMessage: b,
86
- onRemoveOptionalSlides: j,
87
- classDuration: w,
88
- classTimeAlertConfig: A
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
- e,
94
- B,
95
- c,
96
- r,
97
- l,
87
+ t,
88
+ A,
98
89
  a,
99
- y,
100
- k,
101
- z,
90
+ r,
91
+ s,
102
92
  d,
103
- m,
104
93
  R,
105
- n,
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
- v,
104
+ O,
105
+ M,
106
+ _,
107
+ N,
113
108
  b,
114
109
  j,
115
- w,
116
- A
110
+ w
117
111
  ]
118
112
  );
119
- g(() => {
120
- r && p && p(r);
121
- }, [p, r]), g(() => {
122
- E || C == null || C();
123
- }, [S]);
124
- const L = s(
125
- () => !!oe(c).find((t) => t.id === u),
126
- [c, u]
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 g(() => {
129
- a({
130
- studentTimezone: E,
131
- name: M,
132
- grade: L ? u : ""
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
- De as default
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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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cuemath/leap",
3
- "version": "3.3.11-link.0",
3
+ "version": "3.3.11-link.2",
4
4
  "type": "module",
5
5
  "files": [
6
6
  "dist"