@cuemath/leap 2.8.60-as4 → 2.8.60-gs1
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 +1 -1
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
- package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +16 -15
- package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +1 -1
- package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +8 -12
- package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
- package/dist/features/chapters-v2/utils/index.js +4 -5
- package/dist/features/chapters-v2/utils/index.js.map +1 -1
- package/dist/features/chapters-v2/utils/node-card-utils.js +34 -62
- package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +81 -79
- 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 +61 -59
- 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 +85 -83
- 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 +90 -88
- 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 +98 -82
- package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +71 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +31 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +38 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +79 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +18 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +51 -0
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +11 -0
- package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +1 -0
- package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +144 -0
- package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -0
- package/dist/features/sheets/resources-list/resource-item/styled.js +1 -1
- package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
- package/dist/index.d.ts +11 -33
- package/dist/index.js +29 -31
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/dist/features/homework/card-menu-options.js +0 -25
- package/dist/features/homework/card-menu-options.js.map +0 -1
- package/dist/features/homework/homework-card.js +0 -210
- package/dist/features/homework/homework-card.js.map +0 -1
- package/dist/features/homework/styles.js +0 -114
- package/dist/features/homework/styles.js.map +0 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +0 -165
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +0 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +0 -25
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +0 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +0 -82
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +0 -1
- package/dist/features/recent-chapters/api/get-recent-chapters.js +0 -9
- package/dist/features/recent-chapters/api/get-recent-chapters.js.map +0 -1
- package/dist/features/recent-chapters/recent-chapters-styled.js +0 -16
- package/dist/features/recent-chapters/recent-chapters-styled.js.map +0 -1
- package/dist/features/recent-chapters/recent-chapters.js +0 -43
- package/dist/features/recent-chapters/recent-chapters.js.map +0 -1
- package/dist/features/sheet-v2/resource-list/resource-list.js +0 -52
- package/dist/features/sheet-v2/resource-list/resource-list.js.map +0 -1
@@ -1,113 +1,129 @@
|
|
1
|
-
import { jsx as e, jsxs as
|
2
|
-
import { memo as
|
3
|
-
import { IMAGES as
|
4
|
-
import
|
5
|
-
import
|
6
|
-
import
|
7
|
-
import
|
8
|
-
import
|
9
|
-
import
|
10
|
-
import
|
11
|
-
import
|
12
|
-
import
|
13
|
-
import { useGetMilestoneResources as
|
14
|
-
import { MilestoneResourcesWrapper as
|
15
|
-
const
|
1
|
+
import { jsx as e, jsxs as h, Fragment as D } from "react/jsx-runtime";
|
2
|
+
import { memo as q, useCallback as t, useEffect as G } from "react";
|
3
|
+
import { IMAGES as H } from "../../../../assets/images/images.js";
|
4
|
+
import X from "../../../../assets/line-icons/icons/plus.js";
|
5
|
+
import z from "../../../../assets/line-icons/icons/search.js";
|
6
|
+
import F from "../../../sheets/resources-list/resources-list.js";
|
7
|
+
import L from "../../../ui/arrow-tooltip/arrow-tooltip.js";
|
8
|
+
import C from "../../../ui/buttons/button/button.js";
|
9
|
+
import _ from "../../../ui/buttons/icon-button/icon-button.js";
|
10
|
+
import M from "../../../ui/layout/flex-view.js";
|
11
|
+
import V from "../../../ui/loader/app-loader/app-loader.js";
|
12
|
+
import S from "../../../ui/text/text.js";
|
13
|
+
import { useGetMilestoneResources as Y } from "../../milestone-list-container/api/get-milestone-resources.js";
|
14
|
+
import { MilestoneResourcesWrapper as m, SearchButtonWrapper as J, SearchButtonCover as K, DefaultWrapper as P } from "./resources-list-styled.js";
|
15
|
+
const ue = q((T) => {
|
16
16
|
const {
|
17
|
-
isDraftMilestone:
|
18
|
-
isMilestoneActive:
|
19
|
-
userType:
|
20
|
-
studentId:
|
17
|
+
isDraftMilestone: f,
|
18
|
+
isMilestoneActive: s,
|
19
|
+
userType: p,
|
20
|
+
studentId: g,
|
21
21
|
userMilestoneId: r,
|
22
|
-
canUpdatePlan:
|
22
|
+
canUpdatePlan: A,
|
23
23
|
onAssignResources: o,
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
24
|
+
onStart: W,
|
25
|
+
onUnAssignSheet: i,
|
26
|
+
onReset: n,
|
27
|
+
onPreview: x,
|
28
|
+
onReview: j,
|
29
|
+
onResume: k,
|
30
|
+
onReattempt: O
|
31
|
+
} = T, $ = p === "TEACHER", w = !A || !s || s && f, {
|
32
|
+
get: R,
|
33
|
+
isProcessed: a,
|
34
|
+
isProcessing: y,
|
35
|
+
isProcessingFailed: c,
|
36
|
+
isStale: I,
|
37
|
+
data: l
|
38
|
+
} = Y(), b = t(() => {
|
39
|
+
r && R(r, void 0, {
|
40
|
+
studentId: g
|
40
41
|
});
|
41
|
-
}, [
|
42
|
-
|
43
|
-
}, [
|
44
|
-
|
45
|
-
!
|
46
|
-
}, [
|
47
|
-
const
|
42
|
+
}, [g, r, R]), d = t(() => {
|
43
|
+
b();
|
44
|
+
}, [b]);
|
45
|
+
G(() => {
|
46
|
+
!y && (!a && !c || I) && d();
|
47
|
+
}, [d, a, y, c, I]);
|
48
|
+
const E = t(() => {
|
48
49
|
if (typeof o != "function")
|
49
50
|
throw new Error("onAssignResources must be a function");
|
50
51
|
if (!r) throw new Error("userMilestoneId is required");
|
51
52
|
o(r);
|
52
|
-
}, [o, r]),
|
53
|
-
|
54
|
-
|
53
|
+
}, [o, r]), U = t(
|
54
|
+
(u) => {
|
55
|
+
if (typeof i != "function")
|
56
|
+
throw new Error("onUnAssignSheet must be a function");
|
57
|
+
if (!r) throw new Error("userMilestoneId is required");
|
58
|
+
i(u, r);
|
59
|
+
},
|
60
|
+
[i, r]
|
61
|
+
), v = t(
|
62
|
+
(u) => {
|
63
|
+
n == null || n(u, r);
|
64
|
+
},
|
65
|
+
[n, r]
|
66
|
+
), B = l && l.length > 0;
|
67
|
+
return c ? /* @__PURE__ */ e(
|
68
|
+
m,
|
55
69
|
{
|
56
70
|
$alignItems: "center",
|
57
71
|
$justifyContent: "center",
|
58
72
|
$background: "WHITE",
|
59
|
-
children: /* @__PURE__ */
|
60
|
-
/* @__PURE__ */ e(
|
73
|
+
children: /* @__PURE__ */ h(M, { $flexGapX: 1.5, $alignItems: "center", $justifyContent: "center", children: [
|
74
|
+
/* @__PURE__ */ e(S, { $renderAs: "h6", children: "Oops! Something went wrong. Please try again later." }),
|
61
75
|
/* @__PURE__ */ e(
|
62
|
-
|
76
|
+
C,
|
63
77
|
{
|
64
78
|
widthX: 14,
|
65
79
|
size: "small",
|
66
80
|
shape: "square",
|
67
81
|
renderAs: "primary",
|
68
82
|
label: "Try again",
|
69
|
-
onClick:
|
83
|
+
onClick: d
|
70
84
|
}
|
71
85
|
)
|
72
86
|
] })
|
73
87
|
}
|
74
|
-
) :
|
88
|
+
) : a ? /* @__PURE__ */ e(m, { $justifyContent: "space-between", children: B ? /* @__PURE__ */ h(D, { children: [
|
75
89
|
/* @__PURE__ */ e(
|
76
|
-
|
90
|
+
F,
|
77
91
|
{
|
78
|
-
sheets:
|
79
|
-
userType:
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
92
|
+
sheets: l,
|
93
|
+
userType: p,
|
94
|
+
userMilestoneId: r,
|
95
|
+
isMilestoneWidget: !0,
|
96
|
+
onStart: W,
|
97
|
+
onResume: k,
|
98
|
+
onReattempt: O,
|
99
|
+
onUnAssignSheet: U,
|
100
|
+
onReset: v,
|
101
|
+
onPreview: x,
|
102
|
+
onReview: j
|
87
103
|
}
|
88
104
|
),
|
89
|
-
|
90
|
-
|
105
|
+
$ && A && /* @__PURE__ */ e(
|
106
|
+
J,
|
91
107
|
{
|
92
108
|
$flexDirection: "row",
|
93
109
|
$justifyContent: "flex-end",
|
94
110
|
$gapX: 1,
|
95
111
|
$gutterX: 1,
|
96
|
-
children: /* @__PURE__ */ e(
|
97
|
-
|
112
|
+
children: /* @__PURE__ */ e(K, { children: /* @__PURE__ */ e(
|
113
|
+
_,
|
98
114
|
{
|
99
|
-
Icon:
|
115
|
+
Icon: z,
|
100
116
|
renderAs: "secondary",
|
101
117
|
size: "small",
|
102
118
|
analyticsLabel: "Milestone Resource Search",
|
103
|
-
onClick:
|
104
|
-
disabled: !
|
119
|
+
onClick: E,
|
120
|
+
disabled: !s
|
105
121
|
}
|
106
122
|
) })
|
107
123
|
}
|
108
124
|
)
|
109
|
-
] }) : /* @__PURE__ */
|
110
|
-
|
125
|
+
] }) : /* @__PURE__ */ h(
|
126
|
+
M,
|
111
127
|
{
|
112
128
|
$width: "100%",
|
113
129
|
$height: "100%",
|
@@ -115,33 +131,33 @@ const ae = B((M) => {
|
|
115
131
|
$justifyContent: "flex-start",
|
116
132
|
$background: "WHITE",
|
117
133
|
children: [
|
118
|
-
/* @__PURE__ */ e(
|
119
|
-
/* @__PURE__ */ e(
|
120
|
-
|
134
|
+
/* @__PURE__ */ e(P, { $isImageWrapper: !0, children: /* @__PURE__ */ e("img", { src: H.BG_EMPTY_RESOURCES, alt: "Empty resources", width: 420, height: 420 }) }),
|
135
|
+
/* @__PURE__ */ e(P, { children: $ ? /* @__PURE__ */ e(
|
136
|
+
L,
|
121
137
|
{
|
122
138
|
renderAs: "primary",
|
123
139
|
position: "bottom",
|
124
|
-
hidden: !
|
125
|
-
tooltipItem:
|
140
|
+
hidden: !w,
|
141
|
+
tooltipItem: f ? "Allowed after plan is published" : "Plan is completed",
|
126
142
|
children: /* @__PURE__ */ e(
|
127
|
-
|
143
|
+
C,
|
128
144
|
{
|
129
145
|
renderAs: "primary",
|
130
146
|
label: "Assign Resource",
|
131
|
-
Icon:
|
147
|
+
Icon: X,
|
132
148
|
shape: "square",
|
133
149
|
size: "small",
|
134
|
-
onClick:
|
135
|
-
disabled:
|
150
|
+
onClick: E,
|
151
|
+
disabled: w
|
136
152
|
}
|
137
153
|
)
|
138
154
|
}
|
139
|
-
) : /* @__PURE__ */ e(
|
155
|
+
) : /* @__PURE__ */ e(S, { $renderAs: "ab2-bold", children: "Wait for the teacher to assign a resource" }) })
|
140
156
|
]
|
141
157
|
}
|
142
|
-
) }) : /* @__PURE__ */ e(
|
158
|
+
) }) : /* @__PURE__ */ e(m, { $justifyContent: "center", $background: "WHITE", children: /* @__PURE__ */ e(V, { height: "100%" }) });
|
143
159
|
});
|
144
160
|
export {
|
145
|
-
|
161
|
+
ue as default
|
146
162
|
};
|
147
163
|
//# sourceMappingURL=resources-list.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"resources-list.js","sources":["../../../../../src/features/milestone/milestone-resources/resources-list/resources-list.tsx"],"sourcesContent":["import type { IMilestoneWidgetResourcesProps } from './resources-list-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect } from 'react';\n\nimport { IMAGES } from '../../../../assets/images/images';\nimport PlusIcon from '../../../../assets/line-icons/icons/plus';\nimport SearchIcon from '../../../../assets/line-icons/icons/search';\nimport ResourcesList from '../../../sheet-v2/resource-list/resource-list';\nimport ArrowTooltip from '../../../ui/arrow-tooltip/arrow-tooltip';\nimport Button from '../../../ui/buttons/button/button';\nimport IconButton from '../../../ui/buttons/icon-button/icon-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport AppLoader from '../../../ui/loader/app-loader/app-loader';\nimport Text from '../../../ui/text/text';\nimport { useGetMilestoneResources } from '../../milestone-list-container/api/get-milestone-resources';\nimport * as Styled from './resources-list-styled';\n\nconst MilestoneWidgetResources: FC<IMilestoneWidgetResourcesProps> = memo(props => {\n const {\n isDraftMilestone,\n isMilestoneActive,\n userType,\n studentId,\n userMilestoneId,\n canUpdatePlan,\n onAssignResources,\n onNodeAttempt,\n onNodeView,\n onNodeReview,\n onNodeReset,\n onNodeUnassign,\n onNodeReattempt,\n } = props;\n\n const isTeacher = userType === 'TEACHER';\n const isEPSheetCreationDisabled =\n !canUpdatePlan || !isMilestoneActive || (isMilestoneActive && isDraftMilestone);\n\n const {\n get: getMilestoneResources,\n isProcessed,\n isProcessing,\n isProcessingFailed,\n isStale,\n data: sheets,\n } = useGetMilestoneResources();\n\n const fetchMilestoneResources = useCallback(() => {\n if (userMilestoneId) {\n getMilestoneResources(userMilestoneId, undefined, {\n studentId,\n });\n }\n }, [studentId, userMilestoneId, getMilestoneResources]);\n\n const handleOnTryAgain = useCallback(() => {\n fetchMilestoneResources();\n }, [fetchMilestoneResources]);\n\n useEffect(() => {\n if (!isProcessing && ((!isProcessed && !isProcessingFailed) || isStale)) {\n handleOnTryAgain();\n }\n }, [handleOnTryAgain, isProcessed, isProcessing, isProcessingFailed, isStale]);\n\n const handleOnAssignResources = useCallback(() => {\n if (typeof onAssignResources !== 'function')\n throw new Error('onAssignResources must be a function');\n\n if (!userMilestoneId) throw new Error('userMilestoneId is required');\n\n onAssignResources(userMilestoneId);\n }, [onAssignResources, userMilestoneId]);\n\n const sheetsDataPresent = sheets && sheets.length > 0;\n\n if (isProcessingFailed) {\n return (\n <Styled.MilestoneResourcesWrapper\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $background=\"WHITE\"\n >\n <FlexView $flexGapX={1.5} $alignItems=\"center\" $justifyContent=\"center\">\n <Text $renderAs=\"h6\">Oops! Something went wrong. Please try again later.</Text>\n <Button\n widthX={14}\n size=\"small\"\n shape=\"square\"\n renderAs=\"primary\"\n label=\"Try again\"\n onClick={handleOnTryAgain}\n />\n </FlexView>\n </Styled.MilestoneResourcesWrapper>\n );\n }\n\n if (isProcessed) {\n return (\n <Styled.MilestoneResourcesWrapper $justifyContent=\"space-between\">\n {sheetsDataPresent ? (\n <>\n <ResourcesList\n sheets={sheets}\n userType={userType}\n onNodeAttempt={onNodeAttempt}\n onNodeView={onNodeView}\n onNodeReview={onNodeReview}\n onNodeReattempt={onNodeReattempt}\n onNodeReset={onNodeReset}\n onNodeUnassign={onNodeUnassign}\n userMilestoneId={userMilestoneId}\n />\n\n {isTeacher && canUpdatePlan && (\n <Styled.SearchButtonWrapper\n $flexDirection=\"row\"\n $justifyContent=\"flex-end\"\n $gapX={1}\n $gutterX={1}\n >\n <Styled.SearchButtonCover>\n <IconButton\n Icon={SearchIcon}\n renderAs=\"secondary\"\n size=\"small\"\n analyticsLabel=\"Milestone Resource Search\"\n onClick={handleOnAssignResources}\n disabled={!isMilestoneActive}\n />\n </Styled.SearchButtonCover>\n </Styled.SearchButtonWrapper>\n )}\n </>\n ) : (\n <FlexView\n $width=\"100%\"\n $height=\"100%\"\n $alignItems=\"center\"\n $justifyContent=\"flex-start\"\n $background=\"WHITE\"\n >\n <Styled.DefaultWrapper $isImageWrapper>\n <img src={IMAGES.BG_EMPTY_RESOURCES} alt=\"Empty resources\" width={420} height={420} />\n </Styled.DefaultWrapper>\n\n <Styled.DefaultWrapper>\n {isTeacher ? (\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n hidden={!isEPSheetCreationDisabled}\n tooltipItem={\n isDraftMilestone ? 'Allowed after plan is published' : 'Plan is completed'\n }\n >\n <Button\n renderAs=\"primary\"\n label=\"Assign Resource\"\n Icon={PlusIcon}\n shape=\"square\"\n size=\"small\"\n onClick={handleOnAssignResources}\n disabled={isEPSheetCreationDisabled}\n />\n </ArrowTooltip>\n ) : (\n <Text $renderAs=\"ab2-bold\">Wait for the teacher to assign a resource</Text>\n )}\n </Styled.DefaultWrapper>\n </FlexView>\n )}\n </Styled.MilestoneResourcesWrapper>\n );\n }\n\n return (\n <Styled.MilestoneResourcesWrapper $justifyContent=\"center\" $background=\"WHITE\">\n <AppLoader height=\"100%\" />\n </Styled.MilestoneResourcesWrapper>\n );\n});\n\nexport default MilestoneWidgetResources;\n"],"names":["MilestoneWidgetResources","memo","props","isDraftMilestone","isMilestoneActive","userType","studentId","userMilestoneId","canUpdatePlan","onAssignResources","onNodeAttempt","onNodeView","onNodeReview","onNodeReset","onNodeUnassign","onNodeReattempt","isTeacher","isEPSheetCreationDisabled","getMilestoneResources","isProcessed","isProcessing","isProcessingFailed","isStale","sheets","useGetMilestoneResources","fetchMilestoneResources","useCallback","handleOnTryAgain","useEffect","handleOnAssignResources","sheetsDataPresent","jsx","Styled.MilestoneResourcesWrapper","FlexView","Text","Button","jsxs","Fragment","ResourcesList","Styled.SearchButtonWrapper","Styled.SearchButtonCover","IconButton","SearchIcon","Styled.DefaultWrapper","IMAGES","ArrowTooltip","PlusIcon","AppLoader"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"resources-list.js","sources":["../../../../../src/features/milestone/milestone-resources/resources-list/resources-list.tsx"],"sourcesContent":["import type { ISheetItemCallbackProps } from '../../../sheets/sheets-list/sheet-item/sheet-item-types';\nimport type { IMilestoneWidgetResourcesProps } from './resources-list-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect } from 'react';\n\nimport { IMAGES } from '../../../../assets/images/images';\nimport PlusIcon from '../../../../assets/line-icons/icons/plus';\nimport SearchIcon from '../../../../assets/line-icons/icons/search';\nimport ResourcesList from '../../../sheets/resources-list/resources-list';\nimport ArrowTooltip from '../../../ui/arrow-tooltip/arrow-tooltip';\nimport Button from '../../../ui/buttons/button/button';\nimport IconButton from '../../../ui/buttons/icon-button/icon-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport AppLoader from '../../../ui/loader/app-loader/app-loader';\nimport Text from '../../../ui/text/text';\nimport { useGetMilestoneResources } from '../../milestone-list-container/api/get-milestone-resources';\nimport * as Styled from './resources-list-styled';\n\nconst MilestoneWidgetResources: FC<IMilestoneWidgetResourcesProps> = memo(props => {\n const {\n isDraftMilestone,\n isMilestoneActive,\n userType,\n studentId,\n userMilestoneId,\n canUpdatePlan,\n onAssignResources,\n onStart,\n onUnAssignSheet,\n onReset,\n onPreview,\n onReview,\n onResume,\n onReattempt,\n } = props;\n\n const isTeacher = userType === 'TEACHER';\n const isEPSheetCreationDisabled =\n !canUpdatePlan || !isMilestoneActive || (isMilestoneActive && isDraftMilestone);\n\n const {\n get: getMilestoneResources,\n isProcessed,\n isProcessing,\n isProcessingFailed,\n isStale,\n data: sheets,\n } = useGetMilestoneResources();\n\n const fetchMilestoneResources = useCallback(() => {\n if (userMilestoneId) {\n getMilestoneResources(userMilestoneId, undefined, {\n studentId,\n });\n }\n }, [studentId, userMilestoneId, getMilestoneResources]);\n\n const handleOnTryAgain = useCallback(() => {\n fetchMilestoneResources();\n }, [fetchMilestoneResources]);\n\n useEffect(() => {\n if (!isProcessing && ((!isProcessed && !isProcessingFailed) || isStale)) {\n handleOnTryAgain();\n }\n }, [handleOnTryAgain, isProcessed, isProcessing, isProcessingFailed, isStale]);\n\n const handleOnAssignResources = useCallback(() => {\n if (typeof onAssignResources !== 'function')\n throw new Error('onAssignResources must be a function');\n\n if (!userMilestoneId) throw new Error('userMilestoneId is required');\n\n onAssignResources(userMilestoneId);\n }, [onAssignResources, userMilestoneId]);\n\n const handleOnUnAssignResources = useCallback<\n NonNullable<ISheetItemCallbackProps['onUnAssignSheet']>\n >(\n sheet => {\n if (typeof onUnAssignSheet !== 'function')\n throw new Error('onUnAssignSheet must be a function');\n\n if (!userMilestoneId) throw new Error('userMilestoneId is required');\n\n onUnAssignSheet(sheet, userMilestoneId);\n },\n [onUnAssignSheet, userMilestoneId],\n );\n\n const handleOnReset = useCallback<NonNullable<ISheetItemCallbackProps['onReset']>>(\n sheetData => {\n onReset?.(sheetData, userMilestoneId);\n },\n [onReset, userMilestoneId],\n );\n\n const sheetsDataPresent = sheets && sheets.length > 0;\n\n if (isProcessingFailed) {\n return (\n <Styled.MilestoneResourcesWrapper\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $background=\"WHITE\"\n >\n <FlexView $flexGapX={1.5} $alignItems=\"center\" $justifyContent=\"center\">\n <Text $renderAs=\"h6\">Oops! Something went wrong. Please try again later.</Text>\n <Button\n widthX={14}\n size=\"small\"\n shape=\"square\"\n renderAs=\"primary\"\n label=\"Try again\"\n onClick={handleOnTryAgain}\n />\n </FlexView>\n </Styled.MilestoneResourcesWrapper>\n );\n }\n\n if (isProcessed) {\n return (\n <Styled.MilestoneResourcesWrapper $justifyContent=\"space-between\">\n {sheetsDataPresent ? (\n <>\n <ResourcesList\n sheets={sheets}\n userType={userType}\n userMilestoneId={userMilestoneId}\n isMilestoneWidget\n onStart={onStart}\n onResume={onResume}\n onReattempt={onReattempt}\n onUnAssignSheet={handleOnUnAssignResources}\n onReset={handleOnReset}\n onPreview={onPreview}\n onReview={onReview}\n />\n\n {isTeacher && canUpdatePlan && (\n <Styled.SearchButtonWrapper\n $flexDirection=\"row\"\n $justifyContent=\"flex-end\"\n $gapX={1}\n $gutterX={1}\n >\n <Styled.SearchButtonCover>\n <IconButton\n Icon={SearchIcon}\n renderAs=\"secondary\"\n size=\"small\"\n analyticsLabel=\"Milestone Resource Search\"\n onClick={handleOnAssignResources}\n disabled={!isMilestoneActive}\n />\n </Styled.SearchButtonCover>\n </Styled.SearchButtonWrapper>\n )}\n </>\n ) : (\n <FlexView\n $width=\"100%\"\n $height=\"100%\"\n $alignItems=\"center\"\n $justifyContent=\"flex-start\"\n $background=\"WHITE\"\n >\n <Styled.DefaultWrapper $isImageWrapper>\n <img src={IMAGES.BG_EMPTY_RESOURCES} alt=\"Empty resources\" width={420} height={420} />\n </Styled.DefaultWrapper>\n\n <Styled.DefaultWrapper>\n {isTeacher ? (\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n hidden={!isEPSheetCreationDisabled}\n tooltipItem={\n isDraftMilestone ? 'Allowed after plan is published' : 'Plan is completed'\n }\n >\n <Button\n renderAs=\"primary\"\n label=\"Assign Resource\"\n Icon={PlusIcon}\n shape=\"square\"\n size=\"small\"\n onClick={handleOnAssignResources}\n disabled={isEPSheetCreationDisabled}\n />\n </ArrowTooltip>\n ) : (\n <Text $renderAs=\"ab2-bold\">Wait for the teacher to assign a resource</Text>\n )}\n </Styled.DefaultWrapper>\n </FlexView>\n )}\n </Styled.MilestoneResourcesWrapper>\n );\n }\n\n return (\n <Styled.MilestoneResourcesWrapper $justifyContent=\"center\" $background=\"WHITE\">\n <AppLoader height=\"100%\" />\n </Styled.MilestoneResourcesWrapper>\n );\n});\n\nexport default MilestoneWidgetResources;\n"],"names":["MilestoneWidgetResources","memo","props","isDraftMilestone","isMilestoneActive","userType","studentId","userMilestoneId","canUpdatePlan","onAssignResources","onStart","onUnAssignSheet","onReset","onPreview","onReview","onResume","onReattempt","isTeacher","isEPSheetCreationDisabled","getMilestoneResources","isProcessed","isProcessing","isProcessingFailed","isStale","sheets","useGetMilestoneResources","fetchMilestoneResources","useCallback","handleOnTryAgain","useEffect","handleOnAssignResources","handleOnUnAssignResources","sheet","handleOnReset","sheetData","sheetsDataPresent","jsx","Styled.MilestoneResourcesWrapper","FlexView","Text","Button","jsxs","Fragment","ResourcesList","Styled.SearchButtonWrapper","Styled.SearchButtonCover","IconButton","SearchIcon","Styled.DefaultWrapper","IMAGES","ArrowTooltip","PlusIcon","AppLoader"],"mappings":"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"}
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import { jsx as E } from "react/jsx-runtime";
|
2
|
+
import { memo as M, useMemo as _, useCallback as N } from "react";
|
3
|
+
import O from "../../../../../sheets/comps/sheet-button/index.js";
|
4
|
+
import { SHEET_STATE as k } from "../../../../../sheets/constants/sheet.js";
|
5
|
+
import L from "../../../../../ui/layout/flex-view.js";
|
6
|
+
import { IS_CHAPTER_COMPLETED_STATES as $ } from "../../../../create/milestone-create-constants.js";
|
7
|
+
import { TESTS_CREATION_ANALYTICS_EVENTS as g } from "../../../tests-creation/tests-creation-analytics-events.js";
|
8
|
+
import { getTestCtaInfo as H } from "./test-sheet-item-utils.js";
|
9
|
+
const { COMPLETED: U } = k, J = M((d) => {
|
10
|
+
const { milestoneId: n, studentId: m, userType: T, sheet: s, onTestStart: r, onTestReview: i, onTestPreview: a } = d, e = _(() => T === "STUDENT", [T]), { permissions: f, state: c, accuracy: l, user_node_id: u } = s, {
|
11
|
+
can_start: t,
|
12
|
+
can_resume: o,
|
13
|
+
can_review: S,
|
14
|
+
can_teacher_review: w
|
15
|
+
} = f, p = e ? S : w, h = _(
|
16
|
+
() => ({
|
17
|
+
user_node_id: u,
|
18
|
+
milestone_id: n,
|
19
|
+
student_id: m,
|
20
|
+
...e ? {
|
21
|
+
can_start: t,
|
22
|
+
can_resume: o
|
23
|
+
} : {}
|
24
|
+
}),
|
25
|
+
[n, m, o, t, e, u]
|
26
|
+
), C = N(() => {
|
27
|
+
if (e && (t || o)) {
|
28
|
+
if (typeof r == "function") {
|
29
|
+
r(s);
|
30
|
+
return;
|
31
|
+
}
|
32
|
+
throw new Error("No callback is available");
|
33
|
+
}
|
34
|
+
if (p) {
|
35
|
+
if (typeof i != "function")
|
36
|
+
throw new Error("onTestReview must be a function");
|
37
|
+
i(s, n);
|
38
|
+
return;
|
39
|
+
}
|
40
|
+
if (typeof a != "function")
|
41
|
+
throw new Error("onTestPreview must be a function");
|
42
|
+
a(n, s);
|
43
|
+
}, [
|
44
|
+
e,
|
45
|
+
p,
|
46
|
+
a,
|
47
|
+
n,
|
48
|
+
s,
|
49
|
+
t,
|
50
|
+
o,
|
51
|
+
r,
|
52
|
+
i
|
53
|
+
]), y = H(c, f, e), { state: b, renderAs: v = "primary", label: A } = y || {}, I = !(c === U || $.some((x) => x === c)) && !(t || o || S), P = e && I, R = typeof l == "number" ? `${l}%` : void 0, D = e && (t || o) ? g.CUSTOM_TEST_ATTEMPTED : "";
|
54
|
+
return /* @__PURE__ */ E(L, { $flexDirection: "row", $flexGapX: 1, $alignItems: "center", children: /* @__PURE__ */ E(
|
55
|
+
O,
|
56
|
+
{
|
57
|
+
renderAs: v,
|
58
|
+
label: A,
|
59
|
+
onClick: C,
|
60
|
+
disabled: P,
|
61
|
+
state: b,
|
62
|
+
accuracy: R,
|
63
|
+
analyticsLabel: D,
|
64
|
+
analyticsProps: h
|
65
|
+
}
|
66
|
+
) });
|
67
|
+
});
|
68
|
+
export {
|
69
|
+
J as default
|
70
|
+
};
|
71
|
+
//# sourceMappingURL=test-sheet-item-cta.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"test-sheet-item-cta.js","sources":["../../../../../../../src/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.tsx"],"sourcesContent":["import type { ITestSheetItemProps } from './test-sheet-item-types';\nimport type { FC } from 'react';\n\nimport { useCallback, useMemo, memo } from 'react';\n\nimport SheetButton from '../../../../../sheets/comps/sheet-button';\nimport { SHEET_STATE } from '../../../../../sheets/constants/sheet';\nimport FlexView from '../../../../../ui/layout/flex-view';\nimport { IS_CHAPTER_COMPLETED_STATES } from '../../../../create/milestone-create-constants';\nimport { TESTS_CREATION_ANALYTICS_EVENTS } from '../../../tests-creation/tests-creation-analytics-events';\nimport { getTestCtaInfo } from './test-sheet-item-utils';\n\nconst { COMPLETED } = SHEET_STATE;\n\nconst TestSheetItemCta: FC<Omit<ITestSheetItemProps, 'sequenceNo'>> = memo(props => {\n const { milestoneId, studentId, userType, sheet, onTestStart, onTestReview, onTestPreview } =\n props;\n const isStudent = useMemo(() => userType === 'STUDENT', [userType]);\n const { permissions, state: sheetState, accuracy, user_node_id } = sheet;\n const {\n can_start: canStart,\n can_resume: canResume,\n can_review: canReview,\n can_teacher_review: canTeacherReview,\n } = permissions;\n const canReviewSheet = isStudent ? canReview : canTeacherReview;\n\n const analyticsProps = useMemo(\n () => ({\n user_node_id,\n milestone_id: milestoneId,\n student_id: studentId,\n ...(isStudent\n ? {\n can_start: canStart,\n can_resume: canResume,\n }\n : {}),\n }),\n [milestoneId, studentId, canResume, canStart, isStudent, user_node_id],\n );\n\n const handleOnClick = useCallback(() => {\n if (isStudent) {\n if (canStart || canResume) {\n if (typeof onTestStart === 'function') {\n onTestStart(sheet);\n\n return;\n }\n\n throw new Error('No callback is available');\n }\n }\n\n if (canReviewSheet) {\n if (typeof onTestReview !== 'function') {\n throw new Error('onTestReview must be a function');\n }\n\n onTestReview(sheet, milestoneId);\n\n return;\n }\n\n if (typeof onTestPreview !== 'function') {\n throw new Error('onTestPreview must be a function');\n }\n\n onTestPreview(milestoneId, sheet);\n\n return;\n }, [\n isStudent,\n canReviewSheet,\n onTestPreview,\n milestoneId,\n sheet,\n canStart,\n canResume,\n onTestStart,\n onTestReview,\n ]);\n\n const testCtaInfo = getTestCtaInfo(sheetState, permissions, isStudent);\n const { state: testCtaState, renderAs = 'primary', label } = testCtaInfo || {};\n\n const isSheetCompleted =\n sheetState === COMPLETED || IS_CHAPTER_COMPLETED_STATES.some(state => state === sheetState);\n const sheetPermissionDisability = !isSheetCompleted && !(canStart || canResume || canReview);\n const disableCta = isStudent && sheetPermissionDisability;\n const sheetAccuracy = typeof accuracy === 'number' ? `${accuracy}%` : undefined;\n\n const analyticsLabel =\n isStudent && (canStart || canResume)\n ? TESTS_CREATION_ANALYTICS_EVENTS.CUSTOM_TEST_ATTEMPTED\n : '';\n\n return (\n <FlexView $flexDirection=\"row\" $flexGapX={1} $alignItems=\"center\">\n <SheetButton\n renderAs={renderAs}\n label={label}\n onClick={handleOnClick}\n disabled={disableCta}\n state={testCtaState}\n accuracy={sheetAccuracy}\n analyticsLabel={analyticsLabel}\n analyticsProps={analyticsProps}\n />\n </FlexView>\n );\n});\n\nexport default TestSheetItemCta;\n"],"names":["COMPLETED","SHEET_STATE","TestSheetItemCta","memo","props","milestoneId","studentId","userType","sheet","onTestStart","onTestReview","onTestPreview","isStudent","useMemo","permissions","sheetState","accuracy","user_node_id","canStart","canResume","canReview","canTeacherReview","canReviewSheet","analyticsProps","handleOnClick","useCallback","testCtaInfo","getTestCtaInfo","testCtaState","renderAs","label","sheetPermissionDisability","IS_CHAPTER_COMPLETED_STATES","state","disableCta","sheetAccuracy","analyticsLabel","TESTS_CREATION_ANALYTICS_EVENTS","FlexView","jsx","SheetButton"],"mappings":";;;;;;;;AAYA,MAAM,EAAE,WAAAA,EAAc,IAAAC,GAEhBC,IAAgEC,EAAK,CAASC,MAAA;AAC5E,QAAA,EAAE,aAAAC,GAAa,WAAAC,GAAW,UAAAC,GAAU,OAAAC,GAAO,aAAAC,GAAa,cAAAC,GAAc,eAAAC,EAC1E,IAAAP,GACIQ,IAAYC,EAAQ,MAAMN,MAAa,WAAW,CAACA,CAAQ,CAAC,GAC5D,EAAE,aAAAO,GAAa,OAAOC,GAAY,UAAAC,GAAU,cAAAC,EAAiB,IAAAT,GAC7D;AAAA,IACJ,WAAWU;AAAA,IACX,YAAYC;AAAA,IACZ,YAAYC;AAAA,IACZ,oBAAoBC;AAAA,EAClB,IAAAP,GACEQ,IAAiBV,IAAYQ,IAAYC,GAEzCE,IAAiBV;AAAA,IACrB,OAAO;AAAA,MACL,cAAAI;AAAA,MACA,cAAcZ;AAAA,MACd,YAAYC;AAAA,MACZ,GAAIM,IACA;AAAA,QACE,WAAWM;AAAA,QACX,YAAYC;AAAA,MAAA,IAEd,CAAC;AAAA,IAAA;AAAA,IAEP,CAACd,GAAaC,GAAWa,GAAWD,GAAUN,GAAWK,CAAY;AAAA,EAAA,GAGjEO,IAAgBC,EAAY,MAAM;AACtC,QAAIb,MACEM,KAAYC,IAAW;AACrB,UAAA,OAAOV,KAAgB,YAAY;AACrC,QAAAA,EAAYD,CAAK;AAEjB;AAAA,MACF;AAEM,YAAA,IAAI,MAAM,0BAA0B;AAAA,IAC5C;AAGF,QAAIc,GAAgB;AACd,UAAA,OAAOZ,KAAiB;AACpB,cAAA,IAAI,MAAM,iCAAiC;AAGnD,MAAAA,EAAaF,GAAOH,CAAW;AAE/B;AAAA,IACF;AAEI,QAAA,OAAOM,KAAkB;AACrB,YAAA,IAAI,MAAM,kCAAkC;AAGpD,IAAAA,EAAcN,GAAaG,CAAK;AAAA,EAEhC,GACC;AAAA,IACDI;AAAA,IACAU;AAAA,IACAX;AAAA,IACAN;AAAA,IACAG;AAAA,IACAU;AAAA,IACAC;AAAA,IACAV;AAAA,IACAC;AAAA,EAAA,CACD,GAEKgB,IAAcC,EAAeZ,GAAYD,GAAaF,CAAS,GAC/D,EAAE,OAAOgB,GAAc,UAAAC,IAAW,WAAW,OAAAC,EAAM,IAAIJ,KAAe,IAItEK,IAA4B,EADhChB,MAAef,KAAagC,EAA4B,KAAK,CAAAC,MAASA,MAAUlB,CAAU,MACrC,EAAEG,KAAYC,KAAaC,IAC5Ec,IAAatB,KAAamB,GAC1BI,IAAgB,OAAOnB,KAAa,WAAW,GAAGA,CAAQ,MAAM,QAEhEoB,IACJxB,MAAcM,KAAYC,KACtBkB,EAAgC,wBAChC;AAEN,2BACGC,GAAS,EAAA,gBAAe,OAAM,WAAW,GAAG,aAAY,UACvD,UAAA,gBAAAC;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,UAAAX;AAAA,MACA,OAAAC;AAAA,MACA,SAASN;AAAA,MACT,UAAUU;AAAA,MACV,OAAON;AAAA,MACP,UAAUO;AAAA,MACV,gBAAAC;AAAA,MACA,gBAAAb;AAAA,IAAA;AAAA,EAEJ,EAAA,CAAA;AAEJ,CAAC;"}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import o from "styled-components";
|
2
|
+
import i from "../../../../../ui/layout/flex-view.js";
|
3
|
+
import e from "../../../../../ui/text/text.js";
|
4
|
+
const s = o(i)(({ theme: t }) => {
|
5
|
+
const { WHITE_5: r } = t.colors;
|
6
|
+
return `
|
7
|
+
border: 1px solid ${r};
|
8
|
+
border-top-width: 0;
|
9
|
+
border-left-width: 0;
|
10
|
+
|
11
|
+
&:nth-child(even) {
|
12
|
+
border-right-width: 0;
|
13
|
+
}
|
14
|
+
`;
|
15
|
+
}), c = o(e)(({ theme: t }) => `
|
16
|
+
width: fit-content;
|
17
|
+
padding: ${t.layout.gutter * 0.25}px;
|
18
|
+
background-color: ${t.colors.BLUE_2};
|
19
|
+
`), p = o(e)(() => `
|
20
|
+
display: -webkit-box;
|
21
|
+
-webkit-box-orient: vertical;
|
22
|
+
-webkit-line-clamp: 1;
|
23
|
+
text-overflow: ellipsis;
|
24
|
+
overflow: hidden;
|
25
|
+
`);
|
26
|
+
export {
|
27
|
+
s as TestItemCard,
|
28
|
+
p as TestItemTitle,
|
29
|
+
c as TestTag
|
30
|
+
};
|
31
|
+
//# sourceMappingURL=test-sheet-item-styled.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"test-sheet-item-styled.js","sources":["../../../../../../../src/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../../../../ui/layout/flex-view';\nimport Text from '../../../../../ui/text/text';\n\nconst TestItemCard = styled(FlexView)(({ theme }) => {\n const { WHITE_5 } = theme.colors;\n\n return `\n border: 1px solid ${WHITE_5};\n border-top-width: 0;\n border-left-width: 0;\n\n &:nth-child(even) {\n border-right-width: 0;\n }\n `;\n});\n\nconst TestTag = styled(Text)(({ theme }) => {\n return `\n width: fit-content;\n padding: ${theme.layout.gutter * 0.25}px;\n background-color: ${theme.colors.BLUE_2};\n `;\n});\n\nconst TestItemTitle = styled(Text)(() => {\n return `\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n text-overflow: ellipsis;\n overflow: hidden;\n `;\n});\n\nexport { TestItemCard, TestItemTitle, TestTag };\n"],"names":["TestItemCard","styled","FlexView","theme","WHITE_5","TestTag","Text","TestItemTitle"],"mappings":";;;AAKA,MAAMA,IAAeC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QAAY;AAC7C,QAAA,EAAE,SAAAC,EAAQ,IAAID,EAAM;AAEnB,SAAA;AAAA,wBACeC,CAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQ/B,CAAC,GAEKC,IAAUJ,EAAOK,CAAI,EAAE,CAAC,EAAE,OAAAH,QACvB;AAAA;AAAA,eAEMA,EAAM,OAAO,SAAS,IAAI;AAAA,wBACjBA,EAAM,OAAO,MAAM;AAAA,GAE1C,GAEKI,IAAgBN,EAAOK,CAAI,EAAE,MAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAOR;"}
|
@@ -0,0 +1,38 @@
|
|
1
|
+
import { SHEET_STATE as c } from "../../../../../sheets/constants/sheet.js";
|
2
|
+
import { IS_CHAPTER_COMPLETED_STATES as i } from "../../../../create/milestone-create-constants.js";
|
3
|
+
const { COMPLETED: m } = c, l = (r, e, t) => {
|
4
|
+
const { can_start: n, can_resume: a } = e, o = r === m || i.some((s) => s === r);
|
5
|
+
if (t) {
|
6
|
+
if (a)
|
7
|
+
return {
|
8
|
+
state: "in_progress",
|
9
|
+
renderAs: "primary",
|
10
|
+
label: "Resume"
|
11
|
+
};
|
12
|
+
if (n)
|
13
|
+
return {
|
14
|
+
state: void 0,
|
15
|
+
renderAs: "primary",
|
16
|
+
label: "Start"
|
17
|
+
};
|
18
|
+
}
|
19
|
+
return o ? {
|
20
|
+
state: "completed",
|
21
|
+
renderAs: "secondary_black",
|
22
|
+
label: "Review"
|
23
|
+
} : {
|
24
|
+
state: a ? "in_progress" : void 0,
|
25
|
+
renderAs: "primary",
|
26
|
+
label: "View"
|
27
|
+
};
|
28
|
+
}, E = (r) => {
|
29
|
+
const e = /* @__PURE__ */ new Set();
|
30
|
+
return r == null || r.forEach((t) => {
|
31
|
+
e.add(t.chapter_name);
|
32
|
+
}), Array.from(e);
|
33
|
+
};
|
34
|
+
export {
|
35
|
+
l as getTestCtaInfo,
|
36
|
+
E as getTopicsFromItems
|
37
|
+
};
|
38
|
+
//# sourceMappingURL=test-sheet-item-utils.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"test-sheet-item-utils.js","sources":["../../../../../../../src/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.ts"],"sourcesContent":["import type {\n TSheetButtonState,\n TSheetButtonVariant,\n} from '../../../../../sheets/comps/sheet-button/types';\nimport type {\n ISheetDataProps,\n TTestHelpItemsDataProps,\n} from '../../../../../sheets/sheets-list/sheet-item/sheet-item-types';\n\nimport { SHEET_STATE } from '../../../../../sheets/constants/sheet';\nimport { IS_CHAPTER_COMPLETED_STATES } from '../../../../create/milestone-create-constants';\n\nconst { COMPLETED } = SHEET_STATE;\n\ninterface IGetTestSheetCtaInfo {\n (\n state: ISheetDataProps['state'],\n permissions: ISheetDataProps['permissions'],\n isStudent: boolean,\n ): {\n state: TSheetButtonState | undefined;\n renderAs: TSheetButtonVariant;\n label: 'Start' | 'Resume' | 'View' | 'Review';\n };\n}\n\nconst getTestCtaInfo: IGetTestSheetCtaInfo = (sheetState, permissions, isStudent) => {\n const { can_start: canStart, can_resume: canResume } = permissions;\n\n const isSheetCompleted =\n sheetState === COMPLETED ||\n IS_CHAPTER_COMPLETED_STATES.some(completedState => completedState === sheetState);\n\n if (isStudent) {\n if (canResume) {\n return {\n state: 'in_progress',\n renderAs: 'primary',\n label: 'Resume',\n };\n }\n\n if (canStart) {\n return {\n state: undefined,\n renderAs: 'primary',\n label: 'Start',\n };\n }\n }\n\n if (isSheetCompleted) {\n return {\n state: 'completed',\n renderAs: 'secondary_black',\n label: 'Review',\n };\n }\n\n return {\n state: canResume ? 'in_progress' : undefined,\n renderAs: 'primary',\n label: 'View',\n };\n};\n\nconst getTopicsFromItems = (items?: TTestHelpItemsDataProps[]) => {\n const topics = new Set<string>();\n\n items?.forEach(item => {\n topics.add(item.chapter_name);\n });\n\n return Array.from(topics);\n};\n\nexport { getTopicsFromItems, getTestCtaInfo };\n"],"names":["COMPLETED","SHEET_STATE","getTestCtaInfo","sheetState","permissions","isStudent","canStart","canResume","isSheetCompleted","IS_CHAPTER_COMPLETED_STATES","completedState","getTopicsFromItems","items","topics","item"],"mappings":";;AAYA,MAAM,EAAE,WAAAA,EAAc,IAAAC,GAchBC,IAAuC,CAACC,GAAYC,GAAaC,MAAc;AACnF,QAAM,EAAE,WAAWC,GAAU,YAAYC,MAAcH,GAEjDI,IACJL,MAAeH,KACfS,EAA4B,KAAK,CAAAC,MAAkBA,MAAmBP,CAAU;AAElF,MAAIE,GAAW;AACb,QAAIE;AACK,aAAA;AAAA,QACL,OAAO;AAAA,QACP,UAAU;AAAA,QACV,OAAO;AAAA,MAAA;AAIX,QAAID;AACK,aAAA;AAAA,QACL,OAAO;AAAA,QACP,UAAU;AAAA,QACV,OAAO;AAAA,MAAA;AAAA,EAGb;AAEA,SAAIE,IACK;AAAA,IACL,OAAO;AAAA,IACP,UAAU;AAAA,IACV,OAAO;AAAA,EAAA,IAIJ;AAAA,IACL,OAAOD,IAAY,gBAAgB;AAAA,IACnC,UAAU;AAAA,IACV,OAAO;AAAA,EAAA;AAEX,GAEMI,IAAqB,CAACC,MAAsC;AAC1D,QAAAC,wBAAa;AAEnB,SAAAD,KAAA,QAAAA,EAAO,QAAQ,CAAQE,MAAA;AACd,IAAAD,EAAA,IAAIC,EAAK,YAAY;AAAA,EAAA,IAGvB,MAAM,KAAKD,CAAM;AAC1B;"}
|
@@ -0,0 +1,79 @@
|
|
1
|
+
import { jsxs as s, jsx as t } from "react/jsx-runtime";
|
2
|
+
import { h as g } from "../../../../../../node_modules/humanize-plus/dist/humanize.js";
|
3
|
+
import { memo as y, useRef as D, useState as M, useMemo as n, useEffect as b } from "react";
|
4
|
+
import { SHEET_STATE as F } from "../../../../../sheets/constants/sheet.js";
|
5
|
+
import H from "../../../../../ui/arrow-tooltip/arrow-tooltip.js";
|
6
|
+
import f from "../../../../../ui/layout/flex-view.js";
|
7
|
+
import j from "../../../../../ui/text/text.js";
|
8
|
+
import { IS_CHAPTER_COMPLETED_STATES as v } from "../../../../create/milestone-create-constants.js";
|
9
|
+
import R from "./test-sheet-item-cta.js";
|
10
|
+
import { TestItemCard as O, TestTag as P, TestItemTitle as X } from "./test-sheet-item-styled.js";
|
11
|
+
import { getTopicsFromItems as Y } from "./test-sheet-item-utils.js";
|
12
|
+
const { COMPLETED: z } = F, B = {
|
13
|
+
EASY: "Easy",
|
14
|
+
MODERATE: "Moderate",
|
15
|
+
DIFFICULT: "Difficult"
|
16
|
+
}, ee = y((p) => {
|
17
|
+
const { sheet: l, userType: a, milestoneId: h, studentId: d, onTestPreview: u, onTestReview: E, onTestStart: I } = p, {
|
18
|
+
title: C,
|
19
|
+
items: m,
|
20
|
+
sheet_time: o,
|
21
|
+
state: c,
|
22
|
+
difficulty_level: S
|
23
|
+
} = l, e = D(null), [_, $] = M(!1), A = n(() => o && Math.ceil(o / 60) || 0, [o]), r = n(() => Y(m), [m]), i = n(() => r.join(" • "), [r]), T = r.length, w = B[S || "EASY"], x = c === z || v.some((L) => L === c);
|
24
|
+
return b(() => {
|
25
|
+
e.current && e.current.scrollHeight > e.current.clientHeight && $(!0);
|
26
|
+
}, [e]), /* @__PURE__ */ s(
|
27
|
+
O,
|
28
|
+
{
|
29
|
+
$gapX: 1.25,
|
30
|
+
$gutterX: 1.25,
|
31
|
+
$flexGapX: 1.25,
|
32
|
+
$background: x ? "WHITE_3" : "WHITE_1",
|
33
|
+
$justifyContent: "space-between",
|
34
|
+
children: [
|
35
|
+
/* @__PURE__ */ s(f, { $flexGap: 4, children: [
|
36
|
+
/* @__PURE__ */ t(P, { $renderAs: "ac4", $color: "BLACK_T_60", children: C }),
|
37
|
+
/* @__PURE__ */ t(
|
38
|
+
H,
|
39
|
+
{
|
40
|
+
renderAs: "primary",
|
41
|
+
position: "bottom",
|
42
|
+
tooltipItem: i ?? "",
|
43
|
+
widthX: 22.4375,
|
44
|
+
hidden: !_ || !i,
|
45
|
+
children: /* @__PURE__ */ t(X, { ref: e, $renderAs: "ab2", children: i })
|
46
|
+
}
|
47
|
+
),
|
48
|
+
/* @__PURE__ */ s(j, { $renderAs: "ub3", $color: "BLACK_T_60", children: [
|
49
|
+
T,
|
50
|
+
" ",
|
51
|
+
g.pluralize(T, "Chapter"),
|
52
|
+
" • ",
|
53
|
+
w,
|
54
|
+
" •",
|
55
|
+
" ",
|
56
|
+
A,
|
57
|
+
" Mins"
|
58
|
+
] })
|
59
|
+
] }),
|
60
|
+
/* @__PURE__ */ t(f, { $flexDirection: "row", $justifyContent: "space-between", $alignItems: "center", children: /* @__PURE__ */ t(
|
61
|
+
R,
|
62
|
+
{
|
63
|
+
milestoneId: h,
|
64
|
+
studentId: d,
|
65
|
+
sheet: l,
|
66
|
+
userType: a,
|
67
|
+
onTestPreview: u,
|
68
|
+
onTestReview: E,
|
69
|
+
onTestStart: I
|
70
|
+
}
|
71
|
+
) })
|
72
|
+
]
|
73
|
+
}
|
74
|
+
);
|
75
|
+
});
|
76
|
+
export {
|
77
|
+
ee as default
|
78
|
+
};
|
79
|
+
//# sourceMappingURL=test-sheet-item.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"test-sheet-item.js","sources":["../../../../../../../src/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.tsx"],"sourcesContent":["import type { ITestSheetItemProps } from './test-sheet-item-types';\nimport type { FC } from 'react';\n\nimport { pluralize } from 'humanize-plus';\nimport { memo, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { SHEET_STATE } from '../../../../../sheets/constants/sheet';\nimport ArrowTooltip from '../../../../../ui/arrow-tooltip/arrow-tooltip';\nimport FlexView from '../../../../../ui/layout/flex-view';\nimport Text from '../../../../../ui/text/text';\nimport { IS_CHAPTER_COMPLETED_STATES } from '../../../../create/milestone-create-constants';\nimport TestSheetItemCta from './test-sheet-item-cta';\nimport * as Styled from './test-sheet-item-styled';\nimport { getTopicsFromItems } from './test-sheet-item-utils';\n\nconst { COMPLETED } = SHEET_STATE;\n\nconst TEST_DIFFICULTY_LEVEL = {\n EASY: 'Easy',\n MODERATE: 'Moderate',\n DIFFICULT: 'Difficult',\n};\n\nconst TestSheetItem: FC<ITestSheetItemProps> = memo(props => {\n const { sheet, userType, milestoneId, studentId, onTestPreview, onTestReview, onTestStart } =\n props;\n const {\n title,\n items,\n sheet_time: sheetTime,\n state: testState,\n difficulty_level: difficultyLevel,\n } = sheet;\n\n const titleTextRef = useRef<HTMLDivElement>(null);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const totalSheetTime = useMemo(() => (sheetTime && Math.ceil(sheetTime / 60)) || 0, [sheetTime]);\n const topics = useMemo(() => getTopicsFromItems(items), [items]);\n const testChapterName = useMemo(() => topics.join(' • '), [topics]);\n\n const noOfChapters = topics.length;\n\n const testDifficultyLevel = TEST_DIFFICULTY_LEVEL[difficultyLevel || 'EASY'];\n const isTestCompleted =\n testState === COMPLETED || IS_CHAPTER_COMPLETED_STATES.some(state => state === testState);\n\n useEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n return (\n <Styled.TestItemCard\n $gapX={1.25}\n $gutterX={1.25}\n $flexGapX={1.25}\n $background={isTestCompleted ? 'WHITE_3' : 'WHITE_1'}\n $justifyContent=\"space-between\"\n >\n <FlexView $flexGap={4}>\n <Styled.TestTag $renderAs=\"ac4\" $color=\"BLACK_T_60\">\n {title}\n </Styled.TestTag>\n\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={testChapterName ?? ''}\n widthX={22.4375}\n hidden={!showTitleTooltip || !testChapterName}\n >\n <Styled.TestItemTitle ref={titleTextRef} $renderAs=\"ab2\">\n {testChapterName}\n </Styled.TestItemTitle>\n </ArrowTooltip>\n\n <Text $renderAs=\"ub3\" $color=\"BLACK_T_60\">\n {noOfChapters} {pluralize(noOfChapters, 'Chapter')} • {testDifficultyLevel} •{' '}\n {totalSheetTime} Mins\n </Text>\n </FlexView>\n\n <FlexView $flexDirection=\"row\" $justifyContent=\"space-between\" $alignItems=\"center\">\n <TestSheetItemCta\n milestoneId={milestoneId}\n studentId={studentId}\n sheet={sheet}\n userType={userType}\n onTestPreview={onTestPreview}\n onTestReview={onTestReview}\n onTestStart={onTestStart}\n />\n </FlexView>\n </Styled.TestItemCard>\n );\n});\n\nexport default TestSheetItem;\n"],"names":["COMPLETED","SHEET_STATE","TEST_DIFFICULTY_LEVEL","TestSheetItem","memo","props","sheet","userType","milestoneId","studentId","onTestPreview","onTestReview","onTestStart","title","items","sheetTime","testState","difficultyLevel","titleTextRef","useRef","showTitleTooltip","setShowTitleTooltip","useState","totalSheetTime","useMemo","topics","getTopicsFromItems","testChapterName","noOfChapters","testDifficultyLevel","isTestCompleted","IS_CHAPTER_COMPLETED_STATES","state","useEffect","jsxs","Styled.TestItemCard","FlexView","jsx","Styled.TestTag","ArrowTooltip","Styled.TestItemTitle","Text","pluralize","TestSheetItemCta"],"mappings":";;;;;;;;;;;AAeA,MAAM,EAAE,WAAAA,EAAc,IAAAC,GAEhBC,IAAwB;AAAA,EAC5B,MAAM;AAAA,EACN,UAAU;AAAA,EACV,WAAW;AACb,GAEMC,KAAyCC,EAAK,CAASC,MAAA;AACrD,QAAA,EAAE,OAAAC,GAAO,UAAAC,GAAU,aAAAC,GAAa,WAAAC,GAAW,eAAAC,GAAe,cAAAC,GAAc,aAAAC,EAC5E,IAAAP,GACI;AAAA,IACJ,OAAAQ;AAAA,IACA,OAAAC;AAAA,IACA,YAAYC;AAAA,IACZ,OAAOC;AAAA,IACP,kBAAkBC;AAAA,EAChB,IAAAX,GAEEY,IAAeC,EAAuB,IAAI,GAC1C,CAACC,GAAkBC,CAAmB,IAAIC,EAAS,EAAK,GAExDC,IAAiBC,EAAQ,MAAOT,KAAa,KAAK,KAAKA,IAAY,EAAE,KAAM,GAAG,CAACA,CAAS,CAAC,GACzFU,IAASD,EAAQ,MAAME,EAAmBZ,CAAK,GAAG,CAACA,CAAK,CAAC,GACzDa,IAAkBH,EAAQ,MAAMC,EAAO,KAAK,KAAK,GAAG,CAACA,CAAM,CAAC,GAE5DG,IAAeH,EAAO,QAEtBI,IAAsB3B,EAAsBe,KAAmB,MAAM,GACrEa,IACJd,MAAchB,KAAa+B,EAA4B,KAAK,CAAAC,MAASA,MAAUhB,CAAS;AAE1F,SAAAiB,EAAU,MAAM;AACd,IACEf,EAAa,WACbA,EAAa,QAAQ,eAAeA,EAAa,QAAQ,gBAEzDG,EAAoB,EAAI;AAAA,EAC1B,GACC,CAACH,CAAY,CAAC,GAGf,gBAAAgB;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,OAAO;AAAA,MACP,UAAU;AAAA,MACV,WAAW;AAAA,MACX,aAAaL,IAAkB,YAAY;AAAA,MAC3C,iBAAgB;AAAA,MAEhB,UAAA;AAAA,QAAC,gBAAAI,EAAAE,GAAA,EAAS,UAAU,GAClB,UAAA;AAAA,UAAA,gBAAAC,EAACC,GAAA,EAAe,WAAU,OAAM,QAAO,cACpC,UACHzB,GAAA;AAAA,UAEA,gBAAAwB;AAAA,YAACE;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,UAAS;AAAA,cACT,aAAaZ,KAAmB;AAAA,cAChC,QAAQ;AAAA,cACR,QAAQ,CAACP,KAAoB,CAACO;AAAA,cAE9B,UAAA,gBAAAU,EAACG,GAAA,EAAqB,KAAKtB,GAAc,WAAU,OAChD,UACHS,GAAA;AAAA,YAAA;AAAA,UACF;AAAA,UAEC,gBAAAO,EAAAO,GAAA,EAAK,WAAU,OAAM,QAAO,cAC1B,UAAA;AAAA,YAAAb;AAAA,YAAa;AAAA,YAAEc,EAAA,UAAUd,GAAc,SAAS;AAAA,YAAE;AAAA,YAAIC;AAAA,YAAoB;AAAA,YAAG;AAAA,YAC7EN;AAAA,YAAe;AAAA,UAAA,GAClB;AAAA,QAAA,GACF;AAAA,0BAECa,GAAS,EAAA,gBAAe,OAAM,iBAAgB,iBAAgB,aAAY,UACzE,UAAA,gBAAAC;AAAA,UAACM;AAAA,UAAA;AAAA,YACC,aAAAnC;AAAA,YACA,WAAAC;AAAA,YACA,OAAAH;AAAA,YACA,UAAAC;AAAA,YACA,eAAAG;AAAA,YACA,cAAAC;AAAA,YACA,aAAAC;AAAA,UAAA;AAAA,QAAA,GAEJ;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;"}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { styled as o } from "styled-components";
|
2
|
+
const e = o.div(({ theme: t }) => `
|
3
|
+
position: absolute;
|
4
|
+
bottom: ${t.layout.gutter}px;
|
5
|
+
right: ${t.layout.gutter}px;
|
6
|
+
box-shadow: 0px 10px 20px 0px ${t.colors.BLACK_T_20};
|
7
|
+
border-radius: 50%;
|
8
|
+
`), p = o.div`
|
9
|
+
display: grid;
|
10
|
+
grid-template-columns: repeat(2, 1fr);
|
11
|
+
grid-template-rows: max-content;
|
12
|
+
gap: 0;
|
13
|
+
`;
|
14
|
+
export {
|
15
|
+
e as IconContainer,
|
16
|
+
p as TestSheetItemWrapper
|
17
|
+
};
|
18
|
+
//# sourceMappingURL=test-sheets-list-styled.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"test-sheets-list-styled.js","sources":["../../../../../../src/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.tsx"],"sourcesContent":["import { styled } from 'styled-components';\n\nconst IconContainer = styled.div(({ theme }) => {\n return `\n position: absolute;\n bottom: ${theme.layout.gutter}px;\n right: ${theme.layout.gutter}px;\n box-shadow: 0px 10px 20px 0px ${theme.colors.BLACK_T_20};\n border-radius: 50%;\n `;\n});\n\nconst TestSheetItemWrapper = styled.div`\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n grid-template-rows: max-content;\n gap: 0;\n`;\n\nexport { IconContainer, TestSheetItemWrapper };\n"],"names":["IconContainer","styled","theme","TestSheetItemWrapper"],"mappings":";AAEA,MAAMA,IAAgBC,EAAO,IAAI,CAAC,EAAE,OAAAC,QAC3B;AAAA;AAAA,cAEKA,EAAM,OAAO,MAAM;AAAA,aACpBA,EAAM,OAAO,MAAM;AAAA,oCACIA,EAAM,OAAO,UAAU;AAAA;AAAA,GAG1D,GAEKC,IAAuBF,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|