@cuemath/leap 3.3.31 → 3.3.32-j2

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.
Files changed (76) hide show
  1. package/dist/features/auth/pla-signup/pla-analytics-events.js +7 -1
  2. package/dist/features/auth/pla-signup/pla-analytics-events.js.map +1 -1
  3. package/dist/features/auth/signup/circular-step-wrapper/circular-step-wrapper.js.map +1 -1
  4. package/dist/features/auth/signup/custom-input-field/custom-input-field.js +8 -8
  5. package/dist/features/auth/signup/custom-input-field/custom-input-field.js.map +1 -1
  6. package/dist/features/milestone/create/milestone-create-helpers.js +13 -7
  7. package/dist/features/milestone/create/milestone-create-helpers.js.map +1 -1
  8. package/dist/features/student-username/add/add-student-username-constants.js +6 -0
  9. package/dist/features/student-username/add/add-student-username-constants.js.map +1 -0
  10. package/dist/features/student-username/add/add-student-username-helpers.js +6 -0
  11. package/dist/features/student-username/add/add-student-username-helpers.js.map +1 -0
  12. package/dist/features/student-username/add/add-student-username-styled.js +10 -0
  13. package/dist/features/student-username/add/add-student-username-styled.js.map +1 -0
  14. package/dist/features/student-username/add/add-student-username.js +78 -0
  15. package/dist/features/student-username/add/add-student-username.js.map +1 -0
  16. package/dist/features/student-username/add/api/update-username.js +9 -0
  17. package/dist/features/student-username/add/api/update-username.js.map +1 -0
  18. package/dist/features/student-username/add/api/username-availability.js +10 -0
  19. package/dist/features/student-username/add/api/username-availability.js.map +1 -0
  20. package/dist/features/student-username/add/hooks/use-check-username-availability.js +41 -0
  21. package/dist/features/student-username/add/hooks/use-check-username-availability.js.map +1 -0
  22. package/dist/features/trial-session/api/teacher-availability.js +9 -0
  23. package/dist/features/trial-session/api/teacher-availability.js.map +1 -0
  24. package/dist/features/trial-session/comps/class-preference/class-preference.js +61 -49
  25. package/dist/features/trial-session/comps/class-preference/class-preference.js.map +1 -1
  26. package/dist/features/trial-session/comps/class-preference/helpers.js +28 -0
  27. package/dist/features/trial-session/comps/class-preference/helpers.js.map +1 -0
  28. package/dist/features/trial-session/comps/navigation-bar/index.js +25 -25
  29. package/dist/features/trial-session/comps/navigation-bar/index.js.map +1 -1
  30. package/dist/features/trial-session/comps/school-goals/school-goals.js +55 -53
  31. package/dist/features/trial-session/comps/school-goals/school-goals.js.map +1 -1
  32. package/dist/features/trial-session/comps/session-report/session-report.js +15 -15
  33. package/dist/features/trial-session/comps/session-report/session-report.js.map +1 -1
  34. package/dist/features/trial-session/comps/student-enrichment/student-enrichment.js +44 -43
  35. package/dist/features/trial-session/comps/student-enrichment/student-enrichment.js.map +1 -1
  36. package/dist/features/trial-session/comps/student-feedback/student-feedback-constants.js +5 -0
  37. package/dist/features/trial-session/comps/student-feedback/student-feedback-constants.js.map +1 -1
  38. package/dist/features/trial-session/comps/student-feedback/student-feedback.js +96 -51
  39. package/dist/features/trial-session/comps/student-feedback/student-feedback.js.map +1 -1
  40. package/dist/features/trial-session/comps/student-profile/student-profile.js +70 -63
  41. package/dist/features/trial-session/comps/student-profile/student-profile.js.map +1 -1
  42. package/dist/features/trial-session/comps/test-prep/test-prep.js +40 -39
  43. package/dist/features/trial-session/comps/test-prep/test-prep.js.map +1 -1
  44. package/dist/features/trial-session/helper.js +69 -53
  45. package/dist/features/trial-session/helper.js.map +1 -1
  46. package/dist/features/trial-session/hooks/use-slide-config-update.js +49 -0
  47. package/dist/features/trial-session/hooks/use-slide-config-update.js.map +1 -0
  48. package/dist/features/trial-session/hooks/use-trial-session-navigation.js +150 -130
  49. package/dist/features/trial-session/hooks/use-trial-session-navigation.js.map +1 -1
  50. package/dist/features/trial-session/trial-session-types.js.map +1 -1
  51. package/dist/features/trial-session/trial-session-view.js +103 -112
  52. package/dist/features/trial-session/trial-session-view.js.map +1 -1
  53. package/dist/features/ui/accordion/accordion-items/accordion-items.js +13 -13
  54. package/dist/features/ui/accordion/accordion-items/accordion-items.js.map +1 -1
  55. package/dist/features/utils/utils.js +1 -1
  56. package/dist/features/utils/utils.js.map +1 -1
  57. package/dist/index.d.ts +20 -4
  58. package/dist/index.js +32 -30
  59. package/dist/index.js.map +1 -1
  60. package/dist/node_modules/decode-uri-component/index.js.map +1 -0
  61. package/dist/node_modules/query-string/base.js +1 -1
  62. package/dist/node_modules/uuid/dist/esm-browser/native.js +7 -0
  63. package/dist/node_modules/uuid/dist/esm-browser/native.js.map +1 -0
  64. package/dist/node_modules/uuid/dist/esm-browser/rng.js +3 -2
  65. package/dist/node_modules/uuid/dist/esm-browser/rng.js.map +1 -1
  66. package/dist/node_modules/uuid/dist/esm-browser/stringify.js +6 -10
  67. package/dist/node_modules/uuid/dist/esm-browser/stringify.js.map +1 -1
  68. package/dist/node_modules/uuid/dist/esm-browser/v4.js +12 -9
  69. package/dist/node_modules/uuid/dist/esm-browser/v4.js.map +1 -1
  70. package/package.json +3 -2
  71. package/dist/node_modules/query-string/node_modules/decode-uri-component/index.js.map +0 -1
  72. package/dist/node_modules/uuid/dist/esm-browser/regex.js +0 -5
  73. package/dist/node_modules/uuid/dist/esm-browser/regex.js.map +0 -1
  74. package/dist/node_modules/uuid/dist/esm-browser/validate.js +0 -8
  75. package/dist/node_modules/uuid/dist/esm-browser/validate.js.map +0 -1
  76. /package/dist/node_modules/{query-string/node_modules/decode-uri-component → decode-uri-component}/index.js +0 -0
@@ -1,137 +1,128 @@
1
- import { jsx as D, jsxs as z } from "react/jsx-runtime";
2
- import { memo as J, useState as K, useMemo as m, useCallback as Q, useEffect as S } from "react";
3
- import { getGradesFromConfig as W } from "../milestone/create/milestone-create-helpers.js";
4
- import X from "../ui/layout/flex-view.js";
5
- import Y from "./context/trial-session-context.js";
6
- import { useButtonStateForLeftPanel as Z } from "./hooks/use-left-panel-button-state.js";
7
- import ee from "./left-panel/index.js";
8
- import te from "./right-panel/index.js";
9
- const de = J((H) => {
1
+ import { jsx as p, jsxs as O } from "react/jsx-runtime";
2
+ import { memo as q, useState as z, useMemo as h, useCallback as J, useEffect as C } from "react";
3
+ import K from "../ui/layout/flex-view.js";
4
+ import Q from "./context/trial-session-context.js";
5
+ import { useButtonStateForLeftPanel as W } from "./hooks/use-left-panel-button-state.js";
6
+ import { useSlideConfigUpdate as X } from "./hooks/use-slide-config-update.js";
7
+ import Y from "./left-panel/index.js";
8
+ import Z from "./right-panel/index.js";
9
+ const le = q((B) => {
10
10
  const {
11
- userType: r,
12
- teacherPanel: I,
13
- studentPanel: T,
14
- trialGameUrl: x,
15
- formData: s,
16
- height: L = "100vh",
17
- trialHomeData: t,
18
- milestoneConfig: o,
19
- onFormDataChange: u,
20
- worksheet: P,
21
- studentId: i,
22
- teacherId: l,
23
- classStartedOn: _,
24
- worksheetNavigationPanel: v,
25
- questionsRatingPanel: y,
26
- studentAbsentInClass: E,
27
- openEndClassModal: w,
28
- onTrialInformationUpdate: F,
29
- onStudentTimezoneUpdate: f,
30
- handleInfoMessage: G,
31
- onRemoveOptionalSlides: M,
32
- classDuration: R,
33
- studentTimezone: g,
34
- classTimeAlertConfig: $
35
- } = H, a = r === "TEACHER", { pages: p = [], student: O } = t, { name: b, grade: c } = O || {}, [n, q] = K(s), h = a ? n : s, C = h == null ? void 0 : h.id, j = m(
36
- () => p.find((e) => e.id === C) ?? p[0],
37
- [C, p]
38
- ), k = m(() => {
39
- const e = {
40
- circleConfig: t.circle_trial_game_config,
11
+ userType: n,
12
+ teacherPanel: S,
13
+ studentPanel: D,
14
+ trialGameUrl: I,
15
+ formData: o,
16
+ height: G = "100vh",
17
+ trialHomeData: e,
18
+ milestoneConfig: l,
19
+ onFormDataChange: c,
20
+ worksheet: T,
21
+ studentId: s,
22
+ teacherId: i,
23
+ classStartedOn: P,
24
+ worksheetNavigationPanel: x,
25
+ teacherClassroomId: H,
26
+ questionsRatingPanel: _,
27
+ studentAbsentInClass: v,
28
+ openEndClassModal: y,
29
+ onTrialInformationUpdate: w,
30
+ onStudentTimezoneUpdate: d,
31
+ handleInfoMessage: E,
32
+ onRemoveOptionalSlides: R,
33
+ classDuration: F,
34
+ studentTimezone: $,
35
+ classTimeAlertConfig: b
36
+ } = B, t = n === "TEACHER", { pages: m = [] } = e, [r, L] = z(o), f = t ? r : o, u = f == null ? void 0 : f.id, j = h(
37
+ () => m.find((a) => a.id === u) ?? m[0],
38
+ [u, m]
39
+ ), k = h(() => {
40
+ const a = {
41
+ circleConfig: e.circle_trial_game_config,
41
42
  playerDetails: {
42
- userId: a ? l : i,
43
- circle_username: t[a ? "teacher" : "student"].circle_username,
44
- user_avatar: t[a ? "teacher" : "student"].user_avatar,
45
- playerType: r
43
+ userId: t ? i : s,
44
+ circle_username: e[t ? "teacher" : "student"].circle_username,
45
+ user_avatar: e[t ? "teacher" : "student"].user_avatar,
46
+ playerType: n
46
47
  }
47
48
  };
48
- return r === "STUDENT" && (e.playerDetails.grade = t.student.grade), e;
49
- }, [a, i, l, t, r]), d = Q((e) => {
50
- q((B) => B ? { ...B, ...e } : e);
51
- }, []), { buttonState: A, updateButtonState: N } = Z(), U = m(
49
+ return n === "STUDENT" && (a.playerDetails.grade = e.student.grade), a;
50
+ }, [t, s, i, e, n]), g = J((a) => {
51
+ L((V) => V ? { ...V, ...a } : a);
52
+ }, []), { buttonState: A, updateButtonState: M } = W(), { onRenderUpdateSlideConfig: U } = X({
53
+ teacherClassroomId: H,
54
+ milestoneConfig: l,
55
+ studentTimezone: $,
56
+ updateSlideConfig: g
57
+ }), N = h(
52
58
  () => ({
53
- teacherPanel: I,
54
- studentPanel: T,
55
- isTeacher: a,
59
+ teacherPanel: S,
60
+ studentPanel: D,
61
+ isTeacher: t,
56
62
  slideConfig: j,
57
- milestoneConfig: o,
58
- formData: a ? n : s,
59
- updateSlideConfig: d,
60
- worksheet: P,
63
+ milestoneConfig: l,
64
+ formData: t ? r : o,
65
+ updateSlideConfig: g,
66
+ worksheet: T,
61
67
  buttonState: A,
62
- updateButtonState: N,
63
- studentId: i,
64
- teacherId: l,
65
- classStartedOn: _,
66
- trialHomeData: t,
67
- worksheetNavigationPanel: v,
68
- questionsRatingPanel: y,
69
- onTrialInformationUpdate: F,
70
- openEndClassModal: w,
71
- studentAbsentInClass: E,
68
+ updateButtonState: M,
69
+ studentId: s,
70
+ teacherId: i,
71
+ classStartedOn: P,
72
+ trialHomeData: e,
73
+ worksheetNavigationPanel: x,
74
+ questionsRatingPanel: _,
75
+ onTrialInformationUpdate: w,
76
+ openEndClassModal: y,
77
+ studentAbsentInClass: v,
72
78
  circleGames: k,
73
- trialGameUrl: x,
74
- handleInfoMessage: G,
75
- onRemoveOptionalSlides: M,
76
- classDuration: R,
77
- classTimeAlertConfig: $
79
+ trialGameUrl: I,
80
+ handleInfoMessage: E,
81
+ onRemoveOptionalSlides: R,
82
+ classDuration: F,
83
+ classTimeAlertConfig: b
78
84
  }),
79
85
  [
80
- I,
81
- T,
82
- a,
86
+ S,
87
+ D,
88
+ t,
83
89
  j,
90
+ l,
91
+ r,
84
92
  o,
85
- n,
86
- s,
87
- d,
88
- P,
93
+ g,
94
+ T,
89
95
  A,
90
- N,
96
+ M,
97
+ s,
91
98
  i,
92
- l,
99
+ P,
100
+ e,
101
+ x,
93
102
  _,
94
- t,
95
- v,
96
- y,
97
- F,
98
103
  w,
99
- E,
104
+ y,
105
+ v,
100
106
  k,
101
- x,
102
- G,
103
- M,
107
+ I,
108
+ E,
104
109
  R,
105
- $
110
+ F,
111
+ b
106
112
  ]
107
113
  );
108
- S(() => {
109
- n && u && u(n);
110
- }, [u, n]), S(() => {
111
- g || f == null || f();
112
- }, [C]);
113
- const V = m(
114
- () => !!W(o).find((e) => e.id === c),
115
- [o, c]
116
- );
117
- return S(() => {
118
- d({
119
- studentTimezone: g,
120
- name: b,
121
- grade: V ? c : ""
122
- });
123
- }, [
124
- b,
125
- c,
126
- d,
127
- g,
128
- V
129
- ]), /* @__PURE__ */ D(Y.Provider, { value: U, children: /* @__PURE__ */ z(X, { $height: L, $flexDirection: "row", $justifyContent: "center", $alignItems: "center", children: [
130
- /* @__PURE__ */ D(ee, {}),
131
- /* @__PURE__ */ D(te, {})
114
+ return C(() => {
115
+ r && c && c(r);
116
+ }, [c, r]), C(() => {
117
+ $ || d == null || d();
118
+ }, [u]), C(() => {
119
+ t && e && U(e);
120
+ }, [t, U, e]), /* @__PURE__ */ p(Q.Provider, { value: N, children: /* @__PURE__ */ O(K, { $height: G, $flexDirection: "row", $justifyContent: "center", $alignItems: "center", children: [
121
+ /* @__PURE__ */ p(Y, {}),
122
+ /* @__PURE__ */ p(Z, {})
132
123
  ] }) });
133
124
  });
134
125
  export {
135
- de as default
126
+ le as default
136
127
  };
137
128
  //# 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 { getGradesFromConfig } from '../milestone/create/milestone-create-helpers';\nimport FlexView from '../ui/layout/flex-view';\nimport TrialSessionContext from './context/trial-session-context';\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 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 } = trialHomeData;\n const { name: studentName, grade: studentGrade } = student || {};\n const [formData, setFormData] = useState<ITrialSessionFormFields | undefined>(formDataProps);\n const formDataToUse = isTeacher ? formData : formDataProps;\n const currentSlideId = formDataToUse?.id;\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 },\n } as ITrialCircleGameParams;\n\n if (userType === 'STUDENT') {\n data.playerDetails.grade = trialHomeData.student.grade;\n }\n\n return data;\n }, [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 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","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","studentName","studentGrade","formData","setFormData","useState","formDataToUse","currentSlideId","currentSlideConfig","useMemo","config","circleGames","data","updateSlideConfig","useCallback","previousProps","buttonState","updateButtonState","useButtonStateForLeftPanel","contextValue","useEffect","IsGradeExistInMilestoneConfig","getGradesFromConfig","element","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} from './trial-session-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport FlexView from '../ui/layout/flex-view';\nimport TrialSessionContext from './context/trial-session-context';\nimport { useButtonStateForLeftPanel } from './hooks/use-left-panel-button-state';\nimport { useSlideConfigUpdate } from './hooks/use-slide-config-update';\nimport LeftPanel from './left-panel';\nimport RightPanel from './right-panel';\n\nconst TrialSessionView: FC<ITrialSessionViewProps> = memo(props => {\n const {\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 teacherClassroomId,\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 },\n } as ITrialCircleGameParams;\n\n if (userType === 'STUDENT') {\n data.playerDetails.grade = trialHomeData.student.grade;\n }\n\n return data;\n }, [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 { onRenderUpdateSlideConfig } = useSlideConfigUpdate({\n teacherClassroomId,\n milestoneConfig,\n studentTimezone,\n updateSlideConfig,\n });\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 useEffect(() => {\n if (isTeacher && trialHomeData) {\n onRenderUpdateSlideConfig(trialHomeData);\n }\n }, [isTeacher, onRenderUpdateSlideConfig, trialHomeData]);\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","userType","teacherPanel","studentPanel","trialGameUrl","formDataProps","height","trialHomeData","milestoneConfig","onFormDataChange","worksheet","studentId","teacherId","classStartedOn","worksheetNavigationPanel","teacherClassroomId","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","onRenderUpdateSlideConfig","useSlideConfigUpdate","contextValue","useEffect","jsx","TrialSessionContext","jsxs","FlexView","LeftPanel","RightPanel"],"mappings":"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"}
@@ -1,22 +1,22 @@
1
1
  import { jsx as e, jsxs as t } from "react/jsx-runtime";
2
2
  import { memo as C, useCallback as p } from "react";
3
- import { useTheme as u } from "styled-components";
4
- import b from "../../layout/flex-view.js";
3
+ import { useTheme as b } from "styled-components";
4
+ import u from "../../layout/flex-view.js";
5
5
  import x from "../../separator/separator.js";
6
6
  import s from "../../text/text.js";
7
7
  import { EDeviceType as I } from "../../theme/constants.js";
8
8
  import { Container as g, ContentContainer as w, AccordionItemContainer as T, StyledPlusIcon as y, AccordionAnswer as B } from "./accordion-items-styled.js";
9
9
  const M = C((d) => {
10
- const { item: o, index: r, theme: m, refList: a, iconRef: f, visible: $, handleToggle: c } = d, { device: h } = u(), l = h === I.MOBILE, n = m === "dark", A = p(() => {
11
- c(r);
12
- }, [c, r]);
10
+ const { item: r, index: o, theme: m, refList: a, iconRef: f, visible: $, handleToggle: c } = d, { device: h } = b(), l = h === I.MOBILE, n = m === "dark", A = p(() => {
11
+ c(o);
12
+ }, [c, o]);
13
13
  return /* @__PURE__ */ e(
14
14
  g,
15
15
  {
16
16
  $flexDirection: "column",
17
17
  $justifyContent: "center",
18
18
  $alignItems: "flex-start",
19
- $index: r,
19
+ $index: o,
20
20
  $visible: $,
21
21
  onClick: A,
22
22
  $accordionBorderColor: n ? "WHITE" : "BLACK",
@@ -36,15 +36,15 @@ const M = C((d) => {
36
36
  $justifyContent: "space-between",
37
37
  $alignItems: "center",
38
38
  children: [
39
- /* @__PURE__ */ e(s, { $renderAs: "ab1", $renderOnMobileAs: "ab2", $color: n ? "WHITE" : "BLACK", children: o.accordionQuestion + o.accordionQuestion }),
40
- /* @__PURE__ */ e(b, { children: /* @__PURE__ */ e(
39
+ /* @__PURE__ */ e(s, { $renderAs: "ab1", $renderOnMobileAs: "ab2", $color: n ? "WHITE" : "BLACK", children: r.accordionQuestion }),
40
+ /* @__PURE__ */ e(u, { children: /* @__PURE__ */ e(
41
41
  y,
42
42
  {
43
43
  color: n ? "WHITE" : "BLACK",
44
44
  width: l ? 24 : 40,
45
45
  height: l ? 24 : 40,
46
46
  ref: (i) => {
47
- f[r] = i;
47
+ f[o] = i;
48
48
  }
49
49
  }
50
50
  ) })
@@ -55,19 +55,19 @@ const M = C((d) => {
55
55
  B,
56
56
  {
57
57
  ref: (i) => {
58
- a[r] = i;
58
+ a[o] = i;
59
59
  },
60
60
  children: [
61
61
  /* @__PURE__ */ e(x, { height: 12 }),
62
- typeof o.accordionAnswer == "string" ? /* @__PURE__ */ e(
62
+ typeof r.accordionAnswer == "string" ? /* @__PURE__ */ e(
63
63
  s,
64
64
  {
65
65
  $renderAs: "ub2-bold",
66
66
  $renderOnMobileAs: "ub3-bold",
67
67
  $color: n ? "WHITE" : "BLACK",
68
- children: o.accordionAnswer
68
+ children: r.accordionAnswer
69
69
  }
70
- ) : o.accordionAnswer
70
+ ) : r.accordionAnswer
71
71
  ]
72
72
  }
73
73
  )
@@ -1 +1 @@
1
- {"version":3,"file":"accordion-items.js","sources":["../../../../../src/features/ui/accordion/accordion-items/accordion-items.tsx"],"sourcesContent":["import type { AccordionItemProps } from '../accordion-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport FlexView from '../../layout/flex-view';\nimport Separator from '../../separator/separator';\nimport Text from '../../text/text';\nimport { EDeviceType } from '../../theme/constants';\nimport * as Styled from './accordion-items-styled';\n\nconst AccordionItem: FC<AccordionItemProps> = memo(props => {\n const { item, index, theme, refList, iconRef, visible, handleToggle } = props;\n const { device } = useTheme();\n const isMobile = device === EDeviceType.MOBILE;\n const isDarkTheme = theme === 'dark';\n\n const handleClick = useCallback(() => {\n handleToggle(index);\n }, [handleToggle, index]);\n\n return (\n <Styled.Container\n $flexDirection=\"column\"\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $index={index}\n $visible={visible}\n onClick={handleClick}\n $accordionBorderColor={isDarkTheme ? 'WHITE' : 'BLACK'}\n >\n <Styled.ContentContainer\n $flexDirection=\"column\"\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $gap={24}\n >\n <Styled.AccordionItemContainer\n $width=\"100%\"\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n >\n <Text $renderAs=\"ab1\" $renderOnMobileAs=\"ab2\" $color={isDarkTheme ? 'WHITE' : 'BLACK'}>\n {item.accordionQuestion + item.accordionQuestion}\n </Text>\n <FlexView>\n <Styled.StyledPlusIcon\n color={isDarkTheme ? 'WHITE' : 'BLACK'}\n width={isMobile ? 24 : 40}\n height={isMobile ? 24 : 40}\n ref={node => {\n iconRef[index] = node;\n }}\n />\n </FlexView>\n </Styled.AccordionItemContainer>\n\n <Styled.AccordionAnswer\n ref={node => {\n refList[index] = node;\n }}\n >\n <Separator height={12} />\n {typeof item.accordionAnswer === 'string' ? (\n <Text\n $renderAs=\"ub2-bold\"\n $renderOnMobileAs=\"ub3-bold\"\n $color={isDarkTheme ? 'WHITE' : 'BLACK'}\n >\n {item.accordionAnswer}\n </Text>\n ) : (\n item.accordionAnswer\n )}\n </Styled.AccordionAnswer>\n </Styled.ContentContainer>\n </Styled.Container>\n );\n});\n\nexport default AccordionItem;\n"],"names":["AccordionItem","memo","props","item","index","theme","refList","iconRef","visible","handleToggle","device","useTheme","isMobile","EDeviceType","isDarkTheme","handleClick","useCallback","jsx","Styled.Container","jsxs","Styled.ContentContainer","Styled.AccordionItemContainer","Text","FlexView","Styled.StyledPlusIcon","node","Styled.AccordionAnswer","Separator"],"mappings":";;;;;;;;AAYM,MAAAA,IAAwCC,EAAK,CAASC,MAAA;AACpD,QAAA,EAAE,MAAAC,GAAM,OAAAC,GAAO,OAAAC,GAAO,SAAAC,GAAS,SAAAC,GAAS,SAAAC,GAAS,cAAAC,EAAiB,IAAAP,GAClE,EAAE,QAAAQ,MAAWC,KACbC,IAAWF,MAAWG,EAAY,QAClCC,IAAcT,MAAU,QAExBU,IAAcC,EAAY,MAAM;AACpC,IAAAP,EAAaL,CAAK;AAAA,EAAA,GACjB,CAACK,GAAcL,CAAK,CAAC;AAGtB,SAAA,gBAAAa;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,gBAAe;AAAA,MACf,iBAAgB;AAAA,MAChB,aAAY;AAAA,MACZ,QAAQd;AAAA,MACR,UAAUI;AAAA,MACV,SAASO;AAAA,MACT,uBAAuBD,IAAc,UAAU;AAAA,MAE/C,UAAA,gBAAAK;AAAA,QAACC;AAAAA,QAAA;AAAA,UACC,gBAAe;AAAA,UACf,iBAAgB;AAAA,UAChB,aAAY;AAAA,UACZ,MAAM;AAAA,UAEN,UAAA;AAAA,YAAA,gBAAAD;AAAA,cAACE;AAAAA,cAAA;AAAA,gBACC,QAAO;AAAA,gBACP,gBAAe;AAAA,gBACf,iBAAgB;AAAA,gBAChB,aAAY;AAAA,gBAEZ,UAAA;AAAA,kBAAA,gBAAAJ,EAACK,GAAK,EAAA,WAAU,OAAM,mBAAkB,OAAM,QAAQR,IAAc,UAAU,SAC3E,UAAAX,EAAK,oBAAoBA,EAAK,mBACjC;AAAA,oCACCoB,GACC,EAAA,UAAA,gBAAAN;AAAA,oBAACO;AAAAA,oBAAA;AAAA,sBACC,OAAOV,IAAc,UAAU;AAAA,sBAC/B,OAAOF,IAAW,KAAK;AAAA,sBACvB,QAAQA,IAAW,KAAK;AAAA,sBACxB,KAAK,CAAQa,MAAA;AACX,wBAAAlB,EAAQH,CAAK,IAAIqB;AAAA,sBACnB;AAAA,oBAAA;AAAA,kBAAA,GAEJ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACF;AAAA,YAEA,gBAAAN;AAAA,cAACO;AAAAA,cAAA;AAAA,gBACC,KAAK,CAAQD,MAAA;AACX,kBAAAnB,EAAQF,CAAK,IAAIqB;AAAA,gBACnB;AAAA,gBAEA,UAAA;AAAA,kBAAC,gBAAAR,EAAAU,GAAA,EAAU,QAAQ,GAAI,CAAA;AAAA,kBACtB,OAAOxB,EAAK,mBAAoB,WAC/B,gBAAAc;AAAA,oBAACK;AAAA,oBAAA;AAAA,sBACC,WAAU;AAAA,sBACV,mBAAkB;AAAA,sBAClB,QAAQR,IAAc,UAAU;AAAA,sBAE/B,UAAKX,EAAA;AAAA,oBAAA;AAAA,sBAGRA,EAAK;AAAA,gBAAA;AAAA,cAAA;AAAA,YAET;AAAA,UAAA;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;"}
1
+ {"version":3,"file":"accordion-items.js","sources":["../../../../../src/features/ui/accordion/accordion-items/accordion-items.tsx"],"sourcesContent":["import type { AccordionItemProps } from '../accordion-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport FlexView from '../../layout/flex-view';\nimport Separator from '../../separator/separator';\nimport Text from '../../text/text';\nimport { EDeviceType } from '../../theme/constants';\nimport * as Styled from './accordion-items-styled';\n\nconst AccordionItem: FC<AccordionItemProps> = memo(props => {\n const { item, index, theme, refList, iconRef, visible, handleToggle } = props;\n const { device } = useTheme();\n const isMobile = device === EDeviceType.MOBILE;\n const isDarkTheme = theme === 'dark';\n\n const handleClick = useCallback(() => {\n handleToggle(index);\n }, [handleToggle, index]);\n\n return (\n <Styled.Container\n $flexDirection=\"column\"\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $index={index}\n $visible={visible}\n onClick={handleClick}\n $accordionBorderColor={isDarkTheme ? 'WHITE' : 'BLACK'}\n >\n <Styled.ContentContainer\n $flexDirection=\"column\"\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $gap={24}\n >\n <Styled.AccordionItemContainer\n $width=\"100%\"\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n >\n <Text $renderAs=\"ab1\" $renderOnMobileAs=\"ab2\" $color={isDarkTheme ? 'WHITE' : 'BLACK'}>\n {item.accordionQuestion}\n </Text>\n <FlexView>\n <Styled.StyledPlusIcon\n color={isDarkTheme ? 'WHITE' : 'BLACK'}\n width={isMobile ? 24 : 40}\n height={isMobile ? 24 : 40}\n ref={node => {\n iconRef[index] = node;\n }}\n />\n </FlexView>\n </Styled.AccordionItemContainer>\n\n <Styled.AccordionAnswer\n ref={node => {\n refList[index] = node;\n }}\n >\n <Separator height={12} />\n {typeof item.accordionAnswer === 'string' ? (\n <Text\n $renderAs=\"ub2-bold\"\n $renderOnMobileAs=\"ub3-bold\"\n $color={isDarkTheme ? 'WHITE' : 'BLACK'}\n >\n {item.accordionAnswer}\n </Text>\n ) : (\n item.accordionAnswer\n )}\n </Styled.AccordionAnswer>\n </Styled.ContentContainer>\n </Styled.Container>\n );\n});\n\nexport default AccordionItem;\n"],"names":["AccordionItem","memo","props","item","index","theme","refList","iconRef","visible","handleToggle","device","useTheme","isMobile","EDeviceType","isDarkTheme","handleClick","useCallback","jsx","Styled.Container","jsxs","Styled.ContentContainer","Styled.AccordionItemContainer","Text","FlexView","Styled.StyledPlusIcon","node","Styled.AccordionAnswer","Separator"],"mappings":";;;;;;;;AAYM,MAAAA,IAAwCC,EAAK,CAASC,MAAA;AACpD,QAAA,EAAE,MAAAC,GAAM,OAAAC,GAAO,OAAAC,GAAO,SAAAC,GAAS,SAAAC,GAAS,SAAAC,GAAS,cAAAC,EAAiB,IAAAP,GAClE,EAAE,QAAAQ,MAAWC,KACbC,IAAWF,MAAWG,EAAY,QAClCC,IAAcT,MAAU,QAExBU,IAAcC,EAAY,MAAM;AACpC,IAAAP,EAAaL,CAAK;AAAA,EAAA,GACjB,CAACK,GAAcL,CAAK,CAAC;AAGtB,SAAA,gBAAAa;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,gBAAe;AAAA,MACf,iBAAgB;AAAA,MAChB,aAAY;AAAA,MACZ,QAAQd;AAAA,MACR,UAAUI;AAAA,MACV,SAASO;AAAA,MACT,uBAAuBD,IAAc,UAAU;AAAA,MAE/C,UAAA,gBAAAK;AAAA,QAACC;AAAAA,QAAA;AAAA,UACC,gBAAe;AAAA,UACf,iBAAgB;AAAA,UAChB,aAAY;AAAA,UACZ,MAAM;AAAA,UAEN,UAAA;AAAA,YAAA,gBAAAD;AAAA,cAACE;AAAAA,cAAA;AAAA,gBACC,QAAO;AAAA,gBACP,gBAAe;AAAA,gBACf,iBAAgB;AAAA,gBAChB,aAAY;AAAA,gBAEZ,UAAA;AAAA,kBAAC,gBAAAJ,EAAAK,GAAA,EAAK,WAAU,OAAM,mBAAkB,OAAM,QAAQR,IAAc,UAAU,SAC3E,UAAAX,EAAK,kBACR,CAAA;AAAA,oCACCoB,GACC,EAAA,UAAA,gBAAAN;AAAA,oBAACO;AAAAA,oBAAA;AAAA,sBACC,OAAOV,IAAc,UAAU;AAAA,sBAC/B,OAAOF,IAAW,KAAK;AAAA,sBACvB,QAAQA,IAAW,KAAK;AAAA,sBACxB,KAAK,CAAQa,MAAA;AACX,wBAAAlB,EAAQH,CAAK,IAAIqB;AAAA,sBACnB;AAAA,oBAAA;AAAA,kBAAA,GAEJ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACF;AAAA,YAEA,gBAAAN;AAAA,cAACO;AAAAA,cAAA;AAAA,gBACC,KAAK,CAAQD,MAAA;AACX,kBAAAnB,EAAQF,CAAK,IAAIqB;AAAA,gBACnB;AAAA,gBAEA,UAAA;AAAA,kBAAC,gBAAAR,EAAAU,GAAA,EAAU,QAAQ,GAAI,CAAA;AAAA,kBACtB,OAAOxB,EAAK,mBAAoB,WAC/B,gBAAAc;AAAA,oBAACK;AAAA,oBAAA;AAAA,sBACC,WAAU;AAAA,sBACV,mBAAkB;AAAA,sBAClB,QAAQR,IAAc,UAAU;AAAA,sBAE/B,UAAKX,EAAA;AAAA,oBAAA;AAAA,sBAGRA,EAAK;AAAA,gBAAA;AAAA,cAAA;AAAA,YAET;AAAA,UAAA;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;"}
@@ -1,7 +1,7 @@
1
1
  import { addYears as s } from "../../node_modules/date-fns/addYears.js";
2
2
  const i = (r) => Array.isArray(r) && r.length > 0, c = (r) => {
3
3
  const t = (a) => a.toString().padStart(2, "0"), o = Math.floor(r / 3600), e = Math.floor(r % 3600 / 60), n = r % 60;
4
- return o > 0 ? `${t(o)}:${t(e)}:${t(n)}` : `${t(e)}:${t(n)}`;
4
+ return o > 0 ? `${t(o)}:${t(e)}:${t(n)}` : `${t(e)}:${t(Math.abs(n))}`;
5
5
  }, l = (r) => {
6
6
  let t = null;
7
7
  return { promise: new Promise((e) => {
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../../../src/features/utils/utils.ts"],"sourcesContent":["import { addYears } from 'date-fns';\n\nconst isNonEmptyArray = (array: unknown) => {\n return Array.isArray(array) && array.length > 0;\n};\n\n// format the time in HH:MM:SS\nconst formatTimeInHHMMSS = (seconds: number) => {\n const pad = (num: number) => num.toString().padStart(2, '0');\n\n const h = Math.floor(seconds / 3600);\n const m = Math.floor((seconds % 3600) / 60);\n const s = seconds % 60;\n\n return h > 0 ? `${pad(h)}:${pad(m)}:${pad(s)}` : `${pad(m)}:${pad(s)}`;\n};\n\nconst delay = (delayInMs: number) => {\n let timerId: ReturnType<typeof setTimeout> | null = null;\n const promise = new Promise(res => {\n timerId = setTimeout(() => {\n res('resolved');\n }, delayInMs);\n });\n\n return { promise, timerId };\n};\n\nconst epochTimestampAfterOneYear = () => {\n const today = new Date();\n const oneYearLater = addYears(today, 1);\n\n return Math.floor(oneYearLater.getTime() / 1000);\n};\n\nexport { isNonEmptyArray, formatTimeInHHMMSS, delay, epochTimestampAfterOneYear };\n"],"names":["isNonEmptyArray","array","formatTimeInHHMMSS","seconds","pad","num","h","m","s","delay","delayInMs","timerId","res","epochTimestampAfterOneYear","oneYearLater","addYears"],"mappings":";AAEM,MAAAA,IAAkB,CAACC,MAChB,MAAM,QAAQA,CAAK,KAAKA,EAAM,SAAS,GAI1CC,IAAqB,CAACC,MAAoB;AACxC,QAAAC,IAAM,CAACC,MAAgBA,EAAI,WAAW,SAAS,GAAG,GAAG,GAErDC,IAAI,KAAK,MAAMH,IAAU,IAAI,GAC7BI,IAAI,KAAK,MAAOJ,IAAU,OAAQ,EAAE,GACpCK,IAAIL,IAAU;AAEb,SAAAG,IAAI,IAAI,GAAGF,EAAIE,CAAC,CAAC,IAAIF,EAAIG,CAAC,CAAC,IAAIH,EAAII,CAAC,CAAC,KAAK,GAAGJ,EAAIG,CAAC,CAAC,IAAIH,EAAII,CAAC,CAAC;AACtE,GAEMC,IAAQ,CAACC,MAAsB;AACnC,MAAIC,IAAgD;AAO7C,SAAA,EAAE,SANO,IAAI,QAAQ,CAAOC,MAAA;AACjC,IAAAD,IAAU,WAAW,MAAM;AACzB,MAAAC,EAAI,UAAU;AAAA,OACbF,CAAS;AAAA,EAAA,CACb,GAEiB,SAAAC;AACpB,GAEME,IAA6B,MAAM;AAEjC,QAAAC,IAAeC,sBADH,QACmB,CAAC;AAEtC,SAAO,KAAK,MAAMD,EAAa,YAAY,GAAI;AACjD;"}
1
+ {"version":3,"file":"utils.js","sources":["../../../src/features/utils/utils.ts"],"sourcesContent":["import { addYears } from 'date-fns';\n\nconst isNonEmptyArray = (array: unknown) => {\n return Array.isArray(array) && array.length > 0;\n};\n\n// format the time in HH:MM:SS\nconst formatTimeInHHMMSS = (seconds: number) => {\n const pad = (num: number) => num.toString().padStart(2, '0');\n\n const h = Math.floor(seconds / 3600);\n const m = Math.floor((seconds % 3600) / 60);\n const s = seconds % 60;\n\n return h > 0 ? `${pad(h)}:${pad(m)}:${pad(s)}` : `${pad(m)}:${pad(Math.abs(s))}`;\n};\n\nconst delay = (delayInMs: number) => {\n let timerId: ReturnType<typeof setTimeout> | null = null;\n const promise = new Promise(res => {\n timerId = setTimeout(() => {\n res('resolved');\n }, delayInMs);\n });\n\n return { promise, timerId };\n};\n\nconst epochTimestampAfterOneYear = () => {\n const today = new Date();\n const oneYearLater = addYears(today, 1);\n\n return Math.floor(oneYearLater.getTime() / 1000);\n};\n\nexport { isNonEmptyArray, formatTimeInHHMMSS, delay, epochTimestampAfterOneYear };\n"],"names":["isNonEmptyArray","array","formatTimeInHHMMSS","seconds","pad","num","h","m","s","delay","delayInMs","timerId","res","epochTimestampAfterOneYear","oneYearLater","addYears"],"mappings":";AAEM,MAAAA,IAAkB,CAACC,MAChB,MAAM,QAAQA,CAAK,KAAKA,EAAM,SAAS,GAI1CC,IAAqB,CAACC,MAAoB;AACxC,QAAAC,IAAM,CAACC,MAAgBA,EAAI,WAAW,SAAS,GAAG,GAAG,GAErDC,IAAI,KAAK,MAAMH,IAAU,IAAI,GAC7BI,IAAI,KAAK,MAAOJ,IAAU,OAAQ,EAAE,GACpCK,IAAIL,IAAU;AAEb,SAAAG,IAAI,IAAI,GAAGF,EAAIE,CAAC,CAAC,IAAIF,EAAIG,CAAC,CAAC,IAAIH,EAAII,CAAC,CAAC,KAAK,GAAGJ,EAAIG,CAAC,CAAC,IAAIH,EAAI,KAAK,IAAII,CAAC,CAAC,CAAC;AAChF,GAEMC,IAAQ,CAACC,MAAsB;AACnC,MAAIC,IAAgD;AAO7C,SAAA,EAAE,SANO,IAAI,QAAQ,CAAOC,MAAA;AACjC,IAAAD,IAAU,WAAW,MAAM;AACzB,MAAAC,EAAI,UAAU;AAAA,OACbF,CAAS;AAAA,EAAA,CACb,GAEiB,SAAAC;AACpB,GAEME,IAA6B,MAAM;AAEjC,QAAAC,IAAeC,sBADH,QACmB,CAAC;AAEtC,SAAO,KAAK,MAAMD,EAAa,YAAY,GAAI;AACjD;"}
package/dist/index.d.ts CHANGED
@@ -70,6 +70,8 @@ export declare const AchievementNotShareReasonModal: React_2.FC<IShareInstructio
70
70
 
71
71
  export declare const AchievementShareInstructionModal: React_2.FC<IShareInstructionModalProps>;
72
72
 
73
+ export declare const AddStudentUsername: NamedExoticComponent<IAddStudentUsernameProps>;
74
+
73
75
  export declare const AfternoonIcon: React.FC<React.SVGProps<SVGSVGElement>>;
74
76
 
75
77
  export declare const AlertIcon: React_2.FC<React_2.SVGProps<SVGSVGElement>>;
@@ -831,6 +833,12 @@ declare interface IActionData {
831
833
  dimension?: IViewport;
832
834
  }
833
835
 
836
+ declare interface IAddStudentUsernameProps {
837
+ studentId: string;
838
+ onSuccess: (username: string) => void;
839
+ onGoBack: () => void;
840
+ }
841
+
834
842
  declare interface IAnimatedArcProps {
835
843
  radius: number;
836
844
  strokeWidth: number;
@@ -2564,7 +2572,7 @@ declare interface IMilestoneCardPermissions {
2564
2572
  visible_tabs: string[];
2565
2573
  }
2566
2574
 
2567
- declare interface IMilestoneConfig {
2575
+ export declare interface IMilestoneConfig {
2568
2576
  action_plan: Record<'green' | 'red' | 'yellow', {
2569
2577
  share_message_template: string;
2570
2578
  }>;
@@ -3156,12 +3164,13 @@ export declare interface IPostGameStatsRef {
3156
3164
  declare interface IPreferencesCurriculumMap {
3157
3165
  course_stream: TCourseStream;
3158
3166
  is_live: boolean;
3159
- preference_category: TPreferenceCategory;
3167
+ preference_category: TLearningPreferenceCategory;
3160
3168
  preference_code: string;
3161
3169
  preference_grades: string[];
3162
3170
  preference_name: string;
3163
3171
  text_input_needed?: boolean;
3164
3172
  preference_description?: string;
3173
+ lottie_key?: string;
3165
3174
  }
3166
3175
 
3167
3176
  export declare interface IPreviewWorksheetModel {
@@ -4158,6 +4167,7 @@ export declare interface ITrialSessionFormFields {
4158
4167
  personalizedFocus?: string[];
4159
4168
  personalizedBehaviors?: string[];
4160
4169
  personalizedObjectives?: string[];
4170
+ personalizedPosition?: string[];
4161
4171
  isCircleGamePlayed?: boolean;
4162
4172
  isCirclePuzzleSolved?: boolean;
4163
4173
  isCircleSkillCompleted?: boolean;
@@ -5222,6 +5232,12 @@ export declare enum PLA_ANALYTICS_EVENTS {
5222
5232
  SLOT_DATE_SELECTED = "slot_date_selected",
5223
5233
  SLOT_TIME_SELECTED = "slot_time_selected",
5224
5234
  TUTOR_CHANGE_REASON_SELECTED = "tutor_change_reason_selected",
5235
+ SUBSCRIPTION_INTENT_FAILED = "subscription_intent_failed",
5236
+ SUBSCRIPTION_INTENT_CREATED = "subscription_intent_created",
5237
+ STRIPE_PAYMENT_ELEMENT_READY = "stripe_payment_element_ready",
5238
+ STRIPE_PAYMENT_FAILED = "stripe_payment_failed",
5239
+ STRIPE_PAYMENT_SUCCESS = "stripe_payment_success",
5240
+ PAYMENT_PLAN_SELECTED = "payment_plan_selected",
5225
5241
  SUBSCRIPTION_CANCELLATION_FAILED = "subscription_cancellation_failed",
5226
5242
  SUBSCRIPTION_CANCELLATION_SUCCESSFUL = "subscription_cancellation_successful"
5227
5243
  }
@@ -6224,6 +6240,8 @@ export declare type TJourneyId = JOURNEY_ID_STUDENT | JOURNEY_ID_TEACHER;
6224
6240
 
6225
6241
  declare type TLayerKey = 'layer-1' | 'layer-2' | 'layer-3' | 'layer-4';
6226
6242
 
6243
+ export declare type TLearningPreferenceCategory = (typeof PREFERENCE_CATEGORY)[keyof typeof PREFERENCE_CATEGORY];
6244
+
6227
6245
  declare type TLearnosityPreloaderContextValue = {
6228
6246
  scriptStatus: Omit<TScriptStatus, 'loaded'>;
6229
6247
  defaultAPIURL: string;
@@ -6509,8 +6527,6 @@ declare type TPreference = {
6509
6527
  selectedTime: string;
6510
6528
  };
6511
6529
 
6512
- declare type TPreferenceCategory = (typeof PREFERENCE_CATEGORY)[keyof typeof PREFERENCE_CATEGORY];
6513
-
6514
6530
  declare type TProfileHighlight = {
6515
6531
  illustration: string;
6516
6532
  background: TColorNames;