@cuemath/leap 2.9.2-as1 → 2.9.2-gg1

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 (253) hide show
  1. package/dist/assets/illustrations/illustrations.js +0 -9
  2. package/dist/assets/illustrations/illustrations.js.map +1 -1
  3. package/dist/assets/line-icons/icons/bin2.js +8 -7
  4. package/dist/assets/line-icons/icons/bin2.js.map +1 -1
  5. package/dist/assets/line-icons/icons/chevron-left.js.map +1 -1
  6. package/dist/assets/line-icons/icons/chevron-right.js.map +1 -1
  7. package/dist/assets/lottie/lottie.js +1 -9
  8. package/dist/assets/lottie/lottie.js.map +1 -1
  9. package/dist/constants/api.js +2 -3
  10. package/dist/constants/api.js.map +1 -1
  11. package/dist/features/av/av-preview/av-preview.js +54 -0
  12. package/dist/features/av/av-preview/av-preview.js.map +1 -0
  13. package/dist/features/av/av-preview/use-media-devices.js +81 -0
  14. package/dist/features/av/av-preview/use-media-devices.js.map +1 -0
  15. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +33 -99
  16. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
  17. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +49 -92
  18. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  19. package/dist/features/chapters/chapters-list/chapters-list-styled.js +5 -5
  20. package/dist/features/chapters/chapters-list/chapters-list-styled.js.map +1 -1
  21. package/dist/features/chapters/chapters-list/chapters-list.js +70 -64
  22. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  23. package/dist/features/communication/pub-sub/constants.js +2 -5
  24. package/dist/features/communication/pub-sub/constants.js.map +1 -1
  25. package/dist/features/hooks/use-cancellable-promise.js +22 -0
  26. package/dist/features/hooks/use-cancellable-promise.js.map +1 -0
  27. package/dist/features/milestone/create/api/goal-submit.js +1 -1
  28. package/dist/features/milestone/create/api/goal-submit.js.map +1 -1
  29. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js +49 -42
  30. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js.map +1 -1
  31. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js +4 -12
  32. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js.map +1 -1
  33. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js +105 -128
  34. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js.map +1 -1
  35. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js +92 -0
  36. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js.map +1 -0
  37. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js +25 -0
  38. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js.map +1 -0
  39. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js +20 -14
  40. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js.map +1 -1
  41. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js +50 -26
  42. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js.map +1 -1
  43. package/dist/features/milestone/create/milestone-create.js +43 -49
  44. package/dist/features/milestone/create/milestone-create.js.map +1 -1
  45. package/dist/features/milestone/create/utils/index.js +38 -33
  46. package/dist/features/milestone/create/utils/index.js.map +1 -1
  47. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js +1 -1
  48. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js.map +1 -1
  49. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js +1 -1
  50. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js.map +1 -1
  51. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js +53 -51
  52. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js.map +1 -1
  53. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js +40 -42
  54. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js.map +1 -1
  55. package/dist/features/milestone/edit/goal-edit-container.js +62 -64
  56. package/dist/features/milestone/edit/goal-edit-container.js.map +1 -1
  57. package/dist/features/milestone/edit/goal-edit-helpers.js +53 -50
  58. package/dist/features/milestone/edit/goal-edit-helpers.js.map +1 -1
  59. package/dist/features/milestone/edit/milestone-edit-container.js +52 -54
  60. package/dist/features/milestone/edit/milestone-edit-container.js.map +1 -1
  61. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js +1 -1
  62. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
  63. package/dist/features/milestone/milestone-list-container/api/get-milestones.js +17 -9
  64. package/dist/features/milestone/milestone-list-container/api/get-milestones.js.map +1 -1
  65. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js +1 -1
  66. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
  67. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +104 -136
  68. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  69. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js +13 -0
  70. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js.map +1 -0
  71. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js +38 -0
  72. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js.map +1 -0
  73. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +123 -107
  74. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  75. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +175 -155
  76. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  77. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js +10 -24
  78. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js.map +1 -1
  79. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +86 -80
  80. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  81. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js +22 -10
  82. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js.map +1 -1
  83. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js +53 -0
  84. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js.map +1 -0
  85. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js +37 -70
  86. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js.map +1 -1
  87. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +176 -114
  88. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  89. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js +25 -0
  90. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js.map +1 -0
  91. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js +16 -29
  92. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js.map +1 -1
  93. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js +23 -19
  94. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js.map +1 -1
  95. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js +35 -23
  96. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js.map +1 -1
  97. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +100 -96
  98. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  99. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js +1 -1
  100. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js.map +1 -1
  101. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +112 -114
  102. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  103. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js +18 -16
  104. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js.map +1 -1
  105. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +71 -0
  106. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +1 -0
  107. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +31 -0
  108. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +1 -0
  109. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +34 -6
  110. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -1
  111. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +79 -0
  112. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -0
  113. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +18 -0
  114. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -0
  115. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +51 -0
  116. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +1 -0
  117. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +11 -0
  118. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +1 -0
  119. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +135 -0
  120. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -0
  121. package/dist/features/sheets/resources-list/resource-item/styled.js +1 -1
  122. package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
  123. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js +3 -4
  124. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js.map +1 -1
  125. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +29 -30
  126. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  127. package/dist/features/ui/constants/z-index.js +1 -1
  128. package/dist/features/ui/constants/z-index.js.map +1 -1
  129. package/dist/features/ui/context-menu/context-menu-styled.js +14 -28
  130. package/dist/features/ui/context-menu/context-menu-styled.js.map +1 -1
  131. package/dist/features/ui/context-menu/context-menu.js +15 -30
  132. package/dist/features/ui/context-menu/context-menu.js.map +1 -1
  133. package/dist/features/ui/theme/button.js +107 -22
  134. package/dist/features/ui/theme/button.js.map +1 -1
  135. package/dist/index.d.ts +31 -280
  136. package/dist/index.js +472 -496
  137. package/dist/index.js.map +1 -1
  138. package/package.json +1 -1
  139. package/dist/assets/line-icons/icons/alarm.js +0 -41
  140. package/dist/assets/line-icons/icons/alarm.js.map +0 -1
  141. package/dist/assets/line-icons/icons/dart.js +0 -23
  142. package/dist/assets/line-icons/icons/dart.js.map +0 -1
  143. package/dist/assets/line-icons/icons/exclamation.js +0 -26
  144. package/dist/assets/line-icons/icons/exclamation.js.map +0 -1
  145. package/dist/assets/line-icons/icons/home2.js +0 -25
  146. package/dist/assets/line-icons/icons/home2.js.map +0 -1
  147. package/dist/assets/line-icons/icons/important.js +0 -23
  148. package/dist/assets/line-icons/icons/important.js.map +0 -1
  149. package/dist/assets/line-icons/icons/puzzle.js +0 -25
  150. package/dist/assets/line-icons/icons/puzzle.js.map +0 -1
  151. package/dist/assets/line-icons/icons/recap.js +0 -32
  152. package/dist/assets/line-icons/icons/recap.js.map +0 -1
  153. package/dist/assets/line-icons/icons/skip-colored.js +0 -43
  154. package/dist/assets/line-icons/icons/skip-colored.js.map +0 -1
  155. package/dist/assets/line-icons/icons/status.js +0 -41
  156. package/dist/assets/line-icons/icons/status.js.map +0 -1
  157. package/dist/assets/line-icons/icons/testtube.js +0 -33
  158. package/dist/assets/line-icons/icons/testtube.js.map +0 -1
  159. package/dist/features/chapters-v2/api/chapter.js +0 -10
  160. package/dist/features/chapters-v2/api/chapter.js.map +0 -1
  161. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +0 -112
  162. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +0 -1
  163. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js +0 -26
  164. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js.map +0 -1
  165. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +0 -73
  166. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +0 -1
  167. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js +0 -90
  168. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js.map +0 -1
  169. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js +0 -97
  170. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js.map +0 -1
  171. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js +0 -52
  172. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js.map +0 -1
  173. package/dist/features/chapters-v2/chapter-details/chapter-details.js +0 -103
  174. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +0 -1
  175. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js +0 -13
  176. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js.map +0 -1
  177. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +0 -153
  178. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +0 -1
  179. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +0 -16
  180. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +0 -1
  181. package/dist/features/chapters-v2/comps/node-card/node-card.js +0 -12
  182. package/dist/features/chapters-v2/comps/node-card/node-card.js.map +0 -1
  183. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js +0 -32
  184. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js.map +0 -1
  185. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js +0 -31
  186. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js.map +0 -1
  187. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +0 -171
  188. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +0 -1
  189. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +0 -192
  190. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +0 -1
  191. package/dist/features/chapters-v2/comps/tag/tag-styled.js +0 -13
  192. package/dist/features/chapters-v2/comps/tag/tag-styled.js.map +0 -1
  193. package/dist/features/chapters-v2/comps/tag/tag.js +0 -28
  194. package/dist/features/chapters-v2/comps/tag/tag.js.map +0 -1
  195. package/dist/features/chapters-v2/constants/block-constants.js +0 -20
  196. package/dist/features/chapters-v2/constants/block-constants.js.map +0 -1
  197. package/dist/features/chapters-v2/constants/node-constants.js +0 -14
  198. package/dist/features/chapters-v2/constants/node-constants.js.map +0 -1
  199. package/dist/features/chapters-v2/utils/index.js +0 -41
  200. package/dist/features/chapters-v2/utils/index.js.map +0 -1
  201. package/dist/features/chapters-v2/utils/node-card-utils.js +0 -144
  202. package/dist/features/chapters-v2/utils/node-card-utils.js.map +0 -1
  203. package/dist/features/homework/card-menu-options.js +0 -38
  204. package/dist/features/homework/card-menu-options.js.map +0 -1
  205. package/dist/features/homework/card-title.js +0 -21
  206. package/dist/features/homework/card-title.js.map +0 -1
  207. package/dist/features/homework/homework-card-view.js +0 -133
  208. package/dist/features/homework/homework-card-view.js.map +0 -1
  209. package/dist/features/homework/homework-card.js +0 -206
  210. package/dist/features/homework/homework-card.js.map +0 -1
  211. package/dist/features/homework/hw-card-list/api/get-homeworks.js +0 -10
  212. package/dist/features/homework/hw-card-list/api/get-homeworks.js.map +0 -1
  213. package/dist/features/homework/hw-card-list/hw-card-list-styled.js +0 -71
  214. package/dist/features/homework/hw-card-list/hw-card-list-styled.js.map +0 -1
  215. package/dist/features/homework/hw-card-list/hw-card-list.js +0 -182
  216. package/dist/features/homework/hw-card-list/hw-card-list.js.map +0 -1
  217. package/dist/features/homework/node-progress.js +0 -29
  218. package/dist/features/homework/node-progress.js.map +0 -1
  219. package/dist/features/homework/styles.js +0 -130
  220. package/dist/features/homework/styles.js.map +0 -1
  221. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +0 -165
  222. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +0 -1
  223. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +0 -25
  224. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +0 -1
  225. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +0 -85
  226. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +0 -1
  227. package/dist/features/recent-chapters/api/get-recent-chapters.js +0 -9
  228. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +0 -1
  229. package/dist/features/recent-chapters/recent-chapters-styled.js +0 -16
  230. package/dist/features/recent-chapters/recent-chapters-styled.js.map +0 -1
  231. package/dist/features/recent-chapters/recent-chapters.js +0 -34
  232. package/dist/features/recent-chapters/recent-chapters.js.map +0 -1
  233. package/dist/features/sheet-v2/resource-list/resource-list.js +0 -39
  234. package/dist/features/sheet-v2/resource-list/resource-list.js.map +0 -1
  235. package/dist/node_modules/date-fns/differenceInDays.js +0 -17
  236. package/dist/node_modules/date-fns/differenceInDays.js.map +0 -1
  237. package/dist/static/chapter-header-bg-2.c8d96894.svg +0 -1
  238. package/dist/static/competitive-arena.b9c40801.json +0 -1
  239. package/dist/static/learn.71b13323.json +0 -1
  240. package/dist/static/node-custom-test-bg.d3b757be.svg +0 -1
  241. package/dist/static/node-learn-bg.b61f815c.svg +0 -1
  242. package/dist/static/node-practice-bg.16cbaf2a.svg +0 -1
  243. package/dist/static/node-project-bg.e6a33e28.svg +0 -1
  244. package/dist/static/node-puzzle-bg.3422135c.svg +0 -1
  245. package/dist/static/node-recap-bg.546154e4.svg +0 -1
  246. package/dist/static/node-test-prep-bg.42c0b9c4.svg +0 -1
  247. package/dist/static/node-video-bg.3df3f73a.svg +0 -1
  248. package/dist/static/practice.158dd488.json +0 -1
  249. package/dist/static/project.eb665827.json +0 -1
  250. package/dist/static/puzzle.b298c7e4.json +0 -1
  251. package/dist/static/recap.0dd2c1e2.json +0 -1
  252. package/dist/static/test.803d6036.json +0 -1
  253. package/dist/static/video.b41451e2.json +0 -1
@@ -1,130 +0,0 @@
1
- import r from "styled-components";
2
- import n from "../../assets/line-icons/icons/minus2.js";
3
- import e from "../ui/layout/flex-view.js";
4
- import i from "../ui/text/text.js";
5
- const l = r(e)(({ theme: o }) => `
6
- cursor: pointer;
7
- width: 24px;
8
- height: 24px;
9
-
10
-
11
- &:hover {
12
- border-radius: 50%;
13
- background: ${o.colors.WHITE_5};
14
- }
15
- `), d = r(i)`
16
- display: -webkit-box;
17
- -webkit-line-clamp: 1;
18
- -webkit-box-orient: vertical;
19
- overflow: hidden;
20
- text-overflow: ellipsis;
21
- `, u = r(e)(({
22
- $shouldopenonright: o,
23
- $visible: t
24
- }) => `
25
- cursor: pointer;
26
- position: absolute;
27
- z-index: 6;
28
- top: calc(100% + 4px);
29
- right: ${o ? 0 : "auto"};
30
- transform-origin: top;
31
- transform: scaleY(${t ? 1 : 0});
32
- opacity: ${t ? 1 : 0};
33
- transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
34
- box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);
35
- z-index: 10;
36
- `), x = r(e)`
37
- border: 1px solid ${({ theme: o }) => o.colors.BLACK_T_15};
38
-
39
- &:hover {
40
- border: 1px solid ${({ theme: o }) => o.colors.BLACK};
41
- }
42
- `, b = r(e)(({ $bgImage: o }) => o ? `
43
- background-image: url(${o});
44
- background-repeat: no-repeat;
45
- background-size: cover;
46
- background-position: center;
47
- overflow: hidden;
48
- ` : "overflow: hidden;"), h = r(e)`
49
- display: flex;
50
- align-items: center;
51
- justify-content: center;
52
- `, w = r(e)`
53
- position: absolute;
54
- right: -18px;
55
- top: -4px;
56
- `, f = r.img(({ theme: o }) => {
57
- const { gutter: t } = o.layout;
58
- return `
59
- border: 1px solid ${o.colors.BLACK_T_15};
60
- width: ${t * 4}px;
61
- height: ${t * 4}px;
62
- border-radius: 50%;
63
- `;
64
- }), g = r(n)`
65
- path {
66
- stroke: ${({ theme: o }) => o.colors.WHITE};
67
- }
68
- `, m = r(i)`
69
- display: -webkit-box;
70
- -webkit-line-clamp: 2;
71
- -webkit-box-orient: vertical;
72
- overflow: hidden;
73
- text-overflow: ellipsis;
74
- white-space: break-spaces;
75
- `;
76
- r(e)``;
77
- const k = r(e)(({
78
- theme: o,
79
- $disabled: t
80
- }) => `
81
- cursor: ${t ? "not-allowed" : "pointer"};
82
-
83
- &:hover {
84
- background: ${t ? "transparent" : o.colors.BLACK};
85
- };
86
-
87
- path {
88
- fill: ${o.colors.WHITE_1};
89
- }
90
- `), v = r(i)`
91
- white-space: nowrap;
92
- overflow: hidden;
93
- text-overflow: ellipsis;
94
- `, C = r(e)`
95
- position: absolute;
96
- z-index: 6;
97
- top: calc(100% - 36px);
98
- right: 12px;
99
- transform-origin: top;
100
- transform: scaleY(1);
101
- `, $ = r(e)`
102
- position: absolute;
103
- top: 0;
104
- left: 0;
105
- width: 100%;
106
- height: 100%;
107
- opacity: 0.5;
108
- `, y = r(e)`
109
- position: absolute;
110
- right: 42px;
111
- top: 24px;
112
- `;
113
- export {
114
- f as BannerImage,
115
- w as BannerImageWrapper,
116
- $ as BlurContainer,
117
- y as BlurFlexView,
118
- x as CardContainer,
119
- l as CardKebabMenuWrapper,
120
- u as CardMenuOptionsWrapper,
121
- k as CardOptionWrapper,
122
- b as CardWrapper,
123
- m as HeaderText,
124
- h as IconWrapper,
125
- C as MenuWrapper,
126
- v as OptionText,
127
- g as StyledMinus2Icon,
128
- d as SubHeaderText
129
- };
130
- //# 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\ninterface ICardWrapperProps {\n $bgImage: string;\n}\ninterface ICardOptionsMenuWrapperProps {\n $visible: boolean;\n $shouldopenonright: boolean;\n}\n\nexport const CardKebabMenuWrapper = styled(FlexView)(({ theme }) => {\n return `\n cursor: pointer;\n width: 24px;\n height: 24px;\n \n \n &:hover {\n border-radius: 50%;\n background: ${theme.colors.WHITE_5}; \n }\n `;\n});\n\nexport const SubHeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const CardMenuOptionsWrapper = styled(FlexView)<ICardOptionsMenuWrapperProps>(({\n $shouldopenonright,\n $visible,\n}) => {\n return `\n cursor: pointer;\n position: absolute;\n z-index: 6;\n top: calc(100% + 4px);\n right: ${$shouldopenonright ? 0 : 'auto'};\n transform-origin: top;\n transform: scaleY(${$visible ? 1 : 0});\n opacity: ${$visible ? 1 : 0};\n transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;\n box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.4);\n z-index: 10;\n `;\n});\n\nexport const CardContainer = styled(FlexView)`\n border: 1px solid ${({ theme }) => theme.colors.BLACK_T_15};\n\n &:hover {\n border: 1px solid ${({ theme }) => theme.colors.BLACK};\n }\n`;\n\nexport const CardWrapper = styled(FlexView)<ICardWrapperProps>(({ $bgImage }) => {\n if ($bgImage) {\n return `\n background-image: url(${$bgImage});\n background-repeat: no-repeat;\n background-size: cover;\n background-position: center;\n overflow: hidden;\n `;\n }\n\n return 'overflow: hidden;';\n});\n\nexport const IconWrapper = styled(FlexView)`\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const BannerImageWrapper = styled(FlexView)`\n position: absolute;\n right: -18px;\n top: -4px;\n`;\n\nexport const BannerImage = styled.img(({ theme }) => {\n const { gutter } = theme.layout;\n\n return `\n border: 1px solid ${theme.colors.BLACK_T_15};\n width: ${gutter * 4}px;\n height: ${gutter * 4}px;\n border-radius: 50%;\n `;\n});\n\nexport const StyledMinus2Icon = styled(Minus2Icon)`\n path {\n stroke: ${({ theme }) => theme.colors.WHITE};\n }\n`;\n\nexport const HeaderText = styled(Text)`\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: break-spaces;\n`;\n\ninterface ICardOptionWrapperProps {\n $disabled?: boolean;\n}\ninterface ICardOptionsProps {\n $top: number;\n $left: number;\n}\n\nexport const CardOptions = styled(FlexView)<ICardOptionsProps>``;\n\nexport const CardOptionWrapper = styled(FlexView)<ICardOptionWrapperProps>(({\n theme,\n $disabled,\n}) => {\n return `\n cursor: ${$disabled ? 'not-allowed' : 'pointer'};\n \n &:hover {\n background: ${$disabled ? 'transparent' : theme.colors.BLACK};\n };\n \n path {\n fill: ${theme.colors.WHITE_1};\n }\n `;\n});\n\nexport const OptionText = styled(Text)`\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\n\nexport const MenuWrapper = styled(FlexView)`\n position: absolute;\n z-index: 6;\n top: calc(100% - 36px);\n right: 12px;\n transform-origin: top;\n transform: scaleY(1);\n`;\n\nexport const BlurContainer = styled(FlexView)`\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n opacity: 0.5;\n`;\n\nexport const BlurFlexView = styled(FlexView)`\n position: absolute;\n right: 42px;\n top: 24px;\n`;\n"],"names":["CardKebabMenuWrapper","styled","FlexView","theme","SubHeaderText","Text","CardMenuOptionsWrapper","$shouldopenonright","$visible","CardContainer","CardWrapper","$bgImage","IconWrapper","BannerImageWrapper","BannerImage","gutter","StyledMinus2Icon","Minus2Icon","HeaderText","CardOptionWrapper","$disabled","OptionText","MenuWrapper","BlurContainer","BlurFlexView"],"mappings":";;;;AAcO,MAAMA,IAAuBC,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAC,QAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAQWA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGvC,GAEYC,IAAgBH,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ3BC,IAAyBL,EAAOC,CAAQ,EAAgC,CAAC;AAAA,EACpF,oBAAAK;AAAA,EACA,UAAAC;AACF,MACS;AAAA;AAAA;AAAA;AAAA;AAAA,aAKID,IAAqB,IAAI,MAAM;AAAA;AAAA,wBAEpBC,IAAW,IAAI,CAAC;AAAA,eACzBA,IAAW,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA,GAK9B,GAEYC,IAAgBR,EAAOC,CAAQ;AAAA,sBACtB,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,UAAU;AAAA;AAAA;AAAA,wBAGpC,CAAC,EAAE,OAAAA,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAI5CO,IAAcT,EAAOC,CAAQ,EAAqB,CAAC,EAAE,UAAAS,QAC5DA,IACK;AAAA,8BACmBA,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,QAQ7B,mBACR,GAEYC,IAAcX,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAM7BW,IAAqBZ,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAMpCY,IAAcb,EAAO,IAAI,CAAC,EAAE,OAAAE,QAAY;AAC7C,QAAA,EAAE,QAAAY,EAAO,IAAIZ,EAAM;AAElB,SAAA;AAAA,wBACeA,EAAM,OAAO,UAAU;AAAA,aAClCY,IAAS,CAAC;AAAA,cACTA,IAAS,CAAC;AAAA;AAAA;AAGxB,CAAC,GAEYC,IAAmBf,EAAOgB,CAAU;AAAA;AAAA,cAEnC,CAAC,EAAE,OAAAd,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA;AAAA,GAIlCe,IAAajB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBVJ,EAAOC,CAAQ;AAEnC,MAAMiB,IAAoBlB,EAAOC,CAAQ,EAA2B,CAAC;AAAA,EAC1E,OAAAC;AAAA,EACA,WAAAiB;AACF,MACS;AAAA,cACKA,IAAY,gBAAgB,SAAS;AAAA;AAAA;AAAA,oBAG/BA,IAAY,gBAAgBjB,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,cAIpDA,EAAM,OAAO,OAAO;AAAA;AAAA,GAGjC,GAEYkB,IAAapB,EAAOI,CAAI;AAAA;AAAA;AAAA;AAAA,GAMxBiB,IAAcrB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAS7BqB,IAAgBtB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAS/BsB,IAAevB,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;"}
@@ -1,165 +0,0 @@
1
- import { jsxs as u, jsx as e, Fragment as x } from "react/jsx-runtime";
2
- import { memo as H, useCallback as l, useEffect as L } from "react";
3
- import { IMAGES as X } from "../../../../assets/images/images.js";
4
- import D from "../../../ui/arrow-tooltip/arrow-tooltip.js";
5
- import S 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 = H((c) => {
15
- const {
16
- isChaptersAvailable: g,
17
- isDraftMilestone: E,
18
- isMilestoneActive: d,
19
- userType: b,
20
- studentId: m,
21
- userMilestoneId: t,
22
- canUpdatePlan: I
23
- } = c, { onCreateMilestoneTest: i, onTestPreview: o, onTestStart: n, onTestReview: s } = c, {
24
- get: A,
25
- data: r,
26
- isProcessingFailed: p,
27
- isProcessed: f,
28
- isStale: C,
29
- isProcessing: w
30
- } = G(), y = !I || !g || !d || d && E, k = d && !g ? "Chapters need to be assigned" : E ? "Allowed after plan is published" : "Plan is completed", h = l(() => {
31
- A(t, void 0, {
32
- studentId: m
33
- });
34
- }, [A, m, t]);
35
- L(() => {
36
- !w && (!f && !p || C) && h();
37
- }, [h, f, w, p, C]);
38
- const $ = l(() => {
39
- if (typeof i == "function") {
40
- i == null || i(t, ((r == null ? void 0 : r.length) || 0) + 1);
41
- return;
42
- }
43
- throw new Error("No callback provided. If provided it must be a function");
44
- }, [i, t, r]), M = l(
45
- (a) => {
46
- if (typeof o == "function") {
47
- o == null || o(a, t);
48
- return;
49
- }
50
- throw new Error("No callback provided. If provided it must be a function");
51
- },
52
- [o, t]
53
- ), O = l(
54
- (a) => {
55
- if (typeof n == "function") {
56
- n == null || n(a);
57
- return;
58
- }
59
- throw new Error("No callback provided. If provided it must be a function");
60
- },
61
- [n]
62
- ), P = l(
63
- (a) => {
64
- if (typeof s == "function") {
65
- s == null || s(a, t);
66
- return;
67
- }
68
- throw new Error("No callback provided. If provided it must be a function");
69
- },
70
- [s, t]
71
- );
72
- return p ? /* @__PURE__ */ u(
73
- T,
74
- {
75
- $flexGapX: 1.5,
76
- $alignItems: "center",
77
- $justifyContent: "center",
78
- $height: "100%",
79
- $background: "WHITE",
80
- children: [
81
- /* @__PURE__ */ e(N, { $renderAs: "h6", children: "Oops! Something went wrong. Please try again later." }),
82
- /* @__PURE__ */ e(
83
- S,
84
- {
85
- widthX: 14,
86
- size: "small",
87
- shape: "square",
88
- renderAs: "primary",
89
- label: "Try again",
90
- onClick: h
91
- }
92
- )
93
- ]
94
- }
95
- ) : f ? r != null && r.length ? /* @__PURE__ */ e(
96
- W,
97
- {
98
- ...c,
99
- onNodeAttempt: O,
100
- onNodeView: M,
101
- onNodeReview: P,
102
- milestoneId: t,
103
- sheets: r,
104
- userType: b,
105
- studentId: m,
106
- onCreateNewTest: $,
107
- canUpdatedPlan: I,
108
- isMilestoneActive: d
109
- }
110
- ) : /* @__PURE__ */ u(
111
- T,
112
- {
113
- $gapX: 6.75,
114
- $alignItems: "center",
115
- $justifyContent: "center",
116
- $background: "WHITE",
117
- $height: v,
118
- children: [
119
- /* @__PURE__ */ e("img", { src: X.EMPTY_MIX_TESTS, alt: "empty_mix_tests" }),
120
- /* @__PURE__ */ e(_, { heightX: 2 }),
121
- b === "TEACHER" ? /* @__PURE__ */ u(x, { children: [
122
- /* @__PURE__ */ e(
123
- D,
124
- {
125
- renderAs: "primary",
126
- position: "bottom",
127
- hidden: !y,
128
- tooltipItem: k,
129
- children: /* @__PURE__ */ e(
130
- S,
131
- {
132
- widthX: 10,
133
- renderAs: "primary",
134
- shape: "square",
135
- size: "small",
136
- label: "Create a Test",
137
- onClick: $,
138
- disabled: y,
139
- analyticsLabel: R.CUSTOM_TEST_CREATION_STARTED,
140
- analyticsProps: {
141
- milestone_id: t
142
- }
143
- }
144
- )
145
- }
146
- ),
147
- /* @__PURE__ */ e(_, { heightX: 2 })
148
- ] }) : /* @__PURE__ */ e(N, { $renderAs: "ab2-bold", $color: "BLACK_T_87", children: "Wait for the teacher to create a test" })
149
- ]
150
- }
151
- ) : /* @__PURE__ */ e(
152
- T,
153
- {
154
- $height: v,
155
- $alignItems: "center",
156
- $justifyContent: "center",
157
- $background: "WHITE",
158
- children: /* @__PURE__ */ e(j, { height: "100%" })
159
- }
160
- );
161
- });
162
- export {
163
- re as default
164
- };
165
- //# 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 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\n $flexGapX={1.5}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $height=\"100%\"\n $background=\"WHITE\"\n >\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","jsxs","FlexView","jsx","Text","Button","TestSheetsList","MILESTONE_WIDGET_MIN_HEIGHT","IMAGES","Separator","Fragment","ArrowTooltip","TESTS_CREATION_ANALYTICS_EVENTS","AppLoader"],"mappings":"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"}
@@ -1,25 +0,0 @@
1
- import { styled as t } from "styled-components";
2
- import o from "../../../ui/layout/flex-view.js";
3
- const i = t(o)`
4
- position: sticky;
5
- bottom: 0;
6
- margin-left: auto;
7
- `, s = t(o)(({ theme: e }) => {
8
- const { colors: r } = e;
9
- return `
10
- border-radius: 50%;
11
- box-shadow: 0px 10px 20px 0px ${r.BLACK_T_15};
12
- `;
13
- }), a = t.div`
14
- display: grid;
15
- grid-template-columns: repeat(3, 200px);
16
- grid-gap: 32px;
17
- justify-content: center;
18
- padding: 32px 0;
19
- `;
20
- export {
21
- s as IconButtonCover,
22
- i as IconContainer,
23
- a as TestSheetItemWrapper
24
- };
25
- //# sourceMappingURL=test-list-view-styled.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"test-list-view-styled.js","sources":["../../../../../src/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.ts"],"sourcesContent":["import { styled } from 'styled-components';\n\nimport FlexView from '../../../ui/layout/flex-view';\n\nconst IconContainer = styled(FlexView)`\n position: sticky;\n bottom: 0;\n margin-left: auto;\n`;\n\nconst IconButtonCover = styled(FlexView)(({ theme }) => {\n const { colors } = theme;\n\n return `\n border-radius: 50%;\n box-shadow: 0px 10px 20px 0px ${colors.BLACK_T_15};\n `;\n});\n\nconst TestSheetItemWrapper = styled.div`\n display: grid;\n grid-template-columns: repeat(3, 200px);\n grid-gap: 32px;\n justify-content: center;\n padding: 32px 0;\n`;\n\nexport { IconContainer, IconButtonCover, TestSheetItemWrapper };\n"],"names":["IconContainer","styled","FlexView","IconButtonCover","theme","colors","TestSheetItemWrapper"],"mappings":";;AAIM,MAAAA,IAAgBC,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,GAM/BC,IAAkBF,EAAOC,CAAQ,EAAE,CAAC,EAAE,OAAAE,QAAY;AAChD,QAAA,EAAE,QAAAC,EAAW,IAAAD;AAEZ,SAAA;AAAA;AAAA,sCAE6BC,EAAO,UAAU;AAAA;AAEvD,CAAC,GAEKC,IAAuBL,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
@@ -1,85 +0,0 @@
1
- import { jsxs as C, jsx as t } from "react/jsx-runtime";
2
- import { h as S } from "../../../../node_modules/humanize-plus/dist/humanize.js";
3
- import { memo as x } from "react";
4
- import A from "../../../../assets/line-icons/icons/plus2.js";
5
- import N from "../../../homework/homework-card.js";
6
- import w from "../../../ui/buttons/icon-button/icon-button.js";
7
- import O from "../../../ui/layout/flex-view.js";
8
- import { MILESTONE_WIDGET_MIN_HEIGHT as g } from "../../constants.js";
9
- import { TESTS_CREATION_ANALYTICS_EVENTS as j } from "../tests-creation/tests-creation-analytics-events.js";
10
- import { TestSheetItemWrapper as y, IconContainer as H, IconButtonCover as M } from "./test-list-view-styled.js";
11
- const R = (e) => {
12
- const o = /* @__PURE__ */ new Set();
13
- return e == null || e.forEach((r) => {
14
- o.add(r.chapter_name);
15
- }), Array.from(o).join(", ");
16
- }, V = x(
17
- ({
18
- milestoneId: e,
19
- studentId: o,
20
- sheets: r,
21
- userType: i,
22
- onCreateNewTest: m,
23
- isMilestoneActive: c,
24
- canUpdatedPlan: d,
25
- ...l
26
- }) => /* @__PURE__ */ C(
27
- O,
28
- {
29
- $height: g,
30
- $position: "relative",
31
- $justifyContent: "space-between",
32
- children: [
33
- /* @__PURE__ */ t(y, { children: r.map((s, a) => {
34
- const {
35
- items: p,
36
- node_id: T,
37
- sheet_time: h,
38
- total_questions: n,
39
- worksheet_id: u,
40
- is_timed: _
41
- } = s, f = Math.ceil((h || 0) / 60), I = R(p), E = _ ? `${f} Mins` : "", $ = `${n ? `${n} ${S.pluralize(n, "Question")}` : ""} ${E}`;
42
- return /* @__PURE__ */ t(
43
- N,
44
- {
45
- userType: i,
46
- header: I,
47
- subHeader: $,
48
- nodeData: s,
49
- renderAs: "milestone",
50
- shouldOpenOnRight: (a + 1) % 3 === 0,
51
- ...l
52
- },
53
- `${u}_${T}_${a}`
54
- );
55
- }) }),
56
- i === "TEACHER" && d && /* @__PURE__ */ t(
57
- H,
58
- {
59
- $flexDirection: "row",
60
- $justifyContent: "flex-end",
61
- $gapX: 1,
62
- $gutterX: 1,
63
- children: /* @__PURE__ */ t(M, { children: /* @__PURE__ */ t(
64
- w,
65
- {
66
- Icon: A,
67
- renderAs: "secondary",
68
- analyticsLabel: j.CUSTOM_TEST_CREATION_STARTED,
69
- onClick: m,
70
- disabled: !c,
71
- analyticsProps: {
72
- milestone_id: e
73
- }
74
- }
75
- ) })
76
- }
77
- )
78
- ]
79
- }
80
- )
81
- );
82
- export {
83
- V as default
84
- };
85
- //# sourceMappingURL=test-list-view.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"test-list-view.js","sources":["../../../../../src/features/milestone/milestone-tests/test-list-v2/test-list-view.tsx"],"sourcesContent":["import type { TNodeDataTestItemsDataProps } from '../../../chapters-v2/comps/node-card/node-card-types';\nimport type { ITestSheetsList } from './types';\nimport type { FC } from 'react';\n\nimport { pluralize } from 'humanize-plus';\nimport { memo } from 'react';\n\nimport Plus2Icon from '../../../../assets/line-icons/icons/plus2';\nimport HomeworkCard from '../../../homework/homework-card';\nimport IconButton from '../../../ui/buttons/icon-button/icon-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport { MILESTONE_WIDGET_MIN_HEIGHT } from '../../constants';\nimport { TESTS_CREATION_ANALYTICS_EVENTS } from '../tests-creation/tests-creation-analytics-events';\nimport * as Styled from './test-list-view-styled';\n\nconst getTopicNameFromItems = (items?: TNodeDataTestItemsDataProps[]) => {\n const topics = new Set<string>();\n\n items?.forEach(item => {\n topics.add(item.chapter_name);\n });\n\n return Array.from(topics).join(', ');\n};\n\nconst TestSheetsList: FC<ITestSheetsList> = memo(\n ({\n milestoneId,\n studentId,\n sheets,\n userType,\n onCreateNewTest,\n isMilestoneActive,\n canUpdatedPlan,\n ...sheetCallbacks\n }) => {\n return (\n <FlexView\n $height={MILESTONE_WIDGET_MIN_HEIGHT}\n $position=\"relative\"\n $justifyContent=\"space-between\"\n >\n <Styled.TestSheetItemWrapper>\n {sheets.map((sheet, idx) => {\n const {\n items,\n node_id: nodeId,\n sheet_time: sheetTime,\n total_questions: totalQuestions,\n worksheet_id: worksheetId,\n is_timed: isTimed,\n } = sheet;\n const totalSheetTime = Math.ceil((sheetTime || 0) / 60);\n const testChapterName = getTopicNameFromItems(items);\n const sheetTimeText = isTimed ? `${totalSheetTime} Mins` : '';\n const totalQuestionsText = totalQuestions\n ? `${totalQuestions} ${pluralize(totalQuestions, 'Question')}`\n : '';\n const subHeader = `${totalQuestionsText} ${sheetTimeText}`;\n\n return (\n <HomeworkCard\n key={`${worksheetId}_${nodeId}_${idx}`}\n userType={userType}\n header={testChapterName}\n subHeader={subHeader}\n nodeData={sheet}\n renderAs=\"milestone\"\n shouldOpenOnRight={(idx + 1) % 3 === 0}\n {...sheetCallbacks}\n />\n );\n })}\n </Styled.TestSheetItemWrapper>\n\n {userType === 'TEACHER' && canUpdatedPlan && (\n <Styled.IconContainer\n $flexDirection=\"row\"\n $justifyContent=\"flex-end\"\n $gapX={1}\n $gutterX={1}\n >\n <Styled.IconButtonCover>\n <IconButton\n Icon={Plus2Icon}\n renderAs=\"secondary\"\n analyticsLabel={TESTS_CREATION_ANALYTICS_EVENTS.CUSTOM_TEST_CREATION_STARTED}\n onClick={onCreateNewTest}\n disabled={!isMilestoneActive}\n analyticsProps={{\n milestone_id: milestoneId,\n }}\n />\n </Styled.IconButtonCover>\n </Styled.IconContainer>\n )}\n </FlexView>\n );\n },\n);\n\nexport default TestSheetsList;\n"],"names":["getTopicNameFromItems","items","topics","item","TestSheetsList","memo","milestoneId","studentId","sheets","userType","onCreateNewTest","isMilestoneActive","canUpdatedPlan","sheetCallbacks","jsxs","FlexView","MILESTONE_WIDGET_MIN_HEIGHT","jsx","Styled.TestSheetItemWrapper","sheet","idx","nodeId","sheetTime","totalQuestions","worksheetId","isTimed","totalSheetTime","testChapterName","sheetTimeText","subHeader","pluralize","HomeworkCard","Styled.IconContainer","Styled.IconButtonCover","IconButton","Plus2Icon","TESTS_CREATION_ANALYTICS_EVENTS"],"mappings":";;;;;;;;;;AAeA,MAAMA,IAAwB,CAACC,MAA0C;AACjE,QAAAC,wBAAa;AAEnB,SAAAD,KAAA,QAAAA,EAAO,QAAQ,CAAQE,MAAA;AACd,IAAAD,EAAA,IAAIC,EAAK,YAAY;AAAA,EAAA,IAGvB,MAAM,KAAKD,CAAM,EAAE,KAAK,IAAI;AACrC,GAEME,IAAsCC;AAAA,EAC1C,CAAC;AAAA,IACC,aAAAC;AAAA,IACA,WAAAC;AAAA,IACA,QAAAC;AAAA,IACA,UAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,GAAGC;AAAA,EAAA,MAGD,gBAAAC;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,SAASC;AAAA,MACT,WAAU;AAAA,MACV,iBAAgB;AAAA,MAEhB,UAAA;AAAA,QAAA,gBAAAC,EAACC,GAAA,EACE,YAAO,IAAI,CAACC,GAAOC,MAAQ;AACpB,gBAAA;AAAA,YACJ,OAAAnB;AAAA,YACA,SAASoB;AAAA,YACT,YAAYC;AAAA,YACZ,iBAAiBC;AAAA,YACjB,cAAcC;AAAA,YACd,UAAUC;AAAA,UACR,IAAAN,GACEO,IAAiB,KAAK,MAAMJ,KAAa,KAAK,EAAE,GAChDK,IAAkB3B,EAAsBC,CAAK,GAC7C2B,IAAgBH,IAAU,GAAGC,CAAc,UAAU,IAIrDG,IAAY,GAHSN,IACvB,GAAGA,CAAc,IAAIO,EAAU,UAAAP,GAAgB,UAAU,CAAC,KAC1D,EACmC,IAAIK,CAAa;AAGtD,iBAAA,gBAAAX;AAAA,YAACc;AAAA,YAAA;AAAA,cAEC,UAAAtB;AAAA,cACA,QAAQkB;AAAA,cACR,WAAAE;AAAA,cACA,UAAUV;AAAA,cACV,UAAS;AAAA,cACT,oBAAoBC,IAAM,KAAK,MAAM;AAAA,cACpC,GAAGP;AAAA,YAAA;AAAA,YAPC,GAAGW,CAAW,IAAIH,CAAM,IAAID,CAAG;AAAA,UAAA;AAAA,QAUzC,CAAA,GACH;AAAA,QAECX,MAAa,aAAaG,KACzB,gBAAAK;AAAA,UAACe;AAAAA,UAAA;AAAA,YACC,gBAAe;AAAA,YACf,iBAAgB;AAAA,YAChB,OAAO;AAAA,YACP,UAAU;AAAA,YAEV,UAAA,gBAAAf,EAACgB,GAAA,EACC,UAAA,gBAAAhB;AAAA,cAACiB;AAAA,cAAA;AAAA,gBACC,MAAMC;AAAA,gBACN,UAAS;AAAA,gBACT,gBAAgBC,EAAgC;AAAA,gBAChD,SAAS1B;AAAA,gBACT,UAAU,CAACC;AAAA,gBACX,gBAAgB;AAAA,kBACd,cAAcL;AAAA,gBAChB;AAAA,cAAA;AAAA,YAAA,GAEJ;AAAA,UAAA;AAAA,QACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAKV;"}
@@ -1,9 +0,0 @@
1
- import { createGetAPI as r } from "@cuemath/rest-api";
2
- import { BASE_URL_V3 as s } from "../../../constants/api.js";
3
- const { useGet: p } = r({
4
- getURL: (e, o, { courseStream: t }) => `${s}/users/${e}/course-streams/${t}/recent-chapters`
5
- });
6
- export {
7
- p as useGetRecentChapters
8
- };
9
- //# sourceMappingURL=get-recent-chapters.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"get-recent-chapters.js","sources":["../../../../src/features/recent-chapters/api/get-recent-chapters.ts"],"sourcesContent":["import type { IChapterDataProps } from '../../chapters/chapter/chapter-types';\nimport type { TCourseStream } from '../../milestone/create/milestone-create-types';\n\nimport { createGetAPI } from '@cuemath/rest-api';\n\nimport { BASE_URL_V3 } from '../../../constants/api';\n\nconst { useGet: useGetRecentChapters } = createGetAPI<\n IChapterDataProps[],\n void,\n { courseStream: TCourseStream }\n>({\n getURL: (studentId: string, _, { courseStream }) =>\n `${BASE_URL_V3}/users/${studentId}/course-streams/${courseStream}/recent-chapters`,\n});\n\nexport { useGetRecentChapters };\n"],"names":["useGetRecentChapters","createGetAPI","studentId","_","courseStream","BASE_URL_V3"],"mappings":";;AAOA,MAAM,EAAE,QAAQA,EAAqB,IAAIC,EAIvC;AAAA,EACA,QAAQ,CAACC,GAAmBC,GAAG,EAAE,cAAAC,EAAA,MAC/B,GAAGC,CAAW,UAAUH,CAAS,mBAAmBE,CAAY;AACpE,CAAC;"}
@@ -1,16 +0,0 @@
1
- import e from "styled-components";
2
- const p = e.div(({ theme: t }) => {
3
- const { WHITE_5: r, WHITE_2: a } = t.colors;
4
- return `
5
- display: grid;
6
- grid-template-columns: repeat(4, 1fr);
7
- align-content: start;
8
- background: ${a};
9
- background-image: linear-gradient(${r} 0.5px, transparent 0.5px), linear-gradient(90deg, ${r} 0.5px, transparent 0.5px);
10
- background-size: 45px 45px;
11
- `;
12
- });
13
- export {
14
- p as ChaptersWrapper
15
- };
16
- //# sourceMappingURL=recent-chapters-styled.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"recent-chapters-styled.js","sources":["../../../src/features/recent-chapters/recent-chapters-styled.ts"],"sourcesContent":["import styled from 'styled-components';\n\nconst ChaptersWrapper = styled.div(({ theme }) => {\n const { WHITE_5, WHITE_2 } = theme.colors;\n\n return `\n display: grid;\n grid-template-columns: repeat(4, 1fr);\n align-content: start;\n background: ${WHITE_2};\n background-image: linear-gradient(${WHITE_5} 0.5px, transparent 0.5px), linear-gradient(90deg, ${WHITE_5} 0.5px, transparent 0.5px);\n background-size: 45px 45px;\n `;\n});\n\nexport { ChaptersWrapper };\n"],"names":["ChaptersWrapper","styled","theme","WHITE_5","WHITE_2"],"mappings":";AAEA,MAAMA,IAAkBC,EAAO,IAAI,CAAC,EAAE,OAAAC,QAAY;AAChD,QAAM,EAAE,SAAAC,GAAS,SAAAC,MAAYF,EAAM;AAE5B,SAAA;AAAA;AAAA;AAAA;AAAA,kBAISE,CAAO;AAAA,wCACeD,CAAO,sDAAsDA,CAAO;AAAA;AAAA;AAG5G,CAAC;"}
@@ -1,34 +0,0 @@
1
- import { jsxs as s, jsx as l } from "react/jsx-runtime";
2
- import { useCallback as c, useEffect as f } from "react";
3
- import h from "../chapters/chapters-list/chapter-item/chapter-item.js";
4
- import C from "../ui/layout/flex-view.js";
5
- import d from "../ui/text/text.js";
6
- import { useGetRecentChapters as u } from "./api/get-recent-chapters.js";
7
- import { ChaptersWrapper as x } from "./recent-chapters-styled.js";
8
- const g = ({ studentId: r, courseStream: t, onChapterClick: p }) => {
9
- const { get: o, data: e, isProcessingFailed: a } = u(), i = c(() => {
10
- o(r, void 0, { courseStream: t });
11
- }, [t, o, r]);
12
- return f(() => {
13
- i();
14
- }, [i]), a ? null : e && e.length > 0 ? /* @__PURE__ */ s(C, { $flexRowGapX: 1, children: [
15
- /* @__PURE__ */ s(d, { $renderAs: "ac4-black", $color: "BLACK_T_60", children: [
16
- "Recent Chapters (",
17
- e == null ? void 0 : e.length,
18
- ")"
19
- ] }),
20
- /* @__PURE__ */ l(x, { children: e.map((n, m) => /* @__PURE__ */ l(
21
- h,
22
- {
23
- chapter: n,
24
- onChapterClick: p,
25
- itemIndex: m
26
- },
27
- n.id
28
- )) })
29
- ] }) : null;
30
- }, F = g;
31
- export {
32
- F as default
33
- };
34
- //# sourceMappingURL=recent-chapters.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"recent-chapters.js","sources":["../../../src/features/recent-chapters/recent-chapters.tsx"],"sourcesContent":["import type { IChaptersListProps } from '../chapters/chapters-list/chapters-list-types';\nimport type { TCourseStream } from '../milestone/create/milestone-create-types';\nimport type { TUserTypes } from '../ui/types';\nimport type { FC } from 'react';\n\nimport { useCallback, useEffect } from 'react';\n\nimport ChapterItem from '../chapters/chapters-list/chapter-item/chapter-item';\nimport FlexView from '../ui/layout/flex-view';\nimport Text from '../ui/text/text';\nimport { useGetRecentChapters } from './api/get-recent-chapters';\nimport * as Styled from './recent-chapters-styled';\n\ninterface RecentChaptersProps {\n studentId: string;\n courseStream: TCourseStream;\n userType: TUserTypes;\n onChapterClick: IChaptersListProps['onChapterClick'];\n}\n\nconst RecentChapters: FC<RecentChaptersProps> = ({ studentId, courseStream, onChapterClick }) => {\n const { get: getChapters, data: chapterData, isProcessingFailed } = useGetRecentChapters();\n\n const fetchChapterDetails = useCallback(() => {\n getChapters(studentId, undefined, { courseStream });\n }, [courseStream, getChapters, studentId]);\n\n useEffect(() => {\n fetchChapterDetails();\n }, [fetchChapterDetails]);\n\n if (isProcessingFailed) {\n return null;\n }\n\n if (chapterData && chapterData.length > 0) {\n return (\n <FlexView $flexRowGapX={1}>\n <Text $renderAs=\"ac4-black\" $color=\"BLACK_T_60\">\n Recent Chapters ({chapterData?.length})\n </Text>\n <Styled.ChaptersWrapper>\n {chapterData.map((chapter, idx) => (\n <ChapterItem\n key={chapter.id}\n chapter={chapter}\n onChapterClick={onChapterClick}\n itemIndex={idx}\n />\n ))}\n </Styled.ChaptersWrapper>\n </FlexView>\n );\n }\n\n return null;\n};\n\nexport default RecentChapters;\n"],"names":["RecentChapters","studentId","courseStream","onChapterClick","getChapters","chapterData","isProcessingFailed","useGetRecentChapters","fetchChapterDetails","useCallback","useEffect","jsxs","FlexView","Text","jsx","Styled.ChaptersWrapper","chapter","idx","ChapterItem","RecentChapters$1"],"mappings":";;;;;;;AAoBA,MAAMA,IAA0C,CAAC,EAAE,WAAAC,GAAW,cAAAC,GAAc,gBAAAC,QAAqB;AAC/F,QAAM,EAAE,KAAKC,GAAa,MAAMC,GAAa,oBAAAC,EAAA,IAAuBC,KAE9DC,IAAsBC,EAAY,MAAM;AAC5C,IAAAL,EAAYH,GAAW,QAAW,EAAE,cAAAC,EAAc,CAAA;AAAA,EACjD,GAAA,CAACA,GAAcE,GAAaH,CAAS,CAAC;AAMzC,SAJAS,EAAU,MAAM;AACM,IAAAF;EAAA,GACnB,CAACA,CAAmB,CAAC,GAEpBF,IACK,OAGLD,KAAeA,EAAY,SAAS,IAEpC,gBAAAM,EAACC,GAAS,EAAA,cAAc,GACtB,UAAA;AAAA,IAAA,gBAAAD,EAACE,GAAK,EAAA,WAAU,aAAY,QAAO,cAAa,UAAA;AAAA,MAAA;AAAA,MAC5BR,KAAA,gBAAAA,EAAa;AAAA,MAAO;AAAA,IAAA,GACxC;AAAA,IACA,gBAAAS,EAACC,GAAA,EACE,YAAY,IAAI,CAACC,GAASC,MACzB,gBAAAH;AAAA,MAACI;AAAA,MAAA;AAAA,QAEC,SAAAF;AAAA,QACA,gBAAAb;AAAA,QACA,WAAWc;AAAA,MAAA;AAAA,MAHND,EAAQ;AAAA,IAKhB,CAAA,GACH;AAAA,EACF,EAAA,CAAA,IAIG;AACT,GAEAG,IAAenB;"}
@@ -1,39 +0,0 @@
1
- import { jsx as t } from "react/jsx-runtime";
2
- import { h as f } from "../../../node_modules/humanize-plus/dist/humanize.js";
3
- import { memo as $ } from "react";
4
- import x from "styled-components";
5
- import _ from "../../homework/homework-card.js";
6
- import g from "../../ui/layout/flex-view.js";
7
- const w = x.div`
8
- display: grid;
9
- grid-template-columns: repeat(3, 200px);
10
- grid-gap: 32px;
11
- justify-content: center;
12
- padding: 32px 0;
13
- `, R = ({ sheets: r, userType: n, ...m }) => /* @__PURE__ */ t(g, { children: /* @__PURE__ */ t(w, { children: r.map((o, s) => {
14
- const {
15
- title: d,
16
- node_id: a,
17
- worksheet_id: p,
18
- is_timed: l,
19
- sheet_time: c,
20
- total_questions: e
21
- } = o, u = Math.ceil((c || 0) / 60), i = e ? `${e} ${f.pluralize(e, "Question")}` : "", h = l ? `${i} ${u} Mins` : i;
22
- return /* @__PURE__ */ t(
23
- _,
24
- {
25
- header: d,
26
- subHeader: h,
27
- userType: n,
28
- nodeData: o,
29
- renderAs: "milestone",
30
- shouldOpenOnRight: (s + 1) % 3 === 0,
31
- ...m
32
- },
33
- `${p}_${a}_${s}`
34
- );
35
- }) }) }), j = $(R);
36
- export {
37
- j as default
38
- };
39
- //# sourceMappingURL=resource-list.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"resource-list.js","sources":["../../../../src/features/sheet-v2/resource-list/resource-list.tsx"],"sourcesContent":["import type { IResourcesListProps } from './types';\nimport type { FC } from 'react';\n\nimport { pluralize } from 'humanize-plus';\nimport { memo } from 'react';\nimport styled from 'styled-components';\n\nimport HomeworkCard from '../../homework/homework-card';\nimport FlexView from '../../ui/layout/flex-view';\n\nconst ResourceItemListWrapper = styled.div`\n display: grid;\n grid-template-columns: repeat(3, 200px);\n grid-gap: 32px;\n justify-content: center;\n padding: 32px 0;\n`;\n\nconst ResourcesList: FC<IResourcesListProps> = ({ sheets, userType, ...sheetCallBacks }) => (\n <FlexView>\n <ResourceItemListWrapper>\n {sheets.map((sheet, idx) => {\n const {\n title,\n node_id: nodeId,\n worksheet_id: worksheetId,\n is_timed: isTimed,\n sheet_time: sheetTime,\n total_questions: totalQuestions,\n } = sheet;\n const totalSheetTime = Math.ceil((sheetTime || 0) / 60);\n const totalQuestionsText = totalQuestions\n ? `${totalQuestions} ${pluralize(totalQuestions, 'Question')}`\n : '';\n const subHeader = isTimed\n ? `${totalQuestionsText} ${totalSheetTime} Mins`\n : totalQuestionsText;\n\n return (\n <HomeworkCard\n key={`${worksheetId}_${nodeId}_${idx}`}\n header={title}\n subHeader={subHeader}\n userType={userType}\n nodeData={sheet}\n renderAs=\"milestone\"\n shouldOpenOnRight={(idx + 1) % 3 === 0}\n {...sheetCallBacks}\n />\n );\n })}\n </ResourceItemListWrapper>\n </FlexView>\n);\n\nexport default memo(ResourcesList);\n"],"names":["ResourceItemListWrapper","styled","ResourcesList","sheets","userType","sheetCallBacks","jsx","FlexView","sheet","idx","title","nodeId","worksheetId","isTimed","sheetTime","totalQuestions","totalSheetTime","totalQuestionsText","pluralize","subHeader","HomeworkCard","ResourcesList$1","memo"],"mappings":";;;;;;AAUA,MAAMA,IAA0BC,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQjCC,IAAyC,CAAC,EAAE,QAAAC,GAAQ,UAAAC,GAAU,GAAGC,EAAe,MACnF,gBAAAC,EAAAC,GAAA,EACC,4BAACP,GACE,EAAA,UAAAG,EAAO,IAAI,CAACK,GAAOC,MAAQ;AACpB,QAAA;AAAA,IACJ,OAAAC;AAAA,IACA,SAASC;AAAA,IACT,cAAcC;AAAA,IACd,UAAUC;AAAA,IACV,YAAYC;AAAA,IACZ,iBAAiBC;AAAA,EACf,IAAAP,GACEQ,IAAiB,KAAK,MAAMF,KAAa,KAAK,EAAE,GAChDG,IAAqBF,IACvB,GAAGA,CAAc,IAAIG,EAAU,UAAAH,GAAgB,UAAU,CAAC,KAC1D,IACEI,IAAYN,IACd,GAAGI,CAAkB,IAAID,CAAc,UACvCC;AAGF,SAAA,gBAAAX;AAAA,IAACc;AAAA,IAAA;AAAA,MAEC,QAAQV;AAAA,MACR,WAAAS;AAAA,MACA,UAAAf;AAAA,MACA,UAAUI;AAAA,MACV,UAAS;AAAA,MACT,oBAAoBC,IAAM,KAAK,MAAM;AAAA,MACpC,GAAGJ;AAAA,IAAA;AAAA,IAPC,GAAGO,CAAW,IAAID,CAAM,IAAIF,CAAG;AAAA,EAAA;AAU1C,CAAC,GACH,EACF,CAAA,GAGaY,IAAAC,EAAKpB,CAAa;"}
@@ -1,17 +0,0 @@
1
- import { differenceInCalendarDays as g } from "./differenceInCalendarDays.js";
2
- import { toDate as l } from "./toDate.js";
3
- function D(e, n) {
4
- const s = l(e), t = l(n), o = u(s, t), r = Math.abs(g(s, t));
5
- s.setDate(s.getDate() - o * r);
6
- const i = +(u(s, t) === -o), c = o * (r - i);
7
- return c === 0 ? 0 : c;
8
- }
9
- function u(e, n) {
10
- const s = e.getFullYear() - n.getFullYear() || e.getMonth() - n.getMonth() || e.getDate() - n.getDate() || e.getHours() - n.getHours() || e.getMinutes() - n.getMinutes() || e.getSeconds() - n.getSeconds() || e.getMilliseconds() - n.getMilliseconds();
11
- return s < 0 ? -1 : s > 0 ? 1 : s;
12
- }
13
- export {
14
- D as default,
15
- D as differenceInDays
16
- };
17
- //# sourceMappingURL=differenceInDays.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"differenceInDays.js","sources":["../../../node_modules/date-fns/differenceInDays.mjs"],"sourcesContent":["import { differenceInCalendarDays } from \"./differenceInCalendarDays.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name differenceInDays\n * @category Day Helpers\n * @summary Get the number of full days between the given dates.\n *\n * @description\n * Get the number of full day periods between two dates. Fractional days are\n * truncated towards zero.\n *\n * One \"full day\" is the distance between a local time in one day to the same\n * local time on the next or previous day. A full day can sometimes be less than\n * or more than 24 hours if a daylight savings change happens between two dates.\n *\n * To ignore DST and only measure exact 24-hour periods, use this instead:\n * `Math.trunc(differenceInHours(dateLeft, dateRight)/24)|0`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param dateLeft - The later date\n * @param dateRight - The earlier date\n *\n * @returns The number of full days according to the local timezone\n *\n * @example\n * // How many full days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 365\n *\n * @example\n * // How many full days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 0\n *\n * @example\n * // How many full days are between\n * // 1 March 2020 0:00 and 1 June 2020 0:00 ?\n * // Note: because local time is used, the\n * // result will always be 92 days, even in\n * // time zones where DST starts and the\n * // period has only 92*24-1 hours.\n * const result = differenceInDays(\n * new Date(2020, 5, 1),\n * new Date(2020, 2, 1)\n * )\n * //=> 92\n */\nexport function differenceInDays(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n\n const sign = compareLocalAsc(_dateLeft, _dateRight);\n const difference = Math.abs(differenceInCalendarDays(_dateLeft, _dateRight));\n\n _dateLeft.setDate(_dateLeft.getDate() - sign * difference);\n\n // Math.abs(diff in full days - diff in calendar days) === 1 if last calendar day is not full\n // If so, result must be decreased by 1 in absolute value\n const isLastDayNotFull = Number(\n compareLocalAsc(_dateLeft, _dateRight) === -sign,\n );\n const result = sign * (difference - isLastDayNotFull);\n // Prevent negative zero\n return result === 0 ? 0 : result;\n}\n\n// Like `compareAsc` but uses local time not UTC, which is needed\n// for accurate equality comparisons of UTC timestamps that end up\n// having the same representation in local time, e.g. one hour before\n// DST ends vs. the instant that DST ends.\nfunction compareLocalAsc(dateLeft, dateRight) {\n const diff =\n dateLeft.getFullYear() - dateRight.getFullYear() ||\n dateLeft.getMonth() - dateRight.getMonth() ||\n dateLeft.getDate() - dateRight.getDate() ||\n dateLeft.getHours() - dateRight.getHours() ||\n dateLeft.getMinutes() - dateRight.getMinutes() ||\n dateLeft.getSeconds() - dateRight.getSeconds() ||\n dateLeft.getMilliseconds() - dateRight.getMilliseconds();\n\n if (diff < 0) {\n return -1;\n } else if (diff > 0) {\n return 1;\n // Return 0 if diff is 0; return NaN if diff is NaN\n } else {\n return diff;\n }\n}\n\n// Fallback for modularized imports:\nexport default differenceInDays;\n"],"names":["differenceInDays","dateLeft","dateRight","_dateLeft","toDate","_dateRight","sign","compareLocalAsc","difference","differenceInCalendarDays","isLastDayNotFull","result","diff"],"mappings":";;AAyDO,SAASA,EAAiBC,GAAUC,GAAW;AACpD,QAAMC,IAAYC,EAAOH,CAAQ,GAC3BI,IAAaD,EAAOF,CAAS,GAE7BI,IAAOC,EAAgBJ,GAAWE,CAAU,GAC5CG,IAAa,KAAK,IAAIC,EAAyBN,GAAWE,CAAU,CAAC;AAE3E,EAAAF,EAAU,QAAQA,EAAU,QAAO,IAAKG,IAAOE,CAAU;AAIzD,QAAME,IAAmB,EACvBH,EAAgBJ,GAAWE,CAAU,MAAM,CAACC,IAExCK,IAASL,KAAQE,IAAaE;AAEpC,SAAOC,MAAW,IAAI,IAAIA;AAC5B;AAMA,SAASJ,EAAgBN,GAAUC,GAAW;AAC5C,QAAMU,IACJX,EAAS,YAAW,IAAKC,EAAU,YAAa,KAChDD,EAAS,SAAQ,IAAKC,EAAU,SAAU,KAC1CD,EAAS,QAAO,IAAKC,EAAU,QAAS,KACxCD,EAAS,SAAQ,IAAKC,EAAU,SAAU,KAC1CD,EAAS,WAAU,IAAKC,EAAU,WAAY,KAC9CD,EAAS,WAAU,IAAKC,EAAU,WAAY,KAC9CD,EAAS,gBAAe,IAAKC,EAAU,gBAAe;AAExD,SAAIU,IAAO,IACF,KACEA,IAAO,IACT,IAGAA;AAEX;","x_google_ignoreList":[0]}
@@ -1 +0,0 @@
1
- <svg width="992" height="168" fill="none" xmlns="http://www.w3.org/2000/svg"><g clip-path="url(#clip0_7903_34003)"><circle cx="222" cy="83" r="222" fill="white" fill-opacity="0.25"/><circle cx="222" cy="83" r="126" fill="white" fill-opacity="0.25"/><circle cx="222" cy="83" r="78" fill="white" fill-opacity="0.25"/></g><defs><clipPath id="clip0_7903_34003"><rect width="992" height="168" fill="white"/></clipPath></defs></svg>