@cuemath/leap 4.1.1-beta.5 → 4.1.1-link.0

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 (78) hide show
  1. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +27 -25
  2. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  3. package/dist/features/chapters/chapters-list/chapters-list.js +53 -43
  4. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  5. package/dist/features/chapters-v2/chapter-details/chapter-details.js +70 -68
  6. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -1
  7. package/dist/features/journey/journey-id/journey-id-teacher.js +1 -1
  8. package/dist/features/journey/journey-id/journey-id-teacher.js.map +1 -1
  9. package/dist/features/journey/mocks/chapter-page-journey-mock-data.js +1 -1
  10. package/dist/features/journey/mocks/chapter-page-journey-mock-data.js.map +1 -1
  11. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +105 -93
  12. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  13. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +44 -43
  14. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  15. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +36 -34
  16. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  17. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +126 -107
  18. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  19. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +107 -95
  20. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  21. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +116 -104
  22. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  23. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +100 -93
  24. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  25. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +81 -76
  26. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +1 -1
  27. package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report-types.js.map +1 -1
  28. package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report.js +97 -113
  29. package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report.js.map +1 -1
  30. package/dist/features/trial-session/comps/learning-plan/goal-edit-sync.js +40 -0
  31. package/dist/features/trial-session/comps/learning-plan/goal-edit-sync.js.map +1 -0
  32. package/dist/features/trial-session/comps/learning-plan/learning-assign-resource-sync.js +55 -0
  33. package/dist/features/trial-session/comps/learning-plan/learning-assign-resource-sync.js.map +1 -0
  34. package/dist/features/trial-session/comps/learning-plan/learning-chapter-details.js +48 -0
  35. package/dist/features/trial-session/comps/learning-plan/learning-chapter-details.js.map +1 -0
  36. package/dist/features/trial-session/comps/learning-plan/learning-milestone-sync.js +145 -0
  37. package/dist/features/trial-session/comps/learning-plan/learning-milestone-sync.js.map +1 -0
  38. package/dist/features/trial-session/comps/learning-plan/learning-plan-helpers.js +30 -0
  39. package/dist/features/trial-session/comps/learning-plan/learning-plan-helpers.js.map +1 -0
  40. package/dist/features/trial-session/comps/learning-plan/learning-plan-view.js +17 -0
  41. package/dist/features/trial-session/comps/learning-plan/learning-plan-view.js.map +1 -0
  42. package/dist/features/trial-session/comps/learning-plan/learning-plan.js +93 -0
  43. package/dist/features/trial-session/comps/learning-plan/learning-plan.js.map +1 -0
  44. package/dist/features/trial-session/comps/learning-plan/learning-preview-worksheet.js +81 -0
  45. package/dist/features/trial-session/comps/learning-plan/learning-preview-worksheet.js.map +1 -0
  46. package/dist/features/trial-session/comps/learning-plan/learning-test-creation-sync.js +41 -0
  47. package/dist/features/trial-session/comps/learning-plan/learning-test-creation-sync.js.map +1 -0
  48. package/dist/features/trial-session/hooks/use-chapter-details-journey.js +97 -0
  49. package/dist/features/trial-session/hooks/use-chapter-details-journey.js.map +1 -0
  50. package/dist/features/trial-session/hooks/use-learning-plan-journey.js +105 -0
  51. package/dist/features/trial-session/hooks/use-learning-plan-journey.js.map +1 -0
  52. package/dist/features/trial-session/hooks/use-resource-assignment-journey.js +64 -0
  53. package/dist/features/trial-session/hooks/use-resource-assignment-journey.js.map +1 -0
  54. package/dist/features/trial-session/hooks/use-test-creation-journey.js +64 -0
  55. package/dist/features/trial-session/hooks/use-test-creation-journey.js.map +1 -0
  56. package/dist/features/trial-session/hooks/use-worksheet-preview-journey.js +65 -0
  57. package/dist/features/trial-session/hooks/use-worksheet-preview-journey.js.map +1 -0
  58. package/dist/features/trial-session/right-panel/slide-components-map.js +1 -1
  59. package/dist/features/trial-session/right-panel/slide-components-map.js.map +1 -1
  60. package/dist/features/trial-session/trial-session-types.js.map +1 -1
  61. package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js +47 -34
  62. package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js.map +1 -1
  63. package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js +43 -42
  64. package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js.map +1 -1
  65. package/dist/features/worksheet/worksheet-preview/worksheet-preview.js +28 -26
  66. package/dist/features/worksheet/worksheet-preview/worksheet-preview.js.map +1 -1
  67. package/dist/index.d.ts +42 -4
  68. package/package.json +1 -1
  69. package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback-styled.js +0 -16
  70. package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback-styled.js.map +0 -1
  71. package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback.js +0 -56
  72. package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback.js.map +0 -1
  73. package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer-styled.js +0 -22
  74. package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer-styled.js.map +0 -1
  75. package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer.js +0 -14
  76. package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer.js.map +0 -1
  77. package/dist/features/trial-session/comps/learning-plan/index.js +0 -355
  78. package/dist/features/trial-session/comps/learning-plan/index.js.map +0 -1
@@ -1,20 +1,20 @@
1
- import { jsxs as t, jsx as e, Fragment as P } from "react/jsx-runtime";
2
- import { memo as X, useRef as j, useState as H, useMemo as F, useLayoutEffect as K } from "react";
3
- import V from "../../../../../assets/line-icons/icons/check2.js";
4
- import v from "../../../../ui/arrow-tooltip/arrow-tooltip.js";
5
- import U from "../../../../ui/image/image.js";
1
+ import { jsxs as t, jsx as e, Fragment as X } from "react/jsx-runtime";
2
+ import { memo as j, useRef as H, useState as F, useMemo as K, useLayoutEffect as V } from "react";
3
+ import v from "../../../../../assets/line-icons/icons/check2.js";
4
+ import U from "../../../../ui/arrow-tooltip/arrow-tooltip.js";
5
+ import Y from "../../../../ui/image/image.js";
6
6
  import r from "../../../../ui/layout/flex-view.js";
7
- import Y from "../../../../ui/separator/separator.js";
7
+ import q from "../../../../ui/separator/separator.js";
8
8
  import s from "../../../../ui/text/text.js";
9
- import q from "./goals/goal-action-ctas.js";
10
- import { GOAL_CATEGORY_BASED_IMAGES as z } from "./milestone-constants.js";
11
- import { getRemainingDaysToCompleteGoal as J, getGoalCategoryBasedColorTheme as Q, getMilestoneWidgetStatusInfo as Z } from "./milestone-utils.js";
12
- import { ChapterProgressSVG as ee, ChapterProgressSVGCircle as u, StyledCheckIconWrapper as te, MilestoneTitle as re } from "./milestone-widget-styled.js";
13
- import oe from "./outcome/outcome.js";
14
- const Te = X(function({
9
+ import z from "./goals/goal-action-ctas.js";
10
+ import { GOAL_CATEGORY_BASED_IMAGES as J } from "./milestone-constants.js";
11
+ import { getRemainingDaysToCompleteGoal as Q, getGoalCategoryBasedColorTheme as Z, getMilestoneWidgetStatusInfo as ee } from "./milestone-utils.js";
12
+ import { ChapterProgressSVG as te, ChapterProgressSVGCircle as u, StyledCheckIconWrapper as re, MilestoneTitle as oe } from "./milestone-widget-styled.js";
13
+ import ne from "./outcome/outcome.js";
14
+ const xe = j(function({
15
15
  isClassOngoing: C,
16
16
  isStudentPresent: T,
17
- isExpanded: ie,
17
+ isExpanded: le,
18
18
  ...x
19
19
  }) {
20
20
  const {
@@ -29,17 +29,18 @@ const Te = X(function({
29
29
  isDraftModeEnabled: E,
30
30
  onEdit: G,
31
31
  onDraftPublish: b,
32
- onAddOutcome: S
32
+ onAddOutcome: S,
33
+ editButtonRef: B
33
34
  } = x, {
34
35
  milestone_name: m,
35
36
  milestone_date_ts: k,
36
37
  milestone_state: o,
37
38
  goal_category: l,
38
39
  goal_code: p,
39
- progress_stat: B
40
- } = d, { completed: g = 0, total: h = 0 } = B || {}, $ = o === "OUTCOME_PENDING", a = g > 0 ? Math.floor((g / h || 1) * 100) : 0, n = j(null), [M, O] = H(!1), { textColor: N, borderColor: f } = Q(l), c = Z(o), R = ($ ? c == null ? void 0 : c.progressBackgroundColor : f) || "WHITE_5", W = F(() => typeof p == "string", [p]), L = J(k);
41
- return K(() => {
42
- n.current && n.current.scrollHeight > n.current.clientHeight && O(!0);
40
+ progress_stat: M
41
+ } = d, { completed: g = 0, total: h = 0 } = M || {}, $ = o === "OUTCOME_PENDING", a = g > 0 ? Math.floor((g / h || 1) * 100) : 0, n = H(null), [O, R] = F(!1), { textColor: N, borderColor: f } = Z(l), c = ee(o), W = ($ ? c == null ? void 0 : c.progressBackgroundColor : f) || "WHITE_5", L = K(() => typeof p == "string", [p]), P = Q(k);
42
+ return V(() => {
43
+ n.current && n.current.scrollHeight > n.current.clientHeight && R(!0);
43
44
  }, [n]), l ? /* @__PURE__ */ t(
44
45
  r,
45
46
  {
@@ -60,7 +61,7 @@ const Te = X(function({
60
61
  $alignItems: "center",
61
62
  $borderRadiusX: 2,
62
63
  children: [
63
- /* @__PURE__ */ t(ee, { width: "64px", height: "64px", children: [
64
+ /* @__PURE__ */ t(te, { width: "64px", height: "64px", children: [
64
65
  /* @__PURE__ */ e(u, { $progress: 0, r: "31", cx: "32", cy: "32" }),
65
66
  /* @__PURE__ */ e(
66
67
  u,
@@ -75,15 +76,15 @@ const Te = X(function({
75
76
  )
76
77
  ] }),
77
78
  /* @__PURE__ */ e(r, { $widthX: 4, $heightX: 4, $justifyContent: "center", $alignItems: "center", children: /* @__PURE__ */ e(
78
- U,
79
+ Y,
79
80
  {
80
- src: z[l],
81
+ src: J[l],
81
82
  withLoader: !0,
82
83
  width: 40,
83
84
  height: 40
84
85
  }
85
86
  ) }),
86
- a === 100 && /* @__PURE__ */ e(te, { children: /* @__PURE__ */ e(V, { width: 20, height: 20 }) })
87
+ a === 100 && /* @__PURE__ */ e(re, { children: /* @__PURE__ */ e(v, { width: 20, height: 20 }) })
87
88
  ]
88
89
  }
89
90
  ),
@@ -98,7 +99,7 @@ const Te = X(function({
98
99
  $gap: 4,
99
100
  $gutter: 4,
100
101
  $alignItems: "center",
101
- $background: R,
102
+ $background: W,
102
103
  children: /* @__PURE__ */ e(s, { $renderAs: "ac4", $color: "WHITE", children: "Outcome pending" })
103
104
  }
104
105
  ),
@@ -115,17 +116,17 @@ const Te = X(function({
115
116
  )
116
117
  ] }),
117
118
  /* @__PURE__ */ e(
118
- v,
119
+ U,
119
120
  {
120
121
  renderAs: "primary",
121
122
  position: "bottom",
122
123
  tooltipItem: m,
123
- hidden: !M,
124
+ hidden: !O,
124
125
  children: /* @__PURE__ */ e(
125
- re,
126
+ oe,
126
127
  {
127
128
  ref: n,
128
- $renderAs: W ? "ah4" : "ab1",
129
+ $renderAs: L ? "ah4" : "ab1",
129
130
  $color: "BLACK_1",
130
131
  children: m
131
132
  }
@@ -134,17 +135,17 @@ const Te = X(function({
134
135
  ),
135
136
  !!h && o !== "DRAFT" && /* @__PURE__ */ t(s, { $renderAs: "ub4", $color: "BLACK_T_60", children: [
136
137
  `${a}% complete`,
137
- o === "ACTIVE" && L
138
+ o === "ACTIVE" && P
138
139
  ] })
139
140
  ] }),
140
- !!(i != null && i.length) && /* @__PURE__ */ t(P, { children: [
141
- /* @__PURE__ */ e(Y, { width: 40, height: 1, background: "BLACK_T_15" }),
142
- /* @__PURE__ */ e(oe, { outcomes: i })
141
+ !!(i != null && i.length) && /* @__PURE__ */ t(X, { children: [
142
+ /* @__PURE__ */ e(q, { width: 40, height: 1, background: "BLACK_T_15" }),
143
+ /* @__PURE__ */ e(ne, { outcomes: i })
143
144
  ] })
144
145
  ] })
145
146
  ] }),
146
147
  y === "TEACHER" && /* @__PURE__ */ e(
147
- q,
148
+ z,
148
149
  {
149
150
  milestone: d,
150
151
  studentId: A,
@@ -157,7 +158,8 @@ const Te = X(function({
157
158
  onDraftPublish: b,
158
159
  onEdit: G,
159
160
  courseStream: D,
160
- isDraftModeEnabled: E
161
+ isDraftModeEnabled: E,
162
+ editButtonRef: B
161
163
  }
162
164
  )
163
165
  ]
@@ -165,6 +167,6 @@ const Te = X(function({
165
167
  ) : null;
166
168
  });
167
169
  export {
168
- Te as default
170
+ xe as default
169
171
  };
170
172
  //# sourceMappingURL=milestone-info.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"milestone-info.js","sources":["../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.tsx"],"sourcesContent":["import { memo, useLayoutEffect, useMemo, useRef, useState, type FC } from 'react';\n\nimport Check2Icon from '../../../../../assets/line-icons/icons/check2';\nimport ArrowTooltip from '../../../../ui/arrow-tooltip/arrow-tooltip';\nimport Image from '../../../../ui/image/image';\nimport FlexView from '../../../../ui/layout/flex-view';\nimport Separator from '../../../../ui/separator/separator';\nimport Text from '../../../../ui/text/text';\nimport GoalActionCtas from './goals/goal-action-ctas';\nimport { GOAL_CATEGORY_BASED_IMAGES } from './milestone-constants';\nimport {\n getGoalCategoryBasedColorTheme,\n getMilestoneWidgetStatusInfo,\n getRemainingDaysToCompleteGoal,\n} from './milestone-utils';\nimport * as Styled from './milestone-widget-styled';\nimport type { IMileStoneInfoWrapperProps } from './milestone-widget-types';\nimport OutcomeWrapper from './outcome/outcome';\n\nconst MilestoneInfoWrapper: FC<IMileStoneInfoWrapperProps> = memo(function MilestoneInfoWrapper({\n isClassOngoing,\n isStudentPresent,\n isExpanded,\n ...restMilestoneInfoWrapperProps\n}) {\n const {\n milestone,\n studentId,\n studentName,\n teacherName,\n parentName,\n userType,\n courseStream,\n outcomes,\n isDraftModeEnabled,\n onEdit,\n onDraftPublish,\n onAddOutcome,\n } = restMilestoneInfoWrapperProps;\n\n const {\n milestone_name: milestoneName,\n milestone_date_ts: dueDate,\n milestone_state: milestoneState,\n goal_category: goalCategory,\n goal_code: goalCode,\n progress_stat: progressStat,\n } = milestone;\n\n const { completed = 0, total = 0 } = progressStat || {};\n const isOutcomePending = milestoneState === 'OUTCOME_PENDING';\n const progressCompletionPercentage =\n completed > 0 ? Math.floor((completed / total || 1) * 100) : 0;\n\n const titleTextRef = useRef<HTMLDivElement>(null);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const { textColor: goalCategoryTextColor, borderColor } =\n getGoalCategoryBasedColorTheme(goalCategory);\n\n const outcomeStatusInfo = getMilestoneWidgetStatusInfo(milestoneState);\n const backgroundColor =\n (isOutcomePending ? outcomeStatusInfo?.progressBackgroundColor : borderColor) || 'WHITE_5';\n\n const isGoalCreation = useMemo(() => typeof goalCode === 'string', [goalCode]);\n const remainingDays = getRemainingDaysToCompleteGoal(dueDate);\n\n useLayoutEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n if (!goalCategory) return null;\n\n return (\n <FlexView\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $flexGapX={1}\n >\n <FlexView $flexDirection=\"row\" $flexGapX={1.5}>\n <FlexView\n $widthX={4}\n $heightX={4}\n $background=\"WHITE_T_38\"\n $position=\"relative\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $borderRadiusX={2}\n >\n <Styled.ChapterProgressSVG width=\"64px\" height=\"64px\">\n <Styled.ChapterProgressSVGCircle $progress={0} r=\"31\" cx=\"32\" cy=\"32\" />\n <Styled.ChapterProgressSVGCircle\n $progressCircle\n $progressBackground=\"BLACK_1\"\n $progress={progressCompletionPercentage * 2}\n r=\"31\"\n cx=\"32\"\n cy=\"32\"\n />\n </Styled.ChapterProgressSVG>\n\n <FlexView $widthX={4} $heightX={4} $justifyContent=\"center\" $alignItems=\"center\">\n <Image\n src={GOAL_CATEGORY_BASED_IMAGES[goalCategory]}\n withLoader\n width={40}\n height={40}\n />\n </FlexView>\n\n {progressCompletionPercentage === 100 && (\n <Styled.StyledCheckIconWrapper>\n <Check2Icon width={20} height={20} />\n </Styled.StyledCheckIconWrapper>\n )}\n </FlexView>\n\n <FlexView $flexGap={16}>\n <FlexView $flexGap={4}>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexGap={4}>\n <Text $renderAs=\"ac4-black\" $color={goalCategoryTextColor}>\n {goalCategory.split('_').join(' ')}\n </Text>\n\n {isOutcomePending && (\n <FlexView\n $flexDirection=\"row\"\n $gap={4}\n $gutter={4}\n $alignItems=\"center\"\n $background={backgroundColor}\n >\n <Text $renderAs=\"ac4\" $color=\"WHITE\">\n Outcome pending\n </Text>\n </FlexView>\n )}\n\n {milestoneState === 'DRAFT' && (\n <FlexView\n $flexDirection=\"row\"\n $gap={4}\n $gutter={4}\n $alignItems=\"center\"\n $background={borderColor}\n >\n <Text $renderAs=\"ac4\">Draft</Text>\n </FlexView>\n )}\n </FlexView>\n\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={milestoneName}\n hidden={!showTitleTooltip}\n >\n <Styled.MilestoneTitle\n ref={titleTextRef}\n $renderAs={!isGoalCreation ? 'ab1' : 'ah4'}\n $color=\"BLACK_1\"\n >\n {milestoneName}\n </Styled.MilestoneTitle>\n </ArrowTooltip>\n\n {!!total && milestoneState !== 'DRAFT' && (\n <Text $renderAs=\"ub4\" $color=\"BLACK_T_60\">\n {`${progressCompletionPercentage}% complete`}\n {milestoneState === 'ACTIVE' && remainingDays}\n </Text>\n )}\n </FlexView>\n\n {!!outcomes?.length && (\n <>\n <Separator width={40} height={1} background=\"BLACK_T_15\" />\n <OutcomeWrapper outcomes={outcomes} />\n </>\n )}\n </FlexView>\n </FlexView>\n\n {userType === 'TEACHER' && (\n <GoalActionCtas\n milestone={milestone}\n studentId={studentId}\n studentName={studentName}\n teacherName={teacherName ?? ''}\n parentName={parentName ?? ''}\n onAddOutcome={onAddOutcome}\n isClassOngoing={Boolean(isClassOngoing)}\n isStudentPresent={Boolean(isStudentPresent)}\n onDraftPublish={onDraftPublish}\n onEdit={onEdit}\n courseStream={courseStream}\n isDraftModeEnabled={isDraftModeEnabled}\n />\n )}\n </FlexView>\n );\n});\n\nexport default MilestoneInfoWrapper;\n"],"names":["MilestoneInfoWrapper","memo","isClassOngoing","isStudentPresent","isExpanded","restMilestoneInfoWrapperProps","milestone","studentId","studentName","teacherName","parentName","userType","courseStream","outcomes","isDraftModeEnabled","onEdit","onDraftPublish","onAddOutcome","milestoneName","dueDate","milestoneState","goalCategory","goalCode","progressStat","completed","total","isOutcomePending","progressCompletionPercentage","titleTextRef","useRef","showTitleTooltip","setShowTitleTooltip","useState","goalCategoryTextColor","borderColor","getGoalCategoryBasedColorTheme","outcomeStatusInfo","getMilestoneWidgetStatusInfo","backgroundColor","isGoalCreation","useMemo","remainingDays","getRemainingDaysToCompleteGoal","useLayoutEffect","jsxs","FlexView","Styled.ChapterProgressSVG","jsx","Styled.ChapterProgressSVGCircle","Image","GOAL_CATEGORY_BASED_IMAGES","Styled.StyledCheckIconWrapper","Check2Icon","Text","ArrowTooltip","Styled.MilestoneTitle","Fragment","Separator","OutcomeWrapper","GoalActionCtas"],"mappings":"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"}
1
+ {"version":3,"file":"milestone-info.js","sources":["../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.tsx"],"sourcesContent":["import { memo, useLayoutEffect, useMemo, useRef, useState, type FC } from 'react';\n\nimport Check2Icon from '../../../../../assets/line-icons/icons/check2';\nimport ArrowTooltip from '../../../../ui/arrow-tooltip/arrow-tooltip';\nimport Image from '../../../../ui/image/image';\nimport FlexView from '../../../../ui/layout/flex-view';\nimport Separator from '../../../../ui/separator/separator';\nimport Text from '../../../../ui/text/text';\nimport GoalActionCtas from './goals/goal-action-ctas';\nimport { GOAL_CATEGORY_BASED_IMAGES } from './milestone-constants';\nimport {\n getGoalCategoryBasedColorTheme,\n getMilestoneWidgetStatusInfo,\n getRemainingDaysToCompleteGoal,\n} from './milestone-utils';\nimport * as Styled from './milestone-widget-styled';\nimport type { IMileStoneInfoWrapperProps } from './milestone-widget-types';\nimport OutcomeWrapper from './outcome/outcome';\n\nconst MilestoneInfoWrapper: FC<IMileStoneInfoWrapperProps> = memo(function MilestoneInfoWrapper({\n isClassOngoing,\n isStudentPresent,\n isExpanded,\n ...restMilestoneInfoWrapperProps\n}) {\n const {\n milestone,\n studentId,\n studentName,\n teacherName,\n parentName,\n userType,\n courseStream,\n outcomes,\n isDraftModeEnabled,\n onEdit,\n onDraftPublish,\n onAddOutcome,\n editButtonRef,\n } = restMilestoneInfoWrapperProps;\n\n const {\n milestone_name: milestoneName,\n milestone_date_ts: dueDate,\n milestone_state: milestoneState,\n goal_category: goalCategory,\n goal_code: goalCode,\n progress_stat: progressStat,\n } = milestone;\n\n const { completed = 0, total = 0 } = progressStat || {};\n const isOutcomePending = milestoneState === 'OUTCOME_PENDING';\n const progressCompletionPercentage =\n completed > 0 ? Math.floor((completed / total || 1) * 100) : 0;\n\n const titleTextRef = useRef<HTMLDivElement>(null);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const { textColor: goalCategoryTextColor, borderColor } =\n getGoalCategoryBasedColorTheme(goalCategory);\n\n const outcomeStatusInfo = getMilestoneWidgetStatusInfo(milestoneState);\n const backgroundColor =\n (isOutcomePending ? outcomeStatusInfo?.progressBackgroundColor : borderColor) || 'WHITE_5';\n\n const isGoalCreation = useMemo(() => typeof goalCode === 'string', [goalCode]);\n const remainingDays = getRemainingDaysToCompleteGoal(dueDate);\n\n useLayoutEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n if (!goalCategory) return null;\n\n return (\n <FlexView\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $flexGapX={1}\n >\n <FlexView $flexDirection=\"row\" $flexGapX={1.5}>\n <FlexView\n $widthX={4}\n $heightX={4}\n $background=\"WHITE_T_38\"\n $position=\"relative\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $borderRadiusX={2}\n >\n <Styled.ChapterProgressSVG width=\"64px\" height=\"64px\">\n <Styled.ChapterProgressSVGCircle $progress={0} r=\"31\" cx=\"32\" cy=\"32\" />\n <Styled.ChapterProgressSVGCircle\n $progressCircle\n $progressBackground=\"BLACK_1\"\n $progress={progressCompletionPercentage * 2}\n r=\"31\"\n cx=\"32\"\n cy=\"32\"\n />\n </Styled.ChapterProgressSVG>\n\n <FlexView $widthX={4} $heightX={4} $justifyContent=\"center\" $alignItems=\"center\">\n <Image\n src={GOAL_CATEGORY_BASED_IMAGES[goalCategory]}\n withLoader\n width={40}\n height={40}\n />\n </FlexView>\n\n {progressCompletionPercentage === 100 && (\n <Styled.StyledCheckIconWrapper>\n <Check2Icon width={20} height={20} />\n </Styled.StyledCheckIconWrapper>\n )}\n </FlexView>\n\n <FlexView $flexGap={16}>\n <FlexView $flexGap={4}>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexGap={4}>\n <Text $renderAs=\"ac4-black\" $color={goalCategoryTextColor}>\n {goalCategory.split('_').join(' ')}\n </Text>\n\n {isOutcomePending && (\n <FlexView\n $flexDirection=\"row\"\n $gap={4}\n $gutter={4}\n $alignItems=\"center\"\n $background={backgroundColor}\n >\n <Text $renderAs=\"ac4\" $color=\"WHITE\">\n Outcome pending\n </Text>\n </FlexView>\n )}\n\n {milestoneState === 'DRAFT' && (\n <FlexView\n $flexDirection=\"row\"\n $gap={4}\n $gutter={4}\n $alignItems=\"center\"\n $background={borderColor}\n >\n <Text $renderAs=\"ac4\">Draft</Text>\n </FlexView>\n )}\n </FlexView>\n\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={milestoneName}\n hidden={!showTitleTooltip}\n >\n <Styled.MilestoneTitle\n ref={titleTextRef}\n $renderAs={!isGoalCreation ? 'ab1' : 'ah4'}\n $color=\"BLACK_1\"\n >\n {milestoneName}\n </Styled.MilestoneTitle>\n </ArrowTooltip>\n\n {!!total && milestoneState !== 'DRAFT' && (\n <Text $renderAs=\"ub4\" $color=\"BLACK_T_60\">\n {`${progressCompletionPercentage}% complete`}\n {milestoneState === 'ACTIVE' && remainingDays}\n </Text>\n )}\n </FlexView>\n\n {!!outcomes?.length && (\n <>\n <Separator width={40} height={1} background=\"BLACK_T_15\" />\n <OutcomeWrapper outcomes={outcomes} />\n </>\n )}\n </FlexView>\n </FlexView>\n\n {userType === 'TEACHER' && (\n <GoalActionCtas\n milestone={milestone}\n studentId={studentId}\n studentName={studentName}\n teacherName={teacherName ?? ''}\n parentName={parentName ?? ''}\n onAddOutcome={onAddOutcome}\n isClassOngoing={Boolean(isClassOngoing)}\n isStudentPresent={Boolean(isStudentPresent)}\n onDraftPublish={onDraftPublish}\n onEdit={onEdit}\n courseStream={courseStream}\n isDraftModeEnabled={isDraftModeEnabled}\n editButtonRef={editButtonRef}\n />\n )}\n </FlexView>\n );\n});\n\nexport default MilestoneInfoWrapper;\n"],"names":["MilestoneInfoWrapper","memo","isClassOngoing","isStudentPresent","isExpanded","restMilestoneInfoWrapperProps","milestone","studentId","studentName","teacherName","parentName","userType","courseStream","outcomes","isDraftModeEnabled","onEdit","onDraftPublish","onAddOutcome","editButtonRef","milestoneName","dueDate","milestoneState","goalCategory","goalCode","progressStat","completed","total","isOutcomePending","progressCompletionPercentage","titleTextRef","useRef","showTitleTooltip","setShowTitleTooltip","useState","goalCategoryTextColor","borderColor","getGoalCategoryBasedColorTheme","outcomeStatusInfo","getMilestoneWidgetStatusInfo","backgroundColor","isGoalCreation","useMemo","remainingDays","getRemainingDaysToCompleteGoal","useLayoutEffect","jsxs","FlexView","Styled.ChapterProgressSVG","jsx","Styled.ChapterProgressSVGCircle","Image","GOAL_CATEGORY_BASED_IMAGES","Styled.StyledCheckIconWrapper","Check2Icon","Text","ArrowTooltip","Styled.MilestoneTitle","Fragment","Separator","OutcomeWrapper","GoalActionCtas"],"mappings":"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"}
@@ -1,107 +1,121 @@
1
- import { jsx as o, jsxs as Q, Fragment as Y } from "react/jsx-runtime";
2
- import { memo as Z, useMemo as H, useState as ee, useRef as te, useEffect as se, useCallback as oe } from "react";
3
- import ne from "../../../../../chapters/chapters-list/chapters-list.js";
4
- import { useUIContext as re } from "../../../../../ui/context/context.js";
5
- import ae from "../../../../../ui/text/text.js";
6
- import ie from "../../../../milestone-resources/resources-list/resources-list.js";
7
- import le from "../../../../milestone-tests/test-list-v2/test-list-container.js";
8
- import { getGoalCategoryBasedColorTheme as ce } from "../milestone-utils.js";
9
- import { NoPlanCardWrapper as de, TabsWrapper as me, TabsText as ue, TabComponentWrapper as be } from "./milestone-tabs-styled.js";
10
- const Me = Z(function(I) {
11
- var G;
1
+ import { jsx as n, jsxs as se, Fragment as ne } from "react/jsx-runtime";
2
+ import { memo as oe, useMemo as q, useState as re, useRef as ae, useEffect as ie, useCallback as le } from "react";
3
+ import ce from "../../../../../chapters/chapters-list/chapters-list.js";
4
+ import { useUIContext as de } from "../../../../../ui/context/context.js";
5
+ import ue from "../../../../../ui/text/text.js";
6
+ import me from "../../../../milestone-resources/resources-list/resources-list.js";
7
+ import be from "../../../../milestone-tests/test-list-v2/test-list-container.js";
8
+ import { getGoalCategoryBasedColorTheme as pe } from "../milestone-utils.js";
9
+ import { NoPlanCardWrapper as fe, TabsWrapper as Te, TabsText as he, TabComponentWrapper as Ce } from "./milestone-tabs-styled.js";
10
+ const Pe = oe(function(M) {
11
+ var X;
12
12
  const {
13
- goalCategory: L,
13
+ goalCategory: z,
14
14
  isDraftMilestone: a,
15
- isGoalCreation: M,
15
+ isGoalCreation: k,
16
16
  isMilestoneActive: i,
17
17
  userMilestoneId: e,
18
18
  chapters: l,
19
19
  userType: c,
20
20
  canUpdatePlan: d,
21
- studentId: h,
22
- milestoneState: R,
23
- milestonePermissions: O,
24
- activeMilestoneId: C,
25
- activeTabId: X,
26
- selectedTabName: n,
27
- isDraftModeEnabled: q,
28
- defaultVisibleTab: m
29
- } = I, {
30
- onAddChapter: k,
31
- onAssignResources: $,
32
- onChapterClick: D,
33
- onCreateMilestoneTest: P,
34
- onNodeAttempt: x,
35
- onNodeView: E,
36
- onNodeReview: U,
37
- onNodeReattempt: g,
38
- onNodeReset: w,
39
- onNodeUnassign: S,
40
- onNodeAssignAsHomework: N,
41
- onTestPreview: V,
42
- onTestReview: W,
43
- onTestStart: _,
44
- onWidgetTabSelection: u,
45
- onCardClick: j
46
- } = I, { visible_tabs: b } = O, { onEvent: y } = re(), { backgroundColor: z } = ce(L, a), v = H(
21
+ studentId: g,
22
+ milestoneState: $,
23
+ milestonePermissions: K,
24
+ activeMilestoneId: N,
25
+ activeTabId: Q,
26
+ selectedTabName: o,
27
+ isDraftModeEnabled: Y,
28
+ firstChapterRef: D,
29
+ createTestButtonRef: P,
30
+ assignResourceButtonRef: x,
31
+ defaultVisibleTab: u,
32
+ canStartJourney: m
33
+ } = M, {
34
+ onAddChapter: E,
35
+ onAssignResources: S,
36
+ onChapterClick: U,
37
+ onCreateMilestoneTest: w,
38
+ onNodeAttempt: y,
39
+ onNodeView: B,
40
+ onNodeReview: V,
41
+ onNodeReattempt: R,
42
+ onNodeReset: W,
43
+ onNodeUnassign: _,
44
+ onNodeAssignAsHomework: v,
45
+ onTestPreview: j,
46
+ onTestReview: F,
47
+ onTestStart: G,
48
+ onWidgetTabSelection: b,
49
+ onCardClick: H,
50
+ startJourney: p
51
+ } = M, { visible_tabs: f } = K, { onEvent: J } = de(), { backgroundColor: Z } = pe(z, a), A = q(
47
52
  () => ({
48
53
  chapters: {
49
54
  label: "Chapters",
50
- component: /* @__PURE__ */ o(
51
- ne,
55
+ component: /* @__PURE__ */ n(
56
+ ce,
52
57
  {
53
58
  milestoneId: e,
54
59
  chapters: l,
55
60
  userType: c,
56
- isGoalCreation: M,
57
- onChapterClick: D,
58
- onAddChapter: k,
59
- canUpdatePlan: !!(R !== "DRAFT" && d),
60
- isMilestoneActive: i
61
+ isGoalCreation: k,
62
+ onChapterClick: U,
63
+ onAddChapter: E,
64
+ canUpdatePlan: !!($ !== "DRAFT" && d),
65
+ isMilestoneActive: i,
66
+ firstChapterRef: D,
67
+ canStartJourney: m,
68
+ startJourney: p
61
69
  }
62
70
  )
63
71
  },
64
72
  tests: {
65
73
  label: "Tests",
66
- component: /* @__PURE__ */ o(
67
- le,
74
+ component: /* @__PURE__ */ n(
75
+ be,
68
76
  {
69
77
  isDraftMilestone: a,
70
78
  isChaptersAvailable: l.length > 0,
71
79
  isMilestoneActive: i,
72
- studentId: h,
80
+ studentId: g,
73
81
  userMilestoneId: e,
74
82
  userType: c,
75
83
  canUpdatePlan: d,
76
- onCreateMilestoneTest: P,
77
- onNodeReattempt: g,
78
- onTestPreview: V,
79
- onTestStart: _,
80
- onTestReview: W,
81
- onNodeAssignAsHomework: N,
82
- onCardClick: j
84
+ onCreateMilestoneTest: w,
85
+ onNodeReattempt: R,
86
+ onTestPreview: j,
87
+ onTestStart: G,
88
+ onTestReview: F,
89
+ onNodeAssignAsHomework: v,
90
+ onCardClick: H,
91
+ createTestButtonRef: P,
92
+ canStartJourney: m,
93
+ startJourney: p
83
94
  }
84
95
  )
85
96
  },
86
97
  resources: {
87
98
  label: "Resources",
88
- component: /* @__PURE__ */ o(
89
- ie,
99
+ component: /* @__PURE__ */ n(
100
+ me,
90
101
  {
91
102
  isDraftMilestone: a,
92
103
  isMilestoneActive: i,
93
104
  userMilestoneId: e,
94
105
  canUpdatePlan: d,
95
- studentId: h,
106
+ studentId: g,
96
107
  userType: c,
97
- onAssignResources: $,
98
- onNodeAttempt: x,
99
- onNodeView: E,
100
- onNodeReview: U,
101
- onNodeReattempt: g,
102
- onNodeReset: w,
103
- onNodeUnassign: S,
104
- onNodeAssignAsHomework: N
108
+ onAssignResources: S,
109
+ onNodeAttempt: y,
110
+ onNodeView: B,
111
+ onNodeReview: V,
112
+ onNodeReattempt: R,
113
+ onNodeReset: W,
114
+ onNodeUnassign: _,
115
+ onNodeAssignAsHomework: v,
116
+ assignResourceButtonRef: x,
117
+ canStartJourney: m,
118
+ startJourney: p
105
119
  }
106
120
  )
107
121
  }
@@ -110,68 +124,73 @@ const Me = Z(function(I) {
110
124
  e,
111
125
  l,
112
126
  c,
113
- M,
114
- D,
115
127
  k,
116
- R,
128
+ U,
129
+ E,
130
+ $,
117
131
  d,
118
132
  i,
133
+ D,
134
+ m,
135
+ p,
119
136
  a,
120
- h,
121
- P,
122
137
  g,
138
+ w,
139
+ R,
140
+ j,
141
+ G,
142
+ F,
143
+ v,
144
+ H,
145
+ P,
146
+ S,
147
+ y,
148
+ B,
123
149
  V,
124
- _,
125
150
  W,
126
- N,
127
- j,
128
- $,
129
- x,
130
- E,
131
- U,
132
- w,
133
- S
151
+ _,
152
+ x
134
153
  ]
135
- ), r = H(() => {
136
- const t = Object.entries(v), s = (b ?? []).length > 0;
137
- return m ? (b ?? []).includes(
138
- m.toUpperCase()
139
- ) || !s ? t.filter(([T]) => T === m) : [] : s ? t.filter(([f]) => (b ?? []).includes(f.toUpperCase())) : t;
140
- }, [v, m, b]), J = e === C ? X : ((G = r == null ? void 0 : r[0]) == null ? void 0 : G[0]) || "chapters", [p, B] = ee(
141
- n ?? J
142
- ), F = te(n);
143
- se(() => {
144
- n && n !== F.current && (F.current = n, B(n));
145
- }, [n]);
146
- const K = oe(
154
+ ), r = q(() => {
155
+ const t = Object.entries(A), s = (f ?? []).length > 0;
156
+ return u ? (f ?? []).includes(
157
+ u.toUpperCase()
158
+ ) || !s ? t.filter(([C]) => C === u) : [] : s ? t.filter(([h]) => (f ?? []).includes(h.toUpperCase())) : t;
159
+ }, [A, u, f]), ee = e === N ? Q : ((X = r == null ? void 0 : r[0]) == null ? void 0 : X[0]) || "chapters", [T, L] = re(
160
+ o ?? ee
161
+ ), O = ae(o);
162
+ ie(() => {
163
+ o && o !== O.current && (O.current = o, L(o));
164
+ }, [o]);
165
+ const te = le(
147
166
  (t, s) => {
148
- if (C === e && t === p) return null;
149
- B(t), u == null || u(e, t), y("clicked", {
167
+ if (N === e && t === T) return null;
168
+ L(t), b == null || b(e, t), J("clicked", {
150
169
  cta: s,
151
170
  milestone_id: e
152
171
  });
153
172
  },
154
- [C, e, p, u, y]
173
+ [N, e, T, b, J]
155
174
  );
156
- return a && l.length === 0 ? /* @__PURE__ */ o(de, { $gutterX: 2, $background: "WHITE_3", children: /* @__PURE__ */ o(ae, { $renderAs: "ab2", $color: "RED", children: "No chapter has been assigned" }) }) : r.length === 0 ? null : /* @__PURE__ */ Q(Y, { children: [
157
- /* @__PURE__ */ o(me, { $backgroundColor: z, $frames: r.length, children: r.map((t) => {
158
- const [s, f] = t, { label: A } = f, T = s === p;
159
- return /* @__PURE__ */ o(
160
- ue,
175
+ return a && l.length === 0 ? /* @__PURE__ */ n(fe, { $gutterX: 2, $background: "WHITE_3", children: /* @__PURE__ */ n(ue, { $renderAs: "ab2", $color: "RED", children: "No chapter has been assigned" }) }) : r.length === 0 ? null : /* @__PURE__ */ se(ne, { children: [
176
+ /* @__PURE__ */ n(Te, { $backgroundColor: Z, $frames: r.length, children: r.map((t) => {
177
+ const [s, h] = t, { label: I } = h, C = s === T;
178
+ return /* @__PURE__ */ n(
179
+ he,
161
180
  {
162
- $renderAs: T ? "ub4-bold" : "ub4",
181
+ $renderAs: C ? "ub4-bold" : "ub4",
163
182
  $align: "center",
164
- $selected: T,
165
- onClick: () => K(s, A),
166
- children: A
183
+ $selected: C,
184
+ onClick: () => te(s, I),
185
+ children: I
167
186
  },
168
187
  s
169
188
  );
170
189
  }) }),
171
- /* @__PURE__ */ o(be, { $flexibleHeight: q, children: v[p].component })
190
+ /* @__PURE__ */ n(Ce, { $flexibleHeight: Y, children: A[T].component })
172
191
  ] });
173
192
  });
174
193
  export {
175
- Me as default
194
+ Pe as default
176
195
  };
177
196
  //# sourceMappingURL=milestone-tabs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"milestone-tabs.js","sources":["../../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.tsx"],"sourcesContent":["import { memo, useCallback, useEffect, useMemo, useRef, useState, type FC } from 'react';\n\nimport ChaptersList from '../../../../../chapters/chapters-list/chapters-list';\nimport { useUIContext } from '../../../../../ui/context/context';\nimport Text from '../../../../../ui/text/text';\nimport MilestoneWidgetResources from '../../../../milestone-resources/resources-list/resources-list';\nimport MilestoneTestsList from '../../../../milestone-tests/test-list-v2/test-list-container';\nimport { getGoalCategoryBasedColorTheme } from '../milestone-utils';\nimport * as Styled from './milestone-tabs-styled';\nimport type {\n IMilestoneTabConfig,\n IMilestoneTabsProps,\n TMilestoneTabName,\n} from './milestone-tabs-types';\n\nconst MilestoneTabs: FC<IMilestoneTabsProps> = memo(function MilestoneTabs(props) {\n const {\n goalCategory,\n isDraftMilestone,\n isGoalCreation,\n isMilestoneActive,\n userMilestoneId,\n chapters,\n userType,\n canUpdatePlan,\n studentId,\n milestoneState,\n milestonePermissions,\n activeMilestoneId,\n activeTabId,\n selectedTabName: controlledSelectedTabName,\n isDraftModeEnabled,\n defaultVisibleTab,\n } = props;\n const {\n onAddChapter,\n onAssignResources,\n onChapterClick,\n onCreateMilestoneTest,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReattempt,\n onNodeReset,\n onNodeUnassign,\n onNodeAssignAsHomework,\n onTestPreview,\n onTestReview,\n onTestStart,\n onWidgetTabSelection,\n onCardClick,\n } = props;\n const { visible_tabs: visibleTabs } = milestonePermissions;\n const { onEvent: trackEvent } = useUIContext();\n\n const { backgroundColor } = getGoalCategoryBasedColorTheme(goalCategory, isDraftMilestone);\n\n const TAB_CONFIG: IMilestoneTabConfig = useMemo(\n () => ({\n chapters: {\n label: 'Chapters',\n component: (\n <ChaptersList\n milestoneId={userMilestoneId}\n chapters={chapters}\n userType={userType}\n isGoalCreation={isGoalCreation}\n onChapterClick={onChapterClick}\n onAddChapter={onAddChapter}\n canUpdatePlan={Boolean(milestoneState !== 'DRAFT' && canUpdatePlan)}\n isMilestoneActive={isMilestoneActive}\n />\n ),\n },\n tests: {\n label: 'Tests',\n component: (\n <MilestoneTestsList\n isDraftMilestone={isDraftMilestone}\n isChaptersAvailable={chapters.length > 0}\n isMilestoneActive={isMilestoneActive}\n studentId={studentId}\n userMilestoneId={userMilestoneId}\n userType={userType}\n canUpdatePlan={canUpdatePlan}\n onCreateMilestoneTest={onCreateMilestoneTest}\n onNodeReattempt={onNodeReattempt}\n onTestPreview={onTestPreview}\n onTestStart={onTestStart}\n onTestReview={onTestReview}\n onNodeAssignAsHomework={onNodeAssignAsHomework}\n onCardClick={onCardClick}\n />\n ),\n },\n resources: {\n label: 'Resources',\n component: (\n <MilestoneWidgetResources\n isDraftMilestone={isDraftMilestone}\n isMilestoneActive={isMilestoneActive}\n userMilestoneId={userMilestoneId}\n canUpdatePlan={canUpdatePlan}\n studentId={studentId}\n userType={userType}\n onAssignResources={onAssignResources}\n onNodeAttempt={onNodeAttempt}\n onNodeView={onNodeView}\n onNodeReview={onNodeReview}\n onNodeReattempt={onNodeReattempt}\n onNodeReset={onNodeReset}\n onNodeUnassign={onNodeUnassign}\n onNodeAssignAsHomework={onNodeAssignAsHomework}\n />\n ),\n },\n }),\n [\n userMilestoneId,\n chapters,\n userType,\n isGoalCreation,\n onChapterClick,\n onAddChapter,\n milestoneState,\n canUpdatePlan,\n isMilestoneActive,\n isDraftMilestone,\n studentId,\n onCreateMilestoneTest,\n onNodeReattempt,\n onTestPreview,\n onTestStart,\n onTestReview,\n onNodeAssignAsHomework,\n onCardClick,\n onAssignResources,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReset,\n onNodeUnassign,\n ],\n );\n\n // Determine which tabs to show based on defaultVisibleTab and permissions\n const filteredTabConfig = useMemo(() => {\n const allTabs = Object.entries(TAB_CONFIG);\n const hasVisibleTabsPermissions = (visibleTabs ?? []).length > 0;\n\n // If defaultVisibleTab is provided, validate and show only that tab\n if (defaultVisibleTab) {\n const isDefaultTabInPermissions = (visibleTabs ?? []).includes(\n defaultVisibleTab.toUpperCase(),\n );\n const isDefaultTabValid = isDefaultTabInPermissions || !hasVisibleTabsPermissions;\n\n // Validation failed - render no tabs\n if (!isDefaultTabValid) {\n return [];\n }\n\n // Show only the defaultVisibleTab\n return allTabs.filter(([tabName]) => tabName === defaultVisibleTab);\n }\n\n // No defaultVisibleTab - use permissions or show all\n if (hasVisibleTabsPermissions) {\n return allTabs.filter(([tabName]) => (visibleTabs ?? []).includes(tabName.toUpperCase()));\n }\n\n return allTabs;\n }, [TAB_CONFIG, defaultVisibleTab, visibleTabs]);\n\n const defaultTabName =\n userMilestoneId === activeMilestoneId ? activeTabId : filteredTabConfig?.[0]?.[0] || 'chapters';\n\n const [selectedTabName, setSelectedTabName] = useState<TMilestoneTabName>(\n (controlledSelectedTabName ?? defaultTabName) as TMilestoneTabName,\n );\n\n const prevControlledTabNameRef = useRef(controlledSelectedTabName);\n\n useEffect(() => {\n if (!controlledSelectedTabName) return;\n\n if (controlledSelectedTabName === prevControlledTabNameRef.current) return;\n\n prevControlledTabNameRef.current = controlledSelectedTabName;\n setSelectedTabName(controlledSelectedTabName);\n }, [controlledSelectedTabName]);\n\n const handleTabChange = useCallback(\n (tabName: TMilestoneTabName, ctaLabel: string) => {\n if (activeMilestoneId === userMilestoneId && tabName === selectedTabName) return null;\n\n setSelectedTabName(tabName);\n\n onWidgetTabSelection?.(userMilestoneId, tabName);\n\n trackEvent('clicked', {\n cta: ctaLabel,\n milestone_id: userMilestoneId,\n });\n },\n [activeMilestoneId, userMilestoneId, selectedTabName, onWidgetTabSelection, trackEvent],\n );\n\n if (isDraftMilestone && chapters.length === 0) {\n return (\n <Styled.NoPlanCardWrapper $gutterX={2} $background=\"WHITE_3\">\n <Text $renderAs=\"ab2\" $color=\"RED\">\n No chapter has been assigned\n </Text>\n </Styled.NoPlanCardWrapper>\n );\n }\n\n // If no tabs to show due to validation failure, render nothing\n if (filteredTabConfig.length === 0) {\n return null;\n }\n\n return (\n <>\n <Styled.TabsWrapper $backgroundColor={backgroundColor} $frames={filteredTabConfig.length}>\n {filteredTabConfig.map(tabConfig => {\n const [tabName, tabInfo] = tabConfig;\n const { label } = tabInfo;\n const isSelected = tabName === selectedTabName;\n\n return (\n <Styled.TabsText\n $renderAs={isSelected ? 'ub4-bold' : 'ub4'}\n $align=\"center\"\n key={tabName}\n $selected={isSelected}\n onClick={() => handleTabChange(tabName as TMilestoneTabName, label)}\n >\n {label}\n </Styled.TabsText>\n );\n })}\n </Styled.TabsWrapper>\n\n <Styled.TabComponentWrapper $flexibleHeight={isDraftModeEnabled}>\n {TAB_CONFIG[selectedTabName as keyof typeof TAB_CONFIG].component}\n </Styled.TabComponentWrapper>\n </>\n );\n});\n\nexport default MilestoneTabs;\n"],"names":["MilestoneTabs","memo","props","goalCategory","isDraftMilestone","isGoalCreation","isMilestoneActive","userMilestoneId","chapters","userType","canUpdatePlan","studentId","milestoneState","milestonePermissions","activeMilestoneId","activeTabId","controlledSelectedTabName","isDraftModeEnabled","defaultVisibleTab","onAddChapter","onAssignResources","onChapterClick","onCreateMilestoneTest","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onNodeAssignAsHomework","onTestPreview","onTestReview","onTestStart","onWidgetTabSelection","onCardClick","visibleTabs","trackEvent","useUIContext","backgroundColor","getGoalCategoryBasedColorTheme","TAB_CONFIG","useMemo","jsx","ChaptersList","MilestoneTestsList","MilestoneWidgetResources","filteredTabConfig","allTabs","hasVisibleTabsPermissions","tabName","defaultTabName","_a","selectedTabName","setSelectedTabName","useState","prevControlledTabNameRef","useRef","useEffect","handleTabChange","useCallback","ctaLabel","Styled.NoPlanCardWrapper","Text","jsxs","Fragment","Styled.TabsWrapper","tabConfig","tabInfo","label","isSelected","Styled.TabsText","Styled.TabComponentWrapper"],"mappings":"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"}
1
+ {"version":3,"file":"milestone-tabs.js","sources":["../../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.tsx"],"sourcesContent":["import { memo, useCallback, useEffect, useMemo, useRef, useState, type FC } from 'react';\n\nimport ChaptersList from '../../../../../chapters/chapters-list/chapters-list';\nimport { useUIContext } from '../../../../../ui/context/context';\nimport Text from '../../../../../ui/text/text';\nimport MilestoneWidgetResources from '../../../../milestone-resources/resources-list/resources-list';\nimport MilestoneTestsList from '../../../../milestone-tests/test-list-v2/test-list-container';\nimport { getGoalCategoryBasedColorTheme } from '../milestone-utils';\nimport * as Styled from './milestone-tabs-styled';\nimport type {\n IMilestoneTabConfig,\n IMilestoneTabsProps,\n TMilestoneTabName,\n} from './milestone-tabs-types';\n\nconst MilestoneTabs: FC<IMilestoneTabsProps> = memo(function MilestoneTabs(props) {\n const {\n goalCategory,\n isDraftMilestone,\n isGoalCreation,\n isMilestoneActive,\n userMilestoneId,\n chapters,\n userType,\n canUpdatePlan,\n studentId,\n milestoneState,\n milestonePermissions,\n activeMilestoneId,\n activeTabId,\n selectedTabName: controlledSelectedTabName,\n isDraftModeEnabled,\n firstChapterRef,\n createTestButtonRef,\n assignResourceButtonRef,\n defaultVisibleTab,\n canStartJourney,\n } = props;\n const {\n onAddChapter,\n onAssignResources,\n onChapterClick,\n onCreateMilestoneTest,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReattempt,\n onNodeReset,\n onNodeUnassign,\n onNodeAssignAsHomework,\n onTestPreview,\n onTestReview,\n onTestStart,\n onWidgetTabSelection,\n onCardClick,\n startJourney,\n } = props;\n const { visible_tabs: visibleTabs } = milestonePermissions;\n const { onEvent: trackEvent } = useUIContext();\n\n const { backgroundColor } = getGoalCategoryBasedColorTheme(goalCategory, isDraftMilestone);\n\n const TAB_CONFIG: IMilestoneTabConfig = useMemo(\n () => ({\n chapters: {\n label: 'Chapters',\n component: (\n <ChaptersList\n milestoneId={userMilestoneId}\n chapters={chapters}\n userType={userType}\n isGoalCreation={isGoalCreation}\n onChapterClick={onChapterClick}\n onAddChapter={onAddChapter}\n canUpdatePlan={Boolean(milestoneState !== 'DRAFT' && canUpdatePlan)}\n isMilestoneActive={isMilestoneActive}\n firstChapterRef={firstChapterRef}\n canStartJourney={canStartJourney}\n startJourney={startJourney}\n />\n ),\n },\n tests: {\n label: 'Tests',\n component: (\n <MilestoneTestsList\n isDraftMilestone={isDraftMilestone}\n isChaptersAvailable={chapters.length > 0}\n isMilestoneActive={isMilestoneActive}\n studentId={studentId}\n userMilestoneId={userMilestoneId}\n userType={userType}\n canUpdatePlan={canUpdatePlan}\n onCreateMilestoneTest={onCreateMilestoneTest}\n onNodeReattempt={onNodeReattempt}\n onTestPreview={onTestPreview}\n onTestStart={onTestStart}\n onTestReview={onTestReview}\n onNodeAssignAsHomework={onNodeAssignAsHomework}\n onCardClick={onCardClick}\n createTestButtonRef={createTestButtonRef}\n canStartJourney={canStartJourney}\n startJourney={startJourney}\n />\n ),\n },\n resources: {\n label: 'Resources',\n component: (\n <MilestoneWidgetResources\n isDraftMilestone={isDraftMilestone}\n isMilestoneActive={isMilestoneActive}\n userMilestoneId={userMilestoneId}\n canUpdatePlan={canUpdatePlan}\n studentId={studentId}\n userType={userType}\n onAssignResources={onAssignResources}\n onNodeAttempt={onNodeAttempt}\n onNodeView={onNodeView}\n onNodeReview={onNodeReview}\n onNodeReattempt={onNodeReattempt}\n onNodeReset={onNodeReset}\n onNodeUnassign={onNodeUnassign}\n onNodeAssignAsHomework={onNodeAssignAsHomework}\n assignResourceButtonRef={assignResourceButtonRef}\n canStartJourney={canStartJourney}\n startJourney={startJourney}\n />\n ),\n },\n }),\n [\n userMilestoneId,\n chapters,\n userType,\n isGoalCreation,\n onChapterClick,\n onAddChapter,\n milestoneState,\n canUpdatePlan,\n isMilestoneActive,\n firstChapterRef,\n canStartJourney,\n startJourney,\n isDraftMilestone,\n studentId,\n onCreateMilestoneTest,\n onNodeReattempt,\n onTestPreview,\n onTestStart,\n onTestReview,\n onNodeAssignAsHomework,\n onCardClick,\n createTestButtonRef,\n onAssignResources,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReset,\n onNodeUnassign,\n assignResourceButtonRef,\n ],\n );\n\n // Determine which tabs to show based on defaultVisibleTab and permissions\n const filteredTabConfig = useMemo(() => {\n const allTabs = Object.entries(TAB_CONFIG);\n const hasVisibleTabsPermissions = (visibleTabs ?? []).length > 0;\n\n // If defaultVisibleTab is provided, validate and show only that tab\n if (defaultVisibleTab) {\n const isDefaultTabInPermissions = (visibleTabs ?? []).includes(\n defaultVisibleTab.toUpperCase(),\n );\n const isDefaultTabValid = isDefaultTabInPermissions || !hasVisibleTabsPermissions;\n\n // Validation failed - render no tabs\n if (!isDefaultTabValid) {\n return [];\n }\n\n // Show only the defaultVisibleTab\n return allTabs.filter(([tabName]) => tabName === defaultVisibleTab);\n }\n\n // No defaultVisibleTab - use permissions or show all\n if (hasVisibleTabsPermissions) {\n return allTabs.filter(([tabName]) => (visibleTabs ?? []).includes(tabName.toUpperCase()));\n }\n\n return allTabs;\n }, [TAB_CONFIG, defaultVisibleTab, visibleTabs]);\n\n const defaultTabName =\n userMilestoneId === activeMilestoneId ? activeTabId : filteredTabConfig?.[0]?.[0] || 'chapters';\n\n const [selectedTabName, setSelectedTabName] = useState<TMilestoneTabName>(\n (controlledSelectedTabName ?? defaultTabName) as TMilestoneTabName,\n );\n\n const prevControlledTabNameRef = useRef(controlledSelectedTabName);\n\n useEffect(() => {\n if (!controlledSelectedTabName) return;\n\n if (controlledSelectedTabName === prevControlledTabNameRef.current) return;\n\n prevControlledTabNameRef.current = controlledSelectedTabName;\n setSelectedTabName(controlledSelectedTabName);\n }, [controlledSelectedTabName]);\n\n const handleTabChange = useCallback(\n (tabName: TMilestoneTabName, ctaLabel: string) => {\n if (activeMilestoneId === userMilestoneId && tabName === selectedTabName) return null;\n\n setSelectedTabName(tabName);\n\n onWidgetTabSelection?.(userMilestoneId, tabName);\n\n trackEvent('clicked', {\n cta: ctaLabel,\n milestone_id: userMilestoneId,\n });\n },\n [activeMilestoneId, userMilestoneId, selectedTabName, onWidgetTabSelection, trackEvent],\n );\n\n if (isDraftMilestone && chapters.length === 0) {\n return (\n <Styled.NoPlanCardWrapper $gutterX={2} $background=\"WHITE_3\">\n <Text $renderAs=\"ab2\" $color=\"RED\">\n No chapter has been assigned\n </Text>\n </Styled.NoPlanCardWrapper>\n );\n }\n\n // If no tabs to show due to validation failure, render nothing\n if (filteredTabConfig.length === 0) {\n return null;\n }\n\n return (\n <>\n <Styled.TabsWrapper $backgroundColor={backgroundColor} $frames={filteredTabConfig.length}>\n {filteredTabConfig.map(tabConfig => {\n const [tabName, tabInfo] = tabConfig;\n const { label } = tabInfo;\n const isSelected = tabName === selectedTabName;\n\n return (\n <Styled.TabsText\n $renderAs={isSelected ? 'ub4-bold' : 'ub4'}\n $align=\"center\"\n key={tabName}\n $selected={isSelected}\n onClick={() => handleTabChange(tabName as TMilestoneTabName, label)}\n >\n {label}\n </Styled.TabsText>\n );\n })}\n </Styled.TabsWrapper>\n\n <Styled.TabComponentWrapper $flexibleHeight={isDraftModeEnabled}>\n {TAB_CONFIG[selectedTabName as keyof typeof TAB_CONFIG].component}\n </Styled.TabComponentWrapper>\n </>\n );\n});\n\nexport default MilestoneTabs;\n"],"names":["MilestoneTabs","memo","props","goalCategory","isDraftMilestone","isGoalCreation","isMilestoneActive","userMilestoneId","chapters","userType","canUpdatePlan","studentId","milestoneState","milestonePermissions","activeMilestoneId","activeTabId","controlledSelectedTabName","isDraftModeEnabled","firstChapterRef","createTestButtonRef","assignResourceButtonRef","defaultVisibleTab","canStartJourney","onAddChapter","onAssignResources","onChapterClick","onCreateMilestoneTest","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onNodeAssignAsHomework","onTestPreview","onTestReview","onTestStart","onWidgetTabSelection","onCardClick","startJourney","visibleTabs","trackEvent","useUIContext","backgroundColor","getGoalCategoryBasedColorTheme","TAB_CONFIG","useMemo","jsx","ChaptersList","MilestoneTestsList","MilestoneWidgetResources","filteredTabConfig","allTabs","hasVisibleTabsPermissions","tabName","defaultTabName","_a","selectedTabName","setSelectedTabName","useState","prevControlledTabNameRef","useRef","useEffect","handleTabChange","useCallback","ctaLabel","Styled.NoPlanCardWrapper","Text","jsxs","Fragment","Styled.TabsWrapper","tabConfig","tabInfo","label","isSelected","Styled.TabsText","Styled.TabComponentWrapper"],"mappings":"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"}