@cuemath/leap 2.8.60-ag3 → 2.8.60-as3
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/constants/api.js +2 -3
- package/dist/constants/api.js.map +1 -1
- package/dist/features/analytics-events/whitelist-events.js +7 -9
- package/dist/features/analytics-events/whitelist-events.js.map +1 -1
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +4 -5
- 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 +1 -2
- package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
- package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +7 -7
- package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -1
- package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +6 -6
- package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
- package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +2 -2
- package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +1 -1
- package/dist/features/chapters-v2/utils/node-card-utils.js +18 -18
- package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
- package/dist/features/homework/card-menu-options.js +22 -44
- package/dist/features/homework/card-menu-options.js.map +1 -1
- package/dist/features/homework/homework-card.js +173 -219
- package/dist/features/homework/homework-card.js.map +1 -1
- package/dist/features/homework/styles.js +23 -30
- package/dist/features/homework/styles.js.map +1 -1
- package/dist/features/milestone/create/api/goal-submit.js +1 -1
- package/dist/features/milestone/create/api/goal-submit.js.map +1 -1
- package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js +1 -1
- package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js.map +1 -1
- package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js +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 +1 -1
- package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +49 -57
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +1 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +10 -16
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +1 -1
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +57 -76
- package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +1 -1
- package/dist/features/recent-chapters/recent-chapters.js +31 -28
- package/dist/features/recent-chapters/recent-chapters.js.map +1 -1
- package/dist/features/sheet-v2/resource-list/resource-list.js +27 -24
- package/dist/features/sheet-v2/resource-list/resource-list.js.map +1 -1
- package/dist/features/sheets/resources-list/resource-item/resource-item.js.map +1 -1
- package/dist/features/sheets/resources-list/resource-item/styled.js +0 -1
- package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
- package/dist/features/sheets/sheets-analytics-events.js +2 -6
- package/dist/features/sheets/sheets-analytics-events.js.map +1 -1
- package/dist/index.d.ts +9 -12
- package/dist/index.js +326 -328
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/dist/features/homework/hw-card-list/hw-card-list.js +0 -444
- package/dist/features/homework/hw-card-list/hw-card-list.js.map +0 -1
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +0 -10
- package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +0 -1
@@ -1,256 +1,210 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
3
|
-
import
|
4
|
-
import
|
5
|
-
import
|
6
|
-
import
|
7
|
-
import { getNodeTypeBasedBgImage as
|
8
|
-
import { getNodeCardBasedIcon as
|
9
|
-
import
|
10
|
-
import
|
11
|
-
import
|
12
|
-
import
|
13
|
-
import
|
14
|
-
import
|
15
|
-
import { CardContainer as
|
16
|
-
const
|
17
|
-
header:
|
1
|
+
import { jsx as e, jsxs as a } from "react/jsx-runtime";
|
2
|
+
import { useRef as y, useState as q, useLayoutEffect as J, useCallback as x } from "react";
|
3
|
+
import Q from "../../assets/line-icons/icons/eye2.js";
|
4
|
+
import U from "../../assets/line-icons/icons/more-vertical.js";
|
5
|
+
import Y from "../../assets/line-icons/icons/redo.js";
|
6
|
+
import Z from "../chapters-v2/comps/node-card/node-card-tags.js";
|
7
|
+
import { getNodeTypeBasedBgImage as D } from "../chapters-v2/utils/index.js";
|
8
|
+
import { getNodeCardBasedIcon as N } from "../chapters-v2/utils/node-card-utils.js";
|
9
|
+
import E from "../ui/arrow-tooltip/arrow-tooltip.js";
|
10
|
+
import ee from "../ui/buttons/clickable/clickable.js";
|
11
|
+
import re from "../ui/hooks/use-context-menu-click-handler.js";
|
12
|
+
import u from "../ui/layout/flex-view.js";
|
13
|
+
import te from "../ui/text/text.js";
|
14
|
+
import ie from "./card-menu-options.js";
|
15
|
+
import { CardContainer as ne, CardWrapper as ce, IconWrapper as oe, BannerImageWrapper as ae, BannerImage as se, HeaderText as le, SubHeaderText as ue, CardKebabMenuWrapper as he, CardMenuOptionsWrapper as me, StyledMinus2Icon as fe } from "./styles.js";
|
16
|
+
const He = ({
|
17
|
+
header: d,
|
18
18
|
nodeData: r,
|
19
|
-
subHeader:
|
20
|
-
userType:
|
19
|
+
subHeader: I,
|
20
|
+
userType: H,
|
21
21
|
userMilestoneId: t,
|
22
|
-
onNodeUnassign:
|
23
|
-
|
24
|
-
onNodeView:
|
25
|
-
onNodeReview:
|
26
|
-
onNodeAttempt:
|
22
|
+
onNodeUnassign: h,
|
23
|
+
onNodeReset: m,
|
24
|
+
onNodeView: i,
|
25
|
+
onNodeReview: n,
|
26
|
+
onNodeAttempt: f
|
27
27
|
}) => {
|
28
28
|
const {
|
29
|
-
node_type:
|
30
|
-
state:
|
31
|
-
accuracy:
|
32
|
-
due_date_ts:
|
33
|
-
image_url:
|
34
|
-
image_hue:
|
35
|
-
card_header:
|
36
|
-
permissions:
|
37
|
-
user_node_id:
|
38
|
-
} = r,
|
39
|
-
can_start:
|
40
|
-
can_resume:
|
41
|
-
can_review:
|
42
|
-
can_teacher_review:
|
43
|
-
can_unassign:
|
44
|
-
can_reset:
|
45
|
-
} =
|
46
|
-
|
47
|
-
o.current && o.current.scrollHeight > o.current.clientHeight &&
|
29
|
+
node_type: c,
|
30
|
+
state: X,
|
31
|
+
accuracy: S,
|
32
|
+
due_date_ts: W,
|
33
|
+
image_url: w,
|
34
|
+
image_hue: A,
|
35
|
+
card_header: O = "",
|
36
|
+
permissions: B,
|
37
|
+
user_node_id: s
|
38
|
+
} = r, R = c && D(c), $ = c && N(c), b = y(null), { menuVisible: j, onMenuClick: G } = re(b), o = y(null), [K, L] = q(!1), {
|
39
|
+
can_start: g,
|
40
|
+
can_resume: C,
|
41
|
+
can_review: T,
|
42
|
+
can_teacher_review: _,
|
43
|
+
can_unassign: M,
|
44
|
+
can_reset: P
|
45
|
+
} = B || {}, v = H === "STUDENT";
|
46
|
+
J(() => {
|
47
|
+
o.current && o.current.scrollHeight > o.current.clientHeight && L(!0);
|
48
48
|
}, [o]);
|
49
|
-
const
|
50
|
-
if (
|
51
|
-
if (
|
49
|
+
const z = x(() => {
|
50
|
+
if (g || C) {
|
51
|
+
if (typeof f != "function")
|
52
52
|
throw new Error("onNodeAttempt must be a function");
|
53
|
-
|
53
|
+
f(r);
|
54
54
|
return;
|
55
55
|
}
|
56
|
-
if (
|
57
|
-
|
58
|
-
return;
|
59
|
-
}
|
60
|
-
if (g) {
|
61
|
-
if (console.log("calles onStudentView canReview"), typeof i != "function")
|
56
|
+
if (T) {
|
57
|
+
if (typeof n != "function")
|
62
58
|
throw new Error("onReview must be a function");
|
63
|
-
if (!
|
59
|
+
if (!s)
|
64
60
|
throw new Error("user node id must be present to review the sheet");
|
65
|
-
|
61
|
+
n(r, t);
|
66
62
|
return;
|
67
63
|
}
|
64
|
+
if (typeof i != "function")
|
65
|
+
throw new Error("onPreview must be a function");
|
66
|
+
i(r, t);
|
68
67
|
}, [
|
69
|
-
|
70
|
-
|
71
|
-
H,
|
72
|
-
$,
|
68
|
+
C,
|
69
|
+
T,
|
73
70
|
g,
|
74
|
-
|
71
|
+
t,
|
75
72
|
r,
|
76
|
-
|
73
|
+
f,
|
74
|
+
n,
|
77
75
|
i,
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
if (typeof i != "function")
|
76
|
+
s
|
77
|
+
]), F = x(() => {
|
78
|
+
if (_) {
|
79
|
+
if (typeof n != "function")
|
83
80
|
throw new Error("onReview must be a function");
|
84
|
-
if (!
|
81
|
+
if (!s)
|
85
82
|
throw new Error("user node id must be present to review the sheet");
|
86
|
-
|
83
|
+
n(r, t);
|
87
84
|
return;
|
88
85
|
}
|
89
|
-
if (typeof
|
86
|
+
if (typeof i != "function")
|
90
87
|
throw new Error("onPreview must be a function");
|
91
|
-
|
92
|
-
}, [
|
93
|
-
(
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
default:
|
108
|
-
throw new Error(`No callback function for ${X}`);
|
109
|
-
}
|
110
|
-
},
|
111
|
-
[r, a, c, C, k, t]
|
112
|
-
), U = [
|
88
|
+
i(r, t);
|
89
|
+
}, [_, t, r, n, i, s]), p = (l) => {
|
90
|
+
switch (l) {
|
91
|
+
case "card-view":
|
92
|
+
F();
|
93
|
+
return;
|
94
|
+
case "card-unassign":
|
95
|
+
r && (h == null || h(r, t));
|
96
|
+
return;
|
97
|
+
case "card-reset":
|
98
|
+
r && (m == null || m(r, t));
|
99
|
+
return;
|
100
|
+
default:
|
101
|
+
throw new Error(`No callback function for ${l}`);
|
102
|
+
}
|
103
|
+
}, k = [
|
113
104
|
{
|
114
|
-
id: "
|
105
|
+
id: "card-view",
|
115
106
|
label: "View",
|
116
|
-
icon:
|
117
|
-
|
118
|
-
onClick:
|
107
|
+
icon: Q,
|
108
|
+
visible: !0,
|
109
|
+
onClick: p
|
119
110
|
},
|
120
111
|
{
|
121
112
|
id: "card-unassign",
|
122
113
|
label: "Unassign",
|
123
|
-
icon:
|
124
|
-
|
125
|
-
onClick:
|
126
|
-
}
|
127
|
-
], D = [
|
128
|
-
{
|
129
|
-
id: "student-card-click",
|
130
|
-
label: "Review",
|
131
|
-
icon: W,
|
132
|
-
disabled: !!g,
|
133
|
-
onClick: u
|
114
|
+
icon: fe,
|
115
|
+
visible: !!M,
|
116
|
+
onClick: p
|
134
117
|
},
|
135
118
|
{
|
136
|
-
id: "card-
|
137
|
-
label: "
|
138
|
-
icon:
|
139
|
-
|
140
|
-
onClick:
|
119
|
+
id: "card-reset",
|
120
|
+
label: "Reset",
|
121
|
+
icon: Y,
|
122
|
+
visible: !!P,
|
123
|
+
onClick: p
|
141
124
|
}
|
142
|
-
];
|
143
|
-
return
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
$flexGap: 8.5,
|
163
|
-
$position: "relative",
|
164
|
-
children: [
|
165
|
-
/* @__PURE__ */ e(
|
166
|
-
de,
|
167
|
-
{
|
168
|
-
$width: 31,
|
169
|
-
$height: 31,
|
170
|
-
$borderRadiusX: 2,
|
171
|
-
$background: "WHITE_1",
|
172
|
-
$position: "relative",
|
173
|
-
$alignItems: "center",
|
174
|
-
$justifyContent: "center",
|
175
|
-
children: x && /* @__PURE__ */ e(x, { width: 20, height: 20 })
|
176
|
-
}
|
177
|
-
),
|
178
|
-
/* @__PURE__ */ e(le, { $renderAs: "ac4-black", children: P }),
|
179
|
-
!!y && /* @__PURE__ */ e(he, { children: /* @__PURE__ */ e(me, { src: y, alt: "Chapter image" }) })
|
180
|
-
]
|
181
|
-
}
|
182
|
-
),
|
183
|
-
/* @__PURE__ */ e(
|
184
|
-
ne,
|
185
|
-
{
|
186
|
-
nodeType: f,
|
187
|
-
state: K,
|
188
|
-
accuracy: L,
|
189
|
-
dueDateTs: z
|
190
|
-
}
|
191
|
-
),
|
192
|
-
/* @__PURE__ */ n(d, { $gutterX: 0.75, $gapX: 1, $flexRowGapX: 0.5, $background: "WHITE", children: [
|
193
|
-
/* @__PURE__ */ e(
|
194
|
-
A,
|
195
|
-
{
|
196
|
-
renderAs: "primary",
|
197
|
-
position: "bottom",
|
198
|
-
tooltipItem: v,
|
199
|
-
hidden: !Q,
|
200
|
-
widthX: 21.75,
|
201
|
-
children: /* @__PURE__ */ e(d, { $heightX: 2.5, children: /* @__PURE__ */ e(fe, { ref: o, $renderAs: "ab3", children: v }) })
|
202
|
-
}
|
203
|
-
),
|
125
|
+
], V = !!k.find((l) => l.visible);
|
126
|
+
return /* @__PURE__ */ e(ee, { onClick: v ? z : void 0, label: "homework-card", children: /* @__PURE__ */ a(
|
127
|
+
ne,
|
128
|
+
{
|
129
|
+
$widthX: 12.5,
|
130
|
+
$position: "relative",
|
131
|
+
$background: `${A || "ORANGE"}_2`,
|
132
|
+
children: [
|
133
|
+
/* @__PURE__ */ a(
|
134
|
+
ce,
|
135
|
+
{
|
136
|
+
$flexDirection: "row",
|
137
|
+
$alignItems: "center",
|
138
|
+
$width: "100%",
|
139
|
+
$heightX: 3.5,
|
140
|
+
$bgImage: R,
|
141
|
+
$gutterX: 0.78125,
|
142
|
+
$flexGap: 8.5,
|
143
|
+
$position: "relative",
|
144
|
+
children: [
|
204
145
|
/* @__PURE__ */ e(
|
205
|
-
|
146
|
+
oe,
|
206
147
|
{
|
207
|
-
$
|
208
|
-
$
|
148
|
+
$width: 31,
|
149
|
+
$height: 31,
|
150
|
+
$borderRadiusX: 2,
|
151
|
+
$background: "WHITE_1",
|
152
|
+
$position: "relative",
|
209
153
|
$alignItems: "center",
|
210
|
-
$justifyContent: "
|
211
|
-
children: /* @__PURE__ */ e(
|
154
|
+
$justifyContent: "center",
|
155
|
+
children: $ && /* @__PURE__ */ e($, { width: 20, height: 20 })
|
212
156
|
}
|
213
|
-
)
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
{
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
157
|
+
),
|
158
|
+
/* @__PURE__ */ e(te, { $renderAs: "ac4-black", children: O }),
|
159
|
+
!!w && /* @__PURE__ */ e(ae, { children: /* @__PURE__ */ e(se, { src: w, alt: "Chapter image" }) })
|
160
|
+
]
|
161
|
+
}
|
162
|
+
),
|
163
|
+
/* @__PURE__ */ e(Z, { nodeType: c, state: X, accuracy: S, dueDateTs: W }),
|
164
|
+
/* @__PURE__ */ a(u, { $gutterX: 0.75, $gapX: 1, $flexRowGapX: 0.5, $background: "WHITE", children: [
|
165
|
+
/* @__PURE__ */ e(
|
166
|
+
E,
|
167
|
+
{
|
168
|
+
renderAs: "primary",
|
169
|
+
position: "bottom",
|
170
|
+
tooltipItem: d,
|
171
|
+
hidden: !K,
|
172
|
+
widthX: 21.75,
|
173
|
+
children: /* @__PURE__ */ e(u, { $heightX: 2.5, children: /* @__PURE__ */ e(le, { ref: o, $renderAs: "ab3", children: d }) })
|
174
|
+
}
|
175
|
+
),
|
176
|
+
/* @__PURE__ */ a(
|
177
|
+
u,
|
178
|
+
{
|
179
|
+
$flexDirection: "row",
|
180
|
+
$heightX: 1.25,
|
181
|
+
$alignItems: "center",
|
182
|
+
$justifyContent: "space-between",
|
183
|
+
children: [
|
184
|
+
/* @__PURE__ */ e(ue, { $renderAs: "ub3", $color: "BLACK_T_60", children: I }),
|
185
|
+
!v && r && V && /* @__PURE__ */ a(u, { $position: "relative", $width: "fit-content", children: [
|
186
|
+
/* @__PURE__ */ e(
|
187
|
+
E,
|
188
|
+
{
|
189
|
+
renderAs: "primary",
|
190
|
+
tooltipItem: "Review",
|
191
|
+
position: "bottom",
|
192
|
+
zIndex: 5,
|
193
|
+
parentWidth: "100%",
|
194
|
+
children: /* @__PURE__ */ e(he, { ref: b, onClick: G, children: /* @__PURE__ */ e(U, { width: 16, height: 16 }) })
|
195
|
+
}
|
196
|
+
),
|
197
|
+
/* @__PURE__ */ e(me, { $visible: j, children: /* @__PURE__ */ e(ie, { options: k }) })
|
198
|
+
] })
|
199
|
+
]
|
200
|
+
}
|
201
|
+
)
|
202
|
+
] })
|
203
|
+
]
|
204
|
+
}
|
205
|
+
) });
|
206
|
+
};
|
253
207
|
export {
|
254
|
-
|
208
|
+
He as default
|
255
209
|
};
|
256
210
|
//# sourceMappingURL=homework-card.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"homework-card.js","sources":["../../../src/features/homework/homework-card.tsx"],"sourcesContent":["import type {\n INodeCardCallbacks,\n INodeDataProps,\n} from '../chapters-v2/comps/node-card/node-card-types';\nimport type { TUserTypes } from '../ui/types';\n\nimport { memo, useCallback, useLayoutEffect, useRef, useState } from 'react';\n\nimport Eye2Icon from '../../assets/line-icons/icons/eye2';\nimport MoreVerticalIcon from '../../assets/line-icons/icons/more-vertical';\nimport RedoIcon from '../../assets/line-icons/icons/redo';\nimport NodeCardTags from '../chapters-v2/comps/node-card/node-card-tags';\nimport { getNodeTypeBasedBgImage } from '../chapters-v2/utils';\nimport { getNodeCardBasedIcon } from '../chapters-v2/utils/node-card-utils';\nimport ArrowTooltip from '../ui/arrow-tooltip/arrow-tooltip';\nimport Clickable from '../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\nimport CardMenuOptions from './card-menu-options';\nimport * as Styled from './styles';\n\ninterface IHomeworkCardProps extends INodeCardCallbacks {\n header: string;\n nodeData: INodeDataProps;\n subHeader: string;\n userType: TUserTypes;\n userMilestoneId?: string;\n}\n\nconst HomeworkCard = ({\n header,\n nodeData,\n subHeader,\n userType,\n userMilestoneId,\n onNodeUnassign,\n onNodeReattempt,\n onNodeView,\n onNodeReview,\n onNodeAttempt,\n}: IHomeworkCardProps) => {\n const {\n node_type: nodeType,\n state,\n accuracy,\n due_date_ts: dueDateTs,\n image_url: imageUrl,\n image_hue: imageHue,\n card_header: cardHeader = '',\n permissions,\n user_node_id: userNodeId,\n } = nodeData;\n\n const bgImage = getNodeTypeBasedBgImage(nodeType);\n const NodeCardIcon = getNodeCardBasedIcon(nodeType);\n const teacherContainerRef = useRef<HTMLDivElement>(null);\n const studentContainerRef = useRef<HTMLDivElement>(null);\n const titleTextRef = useRef<HTMLDivElement>(null);\n const { menuVisible: teacherMenuVisible, onMenuClick: onTeacherMenuClick } =\n useContextMenuClickHandler(teacherContainerRef);\n const { menuVisible: studentMenuVisible, onMenuClick: onStudentMenuClick } =\n useContextMenuClickHandler(studentContainerRef);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const {\n can_start: canStart,\n can_resume: canResume,\n can_review: canReview,\n can_teacher_review: canTeacherReview,\n can_unassign: canUnassign,\n can_reset: canReset,\n } = permissions;\n const isStudent = userType === 'STUDENT';\n\n useLayoutEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n const onStudentView = useCallback(() => {\n console.log('calles onStudentView view', permissions);\n if (canStart || canResume) {\n console.log('calles onStudentView canStart || canResume');\n\n if (typeof onNodeAttempt !== 'function') {\n throw new Error('onNodeAttempt must be a function');\n }\n\n onNodeAttempt(nodeData);\n\n return;\n }\n\n if (canReset) {\n console.log('calles onStudentView canReset');\n\n onStudentMenuClick();\n\n return;\n }\n\n if (canReview) {\n console.log('calles onStudentView canReview');\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n }, [\n permissions,\n canStart,\n canResume,\n canReset,\n canReview,\n onNodeAttempt,\n nodeData,\n onStudentMenuClick,\n onNodeReview,\n userNodeId,\n userMilestoneId,\n ]);\n\n const onTeacherView = useCallback(() => {\n if (canTeacherReview) {\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n\n if (typeof onNodeView !== 'function') {\n throw new Error('onPreview must be a function');\n }\n\n onNodeView(nodeData, userMilestoneId);\n }, [canTeacherReview, userMilestoneId, nodeData, onNodeReview, onNodeView, userNodeId]);\n\n const handleOnMenuOptionClick = useCallback(\n (optionId: string) => {\n switch (optionId) {\n case 'teacher-card-view':\n onTeacherView();\n\n return;\n\n case 'student-card-click':\n onStudentView();\n\n return;\n case 'card-unassign':\n onNodeUnassign?.(nodeData, userMilestoneId);\n\n return;\n case 'card-reattempt':\n onNodeReattempt?.(nodeData, userMilestoneId);\n\n return;\n\n default:\n throw new Error(`No callback function for ${optionId}`);\n }\n },\n [nodeData, onNodeReattempt, onNodeUnassign, onStudentView, onTeacherView, userMilestoneId],\n );\n\n const teacherOptions = [\n {\n id: 'teacher-card-view',\n label: 'View',\n icon: Eye2Icon,\n disabled: true,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-unassign',\n label: 'Unassign',\n icon: Styled.StyledMinus2Icon,\n disabled: !!canUnassign,\n onClick: handleOnMenuOptionClick,\n },\n ];\n\n const studentOptions = [\n {\n id: 'student-card-click',\n label: 'Review',\n icon: Eye2Icon,\n disabled: !!canReview,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-reattempt',\n label: 'Reattempt',\n icon: RedoIcon,\n disabled: !!canReset,\n onClick: handleOnMenuOptionClick,\n },\n ];\n\n console.log(!isStudent);\n\n return (\n <FlexView $position=\"relative\">\n <Clickable onClick={isStudent ? onStudentView : onTeacherView} label=\"homework-card\">\n <Styled.CardContainer\n ref={studentContainerRef}\n $widthX={12.5}\n $position=\"relative\"\n $background={`${imageHue || 'ORANGE'}_2`}\n >\n <Styled.CardWrapper\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $width=\"100%\"\n $heightX={3.5}\n $bgImage={bgImage}\n $gutterX={0.78125}\n $flexGap={8.5}\n $position=\"relative\"\n >\n <Styled.IconWrapper\n $width={31}\n $height={31}\n $borderRadiusX={2}\n $background=\"WHITE_1\"\n $position=\"relative\"\n $alignItems=\"center\"\n $justifyContent=\"center\"\n >\n {NodeCardIcon && <NodeCardIcon width={20} height={20} />}\n </Styled.IconWrapper>\n <Text $renderAs=\"ac4-black\">{cardHeader}</Text>\n {!!imageUrl && (\n <Styled.BannerImageWrapper>\n <Styled.BannerImage src={imageUrl} alt=\"Chapter image\" />\n </Styled.BannerImageWrapper>\n )}\n </Styled.CardWrapper>\n <NodeCardTags\n nodeType={nodeType}\n state={state}\n accuracy={accuracy}\n dueDateTs={dueDateTs}\n />\n <FlexView $gutterX={0.75} $gapX={1} $flexRowGapX={0.5} $background=\"WHITE\">\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={header}\n hidden={!showTitleTooltip}\n widthX={21.75}\n >\n <FlexView $heightX={2.5}>\n <Styled.HeaderText ref={titleTextRef} $renderAs=\"ab3\">\n {header}\n </Styled.HeaderText>\n </FlexView>\n </ArrowTooltip>\n <FlexView\n $flexDirection=\"row\"\n $heightX={1.25}\n $alignItems=\"center\"\n $justifyContent=\"space-between\"\n >\n <Styled.SubHeaderText $renderAs=\"ub3\" $color=\"BLACK_T_60\">\n {subHeader}\n </Styled.SubHeaderText>\n </FlexView>\n </FlexView>\n </Styled.CardContainer>\n {isStudent && (\n <Styled.CardMenuOptionsWrapper $visible={studentMenuVisible}>\n <CardMenuOptions\n $width={200}\n options={studentOptions}\n triggerRef={studentContainerRef}\n visible={studentMenuVisible}\n />\n </Styled.CardMenuOptionsWrapper>\n )}\n </Clickable>\n {!isStudent && (\n <Styled.MenuWrapper $position=\"absolute\" $width=\"fit-content\">\n <ArrowTooltip\n isAnimated\n renderAs=\"primary\"\n tooltipItem=\"Review\"\n position=\"bottom\"\n zIndex={5}\n parentWidth=\"100%\"\n >\n <Styled.CardKebabMenuWrapper ref={teacherContainerRef} onClick={onTeacherMenuClick}>\n <MoreVerticalIcon width={16} height={16} />\n </Styled.CardKebabMenuWrapper>\n </ArrowTooltip>\n <Styled.CardMenuOptionsWrapper $visible={teacherMenuVisible}>\n <CardMenuOptions\n $width={'fit-content'}\n options={teacherOptions}\n triggerRef={teacherContainerRef}\n visible={teacherMenuVisible}\n />\n </Styled.CardMenuOptionsWrapper>\n </Styled.MenuWrapper>\n )}\n </FlexView>\n );\n};\n\nexport default memo(HomeworkCard);\n"],"names":["HomeworkCard","header","nodeData","subHeader","userType","userMilestoneId","onNodeUnassign","onNodeReattempt","onNodeView","onNodeReview","onNodeAttempt","nodeType","state","accuracy","dueDateTs","imageUrl","imageHue","cardHeader","permissions","userNodeId","bgImage","getNodeTypeBasedBgImage","NodeCardIcon","getNodeCardBasedIcon","teacherContainerRef","useRef","studentContainerRef","titleTextRef","teacherMenuVisible","onTeacherMenuClick","useContextMenuClickHandler","studentMenuVisible","onStudentMenuClick","showTitleTooltip","setShowTitleTooltip","useState","canStart","canResume","canReview","canTeacherReview","canUnassign","canReset","isStudent","useLayoutEffect","onStudentView","useCallback","onTeacherView","handleOnMenuOptionClick","optionId","teacherOptions","Eye2Icon","Styled.StyledMinus2Icon","studentOptions","RedoIcon","jsxs","FlexView","Clickable","Styled.CardContainer","Styled.CardWrapper","jsx","Styled.IconWrapper","Text","Styled.BannerImageWrapper","Styled.BannerImage","NodeCardTags","ArrowTooltip","Styled.HeaderText","Styled.SubHeaderText","Styled.CardMenuOptionsWrapper","CardMenuOptions","Styled.MenuWrapper","Styled.CardKebabMenuWrapper","MoreVerticalIcon","HomeworkCard$1","memo"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"homework-card.js","sources":["../../../src/features/homework/homework-card.tsx"],"sourcesContent":["import type {\n INodeCardCallbacks,\n INodeDataProps,\n} from '../chapters-v2/comps/node-card/node-card-types';\nimport type { ICardMenuOption } from './card-menu-options';\n\nimport { useCallback, useLayoutEffect, useRef, useState } from 'react';\n\nimport Eye2Icon from '../../assets/line-icons/icons/eye2';\nimport MoreVerticalIcon from '../../assets/line-icons/icons/more-vertical';\nimport RedoIcon from '../../assets/line-icons/icons/redo';\nimport NodeCardTags from '../chapters-v2/comps/node-card/node-card-tags';\nimport { getNodeTypeBasedBgImage } from '../chapters-v2/utils';\nimport { getNodeCardBasedIcon } from '../chapters-v2/utils/node-card-utils';\nimport ArrowTooltip from '../ui/arrow-tooltip/arrow-tooltip';\nimport Clickable from '../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\nimport CardMenuOptions from './card-menu-options';\nimport * as Styled from './styles';\n\ninterface IHomeworkCardProps extends INodeCardCallbacks {\n header: string;\n nodeData: INodeDataProps;\n subHeader: string;\n userType: 'TEACHER' | 'STUDENT';\n userMilestoneId?: string;\n}\n\nconst HomeworkCard = ({\n header,\n nodeData,\n subHeader,\n userType,\n userMilestoneId,\n onNodeUnassign,\n onNodeReset,\n onNodeView,\n onNodeReview,\n onNodeAttempt,\n}: IHomeworkCardProps) => {\n const {\n node_type: nodeType,\n state,\n accuracy,\n due_date_ts: dueDateTs,\n image_url: imageUrl,\n image_hue: imageHue,\n card_header: cardHeader = '',\n permissions,\n user_node_id: userNodeId,\n } = nodeData;\n\n const bgImage = nodeType && getNodeTypeBasedBgImage(nodeType);\n const NodeCardIcon = nodeType && getNodeCardBasedIcon(nodeType);\n const containerRef = useRef<HTMLDivElement>(null);\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(containerRef);\n const titleTextRef = useRef<HTMLDivElement>(null);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const {\n can_start: canStart,\n can_resume: canResume,\n can_review: canReview,\n can_teacher_review: canTeacherReview,\n can_unassign: canUnassign,\n can_reset: canReset,\n } = permissions || {};\n const isStudent = userType === 'STUDENT';\n\n useLayoutEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n const onStudentView = useCallback(() => {\n if (canStart || canResume) {\n if (typeof onNodeAttempt !== 'function') {\n throw new Error('onNodeAttempt must be a function');\n }\n\n onNodeAttempt(nodeData);\n\n return;\n }\n\n if (canReview) {\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n\n if (typeof onNodeView !== 'function') {\n throw new Error('onPreview must be a function');\n }\n\n onNodeView(nodeData, userMilestoneId);\n }, [\n canResume,\n canReview,\n canStart,\n userMilestoneId,\n nodeData,\n onNodeAttempt,\n onNodeReview,\n onNodeView,\n userNodeId,\n ]);\n\n const onTeacherView = useCallback(() => {\n if (canTeacherReview) {\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n\n if (typeof onNodeView !== 'function') {\n throw new Error('onPreview must be a function');\n }\n\n onNodeView(nodeData, userMilestoneId);\n }, [canTeacherReview, userMilestoneId, nodeData, onNodeReview, onNodeView, userNodeId]);\n\n const handleOnMenuOptionClick = (optionId: string) => {\n switch (optionId) {\n case 'card-view':\n onTeacherView();\n\n return;\n case 'card-unassign':\n nodeData && onNodeUnassign?.(nodeData, userMilestoneId);\n\n return;\n case 'card-reset':\n nodeData && onNodeReset?.(nodeData, userMilestoneId);\n\n return;\n\n default:\n throw new Error(`No callback function for ${optionId}`);\n }\n };\n\n const menuOptions: ICardMenuOption[] = [\n {\n id: 'card-view',\n label: 'View',\n icon: Eye2Icon,\n visible: true,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-unassign',\n label: 'Unassign',\n icon: Styled.StyledMinus2Icon,\n visible: !!canUnassign,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-reset',\n label: 'Reset',\n icon: RedoIcon,\n visible: !!canReset,\n onClick: handleOnMenuOptionClick,\n },\n ];\n\n const canShowMenuOptions = !!menuOptions.find(option => option.visible);\n\n return (\n <Clickable onClick={isStudent ? onStudentView : undefined} label=\"homework-card\">\n <Styled.CardContainer\n $widthX={12.5}\n $position=\"relative\"\n $background={`${imageHue || 'ORANGE'}_2`}\n >\n <Styled.CardWrapper\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $width=\"100%\"\n $heightX={3.5}\n $bgImage={bgImage}\n $gutterX={0.78125}\n $flexGap={8.5}\n $position=\"relative\"\n >\n <Styled.IconWrapper\n $width={31}\n $height={31}\n $borderRadiusX={2}\n $background=\"WHITE_1\"\n $position=\"relative\"\n $alignItems=\"center\"\n $justifyContent=\"center\"\n >\n {NodeCardIcon && <NodeCardIcon width={20} height={20} />}\n </Styled.IconWrapper>\n <Text $renderAs=\"ac4-black\">{cardHeader}</Text>\n {!!imageUrl && (\n <Styled.BannerImageWrapper>\n <Styled.BannerImage src={imageUrl} alt=\"Chapter image\" />\n </Styled.BannerImageWrapper>\n )}\n </Styled.CardWrapper>\n <NodeCardTags nodeType={nodeType} state={state} accuracy={accuracy} dueDateTs={dueDateTs} />\n <FlexView $gutterX={0.75} $gapX={1} $flexRowGapX={0.5} $background=\"WHITE\">\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={header}\n hidden={!showTitleTooltip}\n widthX={21.75}\n >\n <FlexView $heightX={2.5}>\n <Styled.HeaderText ref={titleTextRef} $renderAs=\"ab3\">\n {header}\n </Styled.HeaderText>\n </FlexView>\n </ArrowTooltip>\n <FlexView\n $flexDirection=\"row\"\n $heightX={1.25}\n $alignItems=\"center\"\n $justifyContent=\"space-between\"\n >\n <Styled.SubHeaderText $renderAs=\"ub3\" $color=\"BLACK_T_60\">\n {subHeader}\n </Styled.SubHeaderText>\n {!isStudent && nodeData && canShowMenuOptions && (\n <FlexView $position=\"relative\" $width=\"fit-content\">\n <ArrowTooltip\n renderAs=\"primary\"\n tooltipItem=\"Review\"\n position=\"bottom\"\n zIndex={5}\n parentWidth=\"100%\"\n >\n <Styled.CardKebabMenuWrapper ref={containerRef} onClick={onMenuClick}>\n <MoreVerticalIcon width={16} height={16} />\n </Styled.CardKebabMenuWrapper>\n </ArrowTooltip>\n <Styled.CardMenuOptionsWrapper $visible={menuVisible}>\n <CardMenuOptions options={menuOptions} />\n </Styled.CardMenuOptionsWrapper>\n </FlexView>\n )}\n </FlexView>\n </FlexView>\n </Styled.CardContainer>\n </Clickable>\n );\n};\n\nexport default HomeworkCard;\n"],"names":["HomeworkCard","header","nodeData","subHeader","userType","userMilestoneId","onNodeUnassign","onNodeReset","onNodeView","onNodeReview","onNodeAttempt","nodeType","state","accuracy","dueDateTs","imageUrl","imageHue","cardHeader","permissions","userNodeId","bgImage","getNodeTypeBasedBgImage","NodeCardIcon","getNodeCardBasedIcon","containerRef","useRef","menuVisible","onMenuClick","useContextMenuClickHandler","titleTextRef","showTitleTooltip","setShowTitleTooltip","useState","canStart","canResume","canReview","canTeacherReview","canUnassign","canReset","isStudent","useLayoutEffect","onStudentView","useCallback","onTeacherView","handleOnMenuOptionClick","optionId","menuOptions","Eye2Icon","Styled.StyledMinus2Icon","RedoIcon","canShowMenuOptions","option","Clickable","jsxs","Styled.CardContainer","Styled.CardWrapper","jsx","Styled.IconWrapper","Text","Styled.BannerImageWrapper","Styled.BannerImage","NodeCardTags","FlexView","ArrowTooltip","Styled.HeaderText","Styled.SubHeaderText","Styled.CardKebabMenuWrapper","MoreVerticalIcon","Styled.CardMenuOptionsWrapper","CardMenuOptions"],"mappings":"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"}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
import r from "styled-components";
|
2
2
|
import i from "../../assets/line-icons/icons/minus2.js";
|
3
|
-
import
|
3
|
+
import t from "../ui/layout/flex-view.js";
|
4
4
|
import n from "../ui/text/text.js";
|
5
|
-
const l = r(
|
5
|
+
const l = r(t)(({ theme: o }) => `
|
6
6
|
cursor: pointer;
|
7
7
|
width: fit-content;
|
8
8
|
|
@@ -16,9 +16,9 @@ const l = r(e)(({ theme: o }) => `
|
|
16
16
|
-webkit-box-orient: vertical;
|
17
17
|
overflow: hidden;
|
18
18
|
text-overflow: ellipsis;
|
19
|
-
`, u = r(
|
19
|
+
`, u = r(t)(({
|
20
20
|
theme: o,
|
21
|
-
$visible:
|
21
|
+
$visible: e
|
22
22
|
}) => `
|
23
23
|
cursor: pointer;
|
24
24
|
position: absolute;
|
@@ -26,43 +26,43 @@ const l = r(e)(({ theme: o }) => `
|
|
26
26
|
top: calc(100% + 4px);
|
27
27
|
left: 0;
|
28
28
|
transform-origin: top;
|
29
|
-
transform: scaleY(${
|
30
|
-
opacity: ${
|
29
|
+
transform: scaleY(${e ? 1 : 0});
|
30
|
+
opacity: ${e ? 1 : 0};
|
31
31
|
transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
|
32
32
|
|
33
33
|
&:hover {
|
34
34
|
border-radius: 50%;
|
35
35
|
background: ${o.colors.WHITE_5};
|
36
36
|
}
|
37
|
-
`), x = r(
|
37
|
+
`), x = r(t)`
|
38
38
|
border: 1px solid ${({ theme: o }) => o.colors.BLACK_T_15};
|
39
39
|
|
40
40
|
&:hover {
|
41
41
|
border: 1px solid ${({ theme: o }) => o.colors.BLACK};
|
42
42
|
}
|
43
|
-
`, b = r(
|
43
|
+
`, b = r(t)(({ $bgImage: o }) => o ? `
|
44
44
|
background-image: url(${o});
|
45
45
|
background-repeat: no-repeat;
|
46
46
|
background-size: cover;
|
47
47
|
background-position: center;
|
48
48
|
overflow: hidden;
|
49
|
-
` : "overflow: hidden;"), f = r(
|
49
|
+
` : "overflow: hidden;"), f = r(t)`
|
50
50
|
display: flex;
|
51
51
|
align-items: center;
|
52
52
|
justify-content: center;
|
53
|
-
`, w = r(
|
53
|
+
`, w = r(t)`
|
54
54
|
position: absolute;
|
55
55
|
right: -18px;
|
56
56
|
top: -4px;
|
57
|
-
`,
|
58
|
-
const { gutter:
|
57
|
+
`, h = r.img(({ theme: o }) => {
|
58
|
+
const { gutter: e } = o.layout;
|
59
59
|
return `
|
60
60
|
border: 1px solid ${o.colors.BLACK_T_15};
|
61
|
-
width: ${
|
62
|
-
height: ${
|
61
|
+
width: ${e * 4}px;
|
62
|
+
height: ${e * 4}px;
|
63
63
|
border-radius: 50%;
|
64
64
|
`;
|
65
|
-
}),
|
65
|
+
}), g = r(i)`
|
66
66
|
path {
|
67
67
|
stroke: ${({ theme: o }) => o.colors.WHITE};
|
68
68
|
}
|
@@ -72,19 +72,20 @@ const l = r(e)(({ theme: o }) => `
|
|
72
72
|
-webkit-box-orient: vertical;
|
73
73
|
overflow: hidden;
|
74
74
|
text-overflow: ellipsis;
|
75
|
-
`, v = r(
|
75
|
+
`, v = r(t)`
|
76
76
|
box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);
|
77
|
+
width: 180px;
|
77
78
|
position: relative;
|
78
79
|
left: 0;
|
79
80
|
top: 0;
|
80
|
-
`, k = r(
|
81
|
+
`, k = r(t)(({
|
81
82
|
theme: o,
|
82
|
-
$disabled:
|
83
|
+
$disabled: e
|
83
84
|
}) => `
|
84
|
-
cursor: ${
|
85
|
+
cursor: ${e ? "not-allowed" : "pointer"};
|
85
86
|
|
86
87
|
&:hover {
|
87
|
-
background: ${
|
88
|
+
background: ${e ? "transparent" : o.colors.BLACK};
|
88
89
|
};
|
89
90
|
|
90
91
|
path {
|
@@ -94,16 +95,9 @@ const l = r(e)(({ theme: o }) => `
|
|
94
95
|
white-space: nowrap;
|
95
96
|
overflow: hidden;
|
96
97
|
text-overflow: ellipsis;
|
97
|
-
`, W = r(e)`
|
98
|
-
position: absolute;
|
99
|
-
z-index: 6;
|
100
|
-
top: calc(100% - 32px);
|
101
|
-
right: 8px;
|
102
|
-
transform-origin: top;
|
103
|
-
transform: scaleY(1);
|
104
98
|
`;
|
105
99
|
export {
|
106
|
-
|
100
|
+
h as BannerImage,
|
107
101
|
w as BannerImageWrapper,
|
108
102
|
x as CardContainer,
|
109
103
|
l as CardKebabMenuWrapper,
|
@@ -113,9 +107,8 @@ export {
|
|
113
107
|
b as CardWrapper,
|
114
108
|
m as HeaderText,
|
115
109
|
f as IconWrapper,
|
116
|
-
W as MenuWrapper,
|
117
110
|
C as OptionText,
|
118
|
-
|
111
|
+
g as StyledMinus2Icon,
|
119
112
|
d as SubHeaderText
|
120
113
|
};
|
121
114
|
//# sourceMappingURL=styles.js.map
|