@cuemath/leap 2.9.4-as5 → 2.9.4-link.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (262) 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/lottie/lottie.js +1 -9
  7. package/dist/assets/lottie/lottie.js.map +1 -1
  8. package/dist/constants/api.js +2 -3
  9. package/dist/constants/api.js.map +1 -1
  10. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js +33 -99
  11. package/dist/features/chapters/chapters-list/chapter-item/chapter-item-styled.js.map +1 -1
  12. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js +49 -92
  13. package/dist/features/chapters/chapters-list/chapter-item/chapter-item.js.map +1 -1
  14. package/dist/features/chapters/chapters-list/chapters-list-styled.js +5 -5
  15. package/dist/features/chapters/chapters-list/chapters-list-styled.js.map +1 -1
  16. package/dist/features/chapters/chapters-list/chapters-list.js +70 -64
  17. package/dist/features/chapters/chapters-list/chapters-list.js.map +1 -1
  18. package/dist/features/communication/pub-sub/constants.js +2 -5
  19. package/dist/features/communication/pub-sub/constants.js.map +1 -1
  20. package/dist/features/journey/comps/coachmark/coachmark-styled.js +5 -12
  21. package/dist/features/journey/comps/coachmark/coachmark-styled.js.map +1 -1
  22. package/dist/features/journey/comps/coachmark/coachmark.js +24 -24
  23. package/dist/features/journey/comps/coachmark/coachmark.js.map +1 -1
  24. package/dist/features/journey/journey-id/journey-id-student.js +2 -3
  25. package/dist/features/journey/journey-id/journey-id-student.js.map +1 -1
  26. package/dist/features/journey/use-journey/journey-context-provider.js +28 -36
  27. package/dist/features/journey/use-journey/journey-context-provider.js.map +1 -1
  28. package/dist/features/journey/use-journey/journey-styled.js +5 -10
  29. package/dist/features/journey/use-journey/journey-styled.js.map +1 -1
  30. package/dist/features/milestone/create/api/goal-submit.js +1 -1
  31. package/dist/features/milestone/create/api/goal-submit.js.map +1 -1
  32. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js +49 -42
  33. package/dist/features/milestone/create/comps/chapter-item/chapter-item.js.map +1 -1
  34. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js +4 -12
  35. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step-styled.js.map +1 -1
  36. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js +105 -128
  37. package/dist/features/milestone/create/comps/chapters-selection-step/chapters-selection-step.js.map +1 -1
  38. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js +92 -0
  39. package/dist/features/milestone/create/comps/milestone-progress-v2/milestone-progress-v2.js.map +1 -0
  40. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js +25 -0
  41. package/dist/features/milestone/create/comps/milestone-progress-v2/styled.js.map +1 -0
  42. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js +20 -14
  43. package/dist/features/milestone/create/comps/sheets-list/sheets-list-styled.js.map +1 -1
  44. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js +50 -26
  45. package/dist/features/milestone/create/comps/sheets-list/sheets-list.js.map +1 -1
  46. package/dist/features/milestone/create/milestone-create.js +43 -49
  47. package/dist/features/milestone/create/milestone-create.js.map +1 -1
  48. package/dist/features/milestone/create/utils/index.js +38 -33
  49. package/dist/features/milestone/create/utils/index.js.map +1 -1
  50. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js +1 -1
  51. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/get-milestone.js.map +1 -1
  52. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js +1 -1
  53. package/dist/features/milestone/edit/comps/edit-milestone-modal/api/patch-goal-plan.js.map +1 -1
  54. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js +53 -51
  55. package/dist/features/milestone/edit/comps/edit-milestone-modal/index.js.map +1 -1
  56. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js +40 -42
  57. package/dist/features/milestone/edit/goal-drafts/goal-draft-edit-container.js.map +1 -1
  58. package/dist/features/milestone/edit/goal-edit-container.js +62 -64
  59. package/dist/features/milestone/edit/goal-edit-container.js.map +1 -1
  60. package/dist/features/milestone/edit/goal-edit-helpers.js +53 -50
  61. package/dist/features/milestone/edit/goal-edit-helpers.js.map +1 -1
  62. package/dist/features/milestone/edit/milestone-edit-container.js +52 -54
  63. package/dist/features/milestone/edit/milestone-edit-container.js.map +1 -1
  64. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js +1 -1
  65. package/dist/features/milestone/milestone-list-container/api/get-milestone-resources.js.map +1 -1
  66. package/dist/features/milestone/milestone-list-container/api/get-milestones.js +17 -9
  67. package/dist/features/milestone/milestone-list-container/api/get-milestones.js.map +1 -1
  68. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js +1 -1
  69. package/dist/features/milestone/milestone-list-container/api/get-tests-list.js.map +1 -1
  70. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js +104 -136
  71. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-list.js.map +1 -1
  72. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js +13 -0
  73. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element-styled.js.map +1 -0
  74. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js +38 -0
  75. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/context-menu-helper/menu-element.js.map +1 -0
  76. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js +123 -107
  77. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/goals/goal-action-ctas.js.map +1 -1
  78. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js +175 -155
  79. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-info.js.map +1 -1
  80. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js +10 -24
  81. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs-styled.js.map +1 -1
  82. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js +86 -80
  83. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-tabs/milestone-tabs.js.map +1 -1
  84. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js +22 -10
  85. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-utils.js.map +1 -1
  86. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js +53 -0
  87. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-status.js.map +1 -0
  88. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js +37 -70
  89. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget-styled.js.map +1 -1
  90. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js +176 -114
  91. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/milestone-widget.js.map +1 -1
  92. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js +25 -0
  93. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-info.js.map +1 -0
  94. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js +16 -29
  95. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-rank.js.map +1 -1
  96. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js +23 -19
  97. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome-styled.js.map +1 -1
  98. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js +35 -23
  99. package/dist/features/milestone/milestone-list-container/milestone-list/milestone-widget/outcome/outcome.js.map +1 -1
  100. package/dist/features/milestone/milestone-list-container/milestone-list-container.js +100 -96
  101. package/dist/features/milestone/milestone-list-container/milestone-list-container.js.map +1 -1
  102. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js +1 -1
  103. package/dist/features/milestone/milestone-resources/resources-list/resources-list-styled.js.map +1 -1
  104. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js +112 -114
  105. package/dist/features/milestone/milestone-resources/resources-list/resources-list.js.map +1 -1
  106. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js +18 -16
  107. package/dist/features/milestone/milestone-tests/tests-creation/tests-creation.js.map +1 -1
  108. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js +71 -0
  109. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-cta.js.map +1 -0
  110. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js +31 -0
  111. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-styled.js.map +1 -0
  112. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js +34 -6
  113. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js.map +1 -1
  114. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js +79 -0
  115. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item.js.map +1 -0
  116. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js +18 -0
  117. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list-styled.js.map +1 -0
  118. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js +51 -0
  119. package/dist/features/milestone/milestone-tests/tests-list/test-sheets-list/test-sheets-list.js.map +1 -0
  120. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js +11 -0
  121. package/dist/features/milestone/milestone-tests/tests-list/tests-list-styled.js.map +1 -0
  122. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js +135 -0
  123. package/dist/features/milestone/milestone-tests/tests-list/tests-list.js.map +1 -0
  124. package/dist/features/sheets/resources-list/resource-item/styled.js +1 -1
  125. package/dist/features/sheets/resources-list/resource-item/styled.js.map +1 -1
  126. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js +3 -4
  127. package/dist/features/sheets/sheets-list/sheet-item/reward-n-actions/teacher-actions/teacher-actions-constant.js.map +1 -1
  128. package/dist/features/trial-session/comps/offering-information/offering-information.js +21 -21
  129. package/dist/features/trial-session/comps/offering-information/offering-information.js.map +1 -1
  130. package/dist/features/trial-session/comps/pricing/pricing-cards.js +45 -45
  131. package/dist/features/trial-session/comps/pricing/pricing-cards.js.map +1 -1
  132. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +29 -30
  133. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  134. package/dist/features/ui/constants/z-index.js +1 -1
  135. package/dist/features/ui/constants/z-index.js.map +1 -1
  136. package/dist/features/ui/context-menu/context-menu-styled.js +14 -28
  137. package/dist/features/ui/context-menu/context-menu-styled.js.map +1 -1
  138. package/dist/features/ui/context-menu/context-menu.js +15 -30
  139. package/dist/features/ui/context-menu/context-menu.js.map +1 -1
  140. package/dist/features/ui/theme/button.js +107 -22
  141. package/dist/features/ui/theme/button.js.map +1 -1
  142. package/dist/index.d.ts +34 -314
  143. package/dist/index.js +470 -499
  144. package/dist/index.js.map +1 -1
  145. package/package.json +2 -3
  146. package/dist/assets/line-icons/icons/alarm.js +0 -41
  147. package/dist/assets/line-icons/icons/alarm.js.map +0 -1
  148. package/dist/assets/line-icons/icons/dart.js +0 -23
  149. package/dist/assets/line-icons/icons/dart.js.map +0 -1
  150. package/dist/assets/line-icons/icons/exclamation.js +0 -26
  151. package/dist/assets/line-icons/icons/exclamation.js.map +0 -1
  152. package/dist/assets/line-icons/icons/home2.js +0 -25
  153. package/dist/assets/line-icons/icons/home2.js.map +0 -1
  154. package/dist/assets/line-icons/icons/important.js +0 -23
  155. package/dist/assets/line-icons/icons/important.js.map +0 -1
  156. package/dist/assets/line-icons/icons/puzzle.js +0 -25
  157. package/dist/assets/line-icons/icons/puzzle.js.map +0 -1
  158. package/dist/assets/line-icons/icons/recap.js +0 -32
  159. package/dist/assets/line-icons/icons/recap.js.map +0 -1
  160. package/dist/assets/line-icons/icons/skip-colored.js +0 -43
  161. package/dist/assets/line-icons/icons/skip-colored.js.map +0 -1
  162. package/dist/assets/line-icons/icons/status.js +0 -41
  163. package/dist/assets/line-icons/icons/status.js.map +0 -1
  164. package/dist/assets/line-icons/icons/testtube.js +0 -33
  165. package/dist/assets/line-icons/icons/testtube.js.map +0 -1
  166. package/dist/features/chapters-v2/api/chapter.js +0 -10
  167. package/dist/features/chapters-v2/api/chapter.js.map +0 -1
  168. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +0 -112
  169. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +0 -1
  170. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js +0 -26
  171. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections-styled.js.map +0 -1
  172. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js +0 -73
  173. package/dist/features/chapters-v2/chapter-details/block-sections/block-sections.js.map +0 -1
  174. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js +0 -90
  175. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner-styled.js.map +0 -1
  176. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js +0 -97
  177. package/dist/features/chapters-v2/chapter-details/chapter-banner/chapter-banner.js.map +0 -1
  178. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js +0 -52
  179. package/dist/features/chapters-v2/chapter-details/chapter-details-styled.js.map +0 -1
  180. package/dist/features/chapters-v2/chapter-details/chapter-details.js +0 -103
  181. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +0 -1
  182. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js +0 -13
  183. package/dist/features/chapters-v2/comps/node-card/border-path-animation.js.map +0 -1
  184. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js +0 -153
  185. package/dist/features/chapters-v2/comps/node-card/node-card-styled.js.map +0 -1
  186. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +0 -16
  187. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +0 -1
  188. package/dist/features/chapters-v2/comps/node-card/node-card.js +0 -12
  189. package/dist/features/chapters-v2/comps/node-card/node-card.js.map +0 -1
  190. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js +0 -32
  191. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options-styled.js.map +0 -1
  192. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js +0 -31
  193. package/dist/features/chapters-v2/comps/node-card/node-menu-options/node-menu-options.js.map +0 -1
  194. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +0 -171
  195. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +0 -1
  196. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +0 -192
  197. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +0 -1
  198. package/dist/features/chapters-v2/comps/tag/tag-styled.js +0 -13
  199. package/dist/features/chapters-v2/comps/tag/tag-styled.js.map +0 -1
  200. package/dist/features/chapters-v2/comps/tag/tag.js +0 -28
  201. package/dist/features/chapters-v2/comps/tag/tag.js.map +0 -1
  202. package/dist/features/chapters-v2/constants/block-constants.js +0 -20
  203. package/dist/features/chapters-v2/constants/block-constants.js.map +0 -1
  204. package/dist/features/chapters-v2/constants/node-constants.js +0 -14
  205. package/dist/features/chapters-v2/constants/node-constants.js.map +0 -1
  206. package/dist/features/chapters-v2/utils/index.js +0 -41
  207. package/dist/features/chapters-v2/utils/index.js.map +0 -1
  208. package/dist/features/chapters-v2/utils/node-card-utils.js +0 -144
  209. package/dist/features/chapters-v2/utils/node-card-utils.js.map +0 -1
  210. package/dist/features/homework/card-menu-options.js +0 -38
  211. package/dist/features/homework/card-menu-options.js.map +0 -1
  212. package/dist/features/homework/card-title.js +0 -15
  213. package/dist/features/homework/card-title.js.map +0 -1
  214. package/dist/features/homework/homework-card-view.js +0 -131
  215. package/dist/features/homework/homework-card-view.js.map +0 -1
  216. package/dist/features/homework/homework-card.js +0 -205
  217. package/dist/features/homework/homework-card.js.map +0 -1
  218. package/dist/features/homework/hw-card-list/api/get-homeworks.js +0 -10
  219. package/dist/features/homework/hw-card-list/api/get-homeworks.js.map +0 -1
  220. package/dist/features/homework/hw-card-list/hw-card-list-styled.js +0 -71
  221. package/dist/features/homework/hw-card-list/hw-card-list-styled.js.map +0 -1
  222. package/dist/features/homework/hw-card-list/hw-card-list.js +0 -208
  223. package/dist/features/homework/hw-card-list/hw-card-list.js.map +0 -1
  224. package/dist/features/homework/node-progress.js +0 -29
  225. package/dist/features/homework/node-progress.js.map +0 -1
  226. package/dist/features/homework/styles.js +0 -130
  227. package/dist/features/homework/styles.js.map +0 -1
  228. package/dist/features/journey/hooks/use-home-page-journey.js +0 -189
  229. package/dist/features/journey/hooks/use-home-page-journey.js.map +0 -1
  230. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js +0 -165
  231. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-container.js.map +0 -1
  232. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js +0 -25
  233. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view-styled.js.map +0 -1
  234. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js +0 -85
  235. package/dist/features/milestone/milestone-tests/test-list-v2/test-list-view.js.map +0 -1
  236. package/dist/features/recent-chapters/api/get-recent-chapters.js +0 -9
  237. package/dist/features/recent-chapters/api/get-recent-chapters.js.map +0 -1
  238. package/dist/features/recent-chapters/recent-chapters-styled.js +0 -16
  239. package/dist/features/recent-chapters/recent-chapters-styled.js.map +0 -1
  240. package/dist/features/recent-chapters/recent-chapters.js +0 -39
  241. package/dist/features/recent-chapters/recent-chapters.js.map +0 -1
  242. package/dist/features/sheet-v2/resource-list/resource-list.js +0 -39
  243. package/dist/features/sheet-v2/resource-list/resource-list.js.map +0 -1
  244. package/dist/node_modules/date-fns/differenceInDays.js +0 -17
  245. package/dist/node_modules/date-fns/differenceInDays.js.map +0 -1
  246. package/dist/static/chapter-header-bg-2.c8d96894.svg +0 -1
  247. package/dist/static/competitive-arena.b9c40801.json +0 -1
  248. package/dist/static/learn.71b13323.json +0 -1
  249. package/dist/static/node-custom-test-bg.d3b757be.svg +0 -1
  250. package/dist/static/node-learn-bg.b61f815c.svg +0 -1
  251. package/dist/static/node-practice-bg.16cbaf2a.svg +0 -1
  252. package/dist/static/node-project-bg.e6a33e28.svg +0 -1
  253. package/dist/static/node-puzzle-bg.3422135c.svg +0 -1
  254. package/dist/static/node-recap-bg.546154e4.svg +0 -1
  255. package/dist/static/node-test-prep-bg.42c0b9c4.svg +0 -1
  256. package/dist/static/node-video-bg.3df3f73a.svg +0 -1
  257. package/dist/static/practice.158dd488.json +0 -1
  258. package/dist/static/project.eb665827.json +0 -1
  259. package/dist/static/puzzle.b298c7e4.json +0 -1
  260. package/dist/static/recap.0dd2c1e2.json +0 -1
  261. package/dist/static/test.803d6036.json +0 -1
  262. package/dist/static/video.b41451e2.json +0 -1
@@ -1,208 +0,0 @@
1
- import { jsxs as c, jsx as o } from "react/jsx-runtime";
2
- import { useRef as re, useState as u, useEffect as h, useCallback as n } from "react";
3
- import ne from "../../../assets/line-icons/icons/chevron-left.js";
4
- import ie from "../../../assets/line-icons/icons/chevron-right.js";
5
- import { useJourney as le } from "../../journey/use-journey/use-journey.js";
6
- import { getTopicsFromItems as ce } from "../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js";
7
- import $ from "../../ui/layout/flex-view.js";
8
- import L from "../../ui/text/text.js";
9
- import se from "../homework-card.js";
10
- import { useGetHomeworks as he } from "./api/get-homeworks.js";
11
- import { ContentWrapper as fe, HoverZone as A, ScrollButton as x, ScrollContainer as ae, QueueWrapper as de, QueueText as ue } from "./hw-card-list-styled.js";
12
- const $e = ({
13
- userType: g = "STUDENT",
14
- studentId: s,
15
- stream: f,
16
- onTestStart: E,
17
- onNodeAttempt: S,
18
- onTestPreview: T,
19
- onNodeView: I,
20
- onTestReview: B,
21
- onNodeReview: W,
22
- onNodeUnassign: N,
23
- homeworkRef: j,
24
- individualHomeworkRef: y,
25
- startHomePageJourney: m,
26
- canStartJourney: k
27
- }) => {
28
- const r = re(null), [K, b] = u(!1), [M, H] = u(!1), [F, G] = u(!1), [X, Q] = u(!0), {
29
- get: _,
30
- data: e,
31
- isProcessingFailed: O,
32
- isProcessing: p,
33
- isStale: R
34
- } = he(s), { isJourneyActive: v } = le();
35
- h(() => {
36
- e != null && e.length && m && !v && k && m({ hwDetails: e, studentId: s, stream: f, userType: g });
37
- }, [
38
- k,
39
- e,
40
- v,
41
- m,
42
- f,
43
- s,
44
- g
45
- ]);
46
- const V = n(() => {
47
- r.current && r.current.scrollBy({ left: -200, behavior: "smooth" });
48
- }, []), z = n(() => {
49
- r.current && r.current.scrollBy({ left: 200, behavior: "smooth" });
50
- }, []), P = n(() => {
51
- b(!0);
52
- }, []), U = n(() => {
53
- b(!1);
54
- }, []), Y = n(() => {
55
- H(!0);
56
- }, []), Z = n(() => {
57
- H(!1);
58
- }, []), i = n(() => {
59
- if (r.current) {
60
- const { scrollLeft: t, scrollWidth: l, clientWidth: C } = r.current;
61
- G(t > 10), Q(t < l - C - 10);
62
- }
63
- }, []);
64
- h(() => {
65
- const t = r.current;
66
- if (t)
67
- return t.addEventListener("scroll", i), i(), () => {
68
- t.removeEventListener("scroll", i);
69
- };
70
- }, [i]), h(() => {
71
- i();
72
- }, [e, i]);
73
- const a = n(() => {
74
- _(s, void 0, { stream: f });
75
- }, [_, f, s]);
76
- h(() => {
77
- !p && R && a();
78
- }, [a, p, R]), h(() => {
79
- a();
80
- }, [a]);
81
- const q = ((e == null ? void 0 : e.filter((t) => t.state === "WAIT_FOR_REVIEW")) || []).length;
82
- return e && e.length === 0 ? /* @__PURE__ */ c($, { $flexRowGapX: 1, children: [
83
- /* @__PURE__ */ c(L, { $renderAs: "ac4-black", $color: "BLACK_T_60", children: [
84
- "Homework (",
85
- e == null ? void 0 : e.length,
86
- ")"
87
- ] }),
88
- /* @__PURE__ */ o(L, { $renderAs: "ab2", $color: "BLACK_T_60", children: "No Homework assigned yet" })
89
- ] }) : O ? null : /* @__PURE__ */ c(fe, { ref: j, $flexRowGapX: 1, $disablePointerEvents: p, children: [
90
- !v && /* @__PURE__ */ c(L, { $renderAs: "ac4-black", $color: "BLACK_T_60", children: [
91
- "Homework (",
92
- q,
93
- "/",
94
- e == null ? void 0 : e.length,
95
- ")"
96
- ] }),
97
- /* @__PURE__ */ c($, { $position: "relative", onMouseEnter: i, children: [
98
- F && /* @__PURE__ */ o(
99
- A,
100
- {
101
- $position: "absolute",
102
- $width: "60px",
103
- left: "0",
104
- right: "auto",
105
- onMouseEnter: P,
106
- onMouseLeave: U,
107
- children: /* @__PURE__ */ o(
108
- x,
109
- {
110
- $position: "absolute",
111
- $background: "BLACK_T_60",
112
- $justifyContent: "center",
113
- $alignItems: "center",
114
- $height: "100%",
115
- onClick: V,
116
- $visible: K,
117
- left: "0px",
118
- right: "auto",
119
- children: /* @__PURE__ */ o(ne, { width: 24, height: 24 })
120
- }
121
- )
122
- },
123
- "left-hover-zone"
124
- ),
125
- /* @__PURE__ */ o(ae, { ref: r, children: /* @__PURE__ */ o($, { $flexDirection: "row", $flexGapX: 1, children: e == null ? void 0 : e.map((t, l) => {
126
- const {
127
- items: C,
128
- node_id: w,
129
- worksheet_id: J,
130
- node_type: D,
131
- title: ee,
132
- subtext: oe
133
- } = t, te = ce(C).join(", "), d = D === "DYNAMIC";
134
- return /* @__PURE__ */ c(
135
- $,
136
- {
137
- ref: l === 0 ? y : void 0,
138
- $flexDirection: "row",
139
- $flexGapX: 1,
140
- children: [
141
- e.length > 10 && l === 10 && /* @__PURE__ */ o(
142
- de,
143
- {
144
- $widthX: 9.5,
145
- $background: "BLACK_4",
146
- $justifyContent: "center",
147
- $gutter: 4,
148
- $gap: 8,
149
- children: /* @__PURE__ */ o(ue, { $renderAs: "ac3", $color: "WHITE", children: "In Queue" })
150
- }
151
- ),
152
- /* @__PURE__ */ o(
153
- se,
154
- {
155
- isInQueue: e.length > 10 && l > 9,
156
- userType: g,
157
- header: d ? te : ee,
158
- subHeader: oe || "",
159
- nodeData: t,
160
- renderAs: "homework",
161
- onNodeAttempt: d ? E : S,
162
- shouldOpenOnRight: e.length > 3 && l === e.length - 1,
163
- onNodeView: d ? T : I,
164
- onNodeReview: d ? B : W,
165
- onNodeUnassign: N
166
- },
167
- `${J}_${w}_${l}`
168
- )
169
- ]
170
- },
171
- w
172
- );
173
- }) }) }),
174
- X && /* @__PURE__ */ o(
175
- A,
176
- {
177
- $position: "absolute",
178
- $width: "60px",
179
- right: "0",
180
- left: "auto",
181
- onMouseEnter: Y,
182
- onMouseLeave: Z,
183
- children: /* @__PURE__ */ o(
184
- x,
185
- {
186
- $position: "absolute",
187
- $width: "60px",
188
- $height: "100%",
189
- $background: "BLACK_T_60",
190
- $justifyContent: "center",
191
- $alignItems: "center",
192
- onClick: z,
193
- $visible: M,
194
- left: "auto",
195
- right: "0px",
196
- children: /* @__PURE__ */ o(ie, { width: 24, height: 24 })
197
- }
198
- )
199
- },
200
- "right-hover-zone"
201
- )
202
- ] })
203
- ] });
204
- }, Ae = $e;
205
- export {
206
- Ae as default
207
- };
208
- //# sourceMappingURL=hw-card-list.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hw-card-list.js","sources":["../../../../src/features/homework/hw-card-list/hw-card-list.tsx"],"sourcesContent":["import type {\n INodeCardCallbacks,\n INodeDataProps,\n} from '../../chapters-v2/comps/node-card/node-card-types';\nimport type { IHomepageStartJourneyProps } from '../../journey/types/homepage-journey-types';\nimport type { TUserTypes } from '../../ui/types';\n\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\n\nimport ChevronLeftIcon from '../../../assets/line-icons/icons/chevron-left';\nimport ChevronRightIcon from '../../../assets/line-icons/icons/chevron-right';\nimport { useJourney } from '../../journey/use-journey/use-journey';\nimport { getTopicsFromItems } from '../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils';\nimport FlexView from '../../ui/layout/flex-view';\nimport Text from '../../ui/text/text';\nimport HomeworkCard from '../homework-card';\nimport { useGetHomeworks } from './api/get-homeworks';\nimport * as Styled from './hw-card-list-styled';\n\ninterface HWCardListProps extends INodeCardCallbacks {\n userType: TUserTypes;\n studentId: string;\n stream: string;\n onTestPreview?: (sheetData: INodeDataProps, milestoneId?: string) => void;\n onTestStart?: (sheetData: INodeDataProps) => void;\n onTestReview?: (sheetData: INodeDataProps, milestoneId?: string) => void;\n homeworkRef?: React.RefObject<HTMLDivElement>;\n individualHomeworkRef?: React.RefObject<HTMLDivElement>;\n startHomePageJourney?: ({\n hwDetails,\n studentId,\n stream,\n userType,\n }: IHomepageStartJourneyProps) => void;\n canStartJourney?: boolean;\n}\n\nconst HWCardList: React.FC<HWCardListProps> = ({\n userType = 'STUDENT',\n studentId,\n stream,\n onTestStart,\n onNodeAttempt,\n onTestPreview,\n onNodeView,\n onTestReview,\n onNodeReview,\n onNodeUnassign,\n homeworkRef,\n individualHomeworkRef,\n startHomePageJourney,\n canStartJourney,\n}) => {\n const scrollRef = useRef<HTMLDivElement>(null);\n const [isLeftHovered, setIsLeftHovered] = useState(false);\n const [isRightHovered, setIsRightHovered] = useState(false);\n const [canScrollLeft, setCanScrollLeft] = useState(false);\n const [canScrollRight, setCanScrollRight] = useState(true);\n const {\n get: getHomeworks,\n data: hwDetails,\n isProcessingFailed,\n isProcessing,\n isStale,\n } = useGetHomeworks(studentId);\n const { isJourneyActive } = useJourney();\n\n useEffect(() => {\n if (hwDetails?.length && startHomePageJourney && !isJourneyActive && canStartJourney) {\n startHomePageJourney({ hwDetails, studentId, stream, userType });\n }\n }, [\n canStartJourney,\n hwDetails,\n isJourneyActive,\n startHomePageJourney,\n stream,\n studentId,\n userType,\n ]);\n\n const handleScrollLeft = useCallback(() => {\n if (scrollRef.current) {\n scrollRef.current.scrollBy({ left: -200, behavior: 'smooth' });\n }\n }, []);\n\n const handleScrollRight = useCallback(() => {\n if (scrollRef.current) {\n scrollRef.current.scrollBy({ left: 200, behavior: 'smooth' });\n }\n }, []);\n\n const handleLeftHoverEnter = useCallback(() => {\n setIsLeftHovered(true);\n }, []);\n\n const handleLeftHoverLeave = useCallback(() => {\n setIsLeftHovered(false);\n }, []);\n\n const handleRightHoverEnter = useCallback(() => {\n setIsRightHovered(true);\n }, []);\n\n const handleRightHoverLeave = useCallback(() => {\n setIsRightHovered(false);\n }, []);\n\n const checkScrollPosition = useCallback(() => {\n if (scrollRef.current) {\n const { scrollLeft, scrollWidth, clientWidth } = scrollRef.current;\n\n setCanScrollLeft(scrollLeft > 10);\n setCanScrollRight(scrollLeft < scrollWidth - clientWidth - 10);\n }\n }, []);\n\n useEffect(() => {\n const scrollElement = scrollRef.current;\n\n if (scrollElement) {\n scrollElement.addEventListener('scroll', checkScrollPosition);\n checkScrollPosition();\n\n return () => {\n scrollElement.removeEventListener('scroll', checkScrollPosition);\n };\n }\n }, [checkScrollPosition]);\n\n // Also check when content changes\n useEffect(() => {\n checkScrollPosition();\n }, [hwDetails, checkScrollPosition]);\n\n const fetchHomeworks = useCallback(() => {\n getHomeworks(studentId, undefined, { stream });\n }, [getHomeworks, stream, studentId]);\n\n useEffect(() => {\n if (!isProcessing && isStale) {\n fetchHomeworks();\n }\n }, [fetchHomeworks, isProcessing, isStale]);\n\n useEffect(() => {\n fetchHomeworks();\n }, [fetchHomeworks]);\n\n const waitForReviewSheets = (hwDetails?.filter(sheet => sheet.state === 'WAIT_FOR_REVIEW') || [])\n .length;\n\n if (hwDetails && hwDetails.length === 0) {\n return (\n <FlexView $flexRowGapX={1}>\n <Text $renderAs=\"ac4-black\" $color=\"BLACK_T_60\">\n Homework ({hwDetails?.length})\n </Text>\n <Text $renderAs=\"ab2\" $color=\"BLACK_T_60\">\n No Homework assigned yet\n </Text>\n </FlexView>\n );\n }\n\n if (isProcessingFailed) {\n return null;\n }\n\n return (\n <Styled.ContentWrapper ref={homeworkRef} $flexRowGapX={1} $disablePointerEvents={isProcessing}>\n {!isJourneyActive && (\n <Text $renderAs=\"ac4-black\" $color=\"BLACK_T_60\">\n Homework ({waitForReviewSheets}/{hwDetails?.length})\n </Text>\n )}\n <FlexView $position=\"relative\" onMouseEnter={checkScrollPosition}>\n {/* Left hover zone */}\n {canScrollLeft && (\n <Styled.HoverZone\n key=\"left-hover-zone\"\n $position=\"absolute\"\n $width=\"60px\"\n left=\"0\"\n right=\"auto\"\n onMouseEnter={handleLeftHoverEnter}\n onMouseLeave={handleLeftHoverLeave}\n >\n {/* Left scroll button - only visible when hovered */}\n <Styled.ScrollButton\n $position=\"absolute\"\n $background=\"BLACK_T_60\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $height=\"100%\"\n onClick={handleScrollLeft}\n $visible={isLeftHovered}\n left=\"0px\"\n right=\"auto\"\n >\n <ChevronLeftIcon width={24} height={24} />\n </Styled.ScrollButton>\n </Styled.HoverZone>\n )}\n\n <Styled.ScrollContainer ref={scrollRef}>\n <FlexView $flexDirection=\"row\" $flexGapX={1}>\n {hwDetails?.map((sheet, idx) => {\n const {\n items,\n node_id: nodeId,\n worksheet_id: worksheetId,\n node_type: nodeType,\n title,\n subtext,\n } = sheet;\n const topics = getTopicsFromItems(items);\n const testChapterName = topics.join(', ');\n const isDynamicSheet = nodeType === 'DYNAMIC';\n\n return (\n <FlexView\n ref={idx === 0 ? individualHomeworkRef : undefined}\n key={nodeId}\n $flexDirection=\"row\"\n $flexGapX={1}\n >\n {hwDetails.length > 10 && idx === 10 && (\n <Styled.QueueWrapper\n $widthX={9.5}\n $background=\"BLACK_4\"\n $justifyContent=\"center\"\n $gutter={4}\n $gap={8}\n >\n <Styled.QueueText $renderAs=\"ac3\" $color=\"WHITE\">\n In Queue\n </Styled.QueueText>\n </Styled.QueueWrapper>\n )}\n <HomeworkCard\n isInQueue={hwDetails.length > 10 && idx > 9}\n key={`${worksheetId}_${nodeId}_${idx}`}\n userType={userType}\n header={isDynamicSheet ? testChapterName : title}\n subHeader={subtext || ''}\n nodeData={sheet}\n renderAs=\"homework\"\n onNodeAttempt={isDynamicSheet ? onTestStart : onNodeAttempt}\n shouldOpenOnRight={hwDetails.length > 3 && idx === hwDetails.length - 1}\n onNodeView={isDynamicSheet ? onTestPreview : onNodeView}\n onNodeReview={isDynamicSheet ? onTestReview : onNodeReview}\n onNodeUnassign={onNodeUnassign}\n />\n </FlexView>\n );\n })}\n </FlexView>\n </Styled.ScrollContainer>\n\n {/* Right hover zone */}\n {canScrollRight && (\n <Styled.HoverZone\n key=\"right-hover-zone\"\n $position=\"absolute\"\n $width=\"60px\"\n right=\"0\"\n left=\"auto\"\n onMouseEnter={handleRightHoverEnter}\n onMouseLeave={handleRightHoverLeave}\n >\n {/* Right scroll button - only visible when hovered */}\n <Styled.ScrollButton\n $position=\"absolute\"\n $width=\"60px\"\n $height=\"100%\"\n $background=\"BLACK_T_60\"\n $justifyContent=\"center\"\n $alignItems=\"center\"\n onClick={handleScrollRight}\n $visible={isRightHovered}\n left=\"auto\"\n right=\"0px\"\n >\n <ChevronRightIcon width={24} height={24} />\n </Styled.ScrollButton>\n </Styled.HoverZone>\n )}\n </FlexView>\n </Styled.ContentWrapper>\n );\n};\n\nexport default HWCardList;\n"],"names":["HWCardList","userType","studentId","stream","onTestStart","onNodeAttempt","onTestPreview","onNodeView","onTestReview","onNodeReview","onNodeUnassign","homeworkRef","individualHomeworkRef","startHomePageJourney","canStartJourney","scrollRef","useRef","isLeftHovered","setIsLeftHovered","useState","isRightHovered","setIsRightHovered","canScrollLeft","setCanScrollLeft","canScrollRight","setCanScrollRight","getHomeworks","hwDetails","isProcessingFailed","isProcessing","isStale","useGetHomeworks","isJourneyActive","useJourney","useEffect","handleScrollLeft","useCallback","handleScrollRight","handleLeftHoverEnter","handleLeftHoverLeave","handleRightHoverEnter","handleRightHoverLeave","checkScrollPosition","scrollLeft","scrollWidth","clientWidth","scrollElement","fetchHomeworks","waitForReviewSheets","sheet","jsxs","FlexView","Text","Styled.ContentWrapper","jsx","Styled.HoverZone","Styled.ScrollButton","ChevronLeftIcon","Styled.ScrollContainer","idx","items","nodeId","worksheetId","nodeType","title","subtext","testChapterName","getTopicsFromItems","isDynamicSheet","Styled.QueueWrapper","Styled.QueueText","HomeworkCard","ChevronRightIcon","HWCardList$1"],"mappings":"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"}
@@ -1,29 +0,0 @@
1
- import { jsx as t } from "react/jsx-runtime";
2
- import { memo as m } from "react";
3
- import a from "styled-components";
4
- import n from "../ui/layout/flex-view.js";
5
- import { differenceInDays as e } from "../../node_modules/date-fns/differenceInDays.js";
6
- const g = a(n)`
7
- height: 100%;
8
- border-radius: 4px;
9
- transition: all 300ms;
10
- width: ${(r) => r.progress}%;
11
- `, d = a(n)`
12
- position: absolute;
13
- top: -1px;
14
- right: 0px;
15
- width: 100%;
16
- height: 2px;
17
- background-color: ${(r) => r.theme.colors.BLACK};
18
- z-index: 2;
19
- `, l = ({ unlockedOn: r, dueDate: i, progressBg: c }) => {
20
- const p = (() => {
21
- const o = e(i, r), s = e(/* @__PURE__ */ new Date(), r);
22
- return s > o ? 100 : Math.min(Math.max(s / o * 100, 0), 100);
23
- })();
24
- return /* @__PURE__ */ t(d, { children: /* @__PURE__ */ t(g, { progress: p, $background: c }) });
25
- }, y = m(l);
26
- export {
27
- y as default
28
- };
29
- //# sourceMappingURL=node-progress.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"node-progress.js","sources":["../../../src/features/homework/node-progress.tsx"],"sourcesContent":["import type { TColorNames } from '../ui/types';\n\nimport { differenceInDays } from 'date-fns';\nimport React, { memo } from 'react';\nimport styled from 'styled-components';\n\nimport FlexView from '../ui/layout/flex-view';\n\ninterface NodeProgressProps {\n unlockedOn: number | string | Date;\n dueDate: number | string | Date;\n progressBg: TColorNames;\n}\n\nconst ProgressBar = styled(FlexView)<{ progress: number }>`\n height: 100%;\n border-radius: 4px;\n transition: all 300ms;\n width: ${props => props.progress}%;\n`;\n\nconst ProgressContainer = styled(FlexView)`\n position: absolute;\n top: -1px;\n right: 0px;\n width: 100%;\n height: 2px;\n background-color: ${props => props.theme.colors.BLACK};\n z-index: 2;\n`;\n\nconst NodeProgress: React.FC<NodeProgressProps> = ({ unlockedOn, dueDate, progressBg }) => {\n const calculateProgress = () => {\n const totalDays = differenceInDays(dueDate, unlockedOn);\n const daysElapsed = differenceInDays(new Date(), unlockedOn);\n\n if (daysElapsed > totalDays) return 100;\n\n const progress = Math.min(Math.max((daysElapsed / totalDays) * 100, 0), 100);\n\n return progress;\n };\n\n const progress = calculateProgress();\n\n return (\n <ProgressContainer>\n <ProgressBar progress={progress} $background={progressBg} />\n </ProgressContainer>\n );\n};\n\nexport default memo(NodeProgress);\n"],"names":["ProgressBar","styled","FlexView","props","ProgressContainer","NodeProgress","unlockedOn","dueDate","progressBg","progress","totalDays","differenceInDays","daysElapsed","jsx","NodeProgress$1","memo"],"mappings":";;;;;AAcA,MAAMA,IAAcC,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA,WAIxB,CAAAC,MAASA,EAAM,QAAQ;AAAA,GAG5BC,IAAoBH,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAMnB,CAASC,MAAAA,EAAM,MAAM,OAAO,KAAK;AAAA;AAAA,GAIjDE,IAA4C,CAAC,EAAE,YAAAC,GAAY,SAAAC,GAAS,YAAAC,QAAiB;AAYzF,QAAMC,KAXoB,MAAM;AACxB,UAAAC,IAAYC,EAAiBJ,GAASD,CAAU,GAChDM,IAAcD,EAAqB,oBAAA,QAAQL,CAAU;AAEvD,WAAAM,IAAcF,IAAkB,MAEnB,KAAK,IAAI,KAAK,IAAKE,IAAcF,IAAa,KAAK,CAAC,GAAG,GAAG;AAAA,EAEpE;AAKT,2BACGN,GACC,EAAA,UAAA,gBAAAS,EAACb,KAAY,UAAAS,GAAoB,aAAaD,EAAY,CAAA,EAC5D,CAAA;AAEJ,GAEeM,IAAAC,EAAKV,CAAY;"}
@@ -1,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,189 +0,0 @@
1
- import { jsx as e, jsxs as h, Fragment as P } from "react/jsx-runtime";
2
- import { useRef as a, useCallback as L, useMemo as Y, useEffect as _ } from "react";
3
- import $ from "../../homework/homework-card.js";
4
- import J from "../../homework/hw-card-list/hw-card-list.js";
5
- import { getTopicsFromItems as U } from "../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils.js";
6
- import z from "../../recent-chapters/recent-chapters.js";
7
- import u from "../../ui/buttons/button/button.js";
8
- import s from "../../ui/layout/flex-view.js";
9
- import C from "../../ui/text/text.js";
10
- import { ELementWrapper as H } from "../comps/coachmark/coachmark-styled.js";
11
- import { JOURNEY_ID_STUDENT as O } from "../journey-id/journey-id-student.js";
12
- import { IndicatorType as f } from "../use-journey/constants.js";
13
- import { useJourney as K } from "../use-journey/use-journey.js";
14
- const ie = () => {
15
- const o = O.HOMEPAGE_JOURNEY, i = a(null), n = a(null), l = a(null), c = a(null), g = a([]), { nextCoachmark: t, setJourney: A, endJourney: w, addCoachmark: E } = K(), y = L(
16
- (r, d, m) => {
17
- c.current ? (E(O.HOMEPAGE_JOURNEY, {
18
- originalElementToHighlightRef: c,
19
- elementToHighlight: /* @__PURE__ */ e(s, { $widthX: 45, children: /* @__PURE__ */ e(
20
- z,
21
- {
22
- studentId: r,
23
- courseStream: m,
24
- userType: d ? "STUDENT" : "TEACHER",
25
- onChapterClick: () => null
26
- }
27
- ) }),
28
- isActive: !1,
29
- type: f.TOOLTIP,
30
- indicator: {
31
- tooltipItem: /* @__PURE__ */ h(s, { $flexRowGapX: 0.75, $justifyContent: "flex-start", children: [
32
- /* @__PURE__ */ e(C, { $renderAs: "ab2-bold", children: "Access all your recent chapters in one place." }),
33
- /* @__PURE__ */ e(
34
- u,
35
- {
36
- label: "Got it",
37
- size: "xsmall",
38
- widthX: 6,
39
- renderAs: "secondary",
40
- onClick: () => w(O.HOMEPAGE_JOURNEY)
41
- }
42
- )
43
- ] }),
44
- position: "top",
45
- renderAs: "primary",
46
- tooltipXCoOrdinates: -227,
47
- tooltipYCoOrdinates: 12,
48
- arrowXCoOrdinates: -110,
49
- backgroundColor: "YELLOW_4",
50
- borderColor: "BLACK",
51
- arrowColor: "BLACK",
52
- arrowSize: 12,
53
- width: 264
54
- }
55
- }), t(o, !1, 0, !0)) : w(o);
56
- },
57
- [t, o, E, w]
58
- ), b = L(
59
- ({ hwDetails: r, studentId: d, stream: m, userType: T }) => {
60
- const { items: k, node_type: X, title: I, subtext: N } = r[0], S = U(k).join(", "), B = X === "DYNAMIC", p = T === "STUDENT";
61
- if (!(i != null && i.current) || !(n != null && n.current) || !(l != null && l.current))
62
- return;
63
- const G = [
64
- {
65
- originalElementToHighlightRef: i,
66
- isActive: !1,
67
- type: f.TOOLTIP,
68
- elementToHighlight: /* @__PURE__ */ e(P, {}),
69
- indicator: {
70
- position: "left",
71
- tooltipXCoOrdinates: 0,
72
- tooltipYCoOrdinates: p ? 100 : 0,
73
- backgroundColor: "BLUE_4",
74
- borderColor: "BLACK",
75
- arrowColor: "BLACK",
76
- arrowSize: 12,
77
- width: 264,
78
- tooltipItem: /* @__PURE__ */ h(s, { $flexRowGapX: 0.75, children: [
79
- /* @__PURE__ */ e(C, { $renderAs: "ab2-bold", children: p ? "Welcome to the all new learning homepage." : "Welcome to the all new tutoring homepage." }),
80
- /* @__PURE__ */ e(
81
- u,
82
- {
83
- label: "Next",
84
- size: "xsmall",
85
- widthX: 6,
86
- renderAs: "secondary",
87
- onClick: () => t(o, !1, 0, !0)
88
- }
89
- )
90
- ] })
91
- }
92
- },
93
- {
94
- originalElementToHighlightRef: n,
95
- elementToHighlight: /* @__PURE__ */ e(H, { children: /* @__PURE__ */ e(J, { userType: T, studentId: d, stream: m }) }),
96
- type: f.TOOLTIP,
97
- indicator: {
98
- position: "top",
99
- tooltipXCoOrdinates: -197,
100
- tooltipYCoOrdinates: -12,
101
- arrowXCoOrdinates: -110,
102
- backgroundColor: "GREEN_4",
103
- borderColor: "BLACK",
104
- arrowColor: "BLACK",
105
- width: 264,
106
- arrowSize: 12,
107
- tooltipItem: /* @__PURE__ */ h(s, { $flexRowGapX: 0.75, children: [
108
- /* @__PURE__ */ e(C, { $renderAs: "ab2-bold", children: p ? "Homework is now easy to access and easy to complete!" : "Homework is now easy to access and easy to review!" }),
109
- /* @__PURE__ */ e(
110
- u,
111
- {
112
- label: "Next",
113
- size: "xsmall",
114
- widthX: 6,
115
- renderAs: "secondary",
116
- onClick: () => t(o, !1, 0, !0)
117
- }
118
- )
119
- ] })
120
- },
121
- isActive: !1
122
- },
123
- {
124
- originalElementToHighlightRef: l,
125
- elementToHighlight: /* @__PURE__ */ e(H, { children: /* @__PURE__ */ e(
126
- $,
127
- {
128
- isInQueue: !1,
129
- userType: T,
130
- header: B ? S : I,
131
- subHeader: N || "",
132
- nodeData: r[0],
133
- renderAs: "homework",
134
- shouldOpenOnRight: !1
135
- }
136
- ) }),
137
- type: f.TOOLTIP,
138
- indicator: {
139
- position: "top",
140
- tooltipXCoOrdinates: -35,
141
- tooltipYCoOrdinates: -7,
142
- backgroundColor: "PURPLE_4",
143
- borderColor: "BLACK",
144
- arrowColor: "BLACK",
145
- arrowXCoOrdinates: -97,
146
- arrowSize: 12,
147
- width: 264,
148
- tooltipItem: /* @__PURE__ */ h(s, { $flexRowGapX: 0.75, children: [
149
- /* @__PURE__ */ e(C, { $renderAs: "ab2-bold", children: "Track homework status and their due dates." }),
150
- /* @__PURE__ */ e(
151
- u,
152
- {
153
- label: c.current ? "Next" : "Got it",
154
- size: "xsmall",
155
- widthX: 6,
156
- renderAs: "secondary",
157
- onClick: () => y(d, p, m)
158
- }
159
- )
160
- ] })
161
- },
162
- isActive: !1
163
- }
164
- ];
165
- A(o, G);
166
- const x = setTimeout(() => {
167
- clearTimeout(x), t(o);
168
- }, 200);
169
- g.current.push(x);
170
- },
171
- [A, o, t, y]
172
- ), R = Y(
173
- () => ({
174
- homepageRef: i,
175
- homeworkRef: n,
176
- individualHomeworkRef: l,
177
- recentChaptersRef: c,
178
- startJourney: b
179
- }),
180
- [b]
181
- );
182
- return _(() => () => {
183
- g.current.forEach((r) => clearTimeout(r)), g.current = [];
184
- }, []), R;
185
- };
186
- export {
187
- ie as useHomePageJourney
188
- };
189
- //# sourceMappingURL=use-home-page-journey.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"use-home-page-journey.js","sources":["../../../../src/features/journey/hooks/use-home-page-journey.tsx"],"sourcesContent":["import type { IHomeworkData } from '../../homework/hw-card-list/api/get-homeworks';\nimport type { TCourseStream } from '../../milestone/create/milestone-create-types';\nimport type { IArrowTooltipProps } from '../../ui/arrow-tooltip/arrow-tooltip-types';\nimport type { IHomepageStartJourneyProps } from '../types/homepage-journey-types';\nimport type { ICoachmarkProps } from '../use-journey/journey-context-types';\n\nimport { useCallback, useEffect, useMemo, useRef } from 'react';\n\nimport HomeworkCard from '../../homework/homework-card';\nimport HWCardList from '../../homework/hw-card-list/hw-card-list';\nimport { getTopicsFromItems } from '../../milestone/milestone-tests/tests-list/test-sheets-list/test-sheet-item/test-sheet-item-utils';\nimport RecentChapters from '../../recent-chapters/recent-chapters';\nimport Button from '../../ui/buttons/button/button';\nimport FlexView from '../../ui/layout/flex-view';\nimport Text from '../../ui/text/text';\nimport { ELementWrapper } from '../comps/coachmark/coachmark-styled';\nimport { JOURNEY_ID_STUDENT } from '../journey-id/journey-id-student';\nimport { IndicatorType } from '../use-journey/constants';\nimport { useJourney } from '../use-journey/use-journey';\n\nexport const useHomePageJourney = () => {\n const journeyId = JOURNEY_ID_STUDENT.HOMEPAGE_JOURNEY;\n\n const homepageRef = useRef<HTMLDivElement>(null);\n const homeworkRef = useRef<HTMLDivElement>(null);\n const individualHomeworkRef = useRef<HTMLDivElement>(null);\n const recentChaptersRef = useRef<HTMLDivElement>(null);\n const timerRefs = useRef<ReturnType<typeof setTimeout>[]>([]);\n const { nextCoachmark, setJourney, endJourney, addCoachmark } = useJourney();\n\n const handleLastStep = useCallback(\n (userId: string, isStudent: boolean, courseValue: string) => {\n if (recentChaptersRef.current) {\n addCoachmark(JOURNEY_ID_STUDENT.HOMEPAGE_JOURNEY, {\n originalElementToHighlightRef: recentChaptersRef,\n elementToHighlight: (\n <FlexView $widthX={45}>\n <RecentChapters\n studentId={userId}\n courseStream={courseValue as TCourseStream}\n userType={isStudent ? 'STUDENT' : 'TEACHER'}\n onChapterClick={() => null}\n />\n </FlexView>\n ),\n isActive: false,\n type: IndicatorType.TOOLTIP,\n indicator: {\n tooltipItem: (\n <FlexView $flexRowGapX={0.75} $justifyContent=\"flex-start\">\n <Text $renderAs=\"ab2-bold\">Access all your recent chapters in one place.</Text>\n <Button\n label=\"Got it\"\n size=\"xsmall\"\n widthX={6}\n renderAs=\"secondary\"\n onClick={() => endJourney(JOURNEY_ID_STUDENT.HOMEPAGE_JOURNEY)}\n />\n </FlexView>\n ),\n position: 'top',\n renderAs: 'primary',\n tooltipXCoOrdinates: -227,\n tooltipYCoOrdinates: 12,\n arrowXCoOrdinates: -110,\n backgroundColor: 'YELLOW_4',\n borderColor: 'BLACK',\n arrowColor: 'BLACK',\n arrowSize: 12,\n width: 264,\n } as IArrowTooltipProps,\n });\n nextCoachmark(journeyId, false, 0, true);\n } else {\n endJourney(journeyId);\n }\n },\n [nextCoachmark, journeyId, addCoachmark, endJourney],\n );\n\n const startJourney = useCallback(\n ({ hwDetails, studentId, stream, userType }: IHomepageStartJourneyProps) => {\n const { items, node_type: nodeType, title, subtext } = hwDetails[0] as IHomeworkData;\n const topics = getTopicsFromItems(items);\n const testChapterName = topics.join(', ');\n const isDynamicSheet = nodeType === 'DYNAMIC';\n const isStudent = userType === 'STUDENT';\n\n if (!homepageRef?.current || !homeworkRef?.current || !individualHomeworkRef?.current) {\n return;\n }\n\n const homepageSteps: ICoachmarkProps[] = [\n {\n originalElementToHighlightRef: homepageRef,\n isActive: false,\n type: IndicatorType.TOOLTIP,\n elementToHighlight: <></>,\n indicator: {\n position: 'left',\n tooltipXCoOrdinates: 0,\n tooltipYCoOrdinates: isStudent ? 100 : 0,\n backgroundColor: 'BLUE_4',\n borderColor: 'BLACK',\n arrowColor: 'BLACK',\n arrowSize: 12,\n width: 264,\n tooltipItem: (\n <FlexView $flexRowGapX={0.75}>\n <Text $renderAs=\"ab2-bold\">\n {isStudent\n ? 'Welcome to the all new learning homepage.'\n : 'Welcome to the all new tutoring homepage.'}\n </Text>\n <Button\n label=\"Next\"\n size=\"xsmall\"\n widthX={6}\n renderAs=\"secondary\"\n onClick={() => nextCoachmark(journeyId, false, 0, true)}\n />\n </FlexView>\n ),\n } as IArrowTooltipProps,\n },\n {\n originalElementToHighlightRef: homeworkRef,\n elementToHighlight: (\n <ELementWrapper>\n <HWCardList userType={userType} studentId={studentId} stream={stream} />\n </ELementWrapper>\n ),\n type: IndicatorType.TOOLTIP,\n indicator: {\n position: 'top',\n tooltipXCoOrdinates: -197,\n tooltipYCoOrdinates: -12,\n arrowXCoOrdinates: -110,\n backgroundColor: 'GREEN_4',\n borderColor: 'BLACK',\n arrowColor: 'BLACK',\n width: 264,\n arrowSize: 12,\n tooltipItem: (\n <FlexView $flexRowGapX={0.75}>\n <Text $renderAs=\"ab2-bold\">\n {isStudent\n ? 'Homework is now easy to access and easy to complete!'\n : 'Homework is now easy to access and easy to review!'}\n </Text>\n <Button\n label=\"Next\"\n size=\"xsmall\"\n widthX={6}\n renderAs=\"secondary\"\n onClick={() => nextCoachmark(journeyId, false, 0, true)}\n />\n </FlexView>\n ),\n } as IArrowTooltipProps,\n isActive: false,\n },\n {\n originalElementToHighlightRef: individualHomeworkRef,\n elementToHighlight: (\n <ELementWrapper>\n <HomeworkCard\n isInQueue={false}\n userType={userType}\n header={isDynamicSheet ? testChapterName : title}\n subHeader={subtext || ''}\n nodeData={hwDetails[0] as IHomeworkData}\n renderAs=\"homework\"\n shouldOpenOnRight={false}\n />\n </ELementWrapper>\n ),\n type: IndicatorType.TOOLTIP,\n indicator: {\n position: 'top',\n tooltipXCoOrdinates: -35,\n tooltipYCoOrdinates: -7,\n backgroundColor: 'PURPLE_4',\n borderColor: 'BLACK',\n arrowColor: 'BLACK',\n arrowXCoOrdinates: -97,\n arrowSize: 12,\n width: 264,\n tooltipItem: (\n <FlexView $flexRowGapX={0.75}>\n <Text $renderAs=\"ab2-bold\">Track homework status and their due dates.</Text>\n <Button\n label={recentChaptersRef.current ? 'Next' : 'Got it'}\n size=\"xsmall\"\n widthX={6}\n renderAs=\"secondary\"\n onClick={() => handleLastStep(studentId, isStudent, stream)}\n />\n </FlexView>\n ),\n } as IArrowTooltipProps,\n isActive: false,\n },\n ];\n\n setJourney(journeyId, homepageSteps);\n\n const delayBeforeStart = setTimeout(() => {\n clearTimeout(delayBeforeStart);\n nextCoachmark(journeyId);\n }, 200);\n\n timerRefs.current.push(delayBeforeStart); // Store to cleanup later\n },\n [setJourney, journeyId, nextCoachmark, handleLastStep],\n );\n\n const data = useMemo(\n () => ({\n homepageRef,\n homeworkRef,\n individualHomeworkRef,\n recentChaptersRef,\n startJourney,\n }),\n [startJourney],\n );\n\n // Cleanup on unmount\n useEffect(() => {\n return () => {\n timerRefs.current.forEach(timer => clearTimeout(timer));\n timerRefs.current = [];\n };\n }, []);\n\n return data;\n};\n"],"names":["useHomePageJourney","journeyId","JOURNEY_ID_STUDENT","homepageRef","useRef","homeworkRef","individualHomeworkRef","recentChaptersRef","timerRefs","nextCoachmark","setJourney","endJourney","addCoachmark","useJourney","handleLastStep","useCallback","userId","isStudent","courseValue","jsx","FlexView","RecentChapters","IndicatorType","jsxs","Text","Button","startJourney","hwDetails","studentId","stream","userType","items","nodeType","title","subtext","testChapterName","getTopicsFromItems","isDynamicSheet","homepageSteps","Fragment","ELementWrapper","HWCardList","HomeworkCard","delayBeforeStart","data","useMemo","useEffect","timer"],"mappings":"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"}