@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.
Files changed (64) hide show
  1. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +1 -1
  2. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  3. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +16 -15
  4. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +1 -1
  5. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +8 -12
  6. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
  7. package/dist/features/chapters-v2/utils/index.js +4 -5
  8. package/dist/features/chapters-v2/utils/index.js.map +1 -1
  9. package/dist/features/chapters-v2/utils/node-card-utils.js +34 -62
  10. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
  11. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
  12. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
  13. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +81 -79
  14. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  15. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +61 -59
  16. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  17. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +85 -83
  18. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  19. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +90 -88
  20. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  21. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +98 -82
  22. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  23. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +71 -0
  24. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +1 -0
  25. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +31 -0
  26. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +1 -0
  27. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +38 -0
  28. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -0
  29. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +79 -0
  30. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -0
  31. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +18 -0
  32. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -0
  33. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +51 -0
  34. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +1 -0
  35. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +11 -0
  36. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +1 -0
  37. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +144 -0
  38. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -0
  39. package/dist/features/sheets/resources-list/resource-item/styled.js +1 -1
  40. package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
  41. package/dist/index.d.ts +11 -33
  42. package/dist/index.js +29 -31
  43. package/dist/index.js.map +1 -1
  44. package/package.json +1 -1
  45. package/dist/features/homework/card-menu-options.js +0 -25
  46. package/dist/features/homework/card-menu-options.js.map +0 -1
  47. package/dist/features/homework/homework-card.js +0 -210
  48. package/dist/features/homework/homework-card.js.map +0 -1
  49. package/dist/features/homework/styles.js +0 -114
  50. package/dist/features/homework/styles.js.map +0 -1
  51. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +0 -165
  52. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +0 -1
  53. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +0 -25
  54. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +0 -1
  55. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +0 -82
  56. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +0 -1
  57. package/dist/features/recent-chapters/api/get-recent-chapters.js +0 -9
  58. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +0 -1
  59. package/dist/features/recent-chapters/recent-chapters-styled.js +0 -16
  60. package/dist/features/recent-chapters/recent-chapters-styled.js.map +0 -1
  61. package/dist/features/recent-chapters/recent-chapters.js +0 -43
  62. package/dist/features/recent-chapters/recent-chapters.js.map +0 -1
  63. package/dist/features/sheet-v2/resource-list/resource-list.js +0 -52
  64. package/dist/features/sheet-v2/resource-list/resource-list.js.map +0 -1
@@ -1,113 +1,129 @@
1
- import { jsx as e, jsxs as c, Fragment as N } from "react/jsx-runtime";
2
- import { memo as B, useCallback as l, useEffect as D } from "react";
3
- import { IMAGES as v } from "../../../../assets/images/images.js";
4
- import G from "../../../../assets/line-icons/icons/plus.js";
5
- import H from "../../../../assets/line-icons/icons/search.js";
6
- import O from "../../../sheet-v2/resource-list/resource-list.js";
7
- import X from "../../../ui/arrow-tooltip/arrow-tooltip.js";
8
- import b from "../../../ui/buttons/button/button.js";
9
- import q from "../../../ui/buttons/icon-button/icon-button.js";
10
- import w from "../../../ui/layout/flex-view.js";
11
- import z from "../../../ui/loader/app-loader/app-loader.js";
12
- import C from "../../../ui/text/text.js";
13
- import { useGetMilestoneResources as F } from "../../milestone-list-container/api/get-milestone-resources.js";
14
- import { MilestoneResourcesWrapper as d, SearchButtonWrapper as L, SearchButtonCover as U, DefaultWrapper as E } from "./resources-list-styled.js";
15
- const ae = B((M) => {
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: m,
18
- isMilestoneActive: t,
19
- userType: u,
20
- studentId: p,
17
+ isDraftMilestone: f,
18
+ isMilestoneActive: s,
19
+ userType: p,
20
+ studentId: g,
21
21
  userMilestoneId: r,
22
- canUpdatePlan: h,
22
+ canUpdatePlan: A,
23
23
  onAssignResources: o,
24
- onNodeAttempt: T,
25
- onNodeView: P,
26
- onNodeReview: S,
27
- onNodeReset: x,
28
- onNodeUnassign: W,
29
- onNodeReattempt: j
30
- } = M, f = u === "TEACHER", g = !h || !t || t && m, {
31
- get: $,
32
- isProcessed: s,
33
- isProcessing: A,
34
- isProcessingFailed: n,
35
- isStale: y,
36
- data: i
37
- } = F(), I = l(() => {
38
- r && $(r, void 0, {
39
- studentId: p
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
- }, [p, r, $]), a = l(() => {
42
- I();
43
- }, [I]);
44
- D(() => {
45
- !A && (!s && !n || y) && a();
46
- }, [a, s, A, n, y]);
47
- const R = l(() => {
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]), k = i && i.length > 0;
53
- return n ? /* @__PURE__ */ e(
54
- d,
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__ */ c(w, { $flexGapX: 1.5, $alignItems: "center", $justifyContent: "center", children: [
60
- /* @__PURE__ */ e(C, { $renderAs: "h6", children: "Oops! Something went wrong. Please try again later." }),
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
- b,
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: a
83
+ onClick: d
70
84
  }
71
85
  )
72
86
  ] })
73
87
  }
74
- ) : s ? /* @__PURE__ */ e(d, { $justifyContent: "space-between", children: k ? /* @__PURE__ */ c(N, { children: [
88
+ ) : a ? /* @__PURE__ */ e(m, { $justifyContent: "space-between", children: B ? /* @__PURE__ */ h(D, { children: [
75
89
  /* @__PURE__ */ e(
76
- O,
90
+ F,
77
91
  {
78
- sheets: i,
79
- userType: u,
80
- onNodeAttempt: T,
81
- onNodeView: P,
82
- onNodeReview: S,
83
- onNodeReattempt: j,
84
- onNodeReset: x,
85
- onNodeUnassign: W,
86
- userMilestoneId: r
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
- f && h && /* @__PURE__ */ e(
90
- L,
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(U, { children: /* @__PURE__ */ e(
97
- q,
112
+ children: /* @__PURE__ */ e(K, { children: /* @__PURE__ */ e(
113
+ _,
98
114
  {
99
- Icon: H,
115
+ Icon: z,
100
116
  renderAs: "secondary",
101
117
  size: "small",
102
118
  analyticsLabel: "Milestone Resource Search",
103
- onClick: R,
104
- disabled: !t
119
+ onClick: E,
120
+ disabled: !s
105
121
  }
106
122
  ) })
107
123
  }
108
124
  )
109
- ] }) : /* @__PURE__ */ c(
110
- w,
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(E, { $isImageWrapper: !0, children: /* @__PURE__ */ e("img", { src: v.BG_EMPTY_RESOURCES, alt: "Empty resources", width: 420, height: 420 }) }),
119
- /* @__PURE__ */ e(E, { children: f ? /* @__PURE__ */ e(
120
- X,
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: !g,
125
- tooltipItem: m ? "Allowed after plan is published" : "Plan is completed",
140
+ hidden: !w,
141
+ tooltipItem: f ? "Allowed after plan is published" : "Plan is completed",
126
142
  children: /* @__PURE__ */ e(
127
- b,
143
+ C,
128
144
  {
129
145
  renderAs: "primary",
130
146
  label: "Assign Resource",
131
- Icon: G,
147
+ Icon: X,
132
148
  shape: "square",
133
149
  size: "small",
134
- onClick: R,
135
- disabled: g
150
+ onClick: E,
151
+ disabled: w
136
152
  }
137
153
  )
138
154
  }
139
- ) : /* @__PURE__ */ e(C, { $renderAs: "ab2-bold", children: "Wait for the teacher to assign a resource" }) })
155
+ ) : /* @__PURE__ */ e(S, { $renderAs: "ab2-bold", children: "Wait for the teacher to assign a resource" }) })
140
156
  ]
141
157
  }
142
- ) }) : /* @__PURE__ */ e(d, { $justifyContent: "center", $background: "WHITE", children: /* @__PURE__ */ e(z, { height: "100%" }) });
158
+ ) }) : /* @__PURE__ */ e(m, { $justifyContent: "center", $background: "WHITE", children: /* @__PURE__ */ e(V, { height: "100%" }) });
143
159
  });
144
160
  export {
145
- ae as default
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;"}