@cuemath/leap 2.8.61-as1 → 2.8.61-as11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/dist/assets/line-icons/icons/chevron-left.js.map +1 -1
  2. package/dist/assets/line-icons/icons/chevron-right.js.map +1 -1
  3. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +23 -22
  4. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
  5. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +88 -74
  6. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  7. package/dist/features/chapters/chapters-list/chapters-list.js +17 -18
  8. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  9. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +39 -39
  10. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -1
  11. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +32 -28
  12. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +1 -1
  13. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js +22 -22
  14. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js.map +1 -1
  15. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +6 -6
  16. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
  17. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +70 -71
  18. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +1 -1
  19. package/dist/features/chapters-v2/constants/node-constants.js +0 -1
  20. package/dist/features/chapters-v2/constants/node-constants.js.map +1 -1
  21. package/dist/features/chapters-v2/utils/index.js +4 -4
  22. package/dist/features/chapters-v2/utils/index.js.map +1 -1
  23. package/dist/features/chapters-v2/utils/node-card-utils.js +59 -42
  24. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
  25. package/dist/features/communication/pub-sub/constants.js +5 -2
  26. package/dist/features/communication/pub-sub/constants.js.map +1 -1
  27. package/dist/features/homework/card-menu-options.js +35 -20
  28. package/dist/features/homework/card-menu-options.js.map +1 -1
  29. package/dist/features/homework/homework-card.js +241 -161
  30. package/dist/features/homework/homework-card.js.map +1 -1
  31. package/dist/features/homework/hw-card-list/api/get-homeworks.js +10 -0
  32. package/dist/features/homework/hw-card-list/api/get-homeworks.js.map +1 -0
  33. package/dist/features/homework/hw-card-list/hw-card-list-styled.js +53 -0
  34. package/dist/features/homework/hw-card-list/hw-card-list-styled.js.map +1 -0
  35. package/dist/features/homework/hw-card-list/hw-card-list.js +164 -0
  36. package/dist/features/homework/hw-card-list/hw-card-list.js.map +1 -0
  37. package/dist/features/homework/node-progress.js +29 -0
  38. package/dist/features/homework/node-progress.js.map +1 -0
  39. package/dist/features/homework/styles.js +41 -38
  40. package/dist/features/homework/styles.js.map +1 -1
  41. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js +42 -49
  42. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js.map +1 -1
  43. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js +14 -20
  44. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js.map +1 -1
  45. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js +26 -50
  46. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js.map +1 -1
  47. package/dist/features/milestone/create/utils/index.js +33 -38
  48. package/dist/features/milestone/create/utils/index.js.map +1 -1
  49. package/dist/features/milestone/edit/goal-edit-helpers.js +50 -53
  50. package/dist/features/milestone/edit/goal-edit-helpers.js.map +1 -1
  51. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +10 -10
  52. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  53. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +17 -15
  54. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +1 -1
  55. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +10 -0
  56. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -0
  57. package/dist/features/recent-chapters/recent-chapters.js +17 -23
  58. package/dist/features/recent-chapters/recent-chapters.js.map +1 -1
  59. package/dist/features/sheet-v2/resource-list/resource-list.js +12 -10
  60. package/dist/features/sheet-v2/resource-list/resource-list.js.map +1 -1
  61. package/dist/index.d.ts +54 -24
  62. package/dist/index.js +41 -37
  63. package/dist/index.js.map +1 -1
  64. package/dist/node_modules/date-fns/differenceInDays.js +17 -0
  65. package/dist/node_modules/date-fns/differenceInDays.js.map +1 -0
  66. package/package.json +1 -1
@@ -0,0 +1,53 @@
1
+ import t, { css as i } from "styled-components";
2
+ import e from "../../ui/layout/flex-view.js";
3
+ const s = t(e)`
4
+ overflow-x: hidden;
5
+ overflow-y: visible;
6
+ padding: 16px 0px 92px 0px;
7
+ margin-bottom: -92px;
8
+ margin-top: -16px;
9
+ `, l = t(e)`
10
+ right: ${({ right: o }) => o};
11
+ left: ${({ left: o }) => o};
12
+ width: 32px;
13
+ cursor: pointer;
14
+ transition: opacity 0.3s ease-in-out;
15
+ opacity: ${({ $visible: o }) => o ? 1 : 0};
16
+ pointer-events: ${({ $visible: o }) => o ? "auto" : "none"};
17
+ z-index: 10;
18
+ path {
19
+ fill: ${({ theme: o }) => o.colors.WHITE};
20
+ }
21
+ `, a = t(e)(
22
+ ({ $disablePointerEvents: o, theme: n }) => `
23
+ position: relative;
24
+ pointer-events: auto;
25
+ z-index: 1;
26
+ ${o && i`
27
+ pointer-events: none;
28
+ :after {
29
+ content: '';
30
+ position: absolute;
31
+ top: 0;
32
+ left: 0;
33
+ right: 0;
34
+ bottom: 0;
35
+ background: ${n.colors.GREY_3};
36
+ }
37
+ `}
38
+ `
39
+ ), c = t(e)`
40
+ cursor: pointer;
41
+ height: 100%;
42
+ right: ${({ right: o }) => o};
43
+ left: ${({ left: o }) => o};
44
+ pointer-events: all;
45
+ z-index: 5;
46
+ `;
47
+ export {
48
+ a as ContentWrapper,
49
+ c as HoverZone,
50
+ l as ScrollButton,
51
+ s as ScrollContainer
52
+ };
53
+ //# sourceMappingURL=hw-card-list-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hw-card-list-styled.js","sources":["../../../../src/features/homework/hw-card-list/hw-card-list-styled.tsx"],"sourcesContent":["import styled, { css } from 'styled-components';\n\nimport FlexView from '../../ui/layout/flex-view';\n\nexport const ScrollContainer = styled(FlexView)`\n overflow-x: hidden;\n overflow-y: visible;\n padding: 16px 0px 92px 0px;\n margin-bottom: -92px;\n margin-top: -16px;\n`;\n\nexport const ScrollButton = styled(FlexView)<{ $visible: boolean; right: string; left: string }>`\n right: ${({ right }) => right};\n left: ${({ left }) => left};\n width: 32px;\n cursor: pointer;\n transition: opacity 0.3s ease-in-out;\n opacity: ${({ $visible }) => ($visible ? 1 : 0)};\n pointer-events: ${({ $visible }) => ($visible ? 'auto' : 'none')};\n z-index: 10;\n path {\n fill: ${({ theme }) => theme.colors.WHITE};\n }\n`;\n\nexport const ContentWrapper = styled(FlexView)<{ $disablePointerEvents: boolean }>(\n ({ $disablePointerEvents, theme }) => `\n position: relative;\n pointer-events: auto;\n z-index: 1;\n ${\n $disablePointerEvents &&\n css`\n pointer-events: none;\n :after {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: ${theme.colors.GREY_3};\n }\n `\n }\n `,\n);\n\nexport const HoverZone = styled(FlexView)<{ right: string; left: string }>`\n cursor: pointer;\n height: 100%;\n right: ${({ right }) => right};\n left: ${({ left }) => left};\n pointer-events: all;\n z-index: 5;\n`;\n"],"names":["ScrollContainer","styled","FlexView","ScrollButton","right","left","$visible","theme","ContentWrapper","$disablePointerEvents","css","HoverZone"],"mappings":";;AAIa,MAAAA,IAAkBC,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQjCC,IAAeF,EAAOC,CAAQ;AAAA,WAChC,CAAC,EAAE,OAAAE,EAAM,MAAMA,CAAK;AAAA,UACrB,CAAC,EAAE,MAAAC,EAAK,MAAMA,CAAI;AAAA;AAAA;AAAA;AAAA,aAIf,CAAC,EAAE,UAAAC,EAAA,MAAgBA,IAAW,IAAI,CAAE;AAAA,oBAC7B,CAAC,EAAE,UAAAA,EAAA,MAAgBA,IAAW,SAAS,MAAO;AAAA;AAAA;AAAA,YAGtD,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAIhCC,IAAiBP,EAAOC,CAAQ;AAAA,EAC3C,CAAC,EAAE,uBAAAO,GAAuB,OAAAF,EAAA,MAAY;AAAA;AAAA;AAAA;AAAA,MAKlCE,KACAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBASkBH,EAAM,OAAO,MAAM;AAAA;AAAA,OAGvC;AAAA;AAEJ,GAEaI,IAAYV,EAAOC,CAAQ;AAAA;AAAA;AAAA,WAG7B,CAAC,EAAE,OAAAE,EAAM,MAAMA,CAAK;AAAA,UACrB,CAAC,EAAE,MAAAC,EAAK,MAAMA,CAAI;AAAA;AAAA;AAAA;"}
@@ -0,0 +1,164 @@
1
+ import { jsxs as s, jsx as t } from "react/jsx-runtime";
2
+ import { h as ee } from "../../../node_modules/humanize-plus/dist/humanize.js";
3
+ import { useRef as te, useState as a, useCallback as n, useEffect as m } from "react";
4
+ import oe from "../../../assets/line-icons/icons/chevron-left.js";
5
+ import re from "../../../assets/line-icons/icons/chevron-right.js";
6
+ import { getTopicsFromItems as ne } from "../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js";
7
+ import u from "../../ui/layout/flex-view.js";
8
+ import p from "../../ui/text/text.js";
9
+ import ie from "../homework-card.js";
10
+ import { useGetHomeworks as se } from "./api/get-homeworks.js";
11
+ import { ContentWrapper as le, HoverZone as b, ScrollButton as _, ScrollContainer as ce } from "./hw-card-list-styled.js";
12
+ const ae = ({
13
+ userType: k = "STUDENT",
14
+ studentId: h,
15
+ stream: $,
16
+ onTestStart: w,
17
+ onNodeAttempt: x,
18
+ onTestPreview: R,
19
+ onNodeView: S,
20
+ onTestReview: E,
21
+ onNodeReview: T,
22
+ onNodeUnassign: A
23
+ }) => {
24
+ const r = te(null), [y, g] = a(!1), [B, v] = a(!1), [I, M] = a(!1), [N, j] = a(!0), {
25
+ get: C,
26
+ data: e,
27
+ isProcessingFailed: K,
28
+ isProcessing: W
29
+ } = se(h), z = n(() => {
30
+ r.current && r.current.scrollBy({ left: -200, behavior: "smooth" });
31
+ }, []), G = n(() => {
32
+ r.current && r.current.scrollBy({ left: 200, behavior: "smooth" });
33
+ }, []), P = n(() => {
34
+ g(!0);
35
+ }, []), F = n(() => {
36
+ g(!1);
37
+ }, []), X = n(() => {
38
+ v(!0);
39
+ }, []), O = n(() => {
40
+ v(!1);
41
+ }, []), i = n(() => {
42
+ if (r.current) {
43
+ const { scrollLeft: o, scrollWidth: l, clientWidth: d } = r.current;
44
+ M(o > 10), j(o < l - d - 10);
45
+ }
46
+ }, []);
47
+ m(() => {
48
+ const o = r.current;
49
+ if (o)
50
+ return o.addEventListener("scroll", i), i(), () => {
51
+ o.removeEventListener("scroll", i);
52
+ };
53
+ }, [i]), m(() => {
54
+ i();
55
+ }, [e, i]);
56
+ const L = n(() => {
57
+ C(h, void 0, { stream: $ });
58
+ }, [C, $, h]);
59
+ return m(() => {
60
+ L();
61
+ }, [L]), e && e.length === 0 ? /* @__PURE__ */ s(u, { $flexRowGapX: 1, children: [
62
+ /* @__PURE__ */ s(p, { $renderAs: "ac4-black", $color: "BLACK_T_60", children: [
63
+ "Homework (",
64
+ e == null ? void 0 : e.length,
65
+ ")"
66
+ ] }),
67
+ /* @__PURE__ */ t(p, { $renderAs: "ab2", $color: "BLACK_T_60", children: "No Homework assigned yet" })
68
+ ] }) : K ? null : /* @__PURE__ */ s(le, { $flexRowGapX: 1, $disablePointerEvents: W, children: [
69
+ /* @__PURE__ */ s(p, { $renderAs: "ac4-black", $color: "BLACK_T_60", children: [
70
+ "Homework (",
71
+ e == null ? void 0 : e.length,
72
+ ")"
73
+ ] }),
74
+ /* @__PURE__ */ s(u, { $position: "relative", onMouseEnter: i, children: [
75
+ I && /* @__PURE__ */ t(
76
+ b,
77
+ {
78
+ $position: "absolute",
79
+ $width: "60px",
80
+ left: "0",
81
+ right: "auto",
82
+ onMouseEnter: P,
83
+ onMouseLeave: F,
84
+ children: /* @__PURE__ */ t(
85
+ _,
86
+ {
87
+ $position: "absolute",
88
+ $background: "BLACK_T_60",
89
+ $justifyContent: "center",
90
+ $alignItems: "center",
91
+ $height: "100%",
92
+ onClick: z,
93
+ $visible: y,
94
+ left: "0px",
95
+ right: "auto",
96
+ children: /* @__PURE__ */ t(oe, { width: 24, height: 24 })
97
+ }
98
+ )
99
+ },
100
+ "left-hover-zone"
101
+ ),
102
+ /* @__PURE__ */ t(ce, { ref: r, children: /* @__PURE__ */ t(u, { $flexDirection: "row", $flexGapX: 1, children: e == null ? void 0 : e.map((o, l) => {
103
+ const {
104
+ items: d,
105
+ node_id: Q,
106
+ sheet_time: H,
107
+ total_questions: f,
108
+ worksheet_id: V,
109
+ node_type: q,
110
+ title: D,
111
+ chapter_name: U
112
+ } = o, Y = H && Math.ceil(H / 60) || 0, Z = ne(d).join(", "), J = `${typeof f == "number" ? `${f} ${ee.pluralize(f, "Question")}, ` : ""}${Y} Mins`, c = q === "DYNAMIC";
113
+ return /* @__PURE__ */ t(
114
+ ie,
115
+ {
116
+ userType: k,
117
+ header: c ? Z : D,
118
+ subHeader: U ?? J,
119
+ nodeData: o,
120
+ renderAs: "homework",
121
+ onNodeAttempt: c ? w : x,
122
+ shouldOpenOnRight: e.length > 3 && l === e.length - 1,
123
+ onNodeView: c ? R : S,
124
+ onNodeReview: c ? E : T,
125
+ onNodeUnassign: A
126
+ },
127
+ `${V}_${Q}_${l}`
128
+ );
129
+ }) }) }),
130
+ N && /* @__PURE__ */ t(
131
+ b,
132
+ {
133
+ $position: "absolute",
134
+ $width: "60px",
135
+ right: "0",
136
+ left: "auto",
137
+ onMouseEnter: X,
138
+ onMouseLeave: O,
139
+ children: /* @__PURE__ */ t(
140
+ _,
141
+ {
142
+ $position: "absolute",
143
+ $width: "60px",
144
+ $height: "100%",
145
+ $background: "BLACK_T_60",
146
+ $justifyContent: "center",
147
+ $alignItems: "center",
148
+ onClick: G,
149
+ $visible: B,
150
+ left: "auto",
151
+ right: "0px",
152
+ children: /* @__PURE__ */ t(re, { width: 24, height: 24 })
153
+ }
154
+ )
155
+ },
156
+ "right-hover-zone"
157
+ )
158
+ ] })
159
+ ] });
160
+ }, be = ae;
161
+ export {
162
+ be as default
163
+ };
164
+ //# sourceMappingURL=hw-card-list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hw-card-list.js","sources":["../../../../src/features/homework/hw-card-list/hw-card-list.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 { pluralize } from 'humanize-plus';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\n\nimport ChevronLeftIcon from '../../../assets/line-icons/icons/chevron-left';\nimport ChevronRightIcon from '../../../assets/line-icons/icons/chevron-right';\nimport { getTopicsFromItems } from '../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils';\nimport FlexView from '../../ui/layout/flex-view';\nimport Text from '../../ui/text/text';\nimport HomeworkCard from '../homework-card';\nimport { useGetHomeworks } from './api/get-homeworks';\nimport * as Styled from './hw-card-list-styled';\n\ninterface HWCardListProps extends INodeCardCallbacks {\n userType: TUserTypes;\n studentId: string;\n stream: string;\n onTestPreview?: (sheetData: INodeDataProps, milestoneId?: string) => void;\n onTestStart?: (sheetData: INodeDataProps) => void;\n onTestReview?: (sheetData: INodeDataProps, milestoneId?: string) => void;\n}\n\nconst HWCardList: React.FC<HWCardListProps> = ({\n userType = 'STUDENT',\n studentId,\n stream,\n onTestStart,\n onNodeAttempt,\n onTestPreview,\n onNodeView,\n onTestReview,\n onNodeReview,\n onNodeUnassign,\n}) => {\n const scrollRef = useRef<HTMLDivElement>(null);\n const [isLeftHovered, setIsLeftHovered] = useState(false);\n const [isRightHovered, setIsRightHovered] = useState(false);\n const [canScrollLeft, setCanScrollLeft] = useState(false);\n const [canScrollRight, setCanScrollRight] = useState(true);\n const {\n get: getHomeworks,\n data: hwDetails,\n isProcessingFailed,\n isProcessing,\n } = useGetHomeworks(studentId);\n\n const handleScrollLeft = useCallback(() => {\n if (scrollRef.current) {\n scrollRef.current.scrollBy({ left: -200, behavior: 'smooth' });\n }\n }, []);\n\n const handleScrollRight = useCallback(() => {\n if (scrollRef.current) {\n scrollRef.current.scrollBy({ left: 200, behavior: 'smooth' });\n }\n }, []);\n\n const handleLeftHoverEnter = useCallback(() => {\n setIsLeftHovered(true);\n }, []);\n\n const handleLeftHoverLeave = useCallback(() => {\n setIsLeftHovered(false);\n }, []);\n\n const handleRightHoverEnter = useCallback(() => {\n setIsRightHovered(true);\n }, []);\n\n const handleRightHoverLeave = useCallback(() => {\n setIsRightHovered(false);\n }, []);\n\n // Function to check scroll position and update button availability\n const checkScrollPosition = useCallback(() => {\n if (scrollRef.current) {\n const { scrollLeft, scrollWidth, clientWidth } = scrollRef.current;\n\n // Can scroll left if scrolled to the right\n setCanScrollLeft(scrollLeft > 10);\n\n // Can scroll right if not at the end\n setCanScrollRight(scrollLeft < scrollWidth - clientWidth - 10);\n }\n }, []);\n\n // Add scroll event listener to check scroll position\n useEffect(() => {\n const scrollElement = scrollRef.current;\n\n if (scrollElement) {\n scrollElement.addEventListener('scroll', checkScrollPosition);\n // Run once on mount to set initial button states\n checkScrollPosition();\n\n return () => {\n scrollElement.removeEventListener('scroll', checkScrollPosition);\n };\n }\n }, [checkScrollPosition]);\n\n // Also check when content changes\n useEffect(() => {\n checkScrollPosition();\n }, [hwDetails, checkScrollPosition]);\n\n const fetchChapterDetails = useCallback(() => {\n getHomeworks(studentId, undefined, { stream });\n }, [getHomeworks, stream, studentId]);\n\n useEffect(() => {\n fetchChapterDetails();\n }, [fetchChapterDetails]);\n\n if (hwDetails && hwDetails.length === 0) {\n return (\n <FlexView $flexRowGapX={1}>\n <Text $renderAs=\"ac4-black\" $color=\"BLACK_T_60\">\n Homework ({hwDetails?.length})\n </Text>\n <Text $renderAs=\"ab2\" $color=\"BLACK_T_60\">\n No Homework assigned yet\n </Text>\n </FlexView>\n );\n }\n\n if (isProcessingFailed) {\n return null;\n }\n\n return (\n <Styled.ContentWrapper $flexRowGapX={1} $disablePointerEvents={isProcessing}>\n <Text $renderAs=\"ac4-black\" $color=\"BLACK_T_60\">\n Homework ({hwDetails?.length})\n </Text>\n <FlexView $position=\"relative\" onMouseEnter={checkScrollPosition}>\n {/* Left hover zone */}\n {canScrollLeft && (\n <Styled.HoverZone\n key=\"left-hover-zone\"\n $position=\"absolute\"\n $width=\"60px\"\n left=\"0\"\n right=\"auto\"\n onMouseEnter={handleLeftHoverEnter}\n onMouseLeave={handleLeftHoverLeave}\n >\n {/* Left scroll button - only visible when hovered */}\n <Styled.ScrollButton\n $position=\"absolute\"\n $background=\"BLACK_T_60\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $height=\"100%\"\n onClick={handleScrollLeft}\n $visible={isLeftHovered}\n left=\"0px\"\n right=\"auto\"\n >\n <ChevronLeftIcon width={24} height={24} />\n </Styled.ScrollButton>\n </Styled.HoverZone>\n )}\n\n <Styled.ScrollContainer ref={scrollRef}>\n <FlexView $flexDirection=\"row\" $flexGapX={1}>\n {hwDetails?.map((sheet, idx) => {\n const {\n items,\n node_id: nodeId,\n sheet_time: sheetTime,\n total_questions: totalQuestions,\n worksheet_id: worksheetId,\n node_type: nodeType,\n title,\n chapter_name: chapterName,\n } = sheet;\n const totalSheetTime = (sheetTime && Math.ceil(sheetTime / 60)) || 0;\n const topics = getTopicsFromItems(items);\n const testChapterName = topics.join(', ');\n const subHeader = `${\n typeof totalQuestions === 'number'\n ? `${totalQuestions} ${pluralize(totalQuestions, 'Question')}, `\n : ''\n }${totalSheetTime} Mins`;\n const isDynamicSheet = nodeType === 'DYNAMIC';\n\n return (\n <HomeworkCard\n key={`${worksheetId}_${nodeId}_${idx}`}\n userType={userType}\n header={isDynamicSheet ? testChapterName : title}\n subHeader={chapterName ?? subHeader}\n nodeData={sheet}\n renderAs=\"homework\"\n onNodeAttempt={isDynamicSheet ? onTestStart : onNodeAttempt}\n shouldOpenOnRight={hwDetails.length > 3 && idx === hwDetails.length - 1}\n onNodeView={isDynamicSheet ? onTestPreview : onNodeView}\n onNodeReview={isDynamicSheet ? onTestReview : onNodeReview}\n onNodeUnassign={onNodeUnassign}\n />\n );\n })}\n </FlexView>\n </Styled.ScrollContainer>\n\n {/* Right hover zone */}\n {canScrollRight && (\n <Styled.HoverZone\n key=\"right-hover-zone\"\n $position=\"absolute\"\n $width=\"60px\"\n right=\"0\"\n left=\"auto\"\n onMouseEnter={handleRightHoverEnter}\n onMouseLeave={handleRightHoverLeave}\n >\n {/* Right scroll button - only visible when hovered */}\n <Styled.ScrollButton\n $position=\"absolute\"\n $width=\"60px\"\n $height=\"100%\"\n $background=\"BLACK_T_60\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n onClick={handleScrollRight}\n $visible={isRightHovered}\n left=\"auto\"\n right=\"0px\"\n >\n <ChevronRightIcon width={24} height={24} />\n </Styled.ScrollButton>\n </Styled.HoverZone>\n )}\n </FlexView>\n </Styled.ContentWrapper>\n );\n};\n\nexport default HWCardList;\n"],"names":["HWCardList","userType","studentId","stream","onTestStart","onNodeAttempt","onTestPreview","onNodeView","onTestReview","onNodeReview","onNodeUnassign","scrollRef","useRef","isLeftHovered","setIsLeftHovered","useState","isRightHovered","setIsRightHovered","canScrollLeft","setCanScrollLeft","canScrollRight","setCanScrollRight","getHomeworks","hwDetails","isProcessingFailed","isProcessing","useGetHomeworks","handleScrollLeft","useCallback","handleScrollRight","handleLeftHoverEnter","handleLeftHoverLeave","handleRightHoverEnter","handleRightHoverLeave","checkScrollPosition","scrollLeft","scrollWidth","clientWidth","useEffect","scrollElement","fetchChapterDetails","jsxs","FlexView","Text","Styled.ContentWrapper","jsx","Styled.HoverZone","Styled.ScrollButton","ChevronLeftIcon","Styled.ScrollContainer","sheet","idx","items","nodeId","sheetTime","totalQuestions","worksheetId","nodeType","title","chapterName","totalSheetTime","testChapterName","getTopicsFromItems","subHeader","pluralize","isDynamicSheet","HomeworkCard","ChevronRightIcon","HWCardList$1"],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ import { jsx as t } from "react/jsx-runtime";
2
+ import { memo as m } from "react";
3
+ import a from "styled-components";
4
+ import n from "../ui/layout/flex-view.js";
5
+ import { differenceInDays as e } from "../../node_modules/date-fns/differenceInDays.js";
6
+ const g = a(n)`
7
+ height: 100%;
8
+ border-radius: 4px;
9
+ transition: all 300ms;
10
+ width: ${(r) => r.progress}%;
11
+ `, d = a(n)`
12
+ position: absolute;
13
+ top: -1px;
14
+ right: 0px;
15
+ width: 100%;
16
+ height: 2px;
17
+ background-color: ${(r) => r.theme.colors.BLACK};
18
+ z-index: 2;
19
+ `, l = ({ unlockedOn: r, dueDate: i, progressBg: c }) => {
20
+ const p = (() => {
21
+ const o = e(i, r), s = e(/* @__PURE__ */ new Date(), r);
22
+ return s > o ? 100 : Math.min(Math.max(s / o * 100, 0), 100);
23
+ })();
24
+ return /* @__PURE__ */ t(d, { children: /* @__PURE__ */ t(g, { progress: p, $background: c }) });
25
+ }, y = m(l);
26
+ export {
27
+ y as default
28
+ };
29
+ //# sourceMappingURL=node-progress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-progress.js","sources":["../../../src/features/homework/node-progress.tsx"],"sourcesContent":["import type { TColorNames } from '../ui/types';\n\nimport { differenceInDays } from 'date-fns';\nimport React, { memo } from 'react';\nimport styled from 'styled-components';\n\nimport FlexView from '../ui/layout/flex-view';\n\ninterface NodeProgressProps {\n unlockedOn: number | string | Date;\n dueDate: number | string | Date;\n progressBg: TColorNames;\n}\n\nconst ProgressBar = styled(FlexView)<{ progress: number }>`\n height: 100%;\n border-radius: 4px;\n transition: all 300ms;\n width: ${props => props.progress}%;\n`;\n\nconst ProgressContainer = styled(FlexView)`\n position: absolute;\n top: -1px;\n right: 0px;\n width: 100%;\n height: 2px;\n background-color: ${props => props.theme.colors.BLACK};\n z-index: 2;\n`;\n\nconst NodeProgress: React.FC<NodeProgressProps> = ({ unlockedOn, dueDate, progressBg }) => {\n const calculateProgress = () => {\n const totalDays = differenceInDays(dueDate, unlockedOn);\n const daysElapsed = differenceInDays(new Date(), unlockedOn);\n\n if (daysElapsed > totalDays) return 100;\n\n const progress = Math.min(Math.max((daysElapsed / totalDays) * 100, 0), 100);\n\n return progress;\n };\n\n const progress = calculateProgress();\n\n return (\n <ProgressContainer>\n <ProgressBar progress={progress} $background={progressBg} />\n </ProgressContainer>\n );\n};\n\nexport default memo(NodeProgress);\n"],"names":["ProgressBar","styled","FlexView","props","ProgressContainer","NodeProgress","unlockedOn","dueDate","progressBg","progress","totalDays","differenceInDays","daysElapsed","jsx","NodeProgress$1","memo"],"mappings":";;;;;AAcA,MAAMA,IAAcC,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,WAIxB,CAAAC,MAASA,EAAM,QAAQ;AAAA,GAG5BC,IAAoBH,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAMnB,CAASC,MAAAA,EAAM,MAAM,OAAO,KAAK;AAAA;AAAA,GAIjDE,IAA4C,CAAC,EAAE,YAAAC,GAAY,SAAAC,GAAS,YAAAC,QAAiB;AAYzF,QAAMC,KAXoB,MAAM;AACxB,UAAAC,IAAYC,EAAiBJ,GAASD,CAAU,GAChDM,IAAcD,EAAqB,oBAAA,QAAQL,CAAU;AAEvD,WAAAM,IAAcF,IAAkB,MAEnB,KAAK,IAAI,KAAK,IAAKE,IAAcF,IAAa,KAAK,CAAC,GAAG,GAAG;AAAA,EAEpE;AAKT,2BACGN,GACC,EAAA,UAAA,gBAAAS,EAACb,KAAY,UAAAS,GAAoB,aAAaD,EAAY,CAAA,EAC5D,CAAA;AAEJ,GAEeM,IAAAC,EAAKV,CAAY;"}
@@ -1,10 +1,12 @@
1
1
  import r from "styled-components";
2
2
  import i from "../../assets/line-icons/icons/minus2.js";
3
- import t from "../ui/layout/flex-view.js";
3
+ import e from "../ui/layout/flex-view.js";
4
4
  import n from "../ui/text/text.js";
5
- const l = r(t)(({ theme: o }) => `
5
+ const l = r(e)(({ theme: o }) => `
6
6
  cursor: pointer;
7
- width: fit-content;
7
+ width: 24px;
8
+ height: 24px;
9
+
8
10
 
9
11
  &:hover {
10
12
  border-radius: 50%;
@@ -16,50 +18,47 @@ const l = r(t)(({ theme: o }) => `
16
18
  -webkit-box-orient: vertical;
17
19
  overflow: hidden;
18
20
  text-overflow: ellipsis;
19
- `, u = r(t)(({
20
- theme: o,
21
- $visible: e
21
+ `, x = r(e)(({
22
+ $shouldopenonright: o,
23
+ $visible: t
22
24
  }) => `
23
25
  cursor: pointer;
24
26
  position: absolute;
25
27
  z-index: 6;
26
28
  top: calc(100% + 4px);
27
- left: 0;
29
+ right: ${o ? 0 : "auto"};
28
30
  transform-origin: top;
29
- transform: scaleY(${e ? 1 : 0});
30
- opacity: ${e ? 1 : 0};
31
+ transform: scaleY(${t ? 1 : 0});
32
+ opacity: ${t ? 1 : 0};
31
33
  transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
32
-
33
- &:hover {
34
- border-radius: 50%;
35
- background: ${o.colors.WHITE_5};
36
- }
37
- `), x = r(t)`
34
+ box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);
35
+ z-index: 10;
36
+ `), u = r(e)`
38
37
  border: 1px solid ${({ theme: o }) => o.colors.BLACK_T_15};
39
38
 
40
39
  &:hover {
41
40
  border: 1px solid ${({ theme: o }) => o.colors.BLACK};
42
41
  }
43
- `, b = r(t)(({ $bgImage: o }) => o ? `
42
+ `, b = r(e)(({ $bgImage: o }) => o ? `
44
43
  background-image: url(${o});
45
44
  background-repeat: no-repeat;
46
45
  background-size: cover;
47
46
  background-position: center;
48
47
  overflow: hidden;
49
- ` : "overflow: hidden;"), f = r(t)`
48
+ ` : "overflow: hidden;"), w = r(e)`
50
49
  display: flex;
51
50
  align-items: center;
52
51
  justify-content: center;
53
- `, w = r(t)`
52
+ `, f = r(e)`
54
53
  position: absolute;
55
54
  right: -18px;
56
55
  top: -4px;
57
56
  `, h = r.img(({ theme: o }) => {
58
- const { gutter: e } = o.layout;
57
+ const { gutter: t } = o.layout;
59
58
  return `
60
59
  border: 1px solid ${o.colors.BLACK_T_15};
61
- width: ${e * 4}px;
62
- height: ${e * 4}px;
60
+ width: ${t * 4}px;
61
+ height: ${t * 4}px;
63
62
  border-radius: 50%;
64
63
  `;
65
64
  }), g = r(i)`
@@ -72,42 +71,46 @@ const l = r(t)(({ theme: o }) => `
72
71
  -webkit-box-orient: vertical;
73
72
  overflow: hidden;
74
73
  text-overflow: ellipsis;
75
- `, v = r(t)`
76
- box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);
77
- width: 180px;
78
- position: relative;
79
- left: 0;
80
- top: 0;
81
- `, k = r(t)(({
74
+ white-space: break-spaces;
75
+ `;
76
+ r(e)``;
77
+ const k = r(e)(({
82
78
  theme: o,
83
- $disabled: e
79
+ $disabled: t
84
80
  }) => `
85
- cursor: ${e ? "not-allowed" : "pointer"};
81
+ cursor: ${t ? "not-allowed" : "pointer"};
86
82
 
87
83
  &:hover {
88
- background: ${e ? "transparent" : o.colors.BLACK};
84
+ background: ${t ? "transparent" : o.colors.BLACK};
89
85
  };
90
86
 
91
87
  path {
92
88
  fill: ${o.colors.WHITE_1};
93
89
  }
94
- `), C = r(n)`
90
+ `), v = r(n)`
95
91
  white-space: nowrap;
96
92
  overflow: hidden;
97
93
  text-overflow: ellipsis;
94
+ `, $ = r(e)`
95
+ position: absolute;
96
+ z-index: 6;
97
+ top: calc(100% - 36px);
98
+ right: 12px;
99
+ transform-origin: top;
100
+ transform: scaleY(1);
98
101
  `;
99
102
  export {
100
103
  h as BannerImage,
101
- w as BannerImageWrapper,
102
- x as CardContainer,
104
+ f as BannerImageWrapper,
105
+ u as CardContainer,
103
106
  l as CardKebabMenuWrapper,
104
- u as CardMenuOptionsWrapper,
107
+ x as CardMenuOptionsWrapper,
105
108
  k as CardOptionWrapper,
106
- v as CardOptions,
107
109
  b as CardWrapper,
108
110
  m as HeaderText,
109
- f as IconWrapper,
110
- C as OptionText,
111
+ w as IconWrapper,
112
+ $ as MenuWrapper,
113
+ v as OptionText,
111
114
  g as StyledMinus2Icon,
112
115
  d as SubHeaderText
113
116
  };
@@ -1 +1 @@
1
- {"version":3,"file":"styles.js","sources":["../../../src/features/homework/styles.ts"],"sourcesContent":["import styled from 'styled-components';\n\nimport Minus2Icon from '../../assets/line-icons/icons/minus2';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\n\ninterface ICardWrapperProps {\n $bgImage: string;\n}\ninterface ICardOptionsMenuWrapperProps {\n $visible: boolean;\n}\n\nexport const CardKebabMenuWrapper = styled(FlexView)(({ theme }) => {\n return `\n cursor: pointer;\n width: fit-content;\n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const SubHeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const CardMenuOptionsWrapper = styled(FlexView)<ICardOptionsMenuWrapperProps>(({\n theme,\n $visible,\n}) => {\n return `\n cursor: pointer;\n position: absolute;\n z-index: 6;\n top: calc(100% + 4px);\n left: 0;\n transform-origin: top;\n transform: scaleY(${$visible ? 1 : 0});\n opacity: ${$visible ? 1 : 0};\n transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;\n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const CardContainer = styled(FlexView)`\n border: 1px solid ${({ theme }) => theme.colors.BLACK_T_15};\n\n &:hover {\n border: 1px solid ${({ theme }) => theme.colors.BLACK};\n }\n`;\n\nexport const CardWrapper = styled(FlexView)<ICardWrapperProps>(({ $bgImage }) => {\n if ($bgImage) {\n return `\n background-image: url(${$bgImage});\n background-repeat: no-repeat;\n background-size: cover;\n background-position: center;\n overflow: hidden;\n `;\n }\n\n return 'overflow: hidden;';\n});\n\nexport const IconWrapper = styled(FlexView)`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const BannerImageWrapper = styled(FlexView)`\n position: absolute;\n right: -18px;\n top: -4px;\n`;\n\nexport const BannerImage = styled.img(({ theme }) => {\n const { gutter } = theme.layout;\n\n return `\n border: 1px solid ${theme.colors.BLACK_T_15};\n width: ${gutter * 4}px;\n height: ${gutter * 4}px;\n border-radius: 50%;\n `;\n});\n\nexport const StyledMinus2Icon = styled(Minus2Icon)`\n path {\n stroke: ${({ theme }) => theme.colors.WHITE};\n }\n`;\n\nexport const HeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport interface ICardOptionWrapperProps {\n $disabled?: boolean;\n}\n\nexport const CardOptions = styled(FlexView)`\n box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);\n width: 180px;\n position: relative;\n left: 0;\n top: 0;\n`;\n\nexport const CardOptionWrapper = styled(FlexView)<ICardOptionWrapperProps>(({\n theme,\n $disabled,\n}) => {\n return `\n cursor: ${$disabled ? 'not-allowed' : 'pointer'};\n \n &:hover {\n background: ${$disabled ? 'transparent' : theme.colors.BLACK};\n };\n \n path {\n fill: ${theme.colors.WHITE_1};\n }\n `;\n});\n\nexport const OptionText = styled(Text)`\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n"],"names":["CardKebabMenuWrapper","styled","FlexView","theme","SubHeaderText","Text","CardMenuOptionsWrapper","$visible","CardContainer","CardWrapper","$bgImage","IconWrapper","BannerImageWrapper","BannerImage","gutter","StyledMinus2Icon","Minus2Icon","HeaderText","CardOptions","CardOptionWrapper","$disabled","OptionText"],"mappings":";;;;AAaO,MAAMA,IAAuBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAMWA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYC,IAAgBH,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ3BC,IAAyBL,EAAOC,CAAQ,EAAgC,CAAC;AAAA,EACpF,OAAAC;AAAA,EACA,UAAAI;AACF,MACS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAOeA,IAAW,IAAI,CAAC;AAAA,eACzBA,IAAW,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,oBAKXJ,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYK,IAAgBP,EAAOC,CAAQ;AAAA,sBACtB,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,UAAU;AAAA;AAAA;AAAA,wBAGpC,CAAC,EAAE,OAAAA,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAI5CM,IAAcR,EAAOC,CAAQ,EAAqB,CAAC,EAAE,UAAAQ,QAC5DA,IACK;AAAA,8BACmBA,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,QAQ7B,mBACR,GAEYC,IAAcV,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAM7BU,IAAqBX,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAMpCW,IAAcZ,EAAO,IAAI,CAAC,EAAE,OAAAE,QAAY;AAC7C,QAAA,EAAE,QAAAW,EAAO,IAAIX,EAAM;AAElB,SAAA;AAAA,wBACeA,EAAM,OAAO,UAAU;AAAA,aAClCW,IAAS,CAAC;AAAA,cACTA,IAAS,CAAC;AAAA;AAAA;AAGxB,CAAC,GAEYC,IAAmBd,EAAOe,CAAU;AAAA;AAAA,cAEnC,CAAC,EAAE,OAAAb,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAIlCc,IAAahB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAYxBa,IAAcjB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ7BiB,IAAoBlB,EAAOC,CAAQ,EAA2B,CAAC;AAAA,EAC1E,OAAAC;AAAA,EACA,WAAAiB;AACF,MACS;AAAA,cACKA,IAAY,gBAAgB,SAAS;AAAA;AAAA;AAAA,oBAG/BA,IAAY,gBAAgBjB,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,cAIpDA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGjC,GAEYkB,IAAapB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;"}
1
+ {"version":3,"file":"styles.js","sources":["../../../src/features/homework/styles.ts"],"sourcesContent":["import styled from 'styled-components';\n\nimport Minus2Icon from '../../assets/line-icons/icons/minus2';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\n\ninterface ICardWrapperProps {\n $bgImage: string;\n}\ninterface ICardOptionsMenuWrapperProps {\n $visible: boolean;\n $shouldopenonright: boolean;\n}\n\nexport const CardKebabMenuWrapper = styled(FlexView)(({ theme }) => {\n return `\n cursor: pointer;\n width: 24px;\n height: 24px;\n \n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const SubHeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const CardMenuOptionsWrapper = styled(FlexView)<ICardOptionsMenuWrapperProps>(({\n $shouldopenonright,\n $visible,\n}) => {\n return `\n cursor: pointer;\n position: absolute;\n z-index: 6;\n top: calc(100% + 4px);\n right: ${$shouldopenonright ? 0 : 'auto'};\n transform-origin: top;\n transform: scaleY(${$visible ? 1 : 0});\n opacity: ${$visible ? 1 : 0};\n transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;\n box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);\n z-index: 10;\n `;\n});\n\nexport const CardContainer = styled(FlexView)`\n border: 1px solid ${({ theme }) => theme.colors.BLACK_T_15};\n\n &:hover {\n border: 1px solid ${({ theme }) => theme.colors.BLACK};\n }\n`;\n\nexport const CardWrapper = styled(FlexView)<ICardWrapperProps>(({ $bgImage }) => {\n if ($bgImage) {\n return `\n background-image: url(${$bgImage});\n background-repeat: no-repeat;\n background-size: cover;\n background-position: center;\n overflow: hidden;\n `;\n }\n\n return 'overflow: hidden;';\n});\n\nexport const IconWrapper = styled(FlexView)`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const BannerImageWrapper = styled(FlexView)`\n position: absolute;\n right: -18px;\n top: -4px;\n`;\n\nexport const BannerImage = styled.img(({ theme }) => {\n const { gutter } = theme.layout;\n\n return `\n border: 1px solid ${theme.colors.BLACK_T_15};\n width: ${gutter * 4}px;\n height: ${gutter * 4}px;\n border-radius: 50%;\n `;\n});\n\nexport const StyledMinus2Icon = styled(Minus2Icon)`\n path {\n stroke: ${({ theme }) => theme.colors.WHITE};\n }\n`;\n\nexport const HeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: break-spaces;\n`;\n\ninterface ICardOptionWrapperProps {\n $disabled?: boolean;\n}\ninterface ICardOptionsProps {\n $top: number;\n $left: number;\n}\n\nexport const CardOptions = styled(FlexView)<ICardOptionsProps>``;\n\nexport const CardOptionWrapper = styled(FlexView)<ICardOptionWrapperProps>(({\n theme,\n $disabled,\n}) => {\n return `\n cursor: ${$disabled ? 'not-allowed' : 'pointer'};\n \n &:hover {\n background: ${$disabled ? 'transparent' : theme.colors.BLACK};\n };\n \n path {\n fill: ${theme.colors.WHITE_1};\n }\n `;\n});\n\nexport const OptionText = styled(Text)`\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const MenuWrapper = styled(FlexView)`\n position: absolute;\n z-index: 6;\n top: calc(100% - 36px);\n right: 12px;\n transform-origin: top;\n transform: scaleY(1);\n`;\n"],"names":["CardKebabMenuWrapper","styled","FlexView","theme","SubHeaderText","Text","CardMenuOptionsWrapper","$shouldopenonright","$visible","CardContainer","CardWrapper","$bgImage","IconWrapper","BannerImageWrapper","BannerImage","gutter","StyledMinus2Icon","Minus2Icon","HeaderText","CardOptionWrapper","$disabled","OptionText","MenuWrapper"],"mappings":";;;;AAcO,MAAMA,IAAuBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAQWA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYC,IAAgBH,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ3BC,IAAyBL,EAAOC,CAAQ,EAAgC,CAAC;AAAA,EACpF,oBAAAK;AAAA,EACA,UAAAC;AACF,MACS;AAAA;AAAA;AAAA;AAAA;AAAA,aAKID,IAAqB,IAAI,MAAM;AAAA;AAAA,wBAEpBC,IAAW,IAAI,CAAC;AAAA,eACzBA,IAAW,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA,GAK9B,GAEYC,IAAgBR,EAAOC,CAAQ;AAAA,sBACtB,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,UAAU;AAAA;AAAA;AAAA,wBAGpC,CAAC,EAAE,OAAAA,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAI5CO,IAAcT,EAAOC,CAAQ,EAAqB,CAAC,EAAE,UAAAS,QAC5DA,IACK;AAAA,8BACmBA,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,QAQ7B,mBACR,GAEYC,IAAcX,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAM7BW,IAAqBZ,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAMpCY,IAAcb,EAAO,IAAI,CAAC,EAAE,OAAAE,QAAY;AAC7C,QAAA,EAAE,QAAAY,EAAO,IAAIZ,EAAM;AAElB,SAAA;AAAA,wBACeA,EAAM,OAAO,UAAU;AAAA,aAClCY,IAAS,CAAC;AAAA,cACTA,IAAS,CAAC;AAAA;AAAA;AAGxB,CAAC,GAEYC,IAAmBf,EAAOgB,CAAU;AAAA;AAAA,cAEnC,CAAC,EAAE,OAAAd,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAIlCe,IAAajB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBVJ,EAAOC,CAAQ;AAEnC,MAAMiB,IAAoBlB,EAAOC,CAAQ,EAA2B,CAAC;AAAA,EAC1E,OAAAC;AAAA,EACA,WAAAiB;AACF,MACS;AAAA,cACKA,IAAY,gBAAgB,SAAS;AAAA;AAAA;AAAA,oBAG/BA,IAAY,gBAAgBjB,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,cAIpDA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGjC,GAEYkB,IAAapB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA,GAMxBiB,IAAcrB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
@@ -1,75 +1,68 @@
1
1
  import { jsxs as n, jsx as t } from "react/jsx-runtime";
2
- import { memo as G, useState as L, useRef as N, useCallback as p } from "react";
3
- import { SHEET_STATE as c } from "../../../../sheets/constants/sheet.js";
4
- import O from "../../../../ui/arrow-tooltip/arrow-tooltip.js";
5
- import X from "../../../../ui/hooks/use-context-menu-click-handler.js";
6
- import j from "../../../../ui/image/image.js";
2
+ import { memo as B, useState as G, useRef as L, useCallback as s } from "react";
3
+ import { SHEET_STATE as p } from "../../../../sheets/constants/sheet.js";
4
+ import N from "../../../../ui/arrow-tooltip/arrow-tooltip.js";
5
+ import O from "../../../../ui/hooks/use-context-menu-click-handler.js";
6
+ import X from "../../../../ui/image/image.js";
7
7
  import w from "../../../../ui/layout/flex-view.js";
8
- import F from "../sheets-list/sheets-list.js";
9
- import { ChapterInfoWrapper as K, ChapterInfoIcon as P, SheetsListWrapper as U, ChapterListWrapper as q, ChapterProgressSVG as z, ChapterProgressSVGCircle as _, StyledText as A } from "./chapter-item-styled.js";
10
- const J = [
8
+ import j from "../sheets-list/sheets-list.js";
9
+ import { ChapterInfoWrapper as F, ChapterInfoIcon as K, SheetsListWrapper as P, ChapterListWrapper as U, ChapterProgressSVG as q, ChapterProgressSVGCircle as A, StyledText as E } from "./chapter-item-styled.js";
10
+ const z = [
11
11
  "STARTED",
12
- c.FAMILIAR,
13
- c.PROFICIENT,
14
- c.MASTERED
15
- ], le = G((E) => {
16
- const { chapterData: x, onChapterItemClick: h, isThisPrimaryChapter: R, showChapterTags: k, canAddChapter: l } = E, {
12
+ p.FAMILIAR,
13
+ p.PROFICIENT,
14
+ p.MASTERED
15
+ ], ie = B((_) => {
16
+ const { chapterData: x, onChapterItemClick: h, isThisPrimaryChapter: R, showChapterTags: k, canAddChapter: l } = _, {
17
17
  name: d,
18
- image_url: y,
18
+ image_url: W,
19
19
  added: m,
20
20
  learning_sheet_data: g,
21
- total_supplementary_sheets: W,
22
21
  id: f,
23
22
  chapter_tags: H,
24
23
  state: a
25
- } = x, M = a && J.includes(a) && g.length > 0, u = a === "MASTERED", [e, C] = L(null), i = N(null), V = p(() => {
26
- var I;
27
- const { current: T } = i;
28
- if (T) {
29
- const r = (I = T.children[0]) == null ? void 0 : I.getBoundingClientRect();
24
+ } = x, M = a && z.includes(a) && g.length > 0, u = a === "MASTERED", [e, C] = G(null), i = L(null), V = s(() => {
25
+ var b;
26
+ const { current: I } = i;
27
+ if (I) {
28
+ const r = (b = I.children[0]) == null ? void 0 : b.getBoundingClientRect();
30
29
  if (r) {
31
- const B = window.innerWidth, b = window.innerHeight, o = {};
32
- r.left + 296 < B ? o.left = r.left : o.left = r.left + 20 - 296, r.top + 252 < b ? o.top = r.top + 20 : o.bottom = b - r.top + 8, Object.keys(o).length && C({ ...o });
30
+ const v = window.innerWidth, S = window.innerHeight, o = {};
31
+ r.left + 296 < v ? o.left = r.left : o.left = r.left + 20 - 296, r.top + 252 < S ? o.top = r.top + 20 : o.bottom = S - r.top + 8, Object.keys(o).length && C({ ...o });
33
32
  }
34
33
  }
35
34
  }, [C, i]), {
36
- menuVisible: s,
35
+ menuVisible: c,
37
36
  onMenuClick: $,
38
- hideMenu: S
39
- } = X(i, V), D = p(() => {
40
- s ? S() : $();
41
- }, [$, S, s]), v = p(() => {
37
+ hideMenu: T
38
+ } = O(i, V), y = s(() => {
39
+ c ? T() : $();
40
+ }, [$, T, c]), D = s(() => {
42
41
  if (!l) return null;
43
42
  h(f);
44
43
  }, [l, f, h]);
45
44
  return /* @__PURE__ */ n(w, { $flexGap: 4, $position: "relative", children: [
46
- /* @__PURE__ */ n(K, { ref: i, onClick: D, children: [
47
- /* @__PURE__ */ t(P, { className: "goal-chapter-info-icon" }),
48
- s && /* @__PURE__ */ t(
49
- U,
45
+ /* @__PURE__ */ n(F, { ref: i, onClick: y, children: [
46
+ /* @__PURE__ */ t(K, { className: "goal-chapter-info-icon" }),
47
+ c && /* @__PURE__ */ t(
48
+ P,
50
49
  {
51
50
  $top: e == null ? void 0 : e.top,
52
51
  $left: e == null ? void 0 : e.left,
53
52
  $bottom: e == null ? void 0 : e.bottom,
54
- children: /* @__PURE__ */ t(
55
- F,
56
- {
57
- learningSheetData: g,
58
- supplementarySheetsCount: W
59
- }
60
- )
53
+ children: /* @__PURE__ */ t(j, { learningSheetData: g })
61
54
  }
62
55
  )
63
56
  ] }),
64
57
  /* @__PURE__ */ t(
65
- O,
58
+ N,
66
59
  {
67
60
  position: "bottom",
68
61
  renderAs: "primary",
69
62
  tooltipItem: "Duplicates can’t be added",
70
63
  hidden: !R,
71
64
  children: /* @__PURE__ */ n(
72
- q,
65
+ U,
73
66
  {
74
67
  $widthX: 9.5,
75
68
  $heightX: 8.875,
@@ -81,13 +74,13 @@ const J = [
81
74
  $selectable: l,
82
75
  $borderColor: m ? "BLACK_T_87" : "WHITE_5",
83
76
  $background: m ? "WHITE_3" : "WHITE_1",
84
- onClick: v,
77
+ onClick: D,
85
78
  children: [
86
79
  /* @__PURE__ */ n(w, { $position: "relative", children: [
87
- M && /* @__PURE__ */ n(z, { width: "62px", height: "62px", children: [
88
- /* @__PURE__ */ t(_, { $progress: 0, r: "30", cx: "31", cy: "31" }),
80
+ M && /* @__PURE__ */ n(q, { width: "62px", height: "62px", children: [
81
+ /* @__PURE__ */ t(A, { $progress: 0, r: "30", cx: "31", cy: "31" }),
89
82
  /* @__PURE__ */ t(
90
- _,
83
+ A,
91
84
  {
92
85
  $progressCircle: !0,
93
86
  $progressBackground: u ? "GREEN_5" : "BLACK",
@@ -99,9 +92,9 @@ const J = [
99
92
  )
100
93
  ] }),
101
94
  /* @__PURE__ */ t(
102
- j,
95
+ X,
103
96
  {
104
- src: y || "",
97
+ src: W || "",
105
98
  alt: d,
106
99
  withLoader: !0,
107
100
  width: 56,
@@ -110,16 +103,16 @@ const J = [
110
103
  }
111
104
  )
112
105
  ] }),
113
- /* @__PURE__ */ t(A, { $renderAs: "ab3", $align: "center", children: d })
106
+ /* @__PURE__ */ t(E, { $renderAs: "ab3", $align: "center", children: d })
114
107
  ]
115
108
  }
116
109
  )
117
110
  }
118
111
  ),
119
- k && /* @__PURE__ */ t(A, { $renderAs: "ab3", $lineClampNo: 1, $color: "BLACK_T_60", children: H })
112
+ k && /* @__PURE__ */ t(E, { $renderAs: "ab3", $lineClampNo: 1, $color: "BLACK_T_60", children: H })
120
113
  ] });
121
114
  });
122
115
  export {
123
- le as default
116
+ ie as default
124
117
  };
125
118
  //# sourceMappingURL=chapter-item.js.map