@cuemath/leap 2.8.60-as3 → 2.8.60-beta-0.1

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 (105) hide show
  1. package/dist/assets/line-icons/icons/bin2.js +8 -7
  2. package/dist/assets/line-icons/icons/bin2.js.map +1 -1
  3. package/dist/features/analytics-events/whitelist-events.js +9 -7
  4. package/dist/features/analytics-events/whitelist-events.js.map +1 -1
  5. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +2 -2
  6. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  7. package/dist/features/chapters-v2/chapter-details/chapter-details.js +24 -24
  8. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -1
  9. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +16 -15
  10. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +1 -1
  11. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +8 -12
  12. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
  13. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +72 -76
  14. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +1 -1
  15. package/dist/features/chapters-v2/utils/index.js +4 -5
  16. package/dist/features/chapters-v2/utils/index.js.map +1 -1
  17. package/dist/features/chapters-v2/utils/node-card-utils.js +34 -62
  18. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
  19. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/segmented-game-card.js +75 -62
  20. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/segmented-game-card.js.map +1 -1
  21. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js +110 -127
  22. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js.map +1 -1
  23. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js +4 -12
  24. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js.map +1 -1
  25. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js +105 -128
  26. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js.map +1 -1
  27. package/dist/features/milestone/create/milestone-create.js +43 -49
  28. package/dist/features/milestone/create/milestone-create.js.map +1 -1
  29. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js +1 -1
  30. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js.map +1 -1
  31. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js +40 -42
  32. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js.map +1 -1
  33. package/dist/features/milestone/edit/goal-edit-container.js +62 -64
  34. package/dist/features/milestone/edit/goal-edit-container.js.map +1 -1
  35. package/dist/features/milestone/edit/milestone-edit-container.js +52 -54
  36. package/dist/features/milestone/edit/milestone-edit-container.js.map +1 -1
  37. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
  38. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
  39. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +89 -96
  40. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  41. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +28 -28
  42. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  43. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +111 -120
  44. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  45. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +61 -59
  46. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  47. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +85 -83
  48. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  49. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +90 -88
  50. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  51. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +98 -82
  52. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  53. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js +18 -16
  54. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js.map +1 -1
  55. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +71 -0
  56. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +1 -0
  57. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +31 -0
  58. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +1 -0
  59. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +38 -0
  60. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -0
  61. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +79 -0
  62. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -0
  63. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +18 -0
  64. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -0
  65. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +51 -0
  66. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +1 -0
  67. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +11 -0
  68. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +1 -0
  69. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +144 -0
  70. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -0
  71. package/dist/features/sheets/resources-list/resource-item/resource-item.js.map +1 -1
  72. package/dist/features/sheets/resources-list/resource-item/styled.js +1 -0
  73. package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
  74. package/dist/features/sheets/sheets-analytics-events.js +6 -2
  75. package/dist/features/sheets/sheets-analytics-events.js.map +1 -1
  76. package/dist/features/ui/lottie-animation/lottie-animation.js +24 -39
  77. package/dist/features/ui/lottie-animation/lottie-animation.js.map +1 -1
  78. package/dist/features/ui/theme/button.js +5 -5
  79. package/dist/features/ui/theme/button.js.map +1 -1
  80. package/dist/index.d.ts +13 -39
  81. package/dist/index.js +377 -381
  82. package/dist/index.js.map +1 -1
  83. package/package.json +1 -1
  84. package/dist/assets/line-icons/icons/skip-colored.js +0 -43
  85. package/dist/assets/line-icons/icons/skip-colored.js.map +0 -1
  86. package/dist/features/homework/card-menu-options.js +0 -25
  87. package/dist/features/homework/card-menu-options.js.map +0 -1
  88. package/dist/features/homework/homework-card.js +0 -210
  89. package/dist/features/homework/homework-card.js.map +0 -1
  90. package/dist/features/homework/styles.js +0 -114
  91. package/dist/features/homework/styles.js.map +0 -1
  92. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +0 -157
  93. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +0 -1
  94. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +0 -19
  95. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +0 -1
  96. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +0 -63
  97. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +0 -1
  98. package/dist/features/recent-chapters/api/get-recent-chapters.js +0 -9
  99. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +0 -1
  100. package/dist/features/recent-chapters/recent-chapters-styled.js +0 -16
  101. package/dist/features/recent-chapters/recent-chapters-styled.js.map +0 -1
  102. package/dist/features/recent-chapters/recent-chapters.js +0 -43
  103. package/dist/features/recent-chapters/recent-chapters.js.map +0 -1
  104. package/dist/features/sheet-v2/resource-list/resource-list.js +0 -52
  105. package/dist/features/sheet-v2/resource-list/resource-list.js.map +0 -1
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cuemath/leap",
3
- "version": "2.8.60-as3",
3
+ "version": "2.8.60-beta-0.1",
4
4
  "type": "module",
5
5
  "files": [
6
6
  "dist"
@@ -1,43 +0,0 @@
1
- import { jsxs as e, jsx as l } from "react/jsx-runtime";
2
- const L = (o) => /* @__PURE__ */ e(
3
- "svg",
4
- {
5
- xmlns: "http://www.w3.org/2000/svg",
6
- width: "24",
7
- height: "24",
8
- viewBox: "0 0 24 24",
9
- fill: "none",
10
- ...o,
11
- children: [
12
- /* @__PURE__ */ l(
13
- "path",
14
- {
15
- fillRule: "evenodd",
16
- clipRule: "evenodd",
17
- d: "M6.3999 5.93884L7.44424 5.53564L11.8999 10.4459V5.93884L12.9442 5.53564L18.4442 11.5968V12.4032L12.9442 18.4644L11.8999 18.0612V13.5541L7.44424 18.4644L6.3999 18.0612V5.93884ZM11.6897 12L7.5999 16.5071V7.49293L11.6897 12ZM13.0999 7.49293V16.5071L17.1897 12L13.0999 7.49293Z",
18
- fill: "currentColor"
19
- }
20
- ),
21
- /* @__PURE__ */ l(
22
- "path",
23
- {
24
- className: "skip-colored-path",
25
- d: "M17.1897 12L13.0999 16.5071V7.49293L17.1897 12Z",
26
- fill: "#00E573"
27
- }
28
- ),
29
- /* @__PURE__ */ l(
30
- "path",
31
- {
32
- className: "skip-colored-path",
33
- d: "M11.6897 12L7.5999 16.5071V7.49293L11.6897 12Z",
34
- fill: "#00E573"
35
- }
36
- )
37
- ]
38
- }
39
- ), s = L;
40
- export {
41
- s as default
42
- };
43
- //# sourceMappingURL=skip-colored.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"skip-colored.js","sources":["../../../../src/assets/line-icons/icons/skip-colored.tsx"],"sourcesContent":["const SkipColoredIcon: React.FC<React.SVGProps<SVGSVGElement>> = props => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n {...props}\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M6.3999 5.93884L7.44424 5.53564L11.8999 10.4459V5.93884L12.9442 5.53564L18.4442 11.5968V12.4032L12.9442 18.4644L11.8999 18.0612V13.5541L7.44424 18.4644L6.3999 18.0612V5.93884ZM11.6897 12L7.5999 16.5071V7.49293L11.6897 12ZM13.0999 7.49293V16.5071L17.1897 12L13.0999 7.49293Z\"\n fill=\"currentColor\"\n />\n <path\n className=\"skip-colored-path\"\n d=\"M17.1897 12L13.0999 16.5071V7.49293L17.1897 12Z\"\n fill=\"#00E573\"\n />\n <path\n className=\"skip-colored-path\"\n d=\"M11.6897 12L7.5999 16.5071V7.49293L11.6897 12Z\"\n fill=\"#00E573\"\n />\n </svg>\n);\n\nexport default SkipColoredIcon;\n"],"names":["SkipColoredIcon","props","jsxs","jsx","SkipColoredIcon$1"],"mappings":";AAAA,MAAMA,IAA2D,CAC/DC,MAAA,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,OAAM;AAAA,IACN,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,MAAK;AAAA,IACJ,GAAGD;AAAA,IAEJ,UAAA;AAAA,MAAA,gBAAAE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,UAAS;AAAA,UACT,UAAS;AAAA,UACT,GAAE;AAAA,UACF,MAAK;AAAA,QAAA;AAAA,MACP;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAU;AAAA,UACV,GAAE;AAAA,UACF,MAAK;AAAA,QAAA;AAAA,MACP;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAU;AAAA,UACV,GAAE;AAAA,UACF,MAAK;AAAA,QAAA;AAAA,MACP;AAAA,IAAA;AAAA,EAAA;AACF,GAGFC,IAAeJ;"}
@@ -1,25 +0,0 @@
1
- import { jsx as r, jsxs as p } from "react/jsx-runtime";
2
- import { memo as a } from "react";
3
- import { CardOptions as u, CardOptionWrapper as c, OptionText as d } from "./styles.js";
4
- const s = a(({ options: e }) => e.length === 0 ? null : /* @__PURE__ */ r(u, { $background: "BLACK_2", $borderColor: "WHITE_T_38", $gapX: 0.5, children: e.map(({ icon: t, label: o, id: n, onClick: i, visible: l }) => l ? /* @__PURE__ */ p(
5
- c,
6
- {
7
- $flexDirection: "row",
8
- $alignItems: "center",
9
- $flexGap: 8,
10
- $gapX: 0.5,
11
- $gutterX: 1,
12
- onClick: () => {
13
- i(n);
14
- },
15
- children: [
16
- /* @__PURE__ */ r(t, { width: 20, height: 20 }),
17
- /* @__PURE__ */ r(d, { $renderAs: "ub3", $color: "WHITE", children: o })
18
- ]
19
- },
20
- n
21
- ) : null) }));
22
- export {
23
- s as default
24
- };
25
- //# sourceMappingURL=card-menu-options.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"card-menu-options.js","sources":["../../../src/features/homework/card-menu-options.tsx"],"sourcesContent":["import type { FC, SVGProps } from 'react';\n\nimport { memo } from 'react';\n\nimport * as Styled from './styles';\n\nexport interface ICardMenuOption {\n id: string;\n label: string;\n icon: FC<SVGProps<SVGSVGElement>>;\n onClick: (id: string) => void;\n visible: boolean;\n}\n\nexport interface ICardMenuOptionsProps {\n options: ICardMenuOption[];\n}\n\nconst CardMenuOptions: FC<ICardMenuOptionsProps> = memo(({ options }) => {\n if (options.length === 0) return null;\n\n return (\n <Styled.CardOptions $background=\"BLACK_2\" $borderColor=\"WHITE_T_38\" $gapX={0.5}>\n {options.map(({ icon: OptionIcon, label, id, onClick, visible }) => {\n if (!visible) return null;\n\n return (\n <Styled.CardOptionWrapper\n key={id}\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $flexGap={8}\n $gapX={0.5}\n $gutterX={1}\n onClick={() => {\n onClick(id);\n }}\n >\n <OptionIcon width={20} height={20} />\n <Styled.OptionText $renderAs=\"ub3\" $color=\"WHITE\">\n {label}\n </Styled.OptionText>\n </Styled.CardOptionWrapper>\n );\n })}\n </Styled.CardOptions>\n );\n});\n\nexport default CardMenuOptions;\n"],"names":["CardMenuOptions","memo","options","jsx","Styled.CardOptions","OptionIcon","label","id","onClick","visible","jsxs","Styled.CardOptionWrapper","Styled.OptionText"],"mappings":";;;AAkBA,MAAMA,IAA6CC,EAAK,CAAC,EAAE,SAAAC,QACrDA,EAAQ,WAAW,IAAU,OAG/B,gBAAAC,EAACC,GAAA,EAAmB,aAAY,WAAU,cAAa,cAAa,OAAO,KACxE,YAAQ,IAAI,CAAC,EAAE,MAAMC,GAAY,OAAAC,GAAO,IAAAC,GAAI,SAAAC,GAAS,SAAAC,QAC/CA,IAGH,gBAAAC;AAAA,EAACC;AAAAA,EAAA;AAAA,IAEC,gBAAe;AAAA,IACf,aAAY;AAAA,IACZ,UAAU;AAAA,IACV,OAAO;AAAA,IACP,UAAU;AAAA,IACV,SAAS,MAAM;AACb,MAAAH,EAAQD,CAAE;AAAA,IACZ;AAAA,IAEA,UAAA;AAAA,MAAA,gBAAAJ,EAACE,GAAW,EAAA,OAAO,IAAI,QAAQ,IAAI;AAAA,MACnC,gBAAAF,EAACS,GAAA,EAAkB,WAAU,OAAM,QAAO,SACvC,UACHN,GAAA;AAAA,IAAA;AAAA,EAAA;AAAA,EAbKC;AAAA,IAJY,IAoBtB,EACH,CAAA,CAEH;"}
@@ -1,210 +0,0 @@
1
- import { jsx as e, jsxs as a } from "react/jsx-runtime";
2
- import { useRef as y, useState as q, useLayoutEffect as J, useCallback as x } from "react";
3
- import Q from "../../assets/line-icons/icons/eye2.js";
4
- import U from "../../assets/line-icons/icons/more-vertical.js";
5
- import Y from "../../assets/line-icons/icons/redo.js";
6
- import Z from "../chapters-v2/comps/node-card/node-card-tags.js";
7
- import { getNodeTypeBasedBgImage as D } from "../chapters-v2/utils/index.js";
8
- import { getNodeCardBasedIcon as N } from "../chapters-v2/utils/node-card-utils.js";
9
- import E from "../ui/arrow-tooltip/arrow-tooltip.js";
10
- import ee from "../ui/buttons/clickable/clickable.js";
11
- import re from "../ui/hooks/use-context-menu-click-handler.js";
12
- import u from "../ui/layout/flex-view.js";
13
- import te from "../ui/text/text.js";
14
- import ie from "./card-menu-options.js";
15
- import { CardContainer as ne, CardWrapper as ce, IconWrapper as oe, BannerImageWrapper as ae, BannerImage as se, HeaderText as le, SubHeaderText as ue, CardKebabMenuWrapper as he, CardMenuOptionsWrapper as me, StyledMinus2Icon as fe } from "./styles.js";
16
- const He = ({
17
- header: d,
18
- nodeData: r,
19
- subHeader: I,
20
- userType: H,
21
- userMilestoneId: t,
22
- onNodeUnassign: h,
23
- onNodeReset: m,
24
- onNodeView: i,
25
- onNodeReview: n,
26
- onNodeAttempt: f
27
- }) => {
28
- const {
29
- node_type: c,
30
- state: X,
31
- accuracy: S,
32
- due_date_ts: W,
33
- image_url: w,
34
- image_hue: A,
35
- card_header: O = "",
36
- permissions: B,
37
- user_node_id: s
38
- } = r, R = c && D(c), $ = c && N(c), b = y(null), { menuVisible: j, onMenuClick: G } = re(b), o = y(null), [K, L] = q(!1), {
39
- can_start: g,
40
- can_resume: C,
41
- can_review: T,
42
- can_teacher_review: _,
43
- can_unassign: M,
44
- can_reset: P
45
- } = B || {}, v = H === "STUDENT";
46
- J(() => {
47
- o.current && o.current.scrollHeight > o.current.clientHeight && L(!0);
48
- }, [o]);
49
- const z = x(() => {
50
- if (g || C) {
51
- if (typeof f != "function")
52
- throw new Error("onNodeAttempt must be a function");
53
- f(r);
54
- return;
55
- }
56
- if (T) {
57
- if (typeof n != "function")
58
- throw new Error("onReview must be a function");
59
- if (!s)
60
- throw new Error("user node id must be present to review the sheet");
61
- n(r, t);
62
- return;
63
- }
64
- if (typeof i != "function")
65
- throw new Error("onPreview must be a function");
66
- i(r, t);
67
- }, [
68
- C,
69
- T,
70
- g,
71
- t,
72
- r,
73
- f,
74
- n,
75
- i,
76
- s
77
- ]), F = x(() => {
78
- if (_) {
79
- if (typeof n != "function")
80
- throw new Error("onReview must be a function");
81
- if (!s)
82
- throw new Error("user node id must be present to review the sheet");
83
- n(r, t);
84
- return;
85
- }
86
- if (typeof i != "function")
87
- throw new Error("onPreview must be a function");
88
- i(r, t);
89
- }, [_, t, r, n, i, s]), p = (l) => {
90
- switch (l) {
91
- case "card-view":
92
- F();
93
- return;
94
- case "card-unassign":
95
- r && (h == null || h(r, t));
96
- return;
97
- case "card-reset":
98
- r && (m == null || m(r, t));
99
- return;
100
- default:
101
- throw new Error(`No callback function for ${l}`);
102
- }
103
- }, k = [
104
- {
105
- id: "card-view",
106
- label: "View",
107
- icon: Q,
108
- visible: !0,
109
- onClick: p
110
- },
111
- {
112
- id: "card-unassign",
113
- label: "Unassign",
114
- icon: fe,
115
- visible: !!M,
116
- onClick: p
117
- },
118
- {
119
- id: "card-reset",
120
- label: "Reset",
121
- icon: Y,
122
- visible: !!P,
123
- onClick: p
124
- }
125
- ], V = !!k.find((l) => l.visible);
126
- return /* @__PURE__ */ e(ee, { onClick: v ? z : void 0, label: "homework-card", children: /* @__PURE__ */ a(
127
- ne,
128
- {
129
- $widthX: 12.5,
130
- $position: "relative",
131
- $background: `${A || "ORANGE"}_2`,
132
- children: [
133
- /* @__PURE__ */ a(
134
- ce,
135
- {
136
- $flexDirection: "row",
137
- $alignItems: "center",
138
- $width: "100%",
139
- $heightX: 3.5,
140
- $bgImage: R,
141
- $gutterX: 0.78125,
142
- $flexGap: 8.5,
143
- $position: "relative",
144
- children: [
145
- /* @__PURE__ */ e(
146
- oe,
147
- {
148
- $width: 31,
149
- $height: 31,
150
- $borderRadiusX: 2,
151
- $background: "WHITE_1",
152
- $position: "relative",
153
- $alignItems: "center",
154
- $justifyContent: "center",
155
- children: $ && /* @__PURE__ */ e($, { width: 20, height: 20 })
156
- }
157
- ),
158
- /* @__PURE__ */ e(te, { $renderAs: "ac4-black", children: O }),
159
- !!w && /* @__PURE__ */ e(ae, { children: /* @__PURE__ */ e(se, { src: w, alt: "Chapter image" }) })
160
- ]
161
- }
162
- ),
163
- /* @__PURE__ */ e(Z, { nodeType: c, state: X, accuracy: S, dueDateTs: W }),
164
- /* @__PURE__ */ a(u, { $gutterX: 0.75, $gapX: 1, $flexRowGapX: 0.5, $background: "WHITE", children: [
165
- /* @__PURE__ */ e(
166
- E,
167
- {
168
- renderAs: "primary",
169
- position: "bottom",
170
- tooltipItem: d,
171
- hidden: !K,
172
- widthX: 21.75,
173
- children: /* @__PURE__ */ e(u, { $heightX: 2.5, children: /* @__PURE__ */ e(le, { ref: o, $renderAs: "ab3", children: d }) })
174
- }
175
- ),
176
- /* @__PURE__ */ a(
177
- u,
178
- {
179
- $flexDirection: "row",
180
- $heightX: 1.25,
181
- $alignItems: "center",
182
- $justifyContent: "space-between",
183
- children: [
184
- /* @__PURE__ */ e(ue, { $renderAs: "ub3", $color: "BLACK_T_60", children: I }),
185
- !v && r && V && /* @__PURE__ */ a(u, { $position: "relative", $width: "fit-content", children: [
186
- /* @__PURE__ */ e(
187
- E,
188
- {
189
- renderAs: "primary",
190
- tooltipItem: "Review",
191
- position: "bottom",
192
- zIndex: 5,
193
- parentWidth: "100%",
194
- children: /* @__PURE__ */ e(he, { ref: b, onClick: G, children: /* @__PURE__ */ e(U, { width: 16, height: 16 }) })
195
- }
196
- ),
197
- /* @__PURE__ */ e(me, { $visible: j, children: /* @__PURE__ */ e(ie, { options: k }) })
198
- ] })
199
- ]
200
- }
201
- )
202
- ] })
203
- ]
204
- }
205
- ) });
206
- };
207
- export {
208
- He as default
209
- };
210
- //# sourceMappingURL=homework-card.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"homework-card.js","sources":["../../../src/features/homework/homework-card.tsx"],"sourcesContent":["import type {\n INodeCardCallbacks,\n INodeDataProps,\n} from '../chapters-v2/comps/node-card/node-card-types';\nimport type { ICardMenuOption } from './card-menu-options';\n\nimport { useCallback, useLayoutEffect, useRef, useState } from 'react';\n\nimport Eye2Icon from '../../assets/line-icons/icons/eye2';\nimport MoreVerticalIcon from '../../assets/line-icons/icons/more-vertical';\nimport RedoIcon from '../../assets/line-icons/icons/redo';\nimport NodeCardTags from '../chapters-v2/comps/node-card/node-card-tags';\nimport { getNodeTypeBasedBgImage } from '../chapters-v2/utils';\nimport { getNodeCardBasedIcon } from '../chapters-v2/utils/node-card-utils';\nimport ArrowTooltip from '../ui/arrow-tooltip/arrow-tooltip';\nimport Clickable from '../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\nimport CardMenuOptions from './card-menu-options';\nimport * as Styled from './styles';\n\ninterface IHomeworkCardProps extends INodeCardCallbacks {\n header: string;\n nodeData: INodeDataProps;\n subHeader: string;\n userType: 'TEACHER' | 'STUDENT';\n userMilestoneId?: string;\n}\n\nconst HomeworkCard = ({\n header,\n nodeData,\n subHeader,\n userType,\n userMilestoneId,\n onNodeUnassign,\n onNodeReset,\n onNodeView,\n onNodeReview,\n onNodeAttempt,\n}: IHomeworkCardProps) => {\n const {\n node_type: nodeType,\n state,\n accuracy,\n due_date_ts: dueDateTs,\n image_url: imageUrl,\n image_hue: imageHue,\n card_header: cardHeader = '',\n permissions,\n user_node_id: userNodeId,\n } = nodeData;\n\n const bgImage = nodeType && getNodeTypeBasedBgImage(nodeType);\n const NodeCardIcon = nodeType && getNodeCardBasedIcon(nodeType);\n const containerRef = useRef<HTMLDivElement>(null);\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(containerRef);\n const titleTextRef = useRef<HTMLDivElement>(null);\n const [showTitleTooltip, setShowTitleTooltip] = useState(false);\n\n const {\n can_start: canStart,\n can_resume: canResume,\n can_review: canReview,\n can_teacher_review: canTeacherReview,\n can_unassign: canUnassign,\n can_reset: canReset,\n } = permissions || {};\n const isStudent = userType === 'STUDENT';\n\n useLayoutEffect(() => {\n if (\n titleTextRef.current &&\n titleTextRef.current.scrollHeight > titleTextRef.current.clientHeight\n ) {\n setShowTitleTooltip(true);\n }\n }, [titleTextRef]);\n\n const onStudentView = useCallback(() => {\n if (canStart || canResume) {\n if (typeof onNodeAttempt !== 'function') {\n throw new Error('onNodeAttempt must be a function');\n }\n\n onNodeAttempt(nodeData);\n\n return;\n }\n\n if (canReview) {\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n\n if (typeof onNodeView !== 'function') {\n throw new Error('onPreview must be a function');\n }\n\n onNodeView(nodeData, userMilestoneId);\n }, [\n canResume,\n canReview,\n canStart,\n userMilestoneId,\n nodeData,\n onNodeAttempt,\n onNodeReview,\n onNodeView,\n userNodeId,\n ]);\n\n const onTeacherView = useCallback(() => {\n if (canTeacherReview) {\n if (typeof onNodeReview !== 'function') {\n throw new Error('onReview must be a function');\n }\n\n if (!userNodeId) {\n throw new Error('user node id must be present to review the sheet');\n }\n\n onNodeReview(nodeData, userMilestoneId);\n\n return;\n }\n\n if (typeof onNodeView !== 'function') {\n throw new Error('onPreview must be a function');\n }\n\n onNodeView(nodeData, userMilestoneId);\n }, [canTeacherReview, userMilestoneId, nodeData, onNodeReview, onNodeView, userNodeId]);\n\n const handleOnMenuOptionClick = (optionId: string) => {\n switch (optionId) {\n case 'card-view':\n onTeacherView();\n\n return;\n case 'card-unassign':\n nodeData && onNodeUnassign?.(nodeData, userMilestoneId);\n\n return;\n case 'card-reset':\n nodeData && onNodeReset?.(nodeData, userMilestoneId);\n\n return;\n\n default:\n throw new Error(`No callback function for ${optionId}`);\n }\n };\n\n const menuOptions: ICardMenuOption[] = [\n {\n id: 'card-view',\n label: 'View',\n icon: Eye2Icon,\n visible: true,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-unassign',\n label: 'Unassign',\n icon: Styled.StyledMinus2Icon,\n visible: !!canUnassign,\n onClick: handleOnMenuOptionClick,\n },\n {\n id: 'card-reset',\n label: 'Reset',\n icon: RedoIcon,\n visible: !!canReset,\n onClick: handleOnMenuOptionClick,\n },\n ];\n\n const canShowMenuOptions = !!menuOptions.find(option => option.visible);\n\n return (\n <Clickable onClick={isStudent ? onStudentView : undefined} label=\"homework-card\">\n <Styled.CardContainer\n $widthX={12.5}\n $position=\"relative\"\n $background={`${imageHue || 'ORANGE'}_2`}\n >\n <Styled.CardWrapper\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $width=\"100%\"\n $heightX={3.5}\n $bgImage={bgImage}\n $gutterX={0.78125}\n $flexGap={8.5}\n $position=\"relative\"\n >\n <Styled.IconWrapper\n $width={31}\n $height={31}\n $borderRadiusX={2}\n $background=\"WHITE_1\"\n $position=\"relative\"\n $alignItems=\"center\"\n $justifyContent=\"center\"\n >\n {NodeCardIcon && <NodeCardIcon width={20} height={20} />}\n </Styled.IconWrapper>\n <Text $renderAs=\"ac4-black\">{cardHeader}</Text>\n {!!imageUrl && (\n <Styled.BannerImageWrapper>\n <Styled.BannerImage src={imageUrl} alt=\"Chapter image\" />\n </Styled.BannerImageWrapper>\n )}\n </Styled.CardWrapper>\n <NodeCardTags nodeType={nodeType} state={state} accuracy={accuracy} dueDateTs={dueDateTs} />\n <FlexView $gutterX={0.75} $gapX={1} $flexRowGapX={0.5} $background=\"WHITE\">\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n tooltipItem={header}\n hidden={!showTitleTooltip}\n widthX={21.75}\n >\n <FlexView $heightX={2.5}>\n <Styled.HeaderText ref={titleTextRef} $renderAs=\"ab3\">\n {header}\n </Styled.HeaderText>\n </FlexView>\n </ArrowTooltip>\n <FlexView\n $flexDirection=\"row\"\n $heightX={1.25}\n $alignItems=\"center\"\n $justifyContent=\"space-between\"\n >\n <Styled.SubHeaderText $renderAs=\"ub3\" $color=\"BLACK_T_60\">\n {subHeader}\n </Styled.SubHeaderText>\n {!isStudent && nodeData && canShowMenuOptions && (\n <FlexView $position=\"relative\" $width=\"fit-content\">\n <ArrowTooltip\n renderAs=\"primary\"\n tooltipItem=\"Review\"\n position=\"bottom\"\n zIndex={5}\n parentWidth=\"100%\"\n >\n <Styled.CardKebabMenuWrapper ref={containerRef} onClick={onMenuClick}>\n <MoreVerticalIcon width={16} height={16} />\n </Styled.CardKebabMenuWrapper>\n </ArrowTooltip>\n <Styled.CardMenuOptionsWrapper $visible={menuVisible}>\n <CardMenuOptions options={menuOptions} />\n </Styled.CardMenuOptionsWrapper>\n </FlexView>\n )}\n </FlexView>\n </FlexView>\n </Styled.CardContainer>\n </Clickable>\n );\n};\n\nexport default HomeworkCard;\n"],"names":["HomeworkCard","header","nodeData","subHeader","userType","userMilestoneId","onNodeUnassign","onNodeReset","onNodeView","onNodeReview","onNodeAttempt","nodeType","state","accuracy","dueDateTs","imageUrl","imageHue","cardHeader","permissions","userNodeId","bgImage","getNodeTypeBasedBgImage","NodeCardIcon","getNodeCardBasedIcon","containerRef","useRef","menuVisible","onMenuClick","useContextMenuClickHandler","titleTextRef","showTitleTooltip","setShowTitleTooltip","useState","canStart","canResume","canReview","canTeacherReview","canUnassign","canReset","isStudent","useLayoutEffect","onStudentView","useCallback","onTeacherView","handleOnMenuOptionClick","optionId","menuOptions","Eye2Icon","Styled.StyledMinus2Icon","RedoIcon","canShowMenuOptions","option","Clickable","jsxs","Styled.CardContainer","Styled.CardWrapper","jsx","Styled.IconWrapper","Text","Styled.BannerImageWrapper","Styled.BannerImage","NodeCardTags","FlexView","ArrowTooltip","Styled.HeaderText","Styled.SubHeaderText","Styled.CardKebabMenuWrapper","MoreVerticalIcon","Styled.CardMenuOptionsWrapper","CardMenuOptions"],"mappings":"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"}
@@ -1,114 +0,0 @@
1
- import r from "styled-components";
2
- import i from "../../assets/line-icons/icons/minus2.js";
3
- import t from "../ui/layout/flex-view.js";
4
- import n from "../ui/text/text.js";
5
- const l = r(t)(({ theme: o }) => `
6
- cursor: pointer;
7
- width: fit-content;
8
-
9
- &:hover {
10
- border-radius: 50%;
11
- background: ${o.colors.WHITE_5};
12
- }
13
- `), d = r(n)`
14
- display: -webkit-box;
15
- -webkit-line-clamp: 1;
16
- -webkit-box-orient: vertical;
17
- overflow: hidden;
18
- text-overflow: ellipsis;
19
- `, u = r(t)(({
20
- theme: o,
21
- $visible: e
22
- }) => `
23
- cursor: pointer;
24
- position: absolute;
25
- z-index: 6;
26
- top: calc(100% + 4px);
27
- left: 0;
28
- transform-origin: top;
29
- transform: scaleY(${e ? 1 : 0});
30
- opacity: ${e ? 1 : 0};
31
- 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)`
38
- border: 1px solid ${({ theme: o }) => o.colors.BLACK_T_15};
39
-
40
- &:hover {
41
- border: 1px solid ${({ theme: o }) => o.colors.BLACK};
42
- }
43
- `, b = r(t)(({ $bgImage: o }) => o ? `
44
- background-image: url(${o});
45
- background-repeat: no-repeat;
46
- background-size: cover;
47
- background-position: center;
48
- overflow: hidden;
49
- ` : "overflow: hidden;"), f = r(t)`
50
- display: flex;
51
- align-items: center;
52
- justify-content: center;
53
- `, w = r(t)`
54
- position: absolute;
55
- right: -18px;
56
- top: -4px;
57
- `, h = r.img(({ theme: o }) => {
58
- const { gutter: e } = o.layout;
59
- return `
60
- border: 1px solid ${o.colors.BLACK_T_15};
61
- width: ${e * 4}px;
62
- height: ${e * 4}px;
63
- border-radius: 50%;
64
- `;
65
- }), g = r(i)`
66
- path {
67
- stroke: ${({ theme: o }) => o.colors.WHITE};
68
- }
69
- `, m = r(n)`
70
- display: -webkit-box;
71
- -webkit-line-clamp: 2;
72
- -webkit-box-orient: vertical;
73
- overflow: hidden;
74
- 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)(({
82
- theme: o,
83
- $disabled: e
84
- }) => `
85
- cursor: ${e ? "not-allowed" : "pointer"};
86
-
87
- &:hover {
88
- background: ${e ? "transparent" : o.colors.BLACK};
89
- };
90
-
91
- path {
92
- fill: ${o.colors.WHITE_1};
93
- }
94
- `), C = r(n)`
95
- white-space: nowrap;
96
- overflow: hidden;
97
- text-overflow: ellipsis;
98
- `;
99
- export {
100
- h as BannerImage,
101
- w as BannerImageWrapper,
102
- x as CardContainer,
103
- l as CardKebabMenuWrapper,
104
- u as CardMenuOptionsWrapper,
105
- k as CardOptionWrapper,
106
- v as CardOptions,
107
- b as CardWrapper,
108
- m as HeaderText,
109
- f as IconWrapper,
110
- C as OptionText,
111
- g as StyledMinus2Icon,
112
- d as SubHeaderText
113
- };
114
- //# sourceMappingURL=styles.js.map
@@ -1 +0,0 @@
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\nexport interface ICardWrapperProps {\n $bgImage: string;\n}\n\nexport interface 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":";;;;AAcO,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,157 +0,0 @@
1
- import { jsxs as u, jsx as e, Fragment as x } from "react/jsx-runtime";
2
- import { memo as L, useCallback as l, useEffect as H } from "react";
3
- import { IMAGES as X } from "../../../../assets/images/images.js";
4
- import D from "../../../ui/arrow-tooltip/arrow-tooltip.js";
5
- import _ from "../../../ui/buttons/button/button.js";
6
- import T from "../../../ui/layout/flex-view.js";
7
- import j from "../../../ui/loader/app-loader/app-loader.js";
8
- import $ from "../../../ui/separator/separator.js";
9
- import N from "../../../ui/text/text.js";
10
- import { MILESTONE_WIDGET_MIN_HEIGHT as v } from "../../constants.js";
11
- import { useGetTestHelpData as G } from "../../milestone-list-container/api/get-tests-list.js";
12
- import { TESTS_CREATION_ANALYTICS_EVENTS as R } from "../tests-creation/tests-creation-analytics-events.js";
13
- import W from "./test-list-view.js";
14
- const re = L((c) => {
15
- const {
16
- isChaptersAvailable: g,
17
- isDraftMilestone: E,
18
- isMilestoneActive: d,
19
- userType: b,
20
- studentId: p,
21
- userMilestoneId: t,
22
- canUpdatePlan: I
23
- } = c, { onCreateMilestoneTest: s, onTestPreview: o, onTestStart: i, onTestReview: n } = c;
24
- console.log(o, n, i, "ayush props MilestoneTestsList");
25
- const {
26
- get: A,
27
- data: r,
28
- isProcessingFailed: m,
29
- isProcessed: f,
30
- isStale: C,
31
- isProcessing: w
32
- } = G(), y = !I || !g || !d || d && E, M = d && !g ? "Chapters need to be assigned" : E ? "Allowed after plan is published" : "Plan is completed", h = l(() => {
33
- A(t, void 0, {
34
- studentId: p
35
- });
36
- }, [A, p, t]);
37
- H(() => {
38
- !w && (!f && !m || C) && h();
39
- }, [h, f, w, m, C]);
40
- const S = l(() => {
41
- if (typeof s == "function") {
42
- s == null || s(t, ((r == null ? void 0 : r.length) || 0) + 1);
43
- return;
44
- }
45
- throw new Error("No callback provided. If provided it must be a function");
46
- }, [s, t, r]), O = l(
47
- (a) => {
48
- if (typeof o == "function") {
49
- o == null || o(a, t);
50
- return;
51
- }
52
- throw new Error("No callback provided. If provided it must be a function");
53
- },
54
- [o, t]
55
- ), k = l(
56
- (a) => {
57
- if (typeof i == "function") {
58
- i == null || i(a);
59
- return;
60
- }
61
- throw new Error("No callback provided. If provided it must be a function");
62
- },
63
- [i]
64
- ), P = l(
65
- (a) => {
66
- if (typeof n == "function") {
67
- n == null || n(a, t);
68
- return;
69
- }
70
- throw new Error("No callback provided. If provided it must be a function");
71
- },
72
- [n, t]
73
- );
74
- return m ? /* @__PURE__ */ u(T, { $flexGapX: 1.5, $alignItems: "center", $justifyContent: "center", children: [
75
- /* @__PURE__ */ e(N, { $renderAs: "h6", children: "Oops! Something went wrong. Please try again later." }),
76
- /* @__PURE__ */ e(
77
- _,
78
- {
79
- widthX: 14,
80
- size: "small",
81
- shape: "square",
82
- renderAs: "primary",
83
- label: "Try again",
84
- onClick: h
85
- }
86
- )
87
- ] }) : f ? r != null && r.length ? /* @__PURE__ */ e(
88
- W,
89
- {
90
- ...c,
91
- onNodeAttempt: k,
92
- onNodeView: O,
93
- onNodeReview: P,
94
- milestoneId: t,
95
- sheets: r,
96
- userType: b,
97
- studentId: p,
98
- onCreateNewTest: S,
99
- canUpdatedPlan: I,
100
- isMilestoneActive: d
101
- }
102
- ) : /* @__PURE__ */ u(
103
- T,
104
- {
105
- $gapX: 6.75,
106
- $alignItems: "center",
107
- $justifyContent: "center",
108
- $background: "WHITE",
109
- $height: v,
110
- children: [
111
- /* @__PURE__ */ e("img", { src: X.EMPTY_MIX_TESTS, alt: "empty_mix_tests" }),
112
- /* @__PURE__ */ e($, { heightX: 2 }),
113
- b === "TEACHER" ? /* @__PURE__ */ u(x, { children: [
114
- /* @__PURE__ */ e(
115
- D,
116
- {
117
- renderAs: "primary",
118
- position: "bottom",
119
- hidden: !y,
120
- tooltipItem: M,
121
- children: /* @__PURE__ */ e(
122
- _,
123
- {
124
- widthX: 10,
125
- renderAs: "primary",
126
- shape: "square",
127
- size: "small",
128
- label: "Create a Test",
129
- onClick: S,
130
- disabled: y,
131
- analyticsLabel: R.CUSTOM_TEST_CREATION_STARTED,
132
- analyticsProps: {
133
- milestone_id: t
134
- }
135
- }
136
- )
137
- }
138
- ),
139
- /* @__PURE__ */ e($, { heightX: 2 })
140
- ] }) : /* @__PURE__ */ e(N, { $renderAs: "ab2-bold", $color: "BLACK_T_87", children: "Wait for the teacher to create a test" })
141
- ]
142
- }
143
- ) : /* @__PURE__ */ e(
144
- T,
145
- {
146
- $height: v,
147
- $alignItems: "center",
148
- $justifyContent: "center",
149
- $background: "WHITE",
150
- children: /* @__PURE__ */ e(j, { height: "100%" })
151
- }
152
- );
153
- });
154
- export {
155
- re as default
156
- };
157
- //# sourceMappingURL=test-list-container.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"test-list-container.js","sources":["../../../../../src/features/milestone/milestone-tests/test-list-v2/test-list-container.tsx"],"sourcesContent":["import type { INodeDataProps } from '../../../chapters-v2/comps/node-card/node-card-types';\nimport type { ITestsListProps } from './types';\n\nimport { memo, useCallback, useEffect, type FC } from 'react';\n\nimport { IMAGES } from '../../../../assets/images/images';\nimport ArrowTooltip from '../../../ui/arrow-tooltip/arrow-tooltip';\nimport Button from '../../../ui/buttons/button/button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport AppLoader from '../../../ui/loader/app-loader/app-loader';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { MILESTONE_WIDGET_MIN_HEIGHT } from '../../constants';\nimport { useGetTestHelpData } from '../../milestone-list-container/api/get-tests-list';\nimport { TESTS_CREATION_ANALYTICS_EVENTS } from '../tests-creation/tests-creation-analytics-events';\nimport TestSheetsList from './test-list-view';\n\nconst MilestoneTestsList: FC<ITestsListProps> = memo(props => {\n const {\n isChaptersAvailable,\n isDraftMilestone,\n isMilestoneActive,\n userType,\n studentId,\n userMilestoneId,\n canUpdatePlan,\n } = props;\n const { onCreateMilestoneTest, onTestPreview, onTestStart, onTestReview } = props;\n\n console.log(onTestPreview, onTestReview, onTestStart, 'ayush props MilestoneTestsList');\n\n const {\n get: getTestHelpData,\n data,\n isProcessingFailed,\n isProcessed,\n isStale,\n isProcessing,\n } = useGetTestHelpData();\n\n const isTestSheetCreationDisabled =\n !canUpdatePlan ||\n !isChaptersAvailable ||\n !isMilestoneActive ||\n (isMilestoneActive && isDraftMilestone);\n const testCreationCtaTooltipText =\n isMilestoneActive && !isChaptersAvailable\n ? 'Chapters need to be assigned'\n : isDraftMilestone\n ? 'Allowed after plan is published'\n : 'Plan is completed';\n\n const handleOnTryAgain = useCallback(() => {\n getTestHelpData(userMilestoneId, undefined, {\n studentId,\n });\n }, [getTestHelpData, studentId, userMilestoneId]);\n\n useEffect(() => {\n if (!isProcessing && ((!isProcessed && !isProcessingFailed) || isStale)) {\n handleOnTryAgain();\n }\n }, [handleOnTryAgain, isProcessed, isProcessing, isProcessingFailed, isStale]);\n\n const handleOnCreateMilestoneTest = useCallback(() => {\n if (typeof onCreateMilestoneTest === 'function') {\n onCreateMilestoneTest?.(userMilestoneId, (data?.length || 0) + 1);\n\n return;\n }\n\n throw new Error('No callback provided. If provided it must be a function');\n }, [onCreateMilestoneTest, userMilestoneId, data]);\n\n const handleOnTestPreview = useCallback(\n (sheetData: INodeDataProps) => {\n if (typeof onTestPreview === 'function') {\n onTestPreview?.(sheetData, userMilestoneId);\n\n return;\n }\n\n throw new Error('No callback provided. If provided it must be a function');\n },\n [onTestPreview, userMilestoneId],\n );\n\n const handleOnTestStart = useCallback(\n (sheetData: INodeDataProps) => {\n if (typeof onTestStart === 'function') {\n onTestStart?.(sheetData);\n\n return;\n }\n\n throw new Error('No callback provided. If provided it must be a function');\n },\n [onTestStart],\n );\n\n const handleOnTestReview = useCallback(\n (sheetData: INodeDataProps) => {\n if (typeof onTestReview === 'function') {\n onTestReview?.(sheetData, userMilestoneId);\n\n return;\n }\n\n throw new Error('No callback provided. If provided it must be a function');\n },\n [onTestReview, userMilestoneId],\n );\n\n if (isProcessingFailed) {\n return (\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 );\n }\n\n if (isProcessed) {\n if (data?.length) {\n return (\n <TestSheetsList\n {...props}\n onNodeAttempt={handleOnTestStart}\n onNodeView={handleOnTestPreview}\n onNodeReview={handleOnTestReview}\n milestoneId={userMilestoneId}\n sheets={data}\n userType={userType}\n studentId={studentId}\n onCreateNewTest={handleOnCreateMilestoneTest}\n canUpdatedPlan={canUpdatePlan}\n isMilestoneActive={isMilestoneActive}\n />\n );\n }\n\n return (\n <FlexView\n $gapX={6.75}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $background=\"WHITE\"\n $height={MILESTONE_WIDGET_MIN_HEIGHT}\n >\n <img src={IMAGES.EMPTY_MIX_TESTS} alt=\"empty_mix_tests\" />\n <Separator heightX={2} />\n {userType === 'TEACHER' ? (\n <>\n <ArrowTooltip\n renderAs=\"primary\"\n position=\"bottom\"\n hidden={!isTestSheetCreationDisabled}\n tooltipItem={testCreationCtaTooltipText}\n >\n <Button\n widthX={10}\n renderAs=\"primary\"\n shape=\"square\"\n size=\"small\"\n label=\"Create a Test\"\n onClick={handleOnCreateMilestoneTest}\n disabled={isTestSheetCreationDisabled}\n analyticsLabel={TESTS_CREATION_ANALYTICS_EVENTS.CUSTOM_TEST_CREATION_STARTED}\n analyticsProps={{\n milestone_id: userMilestoneId,\n }}\n />\n </ArrowTooltip>\n <Separator heightX={2} />\n </>\n ) : (\n <Text $renderAs=\"ab2-bold\" $color=\"BLACK_T_87\">\n Wait for the teacher to create a test\n </Text>\n )}\n </FlexView>\n );\n }\n\n return (\n <FlexView\n $height={MILESTONE_WIDGET_MIN_HEIGHT}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $background=\"WHITE\"\n >\n <AppLoader height=\"100%\" />\n </FlexView>\n );\n});\n\nexport default MilestoneTestsList;\n"],"names":["MilestoneTestsList","memo","props","isChaptersAvailable","isDraftMilestone","isMilestoneActive","userType","studentId","userMilestoneId","canUpdatePlan","onCreateMilestoneTest","onTestPreview","onTestStart","onTestReview","getTestHelpData","data","isProcessingFailed","isProcessed","isStale","isProcessing","useGetTestHelpData","isTestSheetCreationDisabled","testCreationCtaTooltipText","handleOnTryAgain","useCallback","useEffect","handleOnCreateMilestoneTest","handleOnTestPreview","sheetData","handleOnTestStart","handleOnTestReview","FlexView","jsx","Text","Button","TestSheetsList","jsxs","MILESTONE_WIDGET_MIN_HEIGHT","IMAGES","Separator","Fragment","ArrowTooltip","TESTS_CREATION_ANALYTICS_EVENTS","AppLoader"],"mappings":"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"}