@cuemath/leap 3.0.10 → 3.0.11-akm-2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +36 -27
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +43 -31
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
- package/dist/features/chapters/chapters-list/chapters-list.js +16 -15
- package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
- package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +2 -2
- package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -1
- package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +30 -30
- package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +1 -1
- package/dist/features/chapters-v2/chapter-details/chapter-details.js +35 -35
- package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -1
- package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +44 -44
- package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +1 -1
- package/dist/features/circle-games/hooks/use-circle-sounds/use-circle-sounds.js +74 -74
- package/dist/features/circle-games/hooks/use-circle-sounds/use-circle-sounds.js.map +1 -1
- package/dist/features/homework/homework-card.js +146 -131
- package/dist/features/homework/homework-card.js.map +1 -1
- package/dist/features/journey/hooks/use-chapter-journey.js +28 -28
- package/dist/features/journey/hooks/use-chapter-journey.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +40 -38
- 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/milestone-tabs/milestone-tabs.js +53 -50
- 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 +64 -62
- 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 +44 -42
- 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 +39 -37
- 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 +38 -31
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +1 -1
- package/dist/features/post-game-stats/accuracy/accuracy.js +40 -39
- package/dist/features/post-game-stats/accuracy/accuracy.js.map +1 -1
- package/dist/features/post-game-stats/clock/clock.js +45 -45
- package/dist/features/post-game-stats/clock/clock.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/package.json +1 -1
@@ -1,16 +1,16 @@
|
|
1
|
-
import { jsx as t, jsxs as L, Fragment 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 t, jsxs as L, Fragment as V } from "react/jsx-runtime";
|
2
|
+
import { memo as X, useState as q, useCallback as z } from "react";
|
3
|
+
import J from "../../../../../chapters/chapters-list/chapters-list.js";
|
4
|
+
import { useUIContext as K } from "../../../../../ui/context/context.js";
|
5
|
+
import Q from "../../../../../ui/text/text.js";
|
6
|
+
import Y from "../../../../milestone-resources/resources-list/resources-list.js";
|
7
|
+
import Z from "../../../../milestone-tests/test-list-v2/test-list-container.js";
|
8
|
+
import { getGoalCategoryBasedColorTheme as ee } from "../milestone-utils.js";
|
9
|
+
import { NoPlanCardWrapper as te, TabsWrapper as oe, TabsText as se, TabComponentWrapper as ne } from "./milestone-tabs-styled.js";
|
10
|
+
const he = X((h) => {
|
11
|
+
var v;
|
12
12
|
const {
|
13
|
-
goalCategory:
|
13
|
+
goalCategory: k,
|
14
14
|
isDraftMilestone: r,
|
15
15
|
isGoalCreation: I,
|
16
16
|
isMilestoneActive: l,
|
@@ -22,34 +22,35 @@ const be = V((h) => {
|
|
22
22
|
milestoneState: R,
|
23
23
|
milestonePermissions: $,
|
24
24
|
activeMilestoneId: p,
|
25
|
-
activeTabId:
|
25
|
+
activeTabId: M
|
26
26
|
} = h, {
|
27
|
-
onAddChapter:
|
28
|
-
onAssignResources:
|
27
|
+
onAddChapter: x,
|
28
|
+
onAssignResources: w,
|
29
29
|
onChapterClick: P,
|
30
30
|
onCreateMilestoneTest: U,
|
31
31
|
onNodeAttempt: j,
|
32
|
-
onNodeView:
|
33
|
-
onNodeReview:
|
32
|
+
onNodeView: E,
|
33
|
+
onNodeReview: S,
|
34
34
|
onNodeReattempt: C,
|
35
|
-
onNodeReset:
|
36
|
-
onNodeUnassign:
|
37
|
-
|
38
|
-
|
39
|
-
|
35
|
+
onNodeReset: W,
|
36
|
+
onNodeUnassign: _,
|
37
|
+
onNodeAssignAsHomework: T,
|
38
|
+
onTestPreview: y,
|
39
|
+
onTestReview: B,
|
40
|
+
onTestStart: D,
|
40
41
|
onWidgetTabSelection: a
|
41
|
-
} = h, { visible_tabs:
|
42
|
+
} = h, { visible_tabs: g } = $, { onEvent: f } = K(), { backgroundColor: F } = ee(k, r), b = {
|
42
43
|
chapters: {
|
43
44
|
label: "Chapters",
|
44
45
|
component: /* @__PURE__ */ t(
|
45
|
-
|
46
|
+
J,
|
46
47
|
{
|
47
48
|
milestoneId: e,
|
48
49
|
chapters: c,
|
49
50
|
userType: d,
|
50
51
|
isGoalCreation: I,
|
51
52
|
onChapterClick: P,
|
52
|
-
onAddChapter:
|
53
|
+
onAddChapter: x,
|
53
54
|
canUpdatePlan: !!(R !== "DRAFT" && m),
|
54
55
|
isMilestoneActive: l
|
55
56
|
}
|
@@ -58,7 +59,7 @@ const be = V((h) => {
|
|
58
59
|
tests: {
|
59
60
|
label: "Tests",
|
60
61
|
component: /* @__PURE__ */ t(
|
61
|
-
|
62
|
+
Z,
|
62
63
|
{
|
63
64
|
isDraftMilestone: r,
|
64
65
|
isChaptersAvailable: c.length > 0,
|
@@ -69,16 +70,17 @@ const be = V((h) => {
|
|
69
70
|
canUpdatePlan: m,
|
70
71
|
onCreateMilestoneTest: U,
|
71
72
|
onNodeReattempt: C,
|
72
|
-
onTestPreview:
|
73
|
-
onTestStart:
|
74
|
-
onTestReview:
|
73
|
+
onTestPreview: y,
|
74
|
+
onTestStart: D,
|
75
|
+
onTestReview: B,
|
76
|
+
onNodeAssignAsHomework: T
|
75
77
|
}
|
76
78
|
)
|
77
79
|
},
|
78
80
|
resources: {
|
79
81
|
label: "Resources",
|
80
82
|
component: /* @__PURE__ */ t(
|
81
|
-
|
83
|
+
Y,
|
82
84
|
{
|
83
85
|
isDraftMilestone: r,
|
84
86
|
isMilestoneActive: l,
|
@@ -86,49 +88,50 @@ const be = V((h) => {
|
|
86
88
|
canUpdatePlan: m,
|
87
89
|
studentId: u,
|
88
90
|
userType: d,
|
89
|
-
onAssignResources:
|
91
|
+
onAssignResources: w,
|
90
92
|
onNodeAttempt: j,
|
91
|
-
onNodeView:
|
92
|
-
onNodeReview:
|
93
|
+
onNodeView: E,
|
94
|
+
onNodeReview: S,
|
93
95
|
onNodeReattempt: C,
|
94
|
-
onNodeReset:
|
95
|
-
onNodeUnassign:
|
96
|
+
onNodeReset: W,
|
97
|
+
onNodeUnassign: _,
|
98
|
+
onNodeAssignAsHomework: T
|
96
99
|
}
|
97
100
|
)
|
98
101
|
}
|
99
|
-
}, s = (
|
100
|
-
([o]) => (
|
101
|
-
), [i,
|
102
|
-
e === p ?
|
103
|
-
),
|
102
|
+
}, s = (g ?? []).length === 0 ? Object.entries(b) : Object.entries(b).filter(
|
103
|
+
([o]) => (g ?? []).includes(o.toUpperCase())
|
104
|
+
), [i, G] = q(
|
105
|
+
e === p ? M : ((v = s == null ? void 0 : s[0]) == null ? void 0 : v[0]) || "chapters"
|
106
|
+
), O = z(
|
104
107
|
(o, n) => {
|
105
108
|
if (p === e && o === i) return null;
|
106
|
-
|
109
|
+
G(o), a == null || a(e, o), f("clicked", {
|
107
110
|
cta: n,
|
108
111
|
milestone_id: e
|
109
112
|
});
|
110
113
|
},
|
111
|
-
[p, e, i, a,
|
114
|
+
[p, e, i, a, f]
|
112
115
|
);
|
113
|
-
return r && c.length === 0 ? /* @__PURE__ */ t(
|
114
|
-
/* @__PURE__ */ t(
|
115
|
-
const [n,
|
116
|
+
return r && c.length === 0 ? /* @__PURE__ */ t(te, { $gutterX: 2, $background: "WHITE_3", children: /* @__PURE__ */ t(Q, { $renderAs: "ab2", $color: "RED", children: "No chapter has been assigned" }) }) : /* @__PURE__ */ L(V, { children: [
|
117
|
+
/* @__PURE__ */ t(oe, { $backgroundColor: F, $frames: s.length, children: s.map((o) => {
|
118
|
+
const [n, H] = o, { label: A } = H, N = n === i;
|
116
119
|
return /* @__PURE__ */ t(
|
117
|
-
|
120
|
+
se,
|
118
121
|
{
|
119
122
|
$renderAs: N ? "ub3-bold" : "ub3",
|
120
123
|
$align: "center",
|
121
124
|
$selected: N,
|
122
|
-
onClick: () =>
|
123
|
-
children:
|
125
|
+
onClick: () => O(n, A),
|
126
|
+
children: A
|
124
127
|
},
|
125
128
|
n
|
126
129
|
);
|
127
130
|
}) }),
|
128
|
-
/* @__PURE__ */ t(
|
131
|
+
/* @__PURE__ */ t(ne, { children: b[i].component })
|
129
132
|
] });
|
130
133
|
});
|
131
134
|
export {
|
132
|
-
|
135
|
+
he as default
|
133
136
|
};
|
134
137
|
//# 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 type { IMilestoneTabConfig, IMilestoneTabsProps } from './milestone-tabs-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useState } 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';\n\nconst MilestoneTabs: FC<IMilestoneTabsProps> = memo(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 } = props;\n const {\n onAddChapter,\n onAssignResources,\n onChapterClick,\n onCreateMilestoneTest,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReattempt,\n onNodeReset,\n onNodeUnassign,\n onTestPreview,\n onTestReview,\n onTestStart,\n onWidgetTabSelection,\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 = {\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 />\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 />\n ),\n },\n };\n\n const filteredTabConfig =\n (visibleTabs ?? []).length === 0\n ? Object.entries(TAB_CONFIG)\n : Object.entries(TAB_CONFIG).filter(([tabName]) =>\n (visibleTabs ?? []).includes(tabName.toUpperCase()),\n );\n const [selectedTabName, setSelectedTabName] = useState(\n userMilestoneId === activeMilestoneId ? activeTabId : filteredTabConfig?.[0]?.[0] || 'chapters',\n );\n\n const handleTabChange = useCallback(\n (tabName: keyof IMilestoneTabConfig, 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 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 ? 'ub3-bold' : 'ub3'}\n $align=\"center\"\n key={tabName}\n $selected={isSelected}\n onClick={() => handleTabChange(tabName as keyof IMilestoneTabConfig, label)}\n >\n {label}\n </Styled.TabsText>\n );\n })}\n </Styled.TabsWrapper>\n\n <Styled.TabComponentWrapper>\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","onAddChapter","onAssignResources","onChapterClick","onCreateMilestoneTest","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onTestPreview","onTestReview","onTestStart","onWidgetTabSelection","visibleTabs","trackEvent","useUIContext","backgroundColor","getGoalCategoryBasedColorTheme","TAB_CONFIG","jsx","ChaptersList","MilestoneTestsList","MilestoneWidgetResources","filteredTabConfig","tabName","selectedTabName","setSelectedTabName","useState","_a","handleTabChange","useCallback","ctaLabel","Styled.NoPlanCardWrapper","Text","jsxs","Fragment","Styled.TabsWrapper","tabConfig","tabInfo","label","isSelected","Styled.TabsText","Styled.TabComponentWrapper"],"mappings":";;;;;;;;;AAaM,MAAAA,KAAyCC,EAAK,CAASC,MAAA;;AACrD,QAAA;AAAA,IACJ,cAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,UAAAC;AAAA,IACA,UAAAC;AAAA,IACA,eAAAC;AAAA,IACA,WAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,sBAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,aAAAC;AAAA,EACE,IAAAb,GACE;AAAA,IACJ,cAAAc;AAAA,IACA,mBAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,uBAAAC;AAAA,IACA,eAAAC;AAAA,IACA,YAAAC;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,aAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,eAAAC;AAAA,IACA,cAAAC;AAAA,IACA,aAAAC;AAAA,IACA,sBAAAC;AAAA,EACE,
|
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 type { IMilestoneTabConfig, IMilestoneTabsProps } from './milestone-tabs-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useState } 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';\n\nconst MilestoneTabs: FC<IMilestoneTabsProps> = memo(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 } = 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 } = 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 = {\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 />\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 const filteredTabConfig =\n (visibleTabs ?? []).length === 0\n ? Object.entries(TAB_CONFIG)\n : Object.entries(TAB_CONFIG).filter(([tabName]) =>\n (visibleTabs ?? []).includes(tabName.toUpperCase()),\n );\n const [selectedTabName, setSelectedTabName] = useState(\n userMilestoneId === activeMilestoneId ? activeTabId : filteredTabConfig?.[0]?.[0] || 'chapters',\n );\n\n const handleTabChange = useCallback(\n (tabName: keyof IMilestoneTabConfig, 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 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 ? 'ub3-bold' : 'ub3'}\n $align=\"center\"\n key={tabName}\n $selected={isSelected}\n onClick={() => handleTabChange(tabName as keyof IMilestoneTabConfig, label)}\n >\n {label}\n </Styled.TabsText>\n );\n })}\n </Styled.TabsWrapper>\n\n <Styled.TabComponentWrapper>\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","onAddChapter","onAssignResources","onChapterClick","onCreateMilestoneTest","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onNodeAssignAsHomework","onTestPreview","onTestReview","onTestStart","onWidgetTabSelection","visibleTabs","trackEvent","useUIContext","backgroundColor","getGoalCategoryBasedColorTheme","TAB_CONFIG","jsx","ChaptersList","MilestoneTestsList","MilestoneWidgetResources","filteredTabConfig","tabName","selectedTabName","setSelectedTabName","useState","_a","handleTabChange","useCallback","ctaLabel","Styled.NoPlanCardWrapper","Text","jsxs","Fragment","Styled.TabsWrapper","tabConfig","tabInfo","label","isSelected","Styled.TabsText","Styled.TabComponentWrapper"],"mappings":"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"}
|
@@ -1,128 +1,130 @@
|
|
1
|
-
import { jsxs as
|
2
|
-
import { memo as
|
3
|
-
import
|
4
|
-
import
|
5
|
-
import
|
6
|
-
import { getGoalCategoryBasedColorTheme as
|
7
|
-
import { MainContainer as
|
8
|
-
const
|
1
|
+
import { jsxs as ee, jsx as o } from "react/jsx-runtime";
|
2
|
+
import { memo as oe, useState as te, useCallback as f, useEffect as ne } from "react";
|
3
|
+
import se from "../../../../ui/layout/flex-view.js";
|
4
|
+
import ae from "./milestone-info.js";
|
5
|
+
import ie from "./milestone-tabs/milestone-tabs.js";
|
6
|
+
import { getGoalCategoryBasedColorTheme as re } from "./milestone-utils.js";
|
7
|
+
import { MainContainer as de, Wrapper as le, ContentWrapper as ce, Content as me } from "./milestone-widget-styled.js";
|
8
|
+
const Ae = oe((h) => {
|
9
9
|
const { milestone: s, studentId: a, isMilestoneActive: i, ...T } = h, {
|
10
|
-
isStudentPresent:
|
11
|
-
isClassOngoing:
|
10
|
+
isStudentPresent: A,
|
11
|
+
isClassOngoing: E,
|
12
12
|
userType: r,
|
13
|
-
studentName:
|
14
|
-
parentName:
|
15
|
-
teacherName:
|
13
|
+
studentName: M,
|
14
|
+
parentName: N,
|
15
|
+
teacherName: x,
|
16
16
|
courseStream: _,
|
17
17
|
activeMilestoneId: d,
|
18
18
|
activeTabId: b,
|
19
19
|
onAddOutcome: D,
|
20
20
|
onChapterClick: I,
|
21
|
-
onEdit:
|
22
|
-
onCreateMilestoneTest:
|
23
|
-
onDraftPublish:
|
24
|
-
onAddChapter:
|
25
|
-
onAssignResources:
|
26
|
-
onNodeAttempt:
|
27
|
-
onNodeView:
|
28
|
-
onNodeReview:
|
21
|
+
onEdit: w,
|
22
|
+
onCreateMilestoneTest: P,
|
23
|
+
onDraftPublish: R,
|
24
|
+
onAddChapter: W,
|
25
|
+
onAssignResources: $,
|
26
|
+
onNodeAttempt: k,
|
27
|
+
onNodeView: v,
|
28
|
+
onNodeReview: S,
|
29
29
|
onNodeReattempt: y,
|
30
30
|
onNodeReset: O,
|
31
31
|
onNodeUnassign: B,
|
32
|
-
|
32
|
+
onNodeAssignAsHomework: G,
|
33
|
+
onWidgetTabSelection: V,
|
33
34
|
//* Test sheet callbacks
|
34
|
-
onTestPreview:
|
35
|
-
onTestReview:
|
36
|
-
onTestStart:
|
37
|
-
milestoneType:
|
35
|
+
onTestPreview: F,
|
36
|
+
onTestReview: U,
|
37
|
+
onTestStart: j,
|
38
|
+
milestoneType: X
|
38
39
|
} = T, {
|
39
40
|
id: l,
|
40
41
|
user_milestone_plan: c,
|
41
|
-
outcome_data:
|
42
|
+
outcome_data: H,
|
42
43
|
milestone_state: t,
|
43
44
|
permissions: m,
|
44
45
|
goal_code: p,
|
45
46
|
goal_category: g
|
46
|
-
} = s, [u, n] =
|
47
|
-
i && t === "ACTIVE" ||
|
48
|
-
), Y = !!c, { can_update_plan: q } = m, { outcomes: z } =
|
47
|
+
} = s, [u, n] = te(
|
48
|
+
i && t === "ACTIVE" || X === "DRAFT"
|
49
|
+
), Y = !!c, { can_update_plan: q } = m, { outcomes: z } = H || {}, { user_chapters: J = [] } = c || {}, K = f(() => {
|
49
50
|
n((e) => !e);
|
50
|
-
}, []), C = t === "DRAFT",
|
51
|
+
}, []), C = t === "DRAFT", L = t === "OUTCOME_ADDED", { backgroundColor: Q } = re(
|
51
52
|
g,
|
52
53
|
C
|
53
|
-
),
|
54
|
+
), Z = f(() => {
|
54
55
|
n((e) => !e);
|
55
56
|
}, [n]);
|
56
|
-
return
|
57
|
+
return ne(() => {
|
57
58
|
const e = document.getElementById(`milestone-${d}`);
|
58
59
|
e && e.scrollIntoView();
|
59
|
-
}, []), /* @__PURE__ */
|
60
|
+
}, []), /* @__PURE__ */ ee(de, { id: `milestone-${l}`, children: [
|
60
61
|
/* @__PURE__ */ o(
|
61
|
-
|
62
|
+
le,
|
62
63
|
{
|
63
|
-
onClick:
|
64
|
-
$background:
|
64
|
+
onClick: Z,
|
65
|
+
$background: Q,
|
65
66
|
$gapX: 1.5,
|
66
67
|
$borderColor: "GREY_2",
|
67
|
-
children: /* @__PURE__ */ o(
|
68
|
-
|
68
|
+
children: /* @__PURE__ */ o(se, { $flexGapX: p ? 1.5 : 1, children: /* @__PURE__ */ o(
|
69
|
+
ae,
|
69
70
|
{
|
70
71
|
milestone: s,
|
71
|
-
onEdit:
|
72
|
+
onEdit: w,
|
72
73
|
isExpanded: u,
|
73
|
-
toggleExpand:
|
74
|
+
toggleExpand: K,
|
74
75
|
userType: r,
|
75
|
-
isClassOngoing:
|
76
|
-
isStudentPresent:
|
76
|
+
isClassOngoing: E,
|
77
|
+
isStudentPresent: A,
|
77
78
|
onAddOutcome: D,
|
78
79
|
studentId: a,
|
79
|
-
studentName:
|
80
|
-
teacherName:
|
81
|
-
parentName:
|
82
|
-
onDraftPublish:
|
80
|
+
studentName: M,
|
81
|
+
teacherName: x ?? "",
|
82
|
+
parentName: N ?? "",
|
83
|
+
onDraftPublish: R,
|
83
84
|
courseStream: _,
|
84
85
|
outcomes: z
|
85
86
|
}
|
86
87
|
) })
|
87
88
|
}
|
88
89
|
),
|
89
|
-
/* @__PURE__ */ o(
|
90
|
-
|
90
|
+
/* @__PURE__ */ o(ce, { $expanded: u, children: /* @__PURE__ */ o(me, { children: /* @__PURE__ */ o(
|
91
|
+
ie,
|
91
92
|
{
|
92
93
|
goalCategory: g,
|
93
94
|
isGoalCreation: !!p,
|
94
95
|
isDraftMilestone: C,
|
95
|
-
isOutcomeAdded:
|
96
|
+
isOutcomeAdded: L,
|
96
97
|
isMilestoneActive: i,
|
97
98
|
isPlanAvailable: Y,
|
98
99
|
userMilestoneId: l,
|
99
|
-
chapters:
|
100
|
+
chapters: J,
|
100
101
|
userType: r,
|
101
102
|
canUpdatePlan: q,
|
102
103
|
milestoneState: t,
|
103
104
|
studentId: a,
|
104
|
-
onAddChapter:
|
105
|
-
onAssignResources:
|
105
|
+
onAddChapter: W,
|
106
|
+
onAssignResources: $,
|
106
107
|
onChapterClick: I,
|
107
|
-
onCreateMilestoneTest:
|
108
|
-
onTestPreview:
|
109
|
-
onTestReview:
|
110
|
-
onTestStart:
|
111
|
-
onNodeAttempt:
|
112
|
-
onNodeView:
|
113
|
-
onNodeReview:
|
108
|
+
onCreateMilestoneTest: P,
|
109
|
+
onTestPreview: F,
|
110
|
+
onTestReview: U,
|
111
|
+
onTestStart: j,
|
112
|
+
onNodeAttempt: k,
|
113
|
+
onNodeView: v,
|
114
|
+
onNodeReview: S,
|
114
115
|
onNodeReattempt: y,
|
115
116
|
onNodeReset: O,
|
116
117
|
onNodeUnassign: B,
|
118
|
+
onNodeAssignAsHomework: G,
|
117
119
|
milestonePermissions: m,
|
118
120
|
activeMilestoneId: d,
|
119
121
|
activeTabId: b,
|
120
|
-
onWidgetTabSelection:
|
122
|
+
onWidgetTabSelection: V
|
121
123
|
}
|
122
124
|
) }) })
|
123
125
|
] });
|
124
126
|
});
|
125
127
|
export {
|
126
|
-
|
128
|
+
Ae as default
|
127
129
|
};
|
128
130
|
//# sourceMappingURL=milestone-widget.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"milestone-widget.js","sources":["../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.tsx"],"sourcesContent":["import type { IMilestoneWidgetProps } from './milestone-widget-types';\n\nimport React, { memo, useCallback, useEffect, useState } from 'react';\n\nimport FlexView from '../../../../ui/layout/flex-view';\nimport MilestoneInfoWrapper from './milestone-info';\nimport MilestoneTabs from './milestone-tabs/milestone-tabs';\nimport { getGoalCategoryBasedColorTheme } from './milestone-utils';\nimport * as Styled from './milestone-widget-styled';\n\nconst MilestoneWidget: React.FC<IMilestoneWidgetProps> = memo(props => {\n const { milestone, studentId, isMilestoneActive, ...restMilestoneWidgetProps } = props;\n const {\n isStudentPresent,\n isClassOngoing,\n userType,\n studentName,\n parentName,\n teacherName,\n courseStream,\n activeMilestoneId,\n activeTabId,\n onAddOutcome,\n onChapterClick,\n onEdit,\n onCreateMilestoneTest,\n onDraftPublish,\n onAddChapter,\n onAssignResources,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReattempt,\n onNodeReset,\n onNodeUnassign,\n onWidgetTabSelection,\n //* Test sheet callbacks\n onTestPreview,\n onTestReview,\n onTestStart,\n milestoneType,\n } = restMilestoneWidgetProps;\n\n const {\n id: milestoneId,\n user_milestone_plan: userMileStonePlan,\n outcome_data: outcomeData,\n milestone_state: milestoneState,\n permissions: milestonePermissions,\n goal_code: goalCode,\n goal_category: goalCategory,\n } = milestone;\n\n const [widgetExpanded, setWidgetExpanded] = useState(\n (isMilestoneActive && milestoneState === 'ACTIVE') || milestoneType === 'DRAFT',\n );\n\n const isPlanAvailable = Boolean(userMileStonePlan);\n\n const { can_update_plan: canUpdatePlan } = milestonePermissions;\n const { outcomes } = outcomeData || {};\n\n const { user_chapters: chaptersData = [] } = userMileStonePlan || {};\n\n const toggleExpand = useCallback(() => {\n setWidgetExpanded(prev => !prev);\n }, []);\n\n const isDraftMilestone = milestoneState === 'DRAFT';\n const isOutcomeAdded = milestoneState === 'OUTCOME_ADDED';\n\n const { backgroundColor: goalBackgroundColor } = getGoalCategoryBasedColorTheme(\n goalCategory,\n isDraftMilestone,\n );\n\n const handleOnWidgetExpand = useCallback(() => {\n setWidgetExpanded(prev => !prev);\n }, [setWidgetExpanded]);\n\n useEffect(() => {\n const $element = document.getElementById(`milestone-${activeMilestoneId}`);\n\n if ($element) {\n $element.scrollIntoView();\n }\n //* Disabling the exhaustive-deps rule as we want to run this effect only once\n //* We don't want this to run when activeMilestoneId changes, as it will cause component to scroll into the view every time.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return (\n <Styled.MainContainer id={`milestone-${milestoneId}`}>\n <Styled.Wrapper\n onClick={handleOnWidgetExpand}\n $background={goalBackgroundColor}\n $gapX={1.5}\n $borderColor=\"GREY_2\"\n >\n <FlexView $flexGapX={goalCode ? 1.5 : 1}>\n <MilestoneInfoWrapper\n milestone={milestone}\n onEdit={onEdit}\n isExpanded={widgetExpanded}\n toggleExpand={toggleExpand}\n userType={userType}\n isClassOngoing={isClassOngoing}\n isStudentPresent={isStudentPresent}\n onAddOutcome={onAddOutcome}\n studentId={studentId}\n studentName={studentName}\n teacherName={teacherName ?? ''}\n parentName={parentName ?? ''}\n onDraftPublish={onDraftPublish}\n courseStream={courseStream}\n outcomes={outcomes}\n />\n </FlexView>\n </Styled.Wrapper>\n\n <Styled.ContentWrapper $expanded={widgetExpanded}>\n <Styled.Content>\n <MilestoneTabs\n goalCategory={goalCategory}\n isGoalCreation={!!goalCode}\n isDraftMilestone={isDraftMilestone}\n isOutcomeAdded={isOutcomeAdded}\n isMilestoneActive={isMilestoneActive}\n isPlanAvailable={isPlanAvailable}\n userMilestoneId={milestoneId}\n chapters={chaptersData}\n userType={userType}\n canUpdatePlan={canUpdatePlan}\n milestoneState={milestoneState}\n studentId={studentId}\n onAddChapter={onAddChapter}\n onAssignResources={onAssignResources}\n onChapterClick={onChapterClick}\n onCreateMilestoneTest={onCreateMilestoneTest}\n onTestPreview={onTestPreview}\n onTestReview={onTestReview}\n onTestStart={onTestStart}\n onNodeAttempt={onNodeAttempt}\n onNodeView={onNodeView}\n onNodeReview={onNodeReview}\n onNodeReattempt={onNodeReattempt}\n onNodeReset={onNodeReset}\n onNodeUnassign={onNodeUnassign}\n milestonePermissions={milestonePermissions}\n activeMilestoneId={activeMilestoneId}\n activeTabId={activeTabId}\n onWidgetTabSelection={onWidgetTabSelection}\n />\n </Styled.Content>\n </Styled.ContentWrapper>\n </Styled.MainContainer>\n );\n});\n\nexport default MilestoneWidget;\n"],"names":["MilestoneWidget","memo","props","milestone","studentId","isMilestoneActive","restMilestoneWidgetProps","isStudentPresent","isClassOngoing","userType","studentName","parentName","teacherName","courseStream","activeMilestoneId","activeTabId","onAddOutcome","onChapterClick","onEdit","onCreateMilestoneTest","onDraftPublish","onAddChapter","onAssignResources","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onWidgetTabSelection","onTestPreview","onTestReview","onTestStart","milestoneType","milestoneId","userMileStonePlan","outcomeData","milestoneState","milestonePermissions","goalCode","goalCategory","widgetExpanded","setWidgetExpanded","useState","isPlanAvailable","canUpdatePlan","outcomes","chaptersData","toggleExpand","useCallback","prev","isDraftMilestone","isOutcomeAdded","goalBackgroundColor","getGoalCategoryBasedColorTheme","handleOnWidgetExpand","useEffect","$element","Styled.MainContainer","jsx","Styled.Wrapper","FlexView","MilestoneInfoWrapper","Styled.ContentWrapper","Styled.Content","MilestoneTabs"],"mappings":";;;;;;;AAUM,MAAAA,KAAmDC,GAAK,CAASC,MAAA;AACrE,QAAM,EAAE,WAAAC,GAAW,WAAAC,GAAW,mBAAAC,GAAmB,GAAGC,EAA6B,IAAAJ,GAC3E;AAAA,IACJ,kBAAAK;AAAA,IACA,gBAAAC;AAAA,IACA,UAAAC;AAAA,IACA,aAAAC;AAAA,IACA,YAAAC;AAAA,IACA,aAAAC;AAAA,IACA,cAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,aAAAC;AAAA,IACA,cAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,QAAAC;AAAA,IACA,uBAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,cAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,eAAAC;AAAA,IACA,YAAAC;AAAA,IACA,cAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,aAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,sBAAAC;AAAA;AAAA,IAEA,eAAAC;AAAA,IACA,cAAAC;AAAA,IACA,aAAAC;AAAA,IACA,eAAAC;AAAA,EACE,
|
1
|
+
{"version":3,"file":"milestone-widget.js","sources":["../../../../../../src/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.tsx"],"sourcesContent":["import type { IMilestoneWidgetProps } from './milestone-widget-types';\n\nimport React, { memo, useCallback, useEffect, useState } from 'react';\n\nimport FlexView from '../../../../ui/layout/flex-view';\nimport MilestoneInfoWrapper from './milestone-info';\nimport MilestoneTabs from './milestone-tabs/milestone-tabs';\nimport { getGoalCategoryBasedColorTheme } from './milestone-utils';\nimport * as Styled from './milestone-widget-styled';\n\nconst MilestoneWidget: React.FC<IMilestoneWidgetProps> = memo(props => {\n const { milestone, studentId, isMilestoneActive, ...restMilestoneWidgetProps } = props;\n const {\n isStudentPresent,\n isClassOngoing,\n userType,\n studentName,\n parentName,\n teacherName,\n courseStream,\n activeMilestoneId,\n activeTabId,\n onAddOutcome,\n onChapterClick,\n onEdit,\n onCreateMilestoneTest,\n onDraftPublish,\n onAddChapter,\n onAssignResources,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReattempt,\n onNodeReset,\n onNodeUnassign,\n onNodeAssignAsHomework,\n onWidgetTabSelection,\n //* Test sheet callbacks\n onTestPreview,\n onTestReview,\n onTestStart,\n milestoneType,\n } = restMilestoneWidgetProps;\n\n const {\n id: milestoneId,\n user_milestone_plan: userMileStonePlan,\n outcome_data: outcomeData,\n milestone_state: milestoneState,\n permissions: milestonePermissions,\n goal_code: goalCode,\n goal_category: goalCategory,\n } = milestone;\n\n const [widgetExpanded, setWidgetExpanded] = useState(\n (isMilestoneActive && milestoneState === 'ACTIVE') || milestoneType === 'DRAFT',\n );\n\n const isPlanAvailable = Boolean(userMileStonePlan);\n\n const { can_update_plan: canUpdatePlan } = milestonePermissions;\n const { outcomes } = outcomeData || {};\n\n const { user_chapters: chaptersData = [] } = userMileStonePlan || {};\n\n const toggleExpand = useCallback(() => {\n setWidgetExpanded(prev => !prev);\n }, []);\n\n const isDraftMilestone = milestoneState === 'DRAFT';\n const isOutcomeAdded = milestoneState === 'OUTCOME_ADDED';\n\n const { backgroundColor: goalBackgroundColor } = getGoalCategoryBasedColorTheme(\n goalCategory,\n isDraftMilestone,\n );\n\n const handleOnWidgetExpand = useCallback(() => {\n setWidgetExpanded(prev => !prev);\n }, [setWidgetExpanded]);\n\n useEffect(() => {\n const $element = document.getElementById(`milestone-${activeMilestoneId}`);\n\n if ($element) {\n $element.scrollIntoView();\n }\n //* Disabling the exhaustive-deps rule as we want to run this effect only once\n //* We don't want this to run when activeMilestoneId changes, as it will cause component to scroll into the view every time.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return (\n <Styled.MainContainer id={`milestone-${milestoneId}`}>\n <Styled.Wrapper\n onClick={handleOnWidgetExpand}\n $background={goalBackgroundColor}\n $gapX={1.5}\n $borderColor=\"GREY_2\"\n >\n <FlexView $flexGapX={goalCode ? 1.5 : 1}>\n <MilestoneInfoWrapper\n milestone={milestone}\n onEdit={onEdit}\n isExpanded={widgetExpanded}\n toggleExpand={toggleExpand}\n userType={userType}\n isClassOngoing={isClassOngoing}\n isStudentPresent={isStudentPresent}\n onAddOutcome={onAddOutcome}\n studentId={studentId}\n studentName={studentName}\n teacherName={teacherName ?? ''}\n parentName={parentName ?? ''}\n onDraftPublish={onDraftPublish}\n courseStream={courseStream}\n outcomes={outcomes}\n />\n </FlexView>\n </Styled.Wrapper>\n\n <Styled.ContentWrapper $expanded={widgetExpanded}>\n <Styled.Content>\n <MilestoneTabs\n goalCategory={goalCategory}\n isGoalCreation={!!goalCode}\n isDraftMilestone={isDraftMilestone}\n isOutcomeAdded={isOutcomeAdded}\n isMilestoneActive={isMilestoneActive}\n isPlanAvailable={isPlanAvailable}\n userMilestoneId={milestoneId}\n chapters={chaptersData}\n userType={userType}\n canUpdatePlan={canUpdatePlan}\n milestoneState={milestoneState}\n studentId={studentId}\n onAddChapter={onAddChapter}\n onAssignResources={onAssignResources}\n onChapterClick={onChapterClick}\n onCreateMilestoneTest={onCreateMilestoneTest}\n onTestPreview={onTestPreview}\n onTestReview={onTestReview}\n onTestStart={onTestStart}\n onNodeAttempt={onNodeAttempt}\n onNodeView={onNodeView}\n onNodeReview={onNodeReview}\n onNodeReattempt={onNodeReattempt}\n onNodeReset={onNodeReset}\n onNodeUnassign={onNodeUnassign}\n onNodeAssignAsHomework={onNodeAssignAsHomework}\n milestonePermissions={milestonePermissions}\n activeMilestoneId={activeMilestoneId}\n activeTabId={activeTabId}\n onWidgetTabSelection={onWidgetTabSelection}\n />\n </Styled.Content>\n </Styled.ContentWrapper>\n </Styled.MainContainer>\n );\n});\n\nexport default MilestoneWidget;\n"],"names":["MilestoneWidget","memo","props","milestone","studentId","isMilestoneActive","restMilestoneWidgetProps","isStudentPresent","isClassOngoing","userType","studentName","parentName","teacherName","courseStream","activeMilestoneId","activeTabId","onAddOutcome","onChapterClick","onEdit","onCreateMilestoneTest","onDraftPublish","onAddChapter","onAssignResources","onNodeAttempt","onNodeView","onNodeReview","onNodeReattempt","onNodeReset","onNodeUnassign","onNodeAssignAsHomework","onWidgetTabSelection","onTestPreview","onTestReview","onTestStart","milestoneType","milestoneId","userMileStonePlan","outcomeData","milestoneState","milestonePermissions","goalCode","goalCategory","widgetExpanded","setWidgetExpanded","useState","isPlanAvailable","canUpdatePlan","outcomes","chaptersData","toggleExpand","useCallback","prev","isDraftMilestone","isOutcomeAdded","goalBackgroundColor","getGoalCategoryBasedColorTheme","handleOnWidgetExpand","useEffect","$element","Styled.MainContainer","jsx","Styled.Wrapper","FlexView","MilestoneInfoWrapper","Styled.ContentWrapper","Styled.Content","MilestoneTabs"],"mappings":"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"}
|
@@ -1,21 +1,21 @@
|
|
1
|
-
import { jsx as a, jsxs as C, Fragment as
|
2
|
-
import { h as
|
3
|
-
import { memo as
|
4
|
-
import { ILLUSTRATIONS as
|
1
|
+
import { jsx as a, jsxs as C, Fragment as ae } from "react/jsx-runtime";
|
2
|
+
import { h as le } from "../../../node_modules/humanize-plus/dist/humanize.js";
|
3
|
+
import { memo as Se, useMemo as me, useState as u, useCallback as Te, useEffect as p } from "react";
|
4
|
+
import { ILLUSTRATIONS as ce } from "../../../assets/illustrations/illustrations.js";
|
5
5
|
import { EVENTS as e } from "../../communication/pub-sub/constants.js";
|
6
|
-
import { useInClassActionListener as
|
6
|
+
import { useInClassActionListener as de } from "../../communication/pub-sub/hooks.js";
|
7
7
|
import { invalidateHomeworks as f } from "../../homework/hw-card-list/api/get-homeworks.js";
|
8
|
-
import
|
9
|
-
import { invalidateMilestoneResources as
|
10
|
-
import { useGetAllMilestonesdata as
|
11
|
-
import { invalidateTestHelpData as
|
12
|
-
import
|
13
|
-
import
|
14
|
-
import
|
15
|
-
import { ContentWrapper as
|
16
|
-
const
|
17
|
-
|
18
|
-
},
|
8
|
+
import _e from "../../ui/separator/separator.js";
|
9
|
+
import { invalidateMilestoneResources as Ne } from "./api/get-milestone-resources.js";
|
10
|
+
import { useGetAllMilestonesdata as Ae, invalidateMilestonesData as Me } from "./api/get-milestones.js";
|
11
|
+
import { invalidateTestHelpData as De } from "./api/get-tests-list.js";
|
12
|
+
import Ie from "./filter-milestones.js";
|
13
|
+
import Le from "./milestone-list/milestone-list.js";
|
14
|
+
import Re from "./milestone-list/milestone-loader/milestone-loader.js";
|
15
|
+
import { ContentWrapper as Oe, LoaderWrapper as Ce } from "./styled.js";
|
16
|
+
const ue = (d) => {
|
17
|
+
Me(d);
|
18
|
+
}, pe = Se(
|
19
19
|
({ studentName: d, studentId: l, studentClassroomId: h, ...v }) => {
|
20
20
|
const {
|
21
21
|
milestoneType: s,
|
@@ -26,8 +26,8 @@ const Ce = (d) => {
|
|
26
26
|
teacherName: G,
|
27
27
|
parentName: g,
|
28
28
|
courseStream: N,
|
29
|
-
activeMilestoneId:
|
30
|
-
activeTabId:
|
29
|
+
activeMilestoneId: w,
|
30
|
+
activeTabId: F,
|
31
31
|
onExpandPastMilestones: V,
|
32
32
|
onAddOutcome: x,
|
33
33
|
onChapterClick: b,
|
@@ -47,8 +47,9 @@ const Ce = (d) => {
|
|
47
47
|
onTestPreview: Y,
|
48
48
|
onTestReview: Z,
|
49
49
|
onTestStart: ee,
|
50
|
-
onWidgetTabSelection: te
|
51
|
-
|
50
|
+
onWidgetTabSelection: te,
|
51
|
+
onNodeAssignAsHomework: oe
|
52
|
+
} = v, n = me(
|
52
53
|
() => ({
|
53
54
|
milestone_state_group: s === "ACTIVE" ? _ === "TEACHER" ? "LIVE" : "STUDENT_LIVE" : s,
|
54
55
|
course_stream: N,
|
@@ -60,21 +61,21 @@ const Ce = (d) => {
|
|
60
61
|
getAll: m,
|
61
62
|
isStale: M,
|
62
63
|
isProcessing: S
|
63
|
-
} =
|
64
|
+
} = Ae(n), [D, I] = u(), [L, R] = u(!1), se = Te(
|
64
65
|
(T) => {
|
65
66
|
const { searchText: i, selectedBoard: E, selectedGrade: r } = T || {};
|
66
67
|
(i || E || r) && R(!0);
|
67
68
|
const c = o == null ? void 0 : o.filter((t) => {
|
68
|
-
const { milestone_name:
|
69
|
-
return (i ?
|
69
|
+
const { milestone_name: ie, board: Ee, grade: re } = t || {};
|
70
|
+
return (i ? ie.toLowerCase().includes(i.toLowerCase()) : !0) && (E ? Ee === E : !0) && (r ? re === r : !0);
|
70
71
|
});
|
71
72
|
I(c);
|
72
73
|
},
|
73
74
|
[o]
|
74
|
-
),
|
75
|
+
), ne = () => {
|
75
76
|
R(!1), I(void 0);
|
76
77
|
};
|
77
|
-
if (
|
78
|
+
if (de(
|
78
79
|
{
|
79
80
|
studentClassroomId: h,
|
80
81
|
actions: [
|
@@ -108,13 +109,13 @@ const Ce = (d) => {
|
|
108
109
|
)) == null ? void 0 : c.eventPayload;
|
109
110
|
if (i) {
|
110
111
|
const { milestoneId: t } = i || {};
|
111
|
-
f(l),
|
112
|
+
f(l), Ne(t);
|
112
113
|
}
|
113
114
|
if (E) {
|
114
115
|
const { milestoneId: t } = E;
|
115
|
-
f(l),
|
116
|
+
f(l), De(t);
|
116
117
|
}
|
117
|
-
|
118
|
+
ue(n);
|
118
119
|
}
|
119
120
|
},
|
120
121
|
(s === "ACTIVE" || s === "INACTIVE") && A
|
@@ -123,24 +124,24 @@ const Ce = (d) => {
|
|
123
124
|
}, [m, n]), p(() => {
|
124
125
|
!S && M && m(n);
|
125
126
|
}, [m, n, M, S]), S && !o)
|
126
|
-
return /* @__PURE__ */ a(
|
127
|
+
return /* @__PURE__ */ a(Re, { numMilestones: 2 });
|
127
128
|
const O = s === "ACTIVE" && o && o.length > 6;
|
128
|
-
return /* @__PURE__ */ C(
|
129
|
-
S && /* @__PURE__ */ a(
|
130
|
-
O && /* @__PURE__ */ C(
|
129
|
+
return /* @__PURE__ */ C(Oe, { $disablePointerEvents: S, children: [
|
130
|
+
S && /* @__PURE__ */ a(Ce, { children: /* @__PURE__ */ a("img", { src: ce.LOADER_1, alt: "loading" }) }),
|
131
|
+
O && /* @__PURE__ */ C(ae, { children: [
|
131
132
|
/* @__PURE__ */ a(
|
132
|
-
|
133
|
+
Ie,
|
133
134
|
{
|
134
135
|
filteredMilestones: D,
|
135
136
|
milestones: o,
|
136
|
-
handleFilterMilestones:
|
137
|
-
handleClearFilter:
|
137
|
+
handleFilterMilestones: se,
|
138
|
+
handleClearFilter: ne
|
138
139
|
}
|
139
140
|
),
|
140
|
-
/* @__PURE__ */ a(
|
141
|
+
/* @__PURE__ */ a(_e, { heightX: 1.5 })
|
141
142
|
] }),
|
142
143
|
/* @__PURE__ */ a(
|
143
|
-
|
144
|
+
Le,
|
144
145
|
{
|
145
146
|
showFilters: !!O,
|
146
147
|
canCreatePlan: U,
|
@@ -168,11 +169,12 @@ const Ce = (d) => {
|
|
168
169
|
onNodeReattempt: B,
|
169
170
|
onNodeReset: J,
|
170
171
|
onNodeUnassign: Q,
|
171
|
-
|
172
|
-
|
172
|
+
onNodeAssignAsHomework: oe,
|
173
|
+
activeMilestoneId: w,
|
174
|
+
activeTabId: F,
|
173
175
|
onWidgetTabSelection: te,
|
174
176
|
studentId: l,
|
175
|
-
studentName:
|
177
|
+
studentName: le.titleCase(d),
|
176
178
|
teacherName: G,
|
177
179
|
parentName: g,
|
178
180
|
userType: _,
|
@@ -181,8 +183,8 @@ const Ce = (d) => {
|
|
181
183
|
)
|
182
184
|
] });
|
183
185
|
}
|
184
|
-
),
|
186
|
+
), Xe = pe;
|
185
187
|
export {
|
186
|
-
|
188
|
+
Xe as default
|
187
189
|
};
|
188
190
|
//# sourceMappingURL=milestone-list-container.js.map
|