@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.
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +27 -25
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
- package/dist/features/chapters/chapters-list/chapters-list.js +53 -43
- package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
- package/dist/features/chapters-v2/chapter-details/chapter-details.js +70 -68
- package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -1
- package/dist/features/journey/journey-id/journey-id-teacher.js +1 -1
- package/dist/features/journey/journey-id/journey-id-teacher.js.map +1 -1
- package/dist/features/journey/mocks/chapter-page-journey-mock-data.js +1 -1
- package/dist/features/journey/mocks/chapter-page-journey-mock-data.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +105 -93
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +44 -43
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +36 -34
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +126 -107
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +107 -95
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list-container.js +116 -104
- package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
- package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +100 -93
- package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +81 -76
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +1 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report-types.js.map +1 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report.js +97 -113
- package/dist/features/timeline/monthly-timeline/ptm-report/ptm-report.js.map +1 -1
- package/dist/features/trial-session/comps/learning-plan/goal-edit-sync.js +40 -0
- package/dist/features/trial-session/comps/learning-plan/goal-edit-sync.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-assign-resource-sync.js +55 -0
- package/dist/features/trial-session/comps/learning-plan/learning-assign-resource-sync.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-chapter-details.js +48 -0
- package/dist/features/trial-session/comps/learning-plan/learning-chapter-details.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-milestone-sync.js +145 -0
- package/dist/features/trial-session/comps/learning-plan/learning-milestone-sync.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan-helpers.js +30 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan-helpers.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan-view.js +17 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan-view.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan.js +93 -0
- package/dist/features/trial-session/comps/learning-plan/learning-plan.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-preview-worksheet.js +81 -0
- package/dist/features/trial-session/comps/learning-plan/learning-preview-worksheet.js.map +1 -0
- package/dist/features/trial-session/comps/learning-plan/learning-test-creation-sync.js +41 -0
- package/dist/features/trial-session/comps/learning-plan/learning-test-creation-sync.js.map +1 -0
- package/dist/features/trial-session/hooks/use-chapter-details-journey.js +97 -0
- package/dist/features/trial-session/hooks/use-chapter-details-journey.js.map +1 -0
- package/dist/features/trial-session/hooks/use-learning-plan-journey.js +105 -0
- package/dist/features/trial-session/hooks/use-learning-plan-journey.js.map +1 -0
- package/dist/features/trial-session/hooks/use-resource-assignment-journey.js +64 -0
- package/dist/features/trial-session/hooks/use-resource-assignment-journey.js.map +1 -0
- package/dist/features/trial-session/hooks/use-test-creation-journey.js +64 -0
- package/dist/features/trial-session/hooks/use-test-creation-journey.js.map +1 -0
- package/dist/features/trial-session/hooks/use-worksheet-preview-journey.js +65 -0
- package/dist/features/trial-session/hooks/use-worksheet-preview-journey.js.map +1 -0
- package/dist/features/trial-session/right-panel/slide-components-map.js +1 -1
- package/dist/features/trial-session/right-panel/slide-components-map.js.map +1 -1
- package/dist/features/trial-session/trial-session-types.js.map +1 -1
- package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js +47 -34
- package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js.map +1 -1
- package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js +43 -42
- package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js.map +1 -1
- package/dist/features/worksheet/worksheet-preview/worksheet-preview.js +28 -26
- package/dist/features/worksheet/worksheet-preview/worksheet-preview.js.map +1 -1
- package/dist/index.d.ts +42 -4
- package/package.json +1 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback-styled.js +0 -16
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback-styled.js.map +0 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback.js +0 -56
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/ptm-feedback/ptm-feedback.js.map +0 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer-styled.js +0 -22
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer-styled.js.map +0 -1
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer.js +0 -14
- package/dist/features/timeline/monthly-timeline/ptm-report/comps/sticky-footer/sticky-footer.js.map +0 -1
- package/dist/features/trial-session/comps/learning-plan/index.js +0 -355
- 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
|
|
2
|
-
import { memo as
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import
|
|
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
|
|
7
|
+
import q from "../../../../ui/separator/separator.js";
|
|
8
8
|
import s from "../../../../ui/text/text.js";
|
|
9
|
-
import
|
|
10
|
-
import { GOAL_CATEGORY_BASED_IMAGES as
|
|
11
|
-
import { getRemainingDaysToCompleteGoal as
|
|
12
|
-
import { ChapterProgressSVG as
|
|
13
|
-
import
|
|
14
|
-
const
|
|
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:
|
|
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:
|
|
40
|
-
} = d, { completed: g = 0, total: h = 0 } =
|
|
41
|
-
return
|
|
42
|
-
n.current && n.current.scrollHeight > n.current.clientHeight &&
|
|
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(
|
|
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
|
-
|
|
79
|
+
Y,
|
|
79
80
|
{
|
|
80
|
-
src:
|
|
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(
|
|
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:
|
|
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
|
-
|
|
119
|
+
U,
|
|
119
120
|
{
|
|
120
121
|
renderAs: "primary",
|
|
121
122
|
position: "bottom",
|
|
122
123
|
tooltipItem: m,
|
|
123
|
-
hidden: !
|
|
124
|
+
hidden: !O,
|
|
124
125
|
children: /* @__PURE__ */ e(
|
|
125
|
-
|
|
126
|
+
oe,
|
|
126
127
|
{
|
|
127
128
|
ref: n,
|
|
128
|
-
$renderAs:
|
|
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" &&
|
|
138
|
+
o === "ACTIVE" && P
|
|
138
139
|
] })
|
|
139
140
|
] }),
|
|
140
|
-
!!(i != null && i.length) && /* @__PURE__ */ t(
|
|
141
|
-
/* @__PURE__ */ e(
|
|
142
|
-
/* @__PURE__ */ e(
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
2
|
-
import { memo as
|
|
3
|
-
import
|
|
4
|
-
import { useUIContext as
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
import { getGoalCategoryBasedColorTheme as
|
|
9
|
-
import { NoPlanCardWrapper as
|
|
10
|
-
const
|
|
11
|
-
var
|
|
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:
|
|
13
|
+
goalCategory: z,
|
|
14
14
|
isDraftMilestone: a,
|
|
15
|
-
isGoalCreation:
|
|
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:
|
|
22
|
-
milestoneState:
|
|
23
|
-
milestonePermissions:
|
|
24
|
-
activeMilestoneId:
|
|
25
|
-
activeTabId:
|
|
26
|
-
selectedTabName:
|
|
27
|
-
isDraftModeEnabled:
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
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__ */
|
|
51
|
-
|
|
55
|
+
component: /* @__PURE__ */ n(
|
|
56
|
+
ce,
|
|
52
57
|
{
|
|
53
58
|
milestoneId: e,
|
|
54
59
|
chapters: l,
|
|
55
60
|
userType: c,
|
|
56
|
-
isGoalCreation:
|
|
57
|
-
onChapterClick:
|
|
58
|
-
onAddChapter:
|
|
59
|
-
canUpdatePlan: !!(
|
|
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__ */
|
|
67
|
-
|
|
74
|
+
component: /* @__PURE__ */ n(
|
|
75
|
+
be,
|
|
68
76
|
{
|
|
69
77
|
isDraftMilestone: a,
|
|
70
78
|
isChaptersAvailable: l.length > 0,
|
|
71
79
|
isMilestoneActive: i,
|
|
72
|
-
studentId:
|
|
80
|
+
studentId: g,
|
|
73
81
|
userMilestoneId: e,
|
|
74
82
|
userType: c,
|
|
75
83
|
canUpdatePlan: d,
|
|
76
|
-
onCreateMilestoneTest:
|
|
77
|
-
onNodeReattempt:
|
|
78
|
-
onTestPreview:
|
|
79
|
-
onTestStart:
|
|
80
|
-
onTestReview:
|
|
81
|
-
onNodeAssignAsHomework:
|
|
82
|
-
onCardClick:
|
|
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__ */
|
|
89
|
-
|
|
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:
|
|
106
|
+
studentId: g,
|
|
96
107
|
userType: c,
|
|
97
|
-
onAssignResources:
|
|
98
|
-
onNodeAttempt:
|
|
99
|
-
onNodeView:
|
|
100
|
-
onNodeReview:
|
|
101
|
-
onNodeReattempt:
|
|
102
|
-
onNodeReset:
|
|
103
|
-
onNodeUnassign:
|
|
104
|
-
onNodeAssignAsHomework:
|
|
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
|
-
|
|
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
|
-
|
|
127
|
-
|
|
128
|
-
$,
|
|
129
|
-
x,
|
|
130
|
-
E,
|
|
131
|
-
U,
|
|
132
|
-
w,
|
|
133
|
-
S
|
|
151
|
+
_,
|
|
152
|
+
x
|
|
134
153
|
]
|
|
135
|
-
), r =
|
|
136
|
-
const t = Object.entries(
|
|
137
|
-
return
|
|
138
|
-
|
|
139
|
-
) || !s ? t.filter(([
|
|
140
|
-
}, [
|
|
141
|
-
|
|
142
|
-
),
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
}, [
|
|
146
|
-
const
|
|
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 (
|
|
149
|
-
|
|
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
|
-
[
|
|
173
|
+
[N, e, T, b, J]
|
|
155
174
|
);
|
|
156
|
-
return a && l.length === 0 ? /* @__PURE__ */
|
|
157
|
-
/* @__PURE__ */
|
|
158
|
-
const [s,
|
|
159
|
-
return /* @__PURE__ */
|
|
160
|
-
|
|
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:
|
|
181
|
+
$renderAs: C ? "ub4-bold" : "ub4",
|
|
163
182
|
$align: "center",
|
|
164
|
-
$selected:
|
|
165
|
-
onClick: () =>
|
|
166
|
-
children:
|
|
183
|
+
$selected: C,
|
|
184
|
+
onClick: () => te(s, I),
|
|
185
|
+
children: I
|
|
167
186
|
},
|
|
168
187
|
s
|
|
169
188
|
);
|
|
170
189
|
}) }),
|
|
171
|
-
/* @__PURE__ */
|
|
190
|
+
/* @__PURE__ */ n(Ce, { $flexibleHeight: Y, children: A[T].component })
|
|
172
191
|
] });
|
|
173
192
|
});
|
|
174
193
|
export {
|
|
175
|
-
|
|
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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"}
|