@cuemath/leap 2.8.60-aa2 → 2.8.60-ag1

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 (227) hide show
  1. package/dist/assets/illustrations/illustrations.js +9 -0
  2. package/dist/assets/illustrations/illustrations.js.map +1 -1
  3. package/dist/assets/line-icons/icons/alarm.js +41 -0
  4. package/dist/assets/line-icons/icons/alarm.js.map +1 -0
  5. package/dist/assets/line-icons/icons/bin2.js +7 -8
  6. package/dist/assets/line-icons/icons/bin2.js.map +1 -1
  7. package/dist/assets/line-icons/icons/dart.js +23 -0
  8. package/dist/assets/line-icons/icons/dart.js.map +1 -0
  9. package/dist/assets/line-icons/icons/exclamation.js +26 -0
  10. package/dist/assets/line-icons/icons/exclamation.js.map +1 -0
  11. package/dist/assets/line-icons/icons/home2.js +25 -0
  12. package/dist/assets/line-icons/icons/home2.js.map +1 -0
  13. package/dist/assets/line-icons/icons/important.js +23 -0
  14. package/dist/assets/line-icons/icons/important.js.map +1 -0
  15. package/dist/assets/line-icons/icons/puzzle.js +25 -0
  16. package/dist/assets/line-icons/icons/puzzle.js.map +1 -0
  17. package/dist/assets/line-icons/icons/recap.js +32 -0
  18. package/dist/assets/line-icons/icons/recap.js.map +1 -0
  19. package/dist/assets/line-icons/icons/skip-colored.js +43 -0
  20. package/dist/assets/line-icons/icons/skip-colored.js.map +1 -0
  21. package/dist/assets/line-icons/icons/status.js +41 -0
  22. package/dist/assets/line-icons/icons/status.js.map +1 -0
  23. package/dist/assets/line-icons/icons/testtube.js +33 -0
  24. package/dist/assets/line-icons/icons/testtube.js.map +1 -0
  25. package/dist/constants/api.js +3 -2
  26. package/dist/constants/api.js.map +1 -1
  27. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +98 -33
  28. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
  29. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +76 -47
  30. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  31. package/dist/features/chapters/chapters-list/chapters-list-styled.js +5 -5
  32. package/dist/features/chapters/chapters-list/chapters-list-styled.js.map +1 -1
  33. package/dist/features/chapters/chapters-list/chapters-list.js +65 -70
  34. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  35. package/dist/features/chapters/lpar-chapter/block-section/sheet-item/rewards-n-actions/student-actions/student-actions.js +18 -18
  36. package/dist/features/chapters/lpar-chapter/block-section/sheet-item/rewards-n-actions/student-actions/student-actions.js.map +1 -1
  37. package/dist/features/chapters/lpar-chapter/block-section/sheet-item/rewards-n-actions/teacher-actions/teacher-actions.js +10 -10
  38. package/dist/features/chapters/lpar-chapter/block-section/sheet-item/rewards-n-actions/teacher-actions/teacher-actions.js.map +1 -1
  39. package/dist/features/chapters-v2/api/chapter.js +10 -0
  40. package/dist/features/chapters-v2/api/chapter.js.map +1 -0
  41. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +112 -0
  42. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -0
  43. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js +26 -0
  44. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js.map +1 -0
  45. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +69 -0
  46. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +1 -0
  47. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js +90 -0
  48. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js.map +1 -0
  49. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js +97 -0
  50. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js.map +1 -0
  51. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js +52 -0
  52. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js.map +1 -0
  53. package/dist/features/chapters-v2/chapter-details/chapter-details.js +103 -0
  54. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -0
  55. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js +13 -0
  56. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js.map +1 -0
  57. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +153 -0
  58. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +1 -0
  59. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +16 -0
  60. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -0
  61. package/dist/features/chapters-v2/comps/node-card/node-card.js +12 -0
  62. package/dist/features/chapters-v2/comps/node-card/node-card.js.map +1 -0
  63. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js +32 -0
  64. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js.map +1 -0
  65. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js +31 -0
  66. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js.map +1 -0
  67. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +164 -0
  68. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +1 -0
  69. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +184 -0
  70. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +1 -0
  71. package/dist/features/chapters-v2/comps/tag/tag-styled.js +13 -0
  72. package/dist/features/chapters-v2/comps/tag/tag-styled.js.map +1 -0
  73. package/dist/features/chapters-v2/comps/tag/tag.js +28 -0
  74. package/dist/features/chapters-v2/comps/tag/tag.js.map +1 -0
  75. package/dist/features/chapters-v2/constants/block-constants.js +20 -0
  76. package/dist/features/chapters-v2/constants/block-constants.js.map +1 -0
  77. package/dist/features/chapters-v2/constants/node-constants.js +15 -0
  78. package/dist/features/chapters-v2/constants/node-constants.js.map +1 -0
  79. package/dist/features/chapters-v2/utils/index.js +41 -0
  80. package/dist/features/chapters-v2/utils/index.js.map +1 -0
  81. package/dist/features/chapters-v2/utils/node-card-utils.js +105 -0
  82. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -0
  83. package/dist/features/cue-canvas/cue-canvas-provider.js +8 -9
  84. package/dist/features/cue-canvas/cue-canvas-provider.js.map +1 -1
  85. package/dist/features/homework/card-menu-options.js +23 -0
  86. package/dist/features/homework/card-menu-options.js.map +1 -0
  87. package/dist/features/homework/homework-card.js +209 -0
  88. package/dist/features/homework/homework-card.js.map +1 -0
  89. package/dist/features/homework/styles.js +114 -0
  90. package/dist/features/homework/styles.js.map +1 -0
  91. package/dist/features/milestone/create/api/goal-submit.js +1 -1
  92. package/dist/features/milestone/create/api/goal-submit.js.map +1 -1
  93. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js +12 -4
  94. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js.map +1 -1
  95. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js +128 -105
  96. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js.map +1 -1
  97. package/dist/features/milestone/create/milestone-create.js +49 -43
  98. package/dist/features/milestone/create/milestone-create.js.map +1 -1
  99. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js +1 -1
  100. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js.map +1 -1
  101. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js +1 -1
  102. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js.map +1 -1
  103. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js +51 -53
  104. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js.map +1 -1
  105. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js +42 -40
  106. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js.map +1 -1
  107. package/dist/features/milestone/edit/goal-edit-container.js +64 -62
  108. package/dist/features/milestone/edit/goal-edit-container.js.map +1 -1
  109. package/dist/features/milestone/edit/milestone-edit-container.js +54 -52
  110. package/dist/features/milestone/edit/milestone-edit-container.js.map +1 -1
  111. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
  112. package/dist/features/milestone/milestone-list-container/api/get-milestones.js +9 -17
  113. package/dist/features/milestone/milestone-list-container/api/get-milestones.js.map +1 -1
  114. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
  115. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +136 -104
  116. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  117. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +107 -123
  118. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  119. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +157 -176
  120. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  121. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js +24 -10
  122. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js.map +1 -1
  123. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +76 -83
  124. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  125. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js +10 -22
  126. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js.map +1 -1
  127. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js +70 -37
  128. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js.map +1 -1
  129. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +114 -176
  130. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  131. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js +29 -16
  132. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js.map +1 -1
  133. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js +19 -23
  134. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js.map +1 -1
  135. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js +23 -35
  136. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js.map +1 -1
  137. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +96 -100
  138. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  139. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js +1 -1
  140. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js.map +1 -1
  141. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +114 -112
  142. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  143. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +165 -0
  144. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +1 -0
  145. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +25 -0
  146. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +1 -0
  147. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +82 -0
  148. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +1 -0
  149. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js +16 -18
  150. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js.map +1 -1
  151. package/dist/features/recent-chapters/api/get-recent-chapters.js +9 -0
  152. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +1 -0
  153. package/dist/features/recent-chapters/recent-chapters-styled.js +16 -0
  154. package/dist/features/recent-chapters/recent-chapters-styled.js.map +1 -0
  155. package/dist/features/recent-chapters/recent-chapters.js +40 -0
  156. package/dist/features/recent-chapters/recent-chapters.js.map +1 -0
  157. package/dist/features/sheet-v2/resource-list/resource-list.js +49 -0
  158. package/dist/features/sheet-v2/resource-list/resource-list.js.map +1 -0
  159. package/dist/features/sheets/lessons-list/lesson-item/lesson-item-cta-info.js +41 -41
  160. package/dist/features/sheets/lessons-list/lesson-item/lesson-item-cta-info.js.map +1 -1
  161. package/dist/features/sheets/resources-list/resource-item/resource-item.js +20 -20
  162. package/dist/features/sheets/resources-list/resource-item/resource-item.js.map +1 -1
  163. package/dist/features/sheets/resources-list/resource-item/styled.js +1 -1
  164. package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
  165. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/student-actions/student-actions.js +33 -33
  166. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/student-actions/student-actions.js.map +1 -1
  167. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js +4 -3
  168. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js.map +1 -1
  169. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions.js +30 -30
  170. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions.js.map +1 -1
  171. package/dist/features/sheets/utils/is-v3-worksheet.js +15 -6
  172. package/dist/features/sheets/utils/is-v3-worksheet.js.map +1 -1
  173. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +30 -29
  174. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  175. package/dist/features/ui/constants/z-index.js +1 -1
  176. package/dist/features/ui/constants/z-index.js.map +1 -1
  177. package/dist/features/ui/context-menu/context-menu-styled.js +28 -14
  178. package/dist/features/ui/context-menu/context-menu-styled.js.map +1 -1
  179. package/dist/features/ui/context-menu/context-menu.js +30 -15
  180. package/dist/features/ui/context-menu/context-menu.js.map +1 -1
  181. package/dist/features/ui/theme/button.js +22 -107
  182. package/dist/features/ui/theme/button.js.map +1 -1
  183. package/dist/index.d.ts +226 -26
  184. package/dist/index.js +487 -466
  185. package/dist/index.js.map +1 -1
  186. package/dist/static/chapter-header-bg-2.c8d96894.svg +1 -0
  187. package/dist/static/node-custom-test-bg.d3b757be.svg +1 -0
  188. package/dist/static/node-learn-bg.b61f815c.svg +1 -0
  189. package/dist/static/node-practice-bg.16cbaf2a.svg +1 -0
  190. package/dist/static/node-project-bg.e6a33e28.svg +1 -0
  191. package/dist/static/node-puzzle-bg.3422135c.svg +1 -0
  192. package/dist/static/node-recap-bg.546154e4.svg +1 -0
  193. package/dist/static/node-test-prep-bg.42c0b9c4.svg +1 -0
  194. package/dist/static/node-video-bg.3df3f73a.svg +1 -0
  195. package/package.json +2 -4
  196. package/dist/assets/line-icons/icons/closed-eye.js +0 -23
  197. package/dist/assets/line-icons/icons/closed-eye.js.map +0 -1
  198. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js +0 -92
  199. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js.map +0 -1
  200. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js +0 -25
  201. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js.map +0 -1
  202. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js +0 -13
  203. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js.map +0 -1
  204. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js +0 -38
  205. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js.map +0 -1
  206. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js +0 -53
  207. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js.map +0 -1
  208. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js +0 -25
  209. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js.map +0 -1
  210. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +0 -71
  211. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +0 -1
  212. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +0 -31
  213. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +0 -1
  214. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +0 -38
  215. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +0 -1
  216. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +0 -79
  217. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +0 -1
  218. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +0 -18
  219. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +0 -1
  220. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +0 -51
  221. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +0 -1
  222. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +0 -11
  223. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +0 -1
  224. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +0 -135
  225. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +0 -1
  226. package/dist/library/polypad.js +0 -24965
  227. package/dist/library/polypad.js.map +0 -1
@@ -0,0 +1,105 @@
1
+ import { jsx as e, jsxs as m } from "react/jsx-runtime";
2
+ import E from "../../../assets/line-icons/icons/alarm.js";
3
+ import I from "../../../assets/line-icons/icons/bulb2.js";
4
+ import u from "../../../assets/line-icons/icons/check2.js";
5
+ import f from "../../../assets/line-icons/icons/dart.js";
6
+ import d from "../../../assets/line-icons/icons/exclamation.js";
7
+ import p from "../../../assets/line-icons/icons/lock2.js";
8
+ import l from "../../../assets/line-icons/icons/play2.js";
9
+ import T from "../../../assets/line-icons/icons/puzzle.js";
10
+ import R from "../../../assets/line-icons/icons/recap.js";
11
+ import A from "../../../assets/line-icons/icons/status.js";
12
+ import D from "../../../assets/line-icons/icons/testtube.js";
13
+ import h from "../../ui/layout/flex-view.js";
14
+ import s from "../../ui/text/text.js";
15
+ import { InProgressIconWrapper as S } from "../comps/node-card/node-card-styled.js";
16
+ import i from "../comps/tag/tag.js";
17
+ const g = 60 * 60 * 24, $ = ["NOT_STARTED", "IN_PROGRESS"], C = (r) => {
18
+ if (!r)
19
+ return { isOverdue: !1, daysText: "" };
20
+ const c = Math.floor(Date.now() / 1e3), n = r - c, o = Math.ceil(n / g), t = o < 0, a = o > 0 ? `${Math.abs(o)}D` : "";
21
+ return { isOverdue: t, daysText: a };
22
+ }, W = (r, c, n) => {
23
+ const { isOverdue: o, daysText: t } = C(n);
24
+ if (o && $.includes(r))
25
+ return {
26
+ icon: /* @__PURE__ */ e(h, { $background: "RED", $borderRadius: 16, $gapX: 0.24, $gutterX: 0.5, children: /* @__PURE__ */ e(s, { $renderAs: "ac4-black", $color: "WHITE", children: "OVERDUE" }) }),
27
+ top: -10,
28
+ right: -10
29
+ };
30
+ switch (r) {
31
+ case "LOCKED":
32
+ return {
33
+ icon: /* @__PURE__ */ e(p, { width: 32, height: 32 }),
34
+ top: -12,
35
+ right: -12
36
+ };
37
+ case "IN_PROGRESS":
38
+ return {
39
+ icon: /* @__PURE__ */ m(
40
+ S,
41
+ {
42
+ $flexDirection: "row",
43
+ $alignItems: "center",
44
+ $justifyContent: "center",
45
+ $gutterX: t ? 0.5 : 0,
46
+ $borderRadius: 16,
47
+ children: [
48
+ t && /* @__PURE__ */ e(s, { $renderAs: "ac4-black", $color: "WHITE", children: t }),
49
+ /* @__PURE__ */ e(A, {})
50
+ ]
51
+ }
52
+ )
53
+ };
54
+ case "COMPLETED":
55
+ return {
56
+ icon: /* @__PURE__ */ e(
57
+ i,
58
+ {
59
+ Icon: u,
60
+ label: typeof c == "number" ? `${c}%` : void 0
61
+ }
62
+ ),
63
+ top: -10,
64
+ right: -10
65
+ };
66
+ case "WAIT_FOR_REVIEW":
67
+ return {
68
+ icon: /* @__PURE__ */ e(i, { Icon: d }),
69
+ top: -10,
70
+ right: -10
71
+ };
72
+ default:
73
+ return {
74
+ icon: void 0
75
+ };
76
+ }
77
+ }, X = (r) => {
78
+ switch (r) {
79
+ case "LEARNING":
80
+ return I;
81
+ case "RECAP":
82
+ return R;
83
+ case "DYNAMIC":
84
+ case "ASSESSMENT":
85
+ return E;
86
+ case "PRACTICE":
87
+ case "EXTRA_PRACTICE":
88
+ case "TARGET_PRACTICE":
89
+ case "MASTERY":
90
+ return f;
91
+ case "PUZZLE_EASY":
92
+ case "PUZZLE_MEDIUM":
93
+ case "PUZZLE_HARD":
94
+ return T;
95
+ case "VIDEO":
96
+ return l;
97
+ default:
98
+ return D;
99
+ }
100
+ };
101
+ export {
102
+ X as getNodeCardBasedIcon,
103
+ W as getNodeStateBasedTagInfo
104
+ };
105
+ //# sourceMappingURL=node-card-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-card-utils.js","sources":["../../../../src/features/chapters-v2/utils/node-card-utils.tsx"],"sourcesContent":["import type { INodeDataProps } from '../comps/node-card/node-card-types';\n\nimport AlarmIcon from '../../../assets/line-icons/icons/alarm';\nimport Bulb2Icon from '../../../assets/line-icons/icons/bulb2';\nimport Check2Icon from '../../../assets/line-icons/icons/check2';\nimport DartIcon from '../../../assets/line-icons/icons/dart';\nimport ExclamationIcon from '../../../assets/line-icons/icons/exclamation';\nimport Lock2Icon from '../../../assets/line-icons/icons/lock2';\nimport Play2Icon from '../../../assets/line-icons/icons/play2';\nimport PuzzleIcon from '../../../assets/line-icons/icons/puzzle';\nimport RecapIcon from '../../../assets/line-icons/icons/recap';\nimport StatusIcon from '../../../assets/line-icons/icons/status';\nimport TestTubeIcon from '../../../assets/line-icons/icons/testtube';\nimport FlexView from '../..//ui/layout/flex-view';\nimport Text from '../../ui/text/text';\nimport { InProgressIconWrapper } from '../comps/node-card/node-card-styled';\nimport Tag from '../comps/tag/tag';\n\ninterface DueDateInfo {\n isOverdue: boolean;\n daysText: string;\n}\n\nconst SECONDS_PER_DAY = 60 * 60 * 24;\nconst OVERDUE_TAG_STATES: INodeDataProps['state'][] = ['NOT_STARTED', 'IN_PROGRESS'];\n\nconst calculateDueDateInfo = (dueDateTs?: number | null): DueDateInfo => {\n if (!dueDateTs) {\n return { isOverdue: false, daysText: '' };\n }\n\n const currentTimestamp = Math.floor(Date.now() / 1000);\n const differenceInSeconds = dueDateTs - currentTimestamp;\n const differenceInDays = Math.ceil(differenceInSeconds / SECONDS_PER_DAY);\n\n const isOverdue = differenceInDays < 0;\n\n const daysText = differenceInDays > 0 ? `${Math.abs(differenceInDays)}D` : '';\n\n return { isOverdue, daysText };\n};\n\nconst getNodeStateBasedTagInfo = (\n nodeState: INodeDataProps['state'],\n accuracy?: number | null,\n dueDateTs?: number | null,\n) => {\n const { isOverdue, daysText } = calculateDueDateInfo(dueDateTs);\n\n if (isOverdue && OVERDUE_TAG_STATES.includes(nodeState)) {\n return {\n icon: (\n <FlexView $background=\"RED\" $borderRadius={16} $gapX={0.24} $gutterX={0.5}>\n <Text $renderAs=\"ac4-black\" $color=\"WHITE\">\n OVERDUE\n </Text>\n </FlexView>\n ),\n top: -10,\n right: -10,\n };\n }\n\n switch (nodeState) {\n case 'LOCKED':\n return {\n icon: <Lock2Icon width={32} height={32} />,\n top: -12,\n right: -12,\n };\n case 'IN_PROGRESS':\n return {\n icon: (\n <InProgressIconWrapper\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $gutterX={daysText ? 0.5 : 0}\n $borderRadius={16}\n >\n {daysText && (\n <Text $renderAs=\"ac4-black\" $color=\"WHITE\">\n {daysText}\n </Text>\n )}\n <StatusIcon />\n </InProgressIconWrapper>\n ),\n };\n case 'COMPLETED':\n return {\n icon: (\n <Tag\n Icon={Check2Icon}\n label={typeof accuracy === 'number' ? `${accuracy}%` : undefined}\n />\n ),\n top: -10,\n right: -10,\n };\n case 'WAIT_FOR_REVIEW':\n return {\n icon: <Tag Icon={ExclamationIcon} />,\n top: -10,\n right: -10,\n };\n\n default:\n return {\n icon: undefined,\n };\n }\n};\n\nconst getNodeCardBasedIcon = (nodeType: INodeDataProps['node_type']) => {\n switch (nodeType) {\n case 'LEARNING':\n return Bulb2Icon;\n case 'RECAP':\n return RecapIcon;\n case 'DYNAMIC':\n case 'ASSESSMENT':\n return AlarmIcon;\n case 'PRACTICE':\n case 'EXTRA_PRACTICE':\n case 'TARGET_PRACTICE':\n case 'MASTERY':\n return DartIcon;\n case 'PUZZLE_EASY':\n case 'PUZZLE_MEDIUM':\n case 'PUZZLE_HARD':\n return PuzzleIcon;\n case 'VIDEO':\n return Play2Icon;\n\n default:\n return TestTubeIcon;\n }\n};\n\nexport { getNodeStateBasedTagInfo, getNodeCardBasedIcon };\n"],"names":["SECONDS_PER_DAY","OVERDUE_TAG_STATES","calculateDueDateInfo","dueDateTs","currentTimestamp","differenceInSeconds","differenceInDays","isOverdue","daysText","getNodeStateBasedTagInfo","nodeState","accuracy","jsx","FlexView","Text","Lock2Icon","jsxs","InProgressIconWrapper","StatusIcon","Tag","Check2Icon","ExclamationIcon","getNodeCardBasedIcon","nodeType","Bulb2Icon","RecapIcon","AlarmIcon","DartIcon","PuzzleIcon","Play2Icon","TestTubeIcon"],"mappings":";;;;;;;;;;;;;;;;AAuBA,MAAMA,IAAkB,KAAK,KAAK,IAC5BC,IAAgD,CAAC,eAAe,aAAa,GAE7EC,IAAuB,CAACC,MAA2C;AACvE,MAAI,CAACA;AACH,WAAO,EAAE,WAAW,IAAO,UAAU,GAAG;AAG1C,QAAMC,IAAmB,KAAK,MAAM,KAAK,IAAA,IAAQ,GAAI,GAC/CC,IAAsBF,IAAYC,GAClCE,IAAmB,KAAK,KAAKD,IAAsBL,CAAe,GAElEO,IAAYD,IAAmB,GAE/BE,IAAWF,IAAmB,IAAI,GAAG,KAAK,IAAIA,CAAgB,CAAC,MAAM;AAEpE,SAAA,EAAE,WAAAC,GAAW,UAAAC;AACtB,GAEMC,IAA2B,CAC/BC,GACAC,GACAR,MACG;AACH,QAAM,EAAE,WAAAI,GAAW,UAAAC,EAAS,IAAIN,EAAqBC,CAAS;AAE9D,MAAII,KAAaN,EAAmB,SAASS,CAAS;AAC7C,WAAA;AAAA,MACL,MACG,gBAAAE,EAAAC,GAAA,EAAS,aAAY,OAAM,eAAe,IAAI,OAAO,MAAM,UAAU,KACpE,4BAACC,GAAK,EAAA,WAAU,aAAY,QAAO,SAAQ,oBAE3C,CAAA,GACF;AAAA,MAEF,KAAK;AAAA,MACL,OAAO;AAAA,IAAA;AAIX,UAAQJ,GAAW;AAAA,IACjB,KAAK;AACI,aAAA;AAAA,QACL,MAAO,gBAAAE,EAAAG,GAAA,EAAU,OAAO,IAAI,QAAQ,IAAI;AAAA,QACxC,KAAK;AAAA,QACL,OAAO;AAAA,MAAA;AAAA,IAEX,KAAK;AACI,aAAA;AAAA,QACL,MACE,gBAAAC;AAAA,UAACC;AAAA,UAAA;AAAA,YACC,gBAAe;AAAA,YACf,aAAY;AAAA,YACZ,iBAAgB;AAAA,YAChB,UAAUT,IAAW,MAAM;AAAA,YAC3B,eAAe;AAAA,YAEd,UAAA;AAAA,cAAAA,uBACEM,GAAK,EAAA,WAAU,aAAY,QAAO,SAChC,UACHN,GAAA;AAAA,gCAEDU,GAAW,EAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QACd;AAAA,MAAA;AAAA,IAGN,KAAK;AACI,aAAA;AAAA,QACL,MACE,gBAAAN;AAAA,UAACO;AAAA,UAAA;AAAA,YACC,MAAMC;AAAA,YACN,OAAO,OAAOT,KAAa,WAAW,GAAGA,CAAQ,MAAM;AAAA,UAAA;AAAA,QACzD;AAAA,QAEF,KAAK;AAAA,QACL,OAAO;AAAA,MAAA;AAAA,IAEX,KAAK;AACI,aAAA;AAAA,QACL,MAAM,gBAAAC,EAACO,GAAI,EAAA,MAAME,EAAiB,CAAA;AAAA,QAClC,KAAK;AAAA,QACL,OAAO;AAAA,MAAA;AAAA,IAGX;AACS,aAAA;AAAA,QACL,MAAM;AAAA,MAAA;AAAA,EAEZ;AACF,GAEMC,IAAuB,CAACC,MAA0C;AACtE,UAAQA,GAAU;AAAA,IAChB,KAAK;AACI,aAAAC;AAAA,IACT,KAAK;AACI,aAAAC;AAAA,IACT,KAAK;AAAA,IACL,KAAK;AACI,aAAAC;AAAA,IACT,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACI,aAAAC;AAAA,IACT,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACI,aAAAC;AAAA,IACT,KAAK;AACI,aAAAC;AAAA,IAET;AACS,aAAAC;AAAA,EACX;AACF;"}
@@ -1,11 +1,10 @@
1
1
  import { jsx as d } from "react/jsx-runtime";
2
- import "../../library/polypad.js";
3
- import { memo as p, useMemo as i, useState as o } from "react";
4
- import f from "./cue-canvas-context.js";
2
+ import { memo as f, useMemo as n, useState as o } from "react";
3
+ import p from "./cue-canvas-context.js";
5
4
  import { getColorsForUser as x } from "./cue-canvas-helpers.js";
6
- const A = p(
7
- ({ children: n, userType: t }) => {
8
- const a = i(() => x(t), [t]), [e, v] = o(), [r, m] = o("pen"), [s, l] = o(), [c, C] = o(a[0]), u = i(
5
+ const A = f(
6
+ ({ children: a, userType: t }) => {
7
+ const i = n(() => x(t), [t]), [e, v] = o(), [r, m] = o("pen"), [s, l] = o(), [c, C] = o(i[0]), u = n(
9
8
  () => ({
10
9
  activeInstance: e,
11
10
  setActiveInstance: v,
@@ -18,10 +17,10 @@ const A = p(
18
17
  }),
19
18
  [c, e, s, r]
20
19
  );
21
- return /* @__PURE__ */ d(f.Provider, { value: u, children: n });
20
+ return /* @__PURE__ */ d(p.Provider, { value: u, children: a });
22
21
  }
23
- ), j = A;
22
+ ), g = A;
24
23
  export {
25
- j as default
24
+ g as default
26
25
  };
27
26
  //# sourceMappingURL=cue-canvas-provider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cue-canvas-provider.js","sources":["../../../src/features/cue-canvas/cue-canvas-provider.tsx"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type { CueCanvasCore } from './cue-canvas-core';\nimport type { TCueCanvasColors, TCueCanvasSidebar, TCueCanvasTool } from './types/cue-canvas';\nimport '../../library/polypad';\nimport type { FC, PropsWithChildren } from 'react';\n\nimport { useState, memo, useMemo } from 'react';\n\nimport CueCanvasContext from './cue-canvas-context';\nimport { getColorsForUser } from './cue-canvas-helpers';\n\nconst CueCanvasProvider: FC<PropsWithChildren<{ userType: TUserTypes }>> = memo(\n ({ children, userType }) => {\n const colors = useMemo(() => getColorsForUser(userType), [userType]);\n\n const [activeInstance, setActiveInstance] = useState<CueCanvasCore>();\n const [activeTool, setActiveTool] = useState<TCueCanvasTool>('pen');\n const [activeSidebar, setActiveSidebar] = useState<TCueCanvasSidebar>();\n const [activeColor, setActiveColor] = useState<TCueCanvasColors>(colors[0] as TCueCanvasColors);\n const contextValue = useMemo(\n () => ({\n activeInstance: activeInstance,\n setActiveInstance: setActiveInstance,\n activeTool: activeTool,\n setActiveTool: setActiveTool,\n activeColor,\n setActiveColor,\n activeSidebar,\n setActiveSidebar,\n }),\n [activeColor, activeInstance, activeSidebar, activeTool],\n );\n\n return <CueCanvasContext.Provider value={contextValue}>{children}</CueCanvasContext.Provider>;\n },\n);\n\nexport default CueCanvasProvider;\n"],"names":["CueCanvasProvider","memo","children","userType","colors","useMemo","getColorsForUser","activeInstance","setActiveInstance","useState","activeTool","setActiveTool","activeSidebar","setActiveSidebar","activeColor","setActiveColor","contextValue","CueCanvasContext","CueCanvasProvider$1"],"mappings":";;;;;AAWA,MAAMA,IAAqEC;AAAA,EACzE,CAAC,EAAE,UAAAC,GAAU,UAAAC,QAAe;AACpB,UAAAC,IAASC,EAAQ,MAAMC,EAAiBH,CAAQ,GAAG,CAACA,CAAQ,CAAC,GAE7D,CAACI,GAAgBC,CAAiB,IAAIC,EAAwB,GAC9D,CAACC,GAAYC,CAAa,IAAIF,EAAyB,KAAK,GAC5D,CAACG,GAAeC,CAAgB,IAAIJ,EAA4B,GAChE,CAACK,GAAaC,CAAc,IAAIN,EAA2BL,EAAO,CAAC,CAAqB,GACxFY,IAAeX;AAAA,MACnB,OAAO;AAAA,QACL,gBAAAE;AAAA,QACA,mBAAAC;AAAA,QACA,YAAAE;AAAA,QACA,eAAAC;AAAA,QACA,aAAAG;AAAA,QACA,gBAAAC;AAAA,QACA,eAAAH;AAAA,QACA,kBAAAC;AAAA,MAAA;AAAA,MAEF,CAACC,GAAaP,GAAgBK,GAAeF,CAAU;AAAA,IAAA;AAGzD,6BAAQO,EAAiB,UAAjB,EAA0B,OAAOD,GAAe,UAAAd,EAAS,CAAA;AAAA,EACnE;AACF,GAEAgB,IAAelB;"}
1
+ {"version":3,"file":"cue-canvas-provider.js","sources":["../../../src/features/cue-canvas/cue-canvas-provider.tsx"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type { CueCanvasCore } from './cue-canvas-core';\nimport type { TCueCanvasColors, TCueCanvasSidebar, TCueCanvasTool } from './types/cue-canvas';\nimport '../../library/polypad';\nimport type { FC, PropsWithChildren } from 'react';\n\nimport { useState, memo, useMemo } from 'react';\n\nimport CueCanvasContext from './cue-canvas-context';\nimport { getColorsForUser } from './cue-canvas-helpers';\n\nconst CueCanvasProvider: FC<PropsWithChildren<{ userType: TUserTypes }>> = memo(\n ({ children, userType }) => {\n const colors = useMemo(() => getColorsForUser(userType), [userType]);\n\n const [activeInstance, setActiveInstance] = useState<CueCanvasCore>();\n const [activeTool, setActiveTool] = useState<TCueCanvasTool>('pen');\n const [activeSidebar, setActiveSidebar] = useState<TCueCanvasSidebar>();\n const [activeColor, setActiveColor] = useState<TCueCanvasColors>(colors[0] as TCueCanvasColors);\n const contextValue = useMemo(\n () => ({\n activeInstance: activeInstance,\n setActiveInstance: setActiveInstance,\n activeTool: activeTool,\n setActiveTool: setActiveTool,\n activeColor,\n setActiveColor,\n activeSidebar,\n setActiveSidebar,\n }),\n [activeColor, activeInstance, activeSidebar, activeTool],\n );\n\n return <CueCanvasContext.Provider value={contextValue}>{children}</CueCanvasContext.Provider>;\n },\n);\n\nexport default CueCanvasProvider;\n"],"names":["CueCanvasProvider","memo","children","userType","colors","useMemo","getColorsForUser","activeInstance","setActiveInstance","useState","activeTool","setActiveTool","activeSidebar","setActiveSidebar","activeColor","setActiveColor","contextValue","CueCanvasContext","CueCanvasProvider$1"],"mappings":";;;;AAWA,MAAMA,IAAqEC;AAAA,EACzE,CAAC,EAAE,UAAAC,GAAU,UAAAC,QAAe;AACpB,UAAAC,IAASC,EAAQ,MAAMC,EAAiBH,CAAQ,GAAG,CAACA,CAAQ,CAAC,GAE7D,CAACI,GAAgBC,CAAiB,IAAIC,EAAwB,GAC9D,CAACC,GAAYC,CAAa,IAAIF,EAAyB,KAAK,GAC5D,CAACG,GAAeC,CAAgB,IAAIJ,EAA4B,GAChE,CAACK,GAAaC,CAAc,IAAIN,EAA2BL,EAAO,CAAC,CAAqB,GACxFY,IAAeX;AAAA,MACnB,OAAO;AAAA,QACL,gBAAAE;AAAA,QACA,mBAAAC;AAAA,QACA,YAAAE;AAAA,QACA,eAAAC;AAAA,QACA,aAAAG;AAAA,QACA,gBAAAC;AAAA,QACA,eAAAH;AAAA,QACA,kBAAAC;AAAA,MAAA;AAAA,MAEF,CAACC,GAAaP,GAAgBK,GAAeF,CAAU;AAAA,IAAA;AAGzD,6BAAQO,EAAiB,UAAjB,EAA0B,OAAOD,GAAe,UAAAd,EAAS,CAAA;AAAA,EACnE;AACF,GAEAgB,IAAelB;"}
@@ -0,0 +1,23 @@
1
+ import { jsx as r, jsxs as a } from "react/jsx-runtime";
2
+ import { memo as p } from "react";
3
+ import c from "../ui/buttons/clickable/clickable.js";
4
+ import { CardOptions as m, CardOptionWrapper as u, OptionText as d } from "./styles.js";
5
+ const g = p(({ options: n }) => n.length === 0 ? null : /* @__PURE__ */ r(m, { $background: "BLACK_2", $borderColor: "WHITE_T_38", $gapX: 0.5, children: n.map(({ icon: o, label: t, id: e, onClick: l, visible: i }) => i ? /* @__PURE__ */ r(c, { onClick: () => l(e), label: e, children: /* @__PURE__ */ a(
6
+ u,
7
+ {
8
+ $flexDirection: "row",
9
+ $alignItems: "center",
10
+ $flexGap: 8,
11
+ $gapX: 0.5,
12
+ $gutterX: 1,
13
+ children: [
14
+ /* @__PURE__ */ r(o, { width: 20, height: 20 }),
15
+ /* @__PURE__ */ r(d, { $renderAs: "ub3", $color: "WHITE", children: t })
16
+ ]
17
+ },
18
+ e
19
+ ) }) : null) }));
20
+ export {
21
+ g as default
22
+ };
23
+ //# sourceMappingURL=card-menu-options.js.map
@@ -0,0 +1 @@
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 Clickable from '../ui/buttons/clickable/clickable';\nimport * as Styled from './styles';\n\ninterface ICardMenuOption {\n id: string;\n label: string;\n icon: FC<SVGProps<SVGSVGElement>>;\n onClick: (id: string) => void;\n visible: boolean;\n}\n\ninterface 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 <Clickable onClick={() => onClick(id)} label={id}>\n <Styled.CardOptionWrapper\n key={id}\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $flexGap={8}\n $gapX={0.5}\n $gutterX={1}\n >\n <OptionIcon width={20} height={20} />\n <Styled.OptionText $renderAs=\"ub3\" $color=\"WHITE\">\n {label}\n </Styled.OptionText>\n </Styled.CardOptionWrapper>\n </Clickable>\n );\n })}\n </Styled.CardOptions>\n );\n});\n\nexport default CardMenuOptions;\n"],"names":["CardMenuOptions","memo","options","jsx","Styled.CardOptions","OptionIcon","label","id","onClick","visible","Clickable","jsxs","Styled.CardOptionWrapper","Styled.OptionText"],"mappings":";;;;AAmBA,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,gBAAAN,EAACO,KAAU,SAAS,MAAMF,EAAQD,CAAE,GAAG,OAAOA,GAC5C,UAAA,gBAAAI;AAAA,EAACC;AAAAA,EAAA;AAAA,IAEC,gBAAe;AAAA,IACf,aAAY;AAAA,IACZ,UAAU;AAAA,IACV,OAAO;AAAA,IACP,UAAU;AAAA,IAEV,UAAA;AAAA,MAAA,gBAAAT,EAACE,GAAW,EAAA,OAAO,IAAI,QAAQ,IAAI;AAAA,MACnC,gBAAAF,EAACU,GAAA,EAAkB,WAAU,OAAM,QAAO,SACvC,UACHP,GAAA;AAAA,IAAA;AAAA,EAAA;AAAA,EAVKC;AAYT,EAAA,CAAA,IAjBmB,IAmBtB,EACH,CAAA,CAEH;"}
@@ -0,0 +1,209 @@
1
+ import { jsx as e, jsxs as o } from "react/jsx-runtime";
2
+ import { memo as P, useRef as x, useState as q, useLayoutEffect as J, useCallback as f } from "react";
3
+ import Q from "../../assets/line-icons/icons/eye2.js";
4
+ import Y from "../../assets/line-icons/icons/more-vertical.js";
5
+ import Z from "../../assets/line-icons/icons/redo.js";
6
+ import U 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 s 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 oe, IconWrapper as ce, BannerImageWrapper as ae, BannerImage as le, HeaderText as se, SubHeaderText as ue, CardKebabMenuWrapper as me, CardMenuOptionsWrapper as he, StyledMinus2Icon as pe } from "./styles.js";
16
+ const fe = ({
17
+ header: d,
18
+ nodeData: r,
19
+ subHeader: I,
20
+ userType: H,
21
+ userMilestoneId: t,
22
+ onNodeUnassign: c,
23
+ onNodeReset: a,
24
+ onNodeView: u,
25
+ onNodeReview: i,
26
+ onNodeAttempt: m
27
+ }) => {
28
+ const {
29
+ node_type: h,
30
+ state: X,
31
+ accuracy: S,
32
+ due_date_ts: W,
33
+ image_url: w,
34
+ image_hue: A,
35
+ card_header: B = "",
36
+ permissions: O,
37
+ user_node_id: l
38
+ } = r, R = D(h), $ = N(h), b = x(null), n = x(null), { menuVisible: j, onMenuClick: V } = re(b), [G, K] = q(!1), {
39
+ can_start: g,
40
+ can_resume: C,
41
+ can_review: T,
42
+ can_teacher_review: _,
43
+ can_unassign: L,
44
+ can_reset: z
45
+ } = O, k = H === "STUDENT";
46
+ J(() => {
47
+ n.current && n.current.scrollHeight > n.current.clientHeight && K(!0);
48
+ }, [n]);
49
+ const F = f(() => {
50
+ if (g || C) {
51
+ if (typeof m != "function")
52
+ throw new Error("onNodeAttempt must be a function");
53
+ m(r);
54
+ return;
55
+ }
56
+ if (T) {
57
+ if (typeof i != "function")
58
+ throw new Error("onReview must be a function");
59
+ if (!l)
60
+ throw new Error("user node id must be present to review the sheet");
61
+ i(r, t);
62
+ return;
63
+ }
64
+ }, [
65
+ C,
66
+ T,
67
+ g,
68
+ t,
69
+ r,
70
+ m,
71
+ i,
72
+ l
73
+ ]), v = f(() => {
74
+ if (_) {
75
+ if (typeof i != "function")
76
+ throw new Error("onReview must be a function");
77
+ if (!l)
78
+ throw new Error("user node id must be present to review the sheet");
79
+ i(r, t);
80
+ return;
81
+ }
82
+ if (typeof u != "function")
83
+ throw new Error("onPreview must be a function");
84
+ u(r, t);
85
+ }, [_, t, r, i, u, l]), p = f(
86
+ (y) => {
87
+ switch (y) {
88
+ case "card-view":
89
+ v();
90
+ return;
91
+ case "card-unassign":
92
+ c == null || c(r, t);
93
+ return;
94
+ case "card-reset":
95
+ a == null || a(r, t);
96
+ return;
97
+ default:
98
+ throw new Error(`No callback function for ${y}`);
99
+ }
100
+ },
101
+ [r, a, c, v, t]
102
+ ), M = [
103
+ {
104
+ id: "card-view",
105
+ label: "View",
106
+ icon: Q,
107
+ visible: !0,
108
+ onClick: p
109
+ },
110
+ {
111
+ id: "card-unassign",
112
+ label: "Unassign",
113
+ icon: pe,
114
+ visible: !!L,
115
+ onClick: p
116
+ },
117
+ {
118
+ id: "card-reset",
119
+ label: "Reset",
120
+ icon: Z,
121
+ visible: !!z,
122
+ onClick: p
123
+ }
124
+ ];
125
+ return /* @__PURE__ */ e(ee, { onClick: k ? F : void 0, label: "homework-card", children: /* @__PURE__ */ o(
126
+ ne,
127
+ {
128
+ $widthX: 12.5,
129
+ $position: "relative",
130
+ $background: `${A || "ORANGE"}_2`,
131
+ children: [
132
+ /* @__PURE__ */ o(
133
+ oe,
134
+ {
135
+ $flexDirection: "row",
136
+ $alignItems: "center",
137
+ $width: "100%",
138
+ $heightX: 3.5,
139
+ $bgImage: R,
140
+ $gutterX: 0.78125,
141
+ $flexGap: 8.5,
142
+ $position: "relative",
143
+ children: [
144
+ /* @__PURE__ */ e(
145
+ ce,
146
+ {
147
+ $width: 31,
148
+ $height: 31,
149
+ $borderRadiusX: 2,
150
+ $background: "WHITE_1",
151
+ $position: "relative",
152
+ $alignItems: "center",
153
+ $justifyContent: "center",
154
+ children: $ && /* @__PURE__ */ e($, { width: 20, height: 20 })
155
+ }
156
+ ),
157
+ /* @__PURE__ */ e(te, { $renderAs: "ac4-black", children: B }),
158
+ !!w && /* @__PURE__ */ e(ae, { children: /* @__PURE__ */ e(le, { src: w, alt: "Chapter image" }) })
159
+ ]
160
+ }
161
+ ),
162
+ /* @__PURE__ */ e(U, { nodeType: h, state: X, accuracy: S, dueDateTs: W }),
163
+ /* @__PURE__ */ o(s, { $gutterX: 0.75, $gapX: 1, $flexRowGapX: 0.5, $background: "WHITE", children: [
164
+ /* @__PURE__ */ e(
165
+ E,
166
+ {
167
+ renderAs: "primary",
168
+ position: "bottom",
169
+ tooltipItem: d,
170
+ hidden: !G,
171
+ widthX: 21.75,
172
+ children: /* @__PURE__ */ e(s, { $heightX: 2.5, children: /* @__PURE__ */ e(se, { ref: n, $renderAs: "ab3", children: d }) })
173
+ }
174
+ ),
175
+ /* @__PURE__ */ o(
176
+ s,
177
+ {
178
+ $flexDirection: "row",
179
+ $heightX: 1.25,
180
+ $alignItems: "center",
181
+ $justifyContent: "space-between",
182
+ children: [
183
+ /* @__PURE__ */ e(ue, { $renderAs: "ub3", $color: "BLACK_T_60", children: I }),
184
+ !k && /* @__PURE__ */ o(s, { $position: "relative", $width: "fit-content", children: [
185
+ /* @__PURE__ */ e(
186
+ E,
187
+ {
188
+ renderAs: "primary",
189
+ tooltipItem: "Review",
190
+ position: "bottom",
191
+ zIndex: 5,
192
+ parentWidth: "100%",
193
+ children: /* @__PURE__ */ e(me, { ref: b, onClick: V, children: /* @__PURE__ */ e(Y, { width: 16, height: 16 }) })
194
+ }
195
+ ),
196
+ /* @__PURE__ */ e(he, { $visible: j, children: /* @__PURE__ */ e(ie, { options: M }) })
197
+ ] })
198
+ ]
199
+ }
200
+ )
201
+ ] })
202
+ ]
203
+ }
204
+ ) });
205
+ }, Xe = P(fe);
206
+ export {
207
+ Xe as default
208
+ };
209
+ //# sourceMappingURL=homework-card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"homework-card.js","sources":["../../../src/features/homework/homework-card.tsx"],"sourcesContent":["import type {\n INodeCardCallbacks,\n INodeDataProps,\n} from '../chapters-v2/comps/node-card/node-card-types';\n\nimport { memo, useCallback, useLayoutEffect, useRef, useState } from 'react';\n\nimport Eye2Icon from '../../assets/line-icons/icons/eye2';\nimport MoreVerticalIcon from '../../assets/line-icons/icons/more-vertical';\nimport RedoIcon from '../../assets/line-icons/icons/redo';\nimport NodeCardTags from '../chapters-v2/comps/node-card/node-card-tags';\nimport { getNodeTypeBasedBgImage } from '../chapters-v2/utils';\nimport { getNodeCardBasedIcon } from '../chapters-v2/utils/node-card-utils';\nimport ArrowTooltip from '../ui/arrow-tooltip/arrow-tooltip';\nimport Clickable from '../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\nimport CardMenuOptions from './card-menu-options';\nimport * as Styled from './styles';\n\ninterface IHomeworkCardProps extends INodeCardCallbacks {\n header: string;\n nodeData: INodeDataProps;\n subHeader: string;\n userType: '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 = getNodeTypeBasedBgImage(nodeType);\n const NodeCardIcon = getNodeCardBasedIcon(nodeType);\n const containerRef = useRef<HTMLDivElement>(null);\n const titleTextRef = useRef<HTMLDivElement>(null);\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(containerRef);\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 canResume,\n canReview,\n canStart,\n userMilestoneId,\n nodeData,\n onNodeAttempt,\n onNodeReview,\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 = useCallback(\n (optionId: string) => {\n switch (optionId) {\n case 'card-view':\n onTeacherView();\n\n return;\n case 'card-unassign':\n onNodeUnassign?.(nodeData, userMilestoneId);\n\n return;\n case 'card-reset':\n onNodeReset?.(nodeData, userMilestoneId);\n\n return;\n\n default:\n throw new Error(`No callback function for ${optionId}`);\n }\n },\n [nodeData, onNodeReset, onNodeUnassign, onTeacherView, userMilestoneId],\n );\n\n const menuOptions = [\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 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 && (\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 memo(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","titleTextRef","menuVisible","onMenuClick","useContextMenuClickHandler","showTitleTooltip","setShowTitleTooltip","useState","canStart","canResume","canReview","canTeacherReview","canUnassign","canReset","isStudent","useLayoutEffect","onStudentView","useCallback","onTeacherView","handleOnMenuOptionClick","optionId","menuOptions","Eye2Icon","Styled.StyledMinus2Icon","RedoIcon","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","HomeworkCard$1","memo"],"mappings":"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"}
@@ -0,0 +1,114 @@
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sources":["../../../src/features/homework/styles.ts"],"sourcesContent":["import styled from 'styled-components';\n\nimport Minus2Icon from '../../assets/line-icons/icons/minus2';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\n\ninterface ICardWrapperProps {\n $bgImage: string;\n}\ninterface ICardOptionsMenuWrapperProps {\n $visible: boolean;\n}\n\nexport const CardKebabMenuWrapper = styled(FlexView)(({ theme }) => {\n return `\n cursor: pointer;\n width: fit-content;\n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const SubHeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const CardMenuOptionsWrapper = styled(FlexView)<ICardOptionsMenuWrapperProps>(({\n theme,\n $visible,\n}) => {\n return `\n cursor: pointer;\n position: absolute;\n z-index: 6;\n top: calc(100% + 4px);\n left: 0;\n transform-origin: top;\n transform: scaleY(${$visible ? 1 : 0});\n opacity: ${$visible ? 1 : 0};\n transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;\n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const CardContainer = styled(FlexView)`\n border: 1px solid ${({ theme }) => theme.colors.BLACK_T_15};\n\n &:hover {\n border: 1px solid ${({ theme }) => theme.colors.BLACK};\n }\n`;\n\nexport const CardWrapper = styled(FlexView)<ICardWrapperProps>(({ $bgImage }) => {\n if ($bgImage) {\n return `\n background-image: url(${$bgImage});\n background-repeat: no-repeat;\n background-size: cover;\n background-position: center;\n overflow: hidden;\n `;\n }\n\n return 'overflow: hidden;';\n});\n\nexport const IconWrapper = styled(FlexView)`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const BannerImageWrapper = styled(FlexView)`\n position: absolute;\n right: -18px;\n top: -4px;\n`;\n\nexport const BannerImage = styled.img(({ theme }) => {\n const { gutter } = theme.layout;\n\n return `\n border: 1px solid ${theme.colors.BLACK_T_15};\n width: ${gutter * 4}px;\n height: ${gutter * 4}px;\n border-radius: 50%;\n `;\n});\n\nexport const StyledMinus2Icon = styled(Minus2Icon)`\n path {\n stroke: ${({ theme }) => theme.colors.WHITE};\n }\n`;\n\nexport const HeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport interface ICardOptionWrapperProps {\n $disabled?: boolean;\n}\n\nexport const CardOptions = styled(FlexView)`\n box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);\n width: 180px;\n position: relative;\n left: 0;\n top: 0;\n`;\n\nexport const CardOptionWrapper = styled(FlexView)<ICardOptionWrapperProps>(({\n theme,\n $disabled,\n}) => {\n return `\n cursor: ${$disabled ? 'not-allowed' : 'pointer'};\n \n &:hover {\n background: ${$disabled ? 'transparent' : theme.colors.BLACK};\n };\n \n path {\n fill: ${theme.colors.WHITE_1};\n }\n `;\n});\n\nexport const OptionText = styled(Text)`\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n"],"names":["CardKebabMenuWrapper","styled","FlexView","theme","SubHeaderText","Text","CardMenuOptionsWrapper","$visible","CardContainer","CardWrapper","$bgImage","IconWrapper","BannerImageWrapper","BannerImage","gutter","StyledMinus2Icon","Minus2Icon","HeaderText","CardOptions","CardOptionWrapper","$disabled","OptionText"],"mappings":";;;;AAaO,MAAMA,IAAuBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAMWA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYC,IAAgBH,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ3BC,IAAyBL,EAAOC,CAAQ,EAAgC,CAAC;AAAA,EACpF,OAAAC;AAAA,EACA,UAAAI;AACF,MACS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAOeA,IAAW,IAAI,CAAC;AAAA,eACzBA,IAAW,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,oBAKXJ,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYK,IAAgBP,EAAOC,CAAQ;AAAA,sBACtB,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,UAAU;AAAA;AAAA;AAAA,wBAGpC,CAAC,EAAE,OAAAA,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAI5CM,IAAcR,EAAOC,CAAQ,EAAqB,CAAC,EAAE,UAAAQ,QAC5DA,IACK;AAAA,8BACmBA,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,QAQ7B,mBACR,GAEYC,IAAcV,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAM7BU,IAAqBX,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAMpCW,IAAcZ,EAAO,IAAI,CAAC,EAAE,OAAAE,QAAY;AAC7C,QAAA,EAAE,QAAAW,EAAO,IAAIX,EAAM;AAElB,SAAA;AAAA,wBACeA,EAAM,OAAO,UAAU;AAAA,aAClCW,IAAS,CAAC;AAAA,cACTA,IAAS,CAAC;AAAA;AAAA;AAGxB,CAAC,GAEYC,IAAmBd,EAAOe,CAAU;AAAA;AAAA,cAEnC,CAAC,EAAE,OAAAb,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAIlCc,IAAahB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAYxBa,IAAcjB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ7BiB,IAAoBlB,EAAOC,CAAQ,EAA2B,CAAC;AAAA,EAC1E,OAAAC;AAAA,EACA,WAAAiB;AACF,MACS;AAAA,cACKA,IAAY,gBAAgB,SAAS;AAAA;AAAA;AAAA,oBAG/BA,IAAY,gBAAgBjB,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,cAIpDA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGjC,GAEYkB,IAAapB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;"}
@@ -1,5 +1,5 @@
1
1
  import { createPostAPI as t } from "@cuemath/rest-api";
2
- import { BASE_URL_V3_1 as e } from "../../../../constants/api.js";
2
+ import { BASE_URL_V3_2 as e } from "../../../../constants/api.js";
3
3
  const { usePost: i } = t({
4
4
  getURL: (s, { studentId: o }) => `${e}/users/${o}/milestones/`
5
5
  });
@@ -1 +1 @@
1
- {"version":3,"file":"goal-submit.js","sources":["../../../../../src/features/milestone/create/api/goal-submit.ts"],"sourcesContent":["import type { TMilestonePayload } from '../milestone-create-types';\n\nimport { createPostAPI } from '@cuemath/rest-api';\n\nimport { BASE_URL_V3_1 } from '../../../../constants/api';\n\nconst { usePost: useGoalCreationPost } = createPostAPI<\n { id: string },\n TMilestonePayload,\n { studentId: string }\n>({\n getURL: (_, { studentId }) => `${BASE_URL_V3_1}/users/${studentId}/milestones/`,\n});\n\nexport { useGoalCreationPost };\n"],"names":["useGoalCreationPost","createPostAPI","_","studentId","BASE_URL_V3_1"],"mappings":";;AAMA,MAAM,EAAE,SAASA,EAAoB,IAAIC,EAIvC;AAAA,EACA,QAAQ,CAACC,GAAG,EAAE,WAAAC,EAAgB,MAAA,GAAGC,CAAa,UAAUD,CAAS;AACnE,CAAC;"}
1
+ {"version":3,"file":"goal-submit.js","sources":["../../../../../src/features/milestone/create/api/goal-submit.ts"],"sourcesContent":["import type { TMilestonePayload } from '../milestone-create-types';\n\nimport { createPostAPI } from '@cuemath/rest-api';\n\nimport { BASE_URL_V3_2 } from '../../../../constants/api';\n\nconst { usePost: useGoalCreationPost } = createPostAPI<\n { id: string },\n TMilestonePayload,\n { studentId: string }\n>({\n getURL: (_, { studentId }) => `${BASE_URL_V3_2}/users/${studentId}/milestones/`,\n});\n\nexport { useGoalCreationPost };\n"],"names":["useGoalCreationPost","createPostAPI","_","studentId","BASE_URL_V3_2"],"mappings":";;AAMA,MAAM,EAAE,SAASA,EAAoB,IAAIC,EAIvC;AAAA,EACA,QAAQ,CAACC,GAAG,EAAE,WAAAC,EAAgB,MAAA,GAAGC,CAAa,UAAUD,CAAS;AACnE,CAAC;"}
@@ -1,9 +1,17 @@
1
1
  import r from "styled-components";
2
- import p from "../../../../ui/layout/flex-view.js";
3
- const e = r(p)(({ theme: o }) => `
4
- box-shadow: 0px 10px 20px 0px ${o.colors.BLACK_T_20};
2
+ import o from "../../../../ui/layout/flex-view.js";
3
+ const x = r(o)(({ theme: t }) => `
4
+ box-shadow: 0px 10px 20px 0px ${t.colors.BLACK_T_20};
5
+ `), n = r(o)(() => `
6
+ margin-left: auto;
7
+
8
+ svg {
9
+ width: 24px;
10
+ height: 24px;
11
+ }
5
12
  `);
6
13
  export {
7
- e as ButtonWrapper
14
+ n as BinIconWrapper,
15
+ x as ButtonWrapper
8
16
  };
9
17
  //# sourceMappingURL=chapters-selection-step-styled.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"chapters-selection-step-styled.js","sources":["../../../../../../src/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../../../ui/layout/flex-view';\n\nconst ButtonWrapper = styled(FlexView)(({ theme }) => {\n return `\n box-shadow: 0px 10px 20px 0px ${theme.colors.BLACK_T_20};\n `;\n});\n\nexport { ButtonWrapper };\n"],"names":["ButtonWrapper","styled","FlexView","theme"],"mappings":";;AAIA,MAAMA,IAAgBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QACjC;AAAA,oCAC2BA,EAAM,OAAO,UAAU;AAAA,GAE1D;"}
1
+ {"version":3,"file":"chapters-selection-step-styled.js","sources":["../../../../../../src/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../../../ui/layout/flex-view';\n\nconst ButtonWrapper = styled(FlexView)(({ theme }) => {\n return `\n box-shadow: 0px 10px 20px 0px ${theme.colors.BLACK_T_20};\n `;\n});\n\nconst BinIconWrapper = styled(FlexView)(() => {\n return `\n margin-left: auto;\n \n svg {\n width: 24px;\n height: 24px;\n }\n `;\n});\n\nexport { ButtonWrapper, BinIconWrapper };\n"],"names":["ButtonWrapper","styled","FlexView","theme","BinIconWrapper"],"mappings":";;AAIA,MAAMA,IAAgBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QACjC;AAAA,oCAC2BA,EAAM,OAAO,UAAU;AAAA,GAE1D,GAEKC,IAAiBH,EAAOC,CAAQ,EAAE,MAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQR;"}