@cuemath/leap 3.1.0-gg2 → 3.1.1-beta-0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (405) hide show
  1. package/dist/assets/gif/gif.js +22 -22
  2. package/dist/assets/gif/gif.js.map +1 -1
  3. package/dist/assets/illustrations/illustrations.js +128 -127
  4. package/dist/assets/illustrations/illustrations.js.map +1 -1
  5. package/dist/assets/images/images.js +32 -32
  6. package/dist/assets/images/images.js.map +1 -1
  7. package/dist/assets/line-icons/icons/check.js +3 -3
  8. package/dist/assets/line-icons/icons/check.js.map +1 -1
  9. package/dist/assets/line-icons/icons/puzzle-icon.js +51 -0
  10. package/dist/assets/line-icons/icons/puzzle-icon.js.map +1 -0
  11. package/dist/assets/line-icons/icons/share.js +48 -0
  12. package/dist/assets/line-icons/icons/share.js.map +1 -0
  13. package/dist/assets/line-icons/icons/tile.js +54 -0
  14. package/dist/assets/line-icons/icons/tile.js.map +1 -0
  15. package/dist/assets/lottie/lottie.js +86 -86
  16. package/dist/assets/lottie/lottie.js.map +1 -1
  17. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js +34 -32
  18. package/dist/features/chapters-v2/chapter-details/block-sections/block-section-view.js.map +1 -1
  19. package/dist/features/chapters-v2/chapter-details/chapter-details.js +47 -45
  20. package/dist/features/chapters-v2/chapter-details/chapter-details.js.map +1 -1
  21. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js +11 -11
  22. package/dist/features/chapters-v2/comps/node-card/node-card-tags.js.map +1 -1
  23. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js +47 -46
  24. package/dist/features/chapters-v2/comps/node-card/student-actions/student-actions.js.map +1 -1
  25. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js +165 -124
  26. package/dist/features/chapters-v2/comps/node-card/teacher-actions/teacher-actions.js.map +1 -1
  27. package/dist/features/chapters-v2/utils/node-card-utils.js +41 -41
  28. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
  29. package/dist/features/cue-canvas/bottombar/homework-controls.js +73 -0
  30. package/dist/features/cue-canvas/bottombar/homework-controls.js.map +1 -0
  31. package/dist/features/cue-canvas/cue-canvas-context.js +8 -5
  32. package/dist/features/cue-canvas/cue-canvas-context.js.map +1 -1
  33. package/dist/features/cue-canvas/cue-canvas-core.js +80 -75
  34. package/dist/features/cue-canvas/cue-canvas-core.js.map +1 -1
  35. package/dist/features/cue-canvas/cue-canvas-helpers.js +31 -25
  36. package/dist/features/cue-canvas/cue-canvas-helpers.js.map +1 -1
  37. package/dist/features/cue-canvas/cue-canvas-provider.js +14 -12
  38. package/dist/features/cue-canvas/cue-canvas-provider.js.map +1 -1
  39. package/dist/features/cue-canvas/cue-canvas.js +79 -65
  40. package/dist/features/cue-canvas/cue-canvas.js.map +1 -1
  41. package/dist/features/cue-canvas/cue-cavas-styled.js +45 -42
  42. package/dist/features/cue-canvas/cue-cavas-styled.js.map +1 -1
  43. package/dist/features/cue-canvas/hooks/use-canvas-sync-broker.js +61 -54
  44. package/dist/features/cue-canvas/hooks/use-canvas-sync-broker.js.map +1 -1
  45. package/dist/features/cue-canvas/hooks/use-cue-canvas-actions.js +18 -14
  46. package/dist/features/cue-canvas/hooks/use-cue-canvas-actions.js.map +1 -1
  47. package/dist/features/cue-canvas/hooks/use-upload-helper.js +23 -0
  48. package/dist/features/cue-canvas/hooks/use-upload-helper.js.map +1 -0
  49. package/dist/features/cue-canvas/sidebar/homework/helper.js +20 -0
  50. package/dist/features/cue-canvas/sidebar/homework/helper.js.map +1 -0
  51. package/dist/features/cue-canvas/sidebar/homework/homework-menu.js +33 -0
  52. package/dist/features/cue-canvas/sidebar/homework/homework-menu.js.map +1 -0
  53. package/dist/features/cue-canvas/sidebar/homework/homework-request.js +68 -0
  54. package/dist/features/cue-canvas/sidebar/homework/homework-request.js.map +1 -0
  55. package/dist/features/cue-canvas/sidebar/homework/homework-styled.js +25 -0
  56. package/dist/features/cue-canvas/sidebar/homework/homework-styled.js.map +1 -0
  57. package/dist/features/cue-canvas/sidebar/homework/homework.js +39 -0
  58. package/dist/features/cue-canvas/sidebar/homework/homework.js.map +1 -0
  59. package/dist/features/cue-canvas/sidebar/puzzles/api/get-puzzles.js +13 -0
  60. package/dist/features/cue-canvas/sidebar/puzzles/api/get-puzzles.js.map +1 -0
  61. package/dist/features/cue-canvas/sidebar/puzzles/filter-selection-menu.js +60 -0
  62. package/dist/features/cue-canvas/sidebar/puzzles/filter-selection-menu.js.map +1 -0
  63. package/dist/features/cue-canvas/sidebar/puzzles/filters-section.js +44 -0
  64. package/dist/features/cue-canvas/sidebar/puzzles/filters-section.js.map +1 -0
  65. package/dist/features/cue-canvas/sidebar/puzzles/filters.js +107 -0
  66. package/dist/features/cue-canvas/sidebar/puzzles/filters.js.map +1 -0
  67. package/dist/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.js +42 -0
  68. package/dist/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.js.map +1 -0
  69. package/dist/features/cue-canvas/sidebar/puzzles/launch-puzzle.js +84 -0
  70. package/dist/features/cue-canvas/sidebar/puzzles/launch-puzzle.js.map +1 -0
  71. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu-header.js +36 -0
  72. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu-header.js.map +1 -0
  73. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu.js +133 -0
  74. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu.js.map +1 -0
  75. package/dist/features/cue-canvas/sidebar/puzzles/puzzles-styled.js +96 -0
  76. package/dist/features/cue-canvas/sidebar/puzzles/puzzles-styled.js.map +1 -0
  77. package/dist/features/cue-canvas/sidebar/puzzles/puzzles.js +29 -0
  78. package/dist/features/cue-canvas/sidebar/puzzles/puzzles.js.map +1 -0
  79. package/dist/features/cue-canvas/sidebar/puzzles/utils.js +120 -0
  80. package/dist/features/cue-canvas/sidebar/puzzles/utils.js.map +1 -0
  81. package/dist/features/cue-canvas/sidebar/sidebar-styled.js +32 -0
  82. package/dist/features/cue-canvas/sidebar/sidebar-styled.js.map +1 -0
  83. package/dist/features/cue-canvas/sidebar/sidebar.js +29 -0
  84. package/dist/features/cue-canvas/sidebar/sidebar.js.map +1 -0
  85. package/dist/features/cue-canvas/sidebar/tiles/tile.js +16 -0
  86. package/dist/features/cue-canvas/sidebar/tiles/tile.js.map +1 -0
  87. package/dist/features/cue-canvas/toolbar/grid-menu.js +13 -13
  88. package/dist/features/cue-canvas/toolbar/grid-menu.js.map +1 -1
  89. package/dist/features/cue-canvas/toolbar/tool.js +22 -20
  90. package/dist/features/cue-canvas/toolbar/tool.js.map +1 -1
  91. package/dist/features/homework/homework-card-view.js +56 -54
  92. package/dist/features/homework/homework-card-view.js.map +1 -1
  93. package/dist/features/homework/homework-card.js +53 -52
  94. package/dist/features/homework/homework-card.js.map +1 -1
  95. package/dist/features/homework/hw-card-list/api/get-homeworks.js +1 -1
  96. package/dist/features/homework/hw-card-list/api/get-homeworks.js.map +1 -1
  97. package/dist/features/homework/hw-card-list/hw-card-list-utils.js +12 -0
  98. package/dist/features/homework/hw-card-list/hw-card-list-utils.js.map +1 -0
  99. package/dist/features/homework/hw-card-list/hw-card-list-view.js +137 -107
  100. package/dist/features/homework/hw-card-list/hw-card-list-view.js.map +1 -1
  101. package/dist/features/homework/styles.js +5 -4
  102. package/dist/features/homework/styles.js.map +1 -1
  103. package/dist/features/hooks/use-debounce.js +16 -0
  104. package/dist/features/hooks/use-debounce.js.map +1 -0
  105. package/dist/features/journey/hooks/use-home-page-journey/home-page-homeworks-mock.js +199 -262
  106. package/dist/features/journey/hooks/use-home-page-journey/home-page-homeworks-mock.js.map +1 -1
  107. package/dist/features/journey/hooks/use-home-page-journey/use-home-page-journey.js +15 -15
  108. package/dist/features/journey/hooks/use-home-page-journey/use-home-page-journey.js.map +1 -1
  109. package/dist/features/milestone/create/comps/add-custom-chapter/course-catalog.js +38 -36
  110. package/dist/features/milestone/create/comps/add-custom-chapter/course-catalog.js.map +1 -1
  111. package/dist/features/milestone/create/comps/add-custom-chapter/hooks/use-catalog-helpers.js +24 -22
  112. package/dist/features/milestone/create/comps/add-custom-chapter/hooks/use-catalog-helpers.js.map +1 -1
  113. package/dist/features/milestone/create/comps/chapters-selection-step/chapter-selection-step-v2/chapter-category/chapter-category-container.js +23 -22
  114. package/dist/features/milestone/create/comps/chapters-selection-step/chapter-selection-step-v2/chapter-category/chapter-category-container.js.map +1 -1
  115. package/dist/features/milestone/create/comps/chapters-selection-step/utils.js +49 -47
  116. package/dist/features/milestone/create/comps/chapters-selection-step/utils.js.map +1 -1
  117. package/dist/features/milestone/create/comps/class-details-step/class-details-step.js +94 -87
  118. package/dist/features/milestone/create/comps/class-details-step/class-details-step.js.map +1 -1
  119. package/dist/features/milestone/create/comps/class-details-step/class-details-utils.js +13 -12
  120. package/dist/features/milestone/create/comps/class-details-step/class-details-utils.js.map +1 -1
  121. package/dist/features/milestone/create/comps/test-type-step/test-type-step.js +23 -21
  122. package/dist/features/milestone/create/comps/test-type-step/test-type-step.js.map +1 -1
  123. package/dist/features/milestone/create/milestone-create-helpers.js +165 -162
  124. package/dist/features/milestone/create/milestone-create-helpers.js.map +1 -1
  125. package/dist/features/trial-session/comps/pricing/india-pricing/index.js +96 -0
  126. package/dist/features/trial-session/comps/pricing/india-pricing/index.js.map +1 -0
  127. package/dist/features/trial-session/comps/pricing/india-pricing/india-pricing-styled.js +59 -0
  128. package/dist/features/trial-session/comps/pricing/india-pricing/india-pricing-styled.js.map +1 -0
  129. package/dist/features/trial-session/comps/pricing/pricing.js +36 -35
  130. package/dist/features/trial-session/comps/pricing/pricing.js.map +1 -1
  131. package/dist/features/ui/stepper/stepper.js +7 -7
  132. package/dist/features/worksheet/worksheet/hooks/use-s3-helper.js +22 -19
  133. package/dist/features/worksheet/worksheet/hooks/use-s3-helper.js.map +1 -1
  134. package/dist/index.d.ts +311 -260
  135. package/dist/index.js +184 -180
  136. package/dist/index.js.map +1 -1
  137. package/dist/static/accuracy-meter.99585cba.json +4218 -0
  138. package/dist/static/accuracy-needle.cd6e63ac.json +618 -0
  139. package/dist/static/achievement_bg.0d0555ac.png +0 -0
  140. package/dist/static/advance-mode-segment-lottie.51ff6707.json +1 -0
  141. package/dist/static/alarm-clock-orange.31fb90d9.svg +1 -0
  142. package/dist/static/alarm-clock-purple.06d4911c.svg +1 -0
  143. package/dist/static/alien-1.fc7ba696.svg +1 -0
  144. package/dist/static/alien-2.15fdda07.svg +1 -0
  145. package/dist/static/alien-3.2664a37f.svg +1 -0
  146. package/dist/static/alien-4.06ac66da.svg +1 -0
  147. package/dist/static/ashta.0d3926b2.png +0 -0
  148. package/dist/static/avatar-selected.860ee923.json +1 -0
  149. package/dist/static/awesome.8e1cf046.png +0 -0
  150. package/dist/static/badge_success.2f6c8e65.png +0 -0
  151. package/dist/static/beginner1x.489908a7.json +3508 -0
  152. package/dist/static/bg_empty_resources.63b187fd.png +0 -0
  153. package/dist/static/blue-clip.87cc4543.svg +1 -0
  154. package/dist/static/bobwave.5603c70b.gif +0 -0
  155. package/dist/static/book-green.20f6eed3.svg +1 -0
  156. package/dist/static/book-open-blue.d4f8d08c.svg +5 -0
  157. package/dist/static/book-orange.04bdc75e.svg +1 -0
  158. package/dist/static/book-yellow.c210ac06.svg +1 -0
  159. package/dist/static/bronze-1.da4e4b5f.json +4176 -0
  160. package/dist/static/bronze-2.97f9c639.json +4433 -0
  161. package/dist/static/bronze-3.6a433ebd.json +4786 -0
  162. package/dist/static/bullet-yellow.2f892d88.svg +1 -0
  163. package/dist/static/calendar-blue.e0d52d09.svg +1 -0
  164. package/dist/static/calendar-gray.1c72682a.svg +1 -0
  165. package/dist/static/calendar-green.a2b6a393.svg +1 -0
  166. package/dist/static/caution.5766a967.svg +1 -0
  167. package/dist/static/chapter-1.8a1683a0.svg +1 -0
  168. package/dist/static/chapter-10.c97de4a5.svg +1 -0
  169. package/dist/static/chapter-2.71ac6dfc.svg +1 -0
  170. package/dist/static/chapter-3.003fc901.svg +1 -0
  171. package/dist/static/chapter-4.8abbacd8.svg +1 -0
  172. package/dist/static/chapter-5.c774b439.svg +1 -0
  173. package/dist/static/chapter-6.cb5cf1cb.svg +1 -0
  174. package/dist/static/chapter-7.57b0beb4.svg +1 -0
  175. package/dist/static/chapter-8.68d36477.svg +1 -0
  176. package/dist/static/chapter-9.0c00e26f.svg +1 -0
  177. package/dist/static/chapter-completed.1241399b.json +497 -0
  178. package/dist/static/chapter-header-bg-2.c8d96894.svg +1 -0
  179. package/dist/static/chapter-header-bg.4ed173c2.svg +1 -0
  180. package/dist/static/chatva.d0c57a95.png +0 -0
  181. package/dist/static/circle-cuemath-logo-white.e9fafb91.svg +1 -0
  182. package/dist/static/circle-cuemath-logo.8bcb1ad4.svg +1 -0
  183. package/dist/static/circle-outercircle-bg.65f21460.svg +1 -0
  184. package/dist/static/circular-loader.a5a1a0a6.json +238 -0
  185. package/dist/static/clock-30min.eae818b8.json +1197 -0
  186. package/dist/static/clock-45min.df8adf51.json +1197 -0
  187. package/dist/static/clock-60min.2b48d875.json +1197 -0
  188. package/dist/static/clock-90min.3e557ed7.json +1407 -0
  189. package/dist/static/clock-orange.c144059b.svg +6 -0
  190. package/dist/static/color-1.45101b9a.json +4545 -0
  191. package/dist/static/color-2.ccdc7d0a.json +4828 -0
  192. package/dist/static/color-3.5e8e1422.json +5273 -0
  193. package/dist/static/community-bulb.3b42af21.svg +1 -0
  194. package/dist/static/competitive-arena.b9c40801.json +1 -0
  195. package/dist/static/congrats.75718de8.png +0 -0
  196. package/dist/static/cool.1893941c.png +0 -0
  197. package/dist/static/cosa.46c0c49b.png +0 -0
  198. package/dist/static/crosshair-circle.522a26ea.svg +1 -0
  199. package/dist/static/crown-overlay.11fb073c.svg +1 -0
  200. package/dist/static/crown.c18fa217.svg +1 -0
  201. package/dist/static/cuecoin-gold.bcb8085e.svg +1 -0
  202. package/dist/static/cuemath-app-qr-code.4beefe48.svg +1 -0
  203. package/dist/static/cuemath-app-qr-code.ba6cc09b.svg +1 -0
  204. package/dist/static/cuemath-app-qr-code.d0912fc7.png +0 -0
  205. package/dist/static/default-chapter.8ede1160.png +0 -0
  206. package/dist/static/desktop-with-purple-fill.dfec66cc.svg +1 -0
  207. package/dist/static/difficult.6846c064.json +2755 -0
  208. package/dist/static/dob.9ce3c15b.json +1 -0
  209. package/dist/static/doda.3103971c.png +0 -0
  210. package/dist/static/duration-30min-gray.f6442df4.svg +1 -0
  211. package/dist/static/duration-45min-gray.ad90fb23.svg +1 -0
  212. package/dist/static/duration-60min-gray.874e52a2.svg +1 -0
  213. package/dist/static/duration-90min-gray.32a04cef.svg +1 -0
  214. package/dist/static/dvi.fc7b32a5.png +0 -0
  215. package/dist/static/earth-green.e1329b7a.svg +1 -0
  216. package/dist/static/easy-rescheduling.3a6d1a00.gif +0 -0
  217. package/dist/static/easy.68242ddd.json +2658 -0
  218. package/dist/static/eka.b10a06fa.png +0 -0
  219. package/dist/static/elite-circle.3df58972.json +6876 -0
  220. package/dist/static/ellipse-clip.dfb25608.svg +1 -0
  221. package/dist/static/empty_mix_tests.1d251f07.png +0 -0
  222. package/dist/static/enrichment-mini.fc3c0f83.gif +0 -0
  223. package/dist/static/enrichment.571feac0.gif +0 -0
  224. package/dist/static/error-lottie.b3507a4b.json +5255 -0
  225. package/dist/static/error.cbe1ddde.json +1 -0
  226. package/dist/static/familiar1x.7c9c7f15.json +3046 -0
  227. package/dist/static/female-avatar.b8cd1012.svg +1 -0
  228. package/dist/static/fifteen-min-clock.0af4e303.json +715 -0
  229. package/dist/static/five-min-clock.6be5cc41.json +721 -0
  230. package/dist/static/game-play.4982b0cb.svg +1 -0
  231. package/dist/static/games.47abcb18.gif +0 -0
  232. package/dist/static/globe-with-blue-fill.beae6ca4.svg +1 -0
  233. package/dist/static/gold-1.ab2489fe.json +4176 -0
  234. package/dist/static/gold-2.34045826.json +4441 -0
  235. package/dist/static/gold-3.d704698b.json +4810 -0
  236. package/dist/static/grade-grid-background.b17b4ccb.svg +1 -0
  237. package/dist/static/grade.b3730524.json +1 -0
  238. package/dist/static/graduate-hat.4b49eb44.svg +1 -0
  239. package/dist/static/graduate-icon-pink.01fbfb1b.svg +1 -0
  240. package/dist/static/graduate-pink-filled-bg.c91e9c53.svg +1 -0
  241. package/dist/static/great.2a5dcc34.png +0 -0
  242. package/dist/static/green-balloon.67ac8587.svg +1 -0
  243. package/dist/static/green-face.1b4dd82f.svg +1 -0
  244. package/dist/static/hexo.eab4b9f5.png +0 -0
  245. package/dist/static/infinite-button-bg.5909225e.json +1 -0
  246. package/dist/static/infinite-button-symbol.aa31350c.json +1 -0
  247. package/dist/static/jigii-wave.150a6d18.gif +0 -0
  248. package/dist/static/key.d6846476.json +1 -0
  249. package/dist/static/kudos.b7e2aeb6.png +0 -0
  250. package/dist/static/learn.71b13323.json +1 -0
  251. package/dist/static/learned-shield-gray.1495b0d5.svg +1 -0
  252. package/dist/static/learned-shield-green.7c26b423.svg +1 -0
  253. package/dist/static/learning-plan.72d64a61.png +0 -0
  254. package/dist/static/learning-session.71cc8f22.gif +0 -0
  255. package/dist/static/learnt.870c5e38.svg +1 -0
  256. package/dist/static/lesson-overview-banner.f5404af6.png +0 -0
  257. package/dist/static/levelup-rings.b1055283.json +549 -0
  258. package/dist/static/like.cb492460.svg +1 -0
  259. package/dist/static/live-session.a0d25c78.svg +1 -0
  260. package/dist/static/loader-1.6524355e.svg +1 -0
  261. package/dist/static/loader.52f8c35c.svg +1 -0
  262. package/dist/static/locked.0c3b7577.svg +1 -0
  263. package/dist/static/mail.c30e8708.json +1 -0
  264. package/dist/static/maintenance.a26aca65.svg +1 -0
  265. package/dist/static/male-avatar.2febc9eb.svg +1 -0
  266. package/dist/static/mastered-badge.81f156fb.svg +1 -0
  267. package/dist/static/mastered-shield-gray.a58cbe19.svg +1 -0
  268. package/dist/static/mastered-shield-green.070fa4eb.svg +1 -0
  269. package/dist/static/max-wave.44e002c9.gif +0 -0
  270. package/dist/static/medium.94c3829b.json +2289 -0
  271. package/dist/static/mental-math.3c95f169.svg +1 -0
  272. package/dist/static/milestone-intro-1.281a354c.svg +1 -0
  273. package/dist/static/milestone-intro-2.19faee69.svg +1 -0
  274. package/dist/static/milestone-intro-3.6f6055d6.svg +1 -0
  275. package/dist/static/mistake.476d1aa7.svg +1 -0
  276. package/dist/static/no-info.f4bfe437.png +0 -0
  277. package/dist/static/node-custom-test-bg.d3b757be.svg +1 -0
  278. package/dist/static/node-learn-bg.b61f815c.svg +1 -0
  279. package/dist/static/node-practice-bg.16cbaf2a.svg +1 -0
  280. package/dist/static/node-project-bg.e6a33e28.svg +1 -0
  281. package/dist/static/node-puzzle-bg.3422135c.svg +1 -0
  282. package/dist/static/node-recap-bg.546154e4.svg +1 -0
  283. package/dist/static/node-test-prep-bg.42c0b9c4.svg +1 -0
  284. package/dist/static/node-video-bg.3df3f73a.svg +1 -0
  285. package/dist/static/nudge-tap.5cb30093.json +1057 -0
  286. package/dist/static/number-1-orange.cbf526ed.svg +1 -0
  287. package/dist/static/number-2-orange.6f29eb72.svg +1 -0
  288. package/dist/static/number-3-orange.58baf717.svg +1 -0
  289. package/dist/static/number-4-orange.5ed1ec5e.svg +1 -0
  290. package/dist/static/octo.3020bd93.png +0 -0
  291. package/dist/static/one-star-filled.b6084257.svg +1 -0
  292. package/dist/static/orange-face.5824c2e9.svg +1 -0
  293. package/dist/static/otp.2d08f874.json +1 -0
  294. package/dist/static/otp.a3029760.json +1 -0
  295. package/dist/static/parent-avatar.772d53e0.json +1 -0
  296. package/dist/static/people-with-orange-fill.3835b8f1.svg +1 -0
  297. package/dist/static/phone-number.0be312ea.json +1 -0
  298. package/dist/static/phone-number.84f55562.json +1 -0
  299. package/dist/static/play-icon.13baaa7d.svg +1 -0
  300. package/dist/static/play.68d16dec.svg +1 -0
  301. package/dist/static/point1.b53831de.json +2942 -0
  302. package/dist/static/point10.7b5e536d.json +3179 -0
  303. package/dist/static/point100.1df16f82.json +3196 -0
  304. package/dist/static/point15.fea00c32.json +3179 -0
  305. package/dist/static/point2.7cec6e24.json +1 -0
  306. package/dist/static/point20.c88d776d.json +3178 -0
  307. package/dist/static/point25.a18c346a.json +3178 -0
  308. package/dist/static/point3.f96fe7aa.json +1 -0
  309. package/dist/static/point30.c5224b0b.json +3202 -0
  310. package/dist/static/point35.fad343dd.json +3058 -0
  311. package/dist/static/point4.fe04fb83.json +1 -0
  312. package/dist/static/point40.10a16f72.json +3082 -0
  313. package/dist/static/point45.2ad7561f.json +3082 -0
  314. package/dist/static/point5.da40ed1f.json +2948 -0
  315. package/dist/static/point50.5718cb3d.json +3046 -0
  316. package/dist/static/point60.17380d9f.json +3076 -0
  317. package/dist/static/points-sum.360e63de.svg +1 -0
  318. package/dist/static/practice.158dd488.json +1 -0
  319. package/dist/static/practiced-shield-green.90278855.svg +1 -0
  320. package/dist/static/practiced-shield-grey.16cf4fe0.svg +1 -0
  321. package/dist/static/proficient-badge.1a6dbb72.svg +1 -0
  322. package/dist/static/proficient1x.fa6e7b80.json +3430 -0
  323. package/dist/static/profile-board.4f4a17e6.svg +1 -0
  324. package/dist/static/project.eb665827.json +1 -0
  325. package/dist/static/puzzle-student.de530364.svg +1 -0
  326. package/dist/static/puzzle.5aad5cf8.svg +1 -0
  327. package/dist/static/puzzle.b298c7e4.json +1 -0
  328. package/dist/static/puzzle_card_easy.7d9439b5.png +0 -0
  329. package/dist/static/puzzle_card_hard.185a19c4.png +0 -0
  330. package/dist/static/puzzle_card_medium.17daef9c.png +0 -0
  331. package/dist/static/puzzles.1e269965.gif +0 -0
  332. package/dist/static/random-mode-segment-lottie.79cf1c07.json +1 -0
  333. package/dist/static/recap.0dd2c1e2.json +1 -0
  334. package/dist/static/refund-policy-with-headphone.589398e0.svg +1 -0
  335. package/dist/static/refund-policy.912dbb4c.svg +1 -0
  336. package/dist/static/report-404.dd67785c.svg +1 -0
  337. package/dist/static/rocket-broken.1f86fa43.svg +1 -0
  338. package/dist/static/rocket-yellow.62d27e15.svg +1 -0
  339. package/dist/static/school-success-mini.f74a852f.gif +0 -0
  340. package/dist/static/school-success.f9669771.gif +0 -0
  341. package/dist/static/score.41971107.svg +1 -0
  342. package/dist/static/sequence-mode-segment-lottie.11ac49e9.json +1 -0
  343. package/dist/static/shared.3af01b49.png +0 -0
  344. package/dist/static/sheet-reference.9da7a09f.png +0 -0
  345. package/dist/static/silver-1.0396328a.json +4168 -0
  346. package/dist/static/silver-2.bf50615f.json +4433 -0
  347. package/dist/static/silver-3.13d66b84.json +4810 -0
  348. package/dist/static/skills.90ce4cbb.gif +0 -0
  349. package/dist/static/sleepy-boi.031a1165.json +1008 -0
  350. package/dist/static/smiley.49bb7d7c.svg +1 -0
  351. package/dist/static/speckie-wave.510639ce.gif +0 -0
  352. package/dist/static/spinner-white.639e0d87.json +122 -0
  353. package/dist/static/spiral_pattern.9fd3e6e9.png +0 -0
  354. package/dist/static/splash-screen.bbf567ce.json +2411 -0
  355. package/dist/static/star-orange-filled.a7ff9c8f.svg +1 -0
  356. package/dist/static/star-orange.a91a341f.svg +1 -0
  357. package/dist/static/star-with-green-fill.86877d41.svg +1 -0
  358. package/dist/static/stay-connected.371d3d9d.gif +0 -0
  359. package/dist/static/streak-green.b59bf4dd.svg +1 -0
  360. package/dist/static/streak-white.2cbdc9b8.svg +1 -0
  361. package/dist/static/student-avatar.524226bd.json +1 -0
  362. package/dist/static/table-mode-reveal.b44a82c3.json +1 -0
  363. package/dist/static/table-mode-star.b8a1d762.json +1 -0
  364. package/dist/static/table-segment-star.78e851d6.json +1 -0
  365. package/dist/static/target-achieved-text.053bd142.json +2830 -0
  366. package/dist/static/target-achieved-text.10db8475.json +1 -0
  367. package/dist/static/teacher-validation.7577ecdc.json +245 -0
  368. package/dist/static/tera-wave.2954a6a4.gif +0 -0
  369. package/dist/static/test-difficulty-easy.56df71dd.svg +1 -0
  370. package/dist/static/test-difficulty-hard.7250f1f4.svg +1 -0
  371. package/dist/static/test-difficulty-medium.2fd9686e.svg +1 -0
  372. package/dist/static/test-prep-mini.718e5734.gif +0 -0
  373. package/dist/static/test-prep.ea433f71.gif +0 -0
  374. package/dist/static/test.803d6036.json +1 -0
  375. package/dist/static/tetra.354ff2b9.png +0 -0
  376. package/dist/static/three-stars-filled.72b51f03.svg +1 -0
  377. package/dist/static/tick-green.a1654049.svg +1 -0
  378. package/dist/static/total-streak.d5ce7669.json +842 -0
  379. package/dist/static/total-time-spent.434005d3.json +200 -0
  380. package/dist/static/total-time.d979cbb9.json +24383 -0
  381. package/dist/static/tournament-ripple.e5c239a5.json +1047 -0
  382. package/dist/static/track-progress.c75b1031.gif +0 -0
  383. package/dist/static/trophy-blue-filled.7e2b40ab.svg +1 -0
  384. package/dist/static/trophy-blue.e684ba4c.svg +1 -0
  385. package/dist/static/trophy-circle.b7b23e36.svg +1 -0
  386. package/dist/static/trophy-green.6c0741c8.svg +10 -0
  387. package/dist/static/two-stars-filled.a51a14b4.svg +1 -0
  388. package/dist/static/up-arrow.a6946bd3.svg +1 -0
  389. package/dist/static/user-crown-grid-background.c2875a73.svg +1 -0
  390. package/dist/static/user-down.a06f2f94.svg +1 -0
  391. package/dist/static/user-pin.5f334465.svg +1 -0
  392. package/dist/static/user-profile-background.199977a9.svg +1 -0
  393. package/dist/static/user-type-selector-grid-bg.3c9c8ad6.svg +1 -0
  394. package/dist/static/user-type-selector-grid-bg.3ce8142d.svg +1 -0
  395. package/dist/static/user-type-selector-grid-bg.aad0b059.svg +1 -0
  396. package/dist/static/user-up.2aecbbae.svg +1 -0
  397. package/dist/static/username.9e034d51.json +1 -0
  398. package/dist/static/video.b41451e2.json +1 -0
  399. package/dist/static/vinnie-wave.10734dd5.gif +0 -0
  400. package/dist/static/way-forward.1428093e.gif +0 -0
  401. package/dist/static/wow.864fbb02.png +0 -0
  402. package/dist/static/yellow-face.b7525a33.svg +1 -0
  403. package/dist/static/your-goals.63ffbee5.gif +0 -0
  404. package/dist/static/zodasa.336c3bb0.png +0 -0
  405. package/package.json +3 -2
@@ -0,0 +1,68 @@
1
+ import { jsx as o, jsxs as R } from "react/jsx-runtime";
2
+ import { h as c } from "../../../../node_modules/humanize-plus/dist/humanize.js";
3
+ import { memo as q, useCallback as k } from "react";
4
+ import y from "../../../ui/buttons/clickable/clickable.js";
5
+ import $ from "../../../ui/layout/flex-view.js";
6
+ import d from "../../../ui/text/text.js";
7
+ import { useCueCanvasActions as W } from "../../hooks/use-cue-canvas-actions.js";
8
+ import { getDateInInputFormat as _, getMonthNameforNumber as E } from "./helper.js";
9
+ import { HWImageContainer as T } from "./homework-styled.js";
10
+ import l from "../../../../node_modules/uuid/dist/esm-browser/v4.js";
11
+ const v = (u) => {
12
+ var a;
13
+ const { hwRequest: p, onSelect: r, studentName: h } = u, {
14
+ problem_description: m,
15
+ problem_image_urls: e,
16
+ created_on_ts: f,
17
+ homework_id: s
18
+ } = p, { setHomeworkId: n, activeInstance: t } = W(), g = k(() => {
19
+ const x = l();
20
+ if (e && e.length > 0) {
21
+ const i = {
22
+ data: {
23
+ [x]: [
24
+ void 0,
25
+ {
26
+ name: "text",
27
+ html: m,
28
+ x: 500,
29
+ y: 75,
30
+ rot: 0
31
+ }
32
+ ]
33
+ }
34
+ };
35
+ e.forEach((C) => {
36
+ const H = l();
37
+ i.data[H] = [
38
+ void 0,
39
+ {
40
+ name: "image",
41
+ href: C + "?dummyProp=true",
42
+ x: 48,
43
+ y: 72,
44
+ rot: 0,
45
+ width: 400
46
+ }
47
+ ];
48
+ }), t == null || t.replaceCanvas(i);
49
+ }
50
+ r(), n(s);
51
+ }, [t, m, s, e, r, n]), { date: I, month: w } = _(f), b = `${c.ordinal(I)} ${c.titleCase((a = E(w)) == null ? void 0 : a.toLowerCase())}`;
52
+ return /* @__PURE__ */ o(y, { label: "HW Request Item", onClick: g, children: /* @__PURE__ */ R($, { $alignItems: "center", $justifyContent: "center", $borderRadius: 8, $background: "WHITE", children: [
53
+ /* @__PURE__ */ o(
54
+ T,
55
+ {
56
+ src: e[0] + "?dummyProp=true",
57
+ alt: "Homework Request",
58
+ crossOrigin: "anonymous"
59
+ }
60
+ ),
61
+ /* @__PURE__ */ o(d, { $renderAs: "body3", color: "WHITE", children: h }),
62
+ /* @__PURE__ */ o(d, { $renderAs: "body3", color: "WHITE", children: b })
63
+ ] }) });
64
+ }, M = q(v);
65
+ export {
66
+ M as default
67
+ };
68
+ //# sourceMappingURL=homework-request.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"homework-request.js","sources":["../../../../../src/features/cue-canvas/sidebar/homework/homework-request.tsx"],"sourcesContent":["import type { IReplaceCanvas } from '../../types/cue-canvas';\nimport type { IHomeWorkRequestProps } from './homework-types';\n\nimport { ordinal, titleCase } from 'humanize-plus';\nimport { memo, useCallback } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\n\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport { useCueCanvasActions } from '../../hooks/use-cue-canvas-actions';\nimport { getDateInInputFormat, getMonthNameforNumber } from './helper';\nimport * as Styled from './homework-styled';\n\nconst HomeWorkRequest: React.FC<IHomeWorkRequestProps> = props => {\n const { hwRequest, onSelect, studentName } = props;\n const {\n problem_description: hwRequestDesc,\n problem_image_urls: hwRequestImages,\n created_on_ts: createdOnTs,\n homework_id: hwRequestId,\n } = hwRequest;\n const { setHomeworkId, activeInstance } = useCueCanvasActions();\n\n const onSelectHwRequest = useCallback(() => {\n const textId = uuidv4();\n\n if (hwRequestImages && hwRequestImages.length > 0) {\n const actionData: IReplaceCanvas = {\n data: {\n [textId]: [\n undefined,\n {\n name: 'text',\n html: hwRequestDesc,\n x: 500,\n y: 75,\n rot: 0,\n },\n ],\n },\n };\n\n hwRequestImages.forEach(image => {\n const imgId = uuidv4();\n\n actionData.data[imgId] = [\n undefined,\n {\n name: 'image',\n href: image + '?dummyProp=true',\n x: 48,\n y: 72,\n rot: 0,\n width: 400,\n },\n ];\n });\n\n activeInstance?.replaceCanvas(actionData);\n }\n onSelect();\n setHomeworkId(hwRequestId);\n }, [activeInstance, hwRequestDesc, hwRequestId, hwRequestImages, onSelect, setHomeworkId]);\n\n const { date, month } = getDateInInputFormat(createdOnTs);\n\n const dateString = `${ordinal(date)} ${titleCase(getMonthNameforNumber(month)?.toLowerCase())}`;\n\n return (\n <Clickable label=\"HW Request Item\" onClick={onSelectHwRequest}>\n <FlexView $alignItems=\"center\" $justifyContent=\"center\" $borderRadius={8} $background=\"WHITE\">\n <Styled.HWImageContainer\n src={hwRequestImages[0] + '?dummyProp=true'}\n alt=\"Homework Request\"\n crossOrigin=\"anonymous\"\n />\n <Text $renderAs=\"body3\" color=\"WHITE\">\n {studentName}\n </Text>\n <Text $renderAs=\"body3\" color=\"WHITE\">\n {dateString}\n </Text>\n </FlexView>\n </Clickable>\n );\n};\n\nexport default memo(HomeWorkRequest);\n"],"names":["HomeWorkRequest","props","hwRequest","onSelect","studentName","hwRequestDesc","hwRequestImages","createdOnTs","hwRequestId","setHomeworkId","activeInstance","useCueCanvasActions","onSelectHwRequest","useCallback","textId","uuidv4","actionData","image","imgId","date","month","getDateInInputFormat","dateString","ordinal","titleCase","_a","getMonthNameforNumber","jsx","Clickable","jsxs","FlexView","Styled.HWImageContainer","Text","HWRequest","memo"],"mappings":";;;;;;;;;;AAcA,MAAMA,IAAmD,CAASC,MAAA;;AAChE,QAAM,EAAE,WAAAC,GAAW,UAAAC,GAAU,aAAAC,EAAA,IAAgBH,GACvC;AAAA,IACJ,qBAAqBI;AAAA,IACrB,oBAAoBC;AAAA,IACpB,eAAeC;AAAA,IACf,aAAaC;AAAA,EACX,IAAAN,GACE,EAAE,eAAAO,GAAe,gBAAAC,EAAe,IAAIC,EAAoB,GAExDC,IAAoBC,EAAY,MAAM;AAC1C,UAAMC,IAASC;AAEX,QAAAT,KAAmBA,EAAgB,SAAS,GAAG;AACjD,YAAMU,IAA6B;AAAA,QACjC,MAAM;AAAA,UACJ,CAACF,CAAM,GAAG;AAAA,YACR;AAAA,YACA;AAAA,cACE,MAAM;AAAA,cACN,MAAMT;AAAA,cACN,GAAG;AAAA,cACH,GAAG;AAAA,cACH,KAAK;AAAA,YACP;AAAA,UACF;AAAA,QACF;AAAA,MAAA;AAGF,MAAAC,EAAgB,QAAQ,CAASW,MAAA;AAC/B,cAAMC,IAAQH;AAEH,QAAAC,EAAA,KAAKE,CAAK,IAAI;AAAA,UACvB;AAAA,UACA;AAAA,YACE,MAAM;AAAA,YACN,MAAMD,IAAQ;AAAA,YACd,GAAG;AAAA,YACH,GAAG;AAAA,YACH,KAAK;AAAA,YACL,OAAO;AAAA,UACT;AAAA,QAAA;AAAA,MACF,CACD,GAEDP,KAAA,QAAAA,EAAgB,cAAcM;AAAA,IAChC;AACS,IAAAb,KACTM,EAAcD,CAAW;AAAA,EAAA,GACxB,CAACE,GAAgBL,GAAeG,GAAaF,GAAiBH,GAAUM,CAAa,CAAC,GAEnF,EAAE,MAAAU,GAAM,OAAAC,EAAM,IAAIC,EAAqBd,CAAW,GAElDe,IAAa,GAAGC,UAAQJ,CAAI,CAAC,IAAIK,aAAUC,IAAAC,EAAsBN,CAAK,MAA3B,gBAAAK,EAA8B,aAAa,CAAC;AAE7F,SACG,gBAAAE,EAAAC,GAAA,EAAU,OAAM,mBAAkB,SAAShB,GAC1C,UAAA,gBAAAiB,EAACC,GAAS,EAAA,aAAY,UAAS,iBAAgB,UAAS,eAAe,GAAG,aAAY,SACpF,UAAA;AAAA,IAAA,gBAAAH;AAAA,MAACI;AAAAA,MAAA;AAAA,QACC,KAAKzB,EAAgB,CAAC,IAAI;AAAA,QAC1B,KAAI;AAAA,QACJ,aAAY;AAAA,MAAA;AAAA,IACd;AAAA,sBACC0B,GAAK,EAAA,WAAU,SAAQ,OAAM,SAC3B,UACH5B,GAAA;AAAA,sBACC4B,GAAK,EAAA,WAAU,SAAQ,OAAM,SAC3B,UACHV,GAAA;AAAA,EAAA,EACF,CAAA,EACF,CAAA;AAEJ,GAEeW,IAAAC,EAAKlC,CAAe;"}
@@ -0,0 +1,25 @@
1
+ import o from "styled-components";
2
+ import t from "../../../ui/layout/flex-view.js";
3
+ const i = o(t)`
4
+ position: absolute;
5
+ top: 38px;
6
+ left: -87px; //32px + 32 px for icon +8+8(separator) +7 gutter
7
+ width: 248px;
8
+ height: 438px;
9
+ border-radius: 6px;
10
+ background: #292734;
11
+ box-shadow: 0px 4px 8px ${({ theme: r }) => r.colors.BLACK_T_20};
12
+ overflow-y: auto;
13
+ `, a = o.img.attrs({ loading: "lazy" })`
14
+ width: 184px;
15
+ height: 128px;
16
+ border-top-left-radius: 8px;
17
+ border-top-right-radius: 8px;
18
+ border-bottom-left-radius: 0;
19
+ border-bottom-right-radius: 0;
20
+ `;
21
+ export {
22
+ a as HWImageContainer,
23
+ i as MenuContainer
24
+ };
25
+ //# sourceMappingURL=homework-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"homework-styled.js","sources":["../../../../../src/features/cue-canvas/sidebar/homework/homework-styled.ts"],"sourcesContent":["import styled from 'styled-components';\n\nimport FlexView from '../../../ui/layout/flex-view';\n\nconst MenuContainer = styled(FlexView)`\n position: absolute;\n top: 38px;\n left: -87px; //32px + 32 px for icon +8+8(separator) +7 gutter\n width: 248px;\n height: 438px;\n border-radius: 6px;\n background: #292734;\n box-shadow: 0px 4px 8px ${({ theme }) => theme.colors.BLACK_T_20};\n overflow-y: auto;\n`;\nconst HWImageContainer = styled.img.attrs({ loading: 'lazy' })`\n width: 184px;\n height: 128px;\n border-top-left-radius: 8px;\n border-top-right-radius: 8px;\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n`;\n\nexport { MenuContainer, HWImageContainer };\n"],"names":["MenuContainer","styled","FlexView","theme","HWImageContainer"],"mappings":";;AAIM,MAAAA,IAAgBC,EAAOC,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAQT,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,UAAU;AAAA;AAAA,GAG5DC,IAAmBH,EAAO,IAAI,MAAM,EAAE,SAAS,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
@@ -0,0 +1,39 @@
1
+ import { jsxs as a, jsx as o } from "react/jsx-runtime";
2
+ import { memo as u, useRef as d, useCallback as f, useEffect as k } from "react";
3
+ import p from "../../../ui/buttons/clickable/clickable.js";
4
+ import h from "../../../ui/hooks/use-context-menu-click-handler.js";
5
+ import C from "../../../ui/layout/flex-view.js";
6
+ import b from "../../../ui/text/text.js";
7
+ import { StyledWrapper as w, HWWrapper as W } from "../../cue-cavas-styled.js";
8
+ import { useCueCanvasActions as H } from "../../hooks/use-cue-canvas-actions.js";
9
+ import $ from "./homework-menu.js";
10
+ const v = (m) => {
11
+ const { activeSidebar: e, setActiveSidebar: n, hwRequests: s } = m, { activeInstance: r } = H(), c = d(null), { menuVisible: i, onMenuClick: t } = h(
12
+ c,
13
+ void 0,
14
+ !0,
15
+ void 0
16
+ ), l = f(() => {
17
+ e === "tile" && (r == null || r.toggleTiles(!1)), n(e === "homework" ? void 0 : "homework"), t();
18
+ }, [e, r, t, n]);
19
+ return k(() => {
20
+ (e === "tile" || e === "puzzle") && i && t();
21
+ }, [e, i, t]), /* @__PURE__ */ a(C, { $position: "relative", children: [
22
+ /* @__PURE__ */ o(p, { onClick: l, label: "homework help", children: /* @__PURE__ */ o(w, { $active: e === "homework", children: /* @__PURE__ */ o(
23
+ W,
24
+ {
25
+ $background: e === "homework" ? "BLACK" : "WHITE",
26
+ $borderColor: e === "homework" ? "WHITE" : "BLACK",
27
+ $borderRadius: 4,
28
+ $alignItems: "center",
29
+ $justifyContent: "center",
30
+ children: /* @__PURE__ */ o(b, { $color: e === "homework" ? "WHITE" : "BLACK", $renderAs: "ub3-bold", children: "HW" })
31
+ }
32
+ ) }) }),
33
+ i && /* @__PURE__ */ o($, { onSelect: l, hwRequests: s })
34
+ ] });
35
+ }, j = u(v);
36
+ export {
37
+ j as default
38
+ };
39
+ //# sourceMappingURL=homework.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"homework.js","sources":["../../../../../src/features/cue-canvas/sidebar/homework/homework.tsx"],"sourcesContent":["import type { IHomeWorkRequestsContainerProps } from './homework-types';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect, useRef } from 'react';\n\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../../../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport { StyledWrapper, HWWrapper } from '../../cue-cavas-styled';\nimport { useCueCanvasActions } from '../../hooks/use-cue-canvas-actions';\nimport HomeWorkMenu from './homework-menu';\n\nconst HomeWorkRequestsContainer: FC<IHomeWorkRequestsContainerProps> = props => {\n const { activeSidebar, setActiveSidebar, hwRequests } = props;\n const { activeInstance: cueCanvas } = useCueCanvasActions();\n const homeWorkMenuRef = useRef(null);\n\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(\n homeWorkMenuRef,\n undefined,\n true,\n undefined,\n );\n\n const handleClick = useCallback(() => {\n if (activeSidebar === 'tile') {\n cueCanvas?.toggleTiles(false);\n }\n setActiveSidebar(activeSidebar === 'homework' ? undefined : 'homework');\n onMenuClick();\n }, [activeSidebar, cueCanvas, onMenuClick, setActiveSidebar]);\n\n useEffect(() => {\n if ((activeSidebar === 'tile' || activeSidebar === 'puzzle') && menuVisible) {\n onMenuClick();\n }\n }, [activeSidebar, menuVisible, onMenuClick]);\n\n return (\n <FlexView $position=\"relative\">\n <Clickable onClick={handleClick} label=\"homework help\">\n <StyledWrapper $active={activeSidebar === 'homework'}>\n <HWWrapper\n $background={activeSidebar === 'homework' ? 'BLACK' : 'WHITE'}\n $borderColor={activeSidebar === 'homework' ? 'WHITE' : 'BLACK'}\n $borderRadius={4}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n >\n <Text $color={activeSidebar === 'homework' ? 'WHITE' : 'BLACK'} $renderAs=\"ub3-bold\">\n HW\n </Text>\n </HWWrapper>\n </StyledWrapper>\n </Clickable>\n {menuVisible && <HomeWorkMenu onSelect={handleClick} hwRequests={hwRequests} />}\n </FlexView>\n );\n};\n\nexport default memo(HomeWorkRequestsContainer);\n"],"names":["HomeWorkRequestsContainer","props","activeSidebar","setActiveSidebar","hwRequests","cueCanvas","useCueCanvasActions","homeWorkMenuRef","useRef","menuVisible","onMenuClick","useContextMenuClickHandler","handleClick","useCallback","useEffect","jsxs","FlexView","jsx","Clickable","StyledWrapper","HWWrapper","Text","HomeWorkMenu","Homework","memo"],"mappings":";;;;;;;;;AAaA,MAAMA,IAAiE,CAASC,MAAA;AAC9E,QAAM,EAAE,eAAAC,GAAe,kBAAAC,GAAkB,YAAAC,EAAA,IAAeH,GAClD,EAAE,gBAAgBI,EAAU,IAAIC,EAAoB,GACpDC,IAAkBC,EAAO,IAAI,GAE7B,EAAE,aAAAC,GAAa,aAAAC,EAAA,IAAgBC;AAAA,IACnCJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,GAGIK,IAAcC,EAAY,MAAM;AACpC,IAAIX,MAAkB,WACpBG,KAAA,QAAAA,EAAW,YAAY,MAERF,EAAAD,MAAkB,aAAa,SAAY,UAAU,GAC1DQ;KACX,CAACR,GAAeG,GAAWK,GAAaP,CAAgB,CAAC;AAE5D,SAAAW,EAAU,MAAM;AACd,KAAKZ,MAAkB,UAAUA,MAAkB,aAAaO,KAClDC;EAEb,GAAA,CAACR,GAAeO,GAAaC,CAAW,CAAC,GAG1C,gBAAAK,EAACC,GAAS,EAAA,WAAU,YAClB,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAU,SAASN,GAAa,OAAM,iBACrC,UAAC,gBAAAK,EAAAE,GAAA,EAAc,SAASjB,MAAkB,YACxC,UAAA,gBAAAe;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,aAAalB,MAAkB,aAAa,UAAU;AAAA,QACtD,cAAcA,MAAkB,aAAa,UAAU;AAAA,QACvD,eAAe;AAAA,QACf,aAAY;AAAA,QACZ,iBAAgB;AAAA,QAEhB,UAAA,gBAAAe,EAACI,KAAK,QAAQnB,MAAkB,aAAa,UAAU,SAAS,WAAU,YAAW,UAErF,KAAA,CAAA;AAAA,MAAA;AAAA,OAEJ,EACF,CAAA;AAAA,IACCO,KAAe,gBAAAQ,EAACK,GAAa,EAAA,UAAUV,GAAa,YAAAR,GAAwB;AAAA,EAC/E,EAAA,CAAA;AAEJ,GAEemB,IAAAC,EAAKxB,CAAyB;"}
@@ -0,0 +1,13 @@
1
+ import { createGetAPI as e } from "@cuemath/rest-api";
2
+ import { BASE_URL_V3 as r, BASE_URL_V2 as c } from "../../../../../constants/api.js";
3
+ import { stringify as o } from "../../../../../helpers/query-string.js";
4
+ const { get: g } = e({
5
+ getURL: (t, i) => `${r}/curriculum/cueboard-activities/?${o(i)}`
6
+ }), { useGet: _ } = e({
7
+ getURL: (t) => `${c}/curriculum/wb-activities/${t}`
8
+ });
9
+ export {
10
+ g as getPuzzles,
11
+ _ as useGetActivity
12
+ };
13
+ //# sourceMappingURL=get-puzzles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-puzzles.js","sources":["../../../../../../src/features/cue-canvas/sidebar/puzzles/api/get-puzzles.ts"],"sourcesContent":["import { createGetAPI } from '@cuemath/rest-api';\n\nimport { BASE_URL_V2, BASE_URL_V3 } from '../../../../../constants/api';\nimport { stringify } from '../../../../../helpers/query-string';\n\nexport interface IFilterOption {\n applied: boolean;\n code: string;\n name: string;\n}\n\nexport interface IFilterData {\n activity_tiles: IFilterOption[];\n activity_topics: IFilterOption[];\n activity_types: IFilterOption[];\n grades: IFilterOption[];\n search: string;\n}\n\nexport interface IPuzzlesResultData {\n activity_tiles: string[];\n activity_topics: string[];\n activity_types: string[];\n activity_url: string;\n created_on: string;\n created_on_ts: number;\n grades: string[];\n id: string;\n is_live: boolean;\n name: string;\n node_id: string;\n updated_on: string;\n updated_on_ts: number;\n}\nexport interface IPuzzlesResponses {\n filters: IFilterData;\n results: IPuzzlesResultData[];\n}\nexport interface IGetPuzzles {\n activity_tiles?: string[];\n activity_topics?: string[];\n activity_types?: string[];\n grades?: string[];\n search?: string;\n}\n\nexport interface ActivityMetadata {\n code: string;\n description: string | null;\n id: string;\n is_live: boolean;\n name: string;\n priority: number | null;\n type: 'ACTIVITY_TILE' | 'ACTIVITY_TOPIC' | 'ACTIVITY_TYPE' | string;\n}\n\nexport interface IActivityGrade {\n code: string;\n description: string;\n id: string;\n is_live: boolean;\n name: string;\n priority: number;\n type: 'GRADE';\n}\n\nexport interface ActivityData {\n activity_tiles: ActivityMetadata[];\n activity_topics: ActivityMetadata[];\n activity_types: ActivityMetadata[];\n grades: IActivityGrade[];\n worksheet: Worksheet;\n}\n\ninterface Worksheet {\n code: string;\n complete_in: number | null;\n course_type: string;\n description: string | null;\n desmos_calculator_enabled: boolean;\n id: string;\n instructions_ref: string | null;\n is_lesson_v3_enabled: boolean;\n is_live: boolean;\n is_subjective: boolean;\n is_turing: boolean;\n learnosity_activity_ref: string | null;\n name: string;\n points_available: number;\n project_name: string;\n sheet_time: number | null;\n student_instructions_ref: string | null;\n target_accuracy: number;\n thumbnail_url: string | null;\n total_questions: number | null;\n visible_in_mpr: boolean;\n worksheet_type: string;\n}\n\nconst { get: getPuzzles } = createGetAPI<IPuzzlesResponses, IGetPuzzles>({\n getURL: (_, query) => `${BASE_URL_V3}/curriculum/cueboard-activities/?${stringify(query)}`,\n});\n\nconst { useGet: useGetActivity } = createGetAPI<ActivityData>({\n getURL: nodeId => `${BASE_URL_V2}/curriculum/wb-activities/${nodeId}`,\n});\n\nexport { getPuzzles, useGetActivity };\n"],"names":["getPuzzles","createGetAPI","_","query","BASE_URL_V3","stringify","useGetActivity","nodeId","BASE_URL_V2"],"mappings":";;;AAmGA,MAAM,EAAE,KAAKA,EAAW,IAAIC,EAA6C;AAAA,EACvE,QAAQ,CAACC,GAAGC,MAAU,GAAGC,CAAW,oCAAoCC,EAAUF,CAAK,CAAC;AAC1F,CAAC,GAEK,EAAE,QAAQG,EAAe,IAAIL,EAA2B;AAAA,EAC5D,QAAQ,CAAAM,MAAU,GAAGC,CAAW,6BAA6BD,CAAM;AACrE,CAAC;"}
@@ -0,0 +1,60 @@
1
+ import { jsxs as l, jsx as e } from "react/jsx-runtime";
2
+ import { memo as h, useState as u, useCallback as m } from "react";
3
+ import b from "../../../../assets/line-icons/icons/back.js";
4
+ import C from "../../../../assets/line-icons/icons/cross.js";
5
+ import s from "../../../ui/buttons/clickable/clickable.js";
6
+ import x from "../../../ui/buttons/text-button/text-button.js";
7
+ import k from "../../../ui/inputs/checkbox-input-list/checkbox-input-list.js";
8
+ import i from "../../../ui/layout/flex-view.js";
9
+ import d from "../../../ui/text/text.js";
10
+ import { MenuContainer as g, CheckboxWrapper as I } from "./puzzles-styled.js";
11
+ const T = ({
12
+ closeAllPopups: t,
13
+ menuItems: c,
14
+ onFiltersChange: a,
15
+ type: n
16
+ }) => {
17
+ const [o, p] = u(
18
+ c.filter((r) => r.applied).map((r) => r.name)
19
+ ), f = m((r) => {
20
+ p(r);
21
+ }, []), $ = m(() => {
22
+ a({
23
+ [n]: o
24
+ }), t();
25
+ }, [a, t, o, n]);
26
+ return /* @__PURE__ */ l(g, { children: [
27
+ /* @__PURE__ */ l(i, { $justifyContent: "space-between", $flexDirection: "row", $gutterX: 1, $gapX: 0.5, children: [
28
+ /* @__PURE__ */ l(i, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
29
+ /* @__PURE__ */ e(s, { onClick: t, label: "back", children: /* @__PURE__ */ e(b, { color: "WHITE" }) }),
30
+ /* @__PURE__ */ l(d, { $color: "WHITE", $renderAs: "eyebrow2", children: [
31
+ "Select ",
32
+ n === "grades" ? n : n.split("_")[1],
33
+ o.length > 0 && /* @__PURE__ */ e("span", { children: ` (${o.length})` })
34
+ ] })
35
+ ] }),
36
+ /* @__PURE__ */ l(i, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
37
+ /* @__PURE__ */ e(x, { color: "WHITE", label: "Apply", onClick: $ }),
38
+ /* @__PURE__ */ e(s, { onClick: t, label: "close filter menu", children: /* @__PURE__ */ e(C, { color: "WHITE" }) })
39
+ ] })
40
+ ] }),
41
+ /* @__PURE__ */ e(I, { $gutterX: 1, $gapX: 1, children: /* @__PURE__ */ e(
42
+ k,
43
+ {
44
+ size: "medium",
45
+ renderAs: "black-dark",
46
+ numColumns: 3,
47
+ options: c.map((r) => ({
48
+ id: r.name,
49
+ label: /* @__PURE__ */ e(d, { $renderAs: "ub3-bold", $color: "WHITE", $inline: !0, children: r.name })
50
+ })),
51
+ value: o,
52
+ onChange: f
53
+ }
54
+ ) })
55
+ ] });
56
+ }, A = h(T);
57
+ export {
58
+ A as default
59
+ };
60
+ //# sourceMappingURL=filter-selection-menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-selection-menu.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filter-selection-menu.tsx"],"sourcesContent":["import type { IFilterOption } from './api/get-puzzles';\nimport type { FilterSelectionMenuProps } from './puzzles-type';\n\nimport { memo, useCallback, useState } from 'react';\n\nimport BackIcon from '../../../../assets/line-icons/icons/back';\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport CheckboxInputList from '../../../ui/inputs/checkbox-input-list/checkbox-input-list';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport * as Styled from './puzzles-styled';\n\nconst FilterSelectionMenu: React.FC<FilterSelectionMenuProps> = ({\n closeAllPopups,\n menuItems,\n onFiltersChange,\n type,\n}) => {\n const [selectedOptions, setSelectedOptions] = useState<string[]>(\n menuItems.filter((ele: IFilterOption) => ele.applied).map((ele: IFilterOption) => ele.name),\n );\n\n const handleFilterChange = useCallback((selectedCodes: string[]) => {\n setSelectedOptions(selectedCodes);\n }, []);\n\n const handleApplyFilters = useCallback(() => {\n onFiltersChange({\n [type]: selectedOptions,\n });\n\n closeAllPopups();\n }, [onFiltersChange, closeAllPopups, selectedOptions, type]);\n\n return (\n <Styled.MenuContainer>\n <FlexView $justifyContent=\"space-between\" $flexDirection=\"row\" $gutterX={1} $gapX={0.5}>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <Clickable onClick={closeAllPopups} label=\"back\">\n <BackIcon color=\"WHITE\" />\n </Clickable>\n <Text $color=\"WHITE\" $renderAs=\"eyebrow2\">\n Select {type === 'grades' ? type : type.split('_')[1]}\n {selectedOptions.length > 0 && <span>{` (${selectedOptions.length})`}</span>}\n </Text>\n </FlexView>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <TextButton color=\"WHITE\" label=\"Apply\" onClick={handleApplyFilters} />\n <Clickable onClick={closeAllPopups} label=\"close filter menu\">\n <CrossIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n </FlexView>\n <Styled.CheckboxWrapper $gutterX={1} $gapX={1}>\n <CheckboxInputList\n size=\"medium\"\n renderAs=\"black-dark\"\n numColumns={3}\n options={menuItems.map(ele => ({\n id: ele.name,\n label: (\n <Text $renderAs=\"ub3-bold\" $color=\"WHITE\" $inline>\n {ele.name}\n </Text>\n ),\n }))}\n value={selectedOptions}\n onChange={handleFilterChange}\n />\n </Styled.CheckboxWrapper>\n </Styled.MenuContainer>\n );\n};\n\nexport default memo(FilterSelectionMenu);\n"],"names":["FilterSelectionMenu","closeAllPopups","menuItems","onFiltersChange","type","selectedOptions","setSelectedOptions","useState","ele","handleFilterChange","useCallback","selectedCodes","handleApplyFilters","jsxs","Styled.MenuContainer","FlexView","jsx","Clickable","BackIcon","Text","TextButton","CrossIcon","Styled.CheckboxWrapper","CheckboxInputList","FilterSelectionMenu$1","memo"],"mappings":";;;;;;;;;;AAcA,MAAMA,IAA0D,CAAC;AAAA,EAC/D,gBAAAC;AAAA,EACA,WAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,MAAAC;AACF,MAAM;AACE,QAAA,CAACC,GAAiBC,CAAkB,IAAIC;AAAA,IAC5CL,EAAU,OAAO,CAACM,MAAuBA,EAAI,OAAO,EAAE,IAAI,CAACA,MAAuBA,EAAI,IAAI;AAAA,EAAA,GAGtFC,IAAqBC,EAAY,CAACC,MAA4B;AAClE,IAAAL,EAAmBK,CAAa;AAAA,EAClC,GAAG,CAAE,CAAA,GAECC,IAAqBF,EAAY,MAAM;AAC3B,IAAAP,EAAA;AAAA,MACd,CAACC,CAAI,GAAGC;AAAA,IAAA,CACT,GAEcJ;KACd,CAACE,GAAiBF,GAAgBI,GAAiBD,CAAI,CAAC;AAGzD,SAAA,gBAAAS,EAACC,GAAA,EACC,UAAA;AAAA,IAAC,gBAAAD,EAAAE,GAAA,EAAS,iBAAgB,iBAAgB,gBAAe,OAAM,UAAU,GAAG,OAAO,KACjF,UAAA;AAAA,MAAA,gBAAAF,EAACE,KAAS,gBAAe,OAAM,aAAY,UAAS,iBAAiB,GACnE,UAAA;AAAA,QAAC,gBAAAC,EAAAC,GAAA,EAAU,SAAShB,GAAgB,OAAM,QACxC,UAAC,gBAAAe,EAAAE,GAAA,EAAS,OAAM,QAAA,CAAQ,EAC1B,CAAA;AAAA,QACC,gBAAAL,EAAAM,GAAA,EAAK,QAAO,SAAQ,WAAU,YAAW,UAAA;AAAA,UAAA;AAAA,UAChCf,MAAS,WAAWA,IAAOA,EAAK,MAAM,GAAG,EAAE,CAAC;AAAA,UACnDC,EAAgB,SAAS,KAAK,gBAAAW,EAAC,UAAM,UAAK,KAAAX,EAAgB,MAAM,IAAI,CAAA;AAAA,QAAA,GACvE;AAAA,MAAA,GACF;AAAA,wBACCU,GAAS,EAAA,gBAAe,OAAM,aAAY,UAAS,iBAAiB,GACnE,UAAA;AAAA,QAAA,gBAAAC,EAACI,KAAW,OAAM,SAAQ,OAAM,SAAQ,SAASR,GAAoB;AAAA,QACrE,gBAAAI,EAACC,GAAU,EAAA,SAAShB,GAAgB,OAAM,qBACxC,UAAC,gBAAAe,EAAAK,GAAA,EAAU,OAAM,QAAA,CAAQ,EAC3B,CAAA;AAAA,MAAA,GACF;AAAA,IAAA,GACF;AAAA,sBACCC,GAAA,EAAuB,UAAU,GAAG,OAAO,GAC1C,UAAA,gBAAAN;AAAA,MAACO;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,UAAS;AAAA,QACT,YAAY;AAAA,QACZ,SAASrB,EAAU,IAAI,CAAQM,OAAA;AAAA,UAC7B,IAAIA,EAAI;AAAA,UACR,OACG,gBAAAQ,EAAAG,GAAA,EAAK,WAAU,YAAW,QAAO,SAAQ,SAAO,IAC9C,UAAAX,EAAI,KACP,CAAA;AAAA,QAAA,EAEF;AAAA,QACF,OAAOH;AAAA,QACP,UAAUI;AAAA,MAAA;AAAA,IAAA,GAEd;AAAA,EACF,EAAA,CAAA;AAEJ,GAEee,IAAAC,EAAKzB,CAAmB;"}
@@ -0,0 +1,44 @@
1
+ import { jsxs as l, Fragment as s, jsx as r } from "react/jsx-runtime";
2
+ import { memo as a } from "react";
3
+ import d from "../../../ui/buttons/text-button/text-button.js";
4
+ import p from "../../../ui/inputs/checkbox-input-list/checkbox-input-list.js";
5
+ import u from "../../../ui/layout/flex-view.js";
6
+ import t from "../../../ui/text/text.js";
7
+ const $ = ({
8
+ title: n,
9
+ items: e,
10
+ selectedItems: i,
11
+ onChange: m,
12
+ openSelector: c
13
+ }) => /* @__PURE__ */ l(s, { children: [
14
+ /* @__PURE__ */ r(t, { $renderAs: "eyebrow2", $color: "WHITE", children: n }),
15
+ /* @__PURE__ */ l(u, { $gutterX: 0.5, $gapX: 0.5, $flexRowGapX: 0.25, children: [
16
+ e.length > 0 && /* @__PURE__ */ r(
17
+ p,
18
+ {
19
+ size: "medium",
20
+ renderAs: "black-dark",
21
+ numColumns: 1,
22
+ options: e.slice(0, 3).map((o) => ({
23
+ id: o,
24
+ label: /* @__PURE__ */ r(t, { $renderAs: "ub3-bold", $color: "WHITE", $inline: !0, children: o })
25
+ })),
26
+ value: i,
27
+ onChange: m
28
+ }
29
+ ),
30
+ e.length > 3 && /* @__PURE__ */ r(
31
+ d,
32
+ {
33
+ size: "small",
34
+ color: "GREY_2",
35
+ onClick: c,
36
+ label: `${e.length - 3}+ more`
37
+ }
38
+ )
39
+ ] })
40
+ ] }), F = a($);
41
+ export {
42
+ F as default
43
+ };
44
+ //# sourceMappingURL=filters-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters-section.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filters-section.tsx"],"sourcesContent":["import type { IFilterSectionProps } from './puzzles-type';\n\nimport React, { memo } from 'react';\n\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport CheckboxInputList from '../../../ui/inputs/checkbox-input-list/checkbox-input-list';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\n\nconst FilterSection: React.FC<IFilterSectionProps> = ({\n title,\n items,\n selectedItems,\n onChange,\n openSelector,\n}) => {\n return (\n <>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n {title}\n </Text>\n <FlexView $gutterX={0.5} $gapX={0.5} $flexRowGapX={0.25}>\n {items.length > 0 && (\n <CheckboxInputList\n size=\"medium\"\n renderAs=\"black-dark\"\n numColumns={1}\n options={items.slice(0, 3).map(ele => ({\n id: ele,\n label: (\n <Text $renderAs=\"ub3-bold\" $color=\"WHITE\" $inline>\n {ele}\n </Text>\n ),\n }))}\n value={selectedItems}\n onChange={onChange}\n />\n )}\n {items.length > 3 && (\n <TextButton\n size=\"small\"\n color=\"GREY_2\"\n onClick={openSelector}\n label={`${items.length - 3}+ more`}\n />\n )}\n </FlexView>\n </>\n );\n};\n\nexport default memo(FilterSection);\n"],"names":["FilterSection","title","items","selectedItems","onChange","openSelector","jsxs","Fragment","jsx","Text","FlexView","CheckboxInputList","ele","TextButton","FilterSection$1","memo"],"mappings":";;;;;;AASA,MAAMA,IAA+C,CAAC;AAAA,EACpD,OAAAC;AAAA,EACA,OAAAC;AAAA,EACA,eAAAC;AAAA,EACA,UAAAC;AAAA,EACA,cAAAC;AACF,MAGM,gBAAAC,EAAAC,GAAA,EAAA,UAAA;AAAA,EAAA,gBAAAC,EAACC,GAAK,EAAA,WAAU,YAAW,QAAO,SAC/B,UACHR,GAAA;AAAA,oBACCS,GAAS,EAAA,UAAU,KAAK,OAAO,KAAK,cAAc,MAChD,UAAA;AAAA,IAAAR,EAAM,SAAS,KACd,gBAAAM;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,UAAS;AAAA,QACT,YAAY;AAAA,QACZ,SAAST,EAAM,MAAM,GAAG,CAAC,EAAE,IAAI,CAAQU,OAAA;AAAA,UACrC,IAAIA;AAAA,UACJ,yBACGH,GAAK,EAAA,WAAU,YAAW,QAAO,SAAQ,SAAO,IAC9C,UACHG,EAAA,CAAA;AAAA,QAAA,EAEF;AAAA,QACF,OAAOT;AAAA,QACP,UAAAC;AAAA,MAAA;AAAA,IACF;AAAA,IAEDF,EAAM,SAAS,KACd,gBAAAM;AAAA,MAACK;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAM;AAAA,QACN,SAASR;AAAA,QACT,OAAO,GAAGH,EAAM,SAAS,CAAC;AAAA,MAAA;AAAA,IAC5B;AAAA,EAAA,GAEJ;AACF,EAAA,CAAA,GAIWY,IAAAC,EAAKf,CAAa;"}
@@ -0,0 +1,107 @@
1
+ import { jsxs as h, Fragment as B, jsx as o } from "react/jsx-runtime";
2
+ import { memo as L, useState as T, useMemo as u, useCallback as r, useEffect as g } from "react";
3
+ import I from "../../../ui/buttons/text-button/text-button.js";
4
+ import A from "../../../ui/layout/flex-view.js";
5
+ import M from "../../../ui/tab/tab.js";
6
+ import b from "../../../ui/text/text.js";
7
+ import w from "./filters-section.js";
8
+ import { SelectedGrades as R } from "./puzzles-styled.js";
9
+ import { GRADE_DISPLAY_NAMES as Y } from "./utils.js";
10
+ const l = (n) => n.filter((t) => t.applied).map((t) => t.name), $ = (n) => n.map((t) => t.name), q = (n) => {
11
+ const { handleFiltersChange: t, filterGrades: f, filterTypes: i, filterTiles: c, filterTopics: a, togglePopup: s } = n, [d, x] = T(l(f)), [F, y] = T(l(c)), [G, S] = T(l(a)), [p, E] = T(l(i)), P = u(() => $(i), [i]), W = u(() => $(c), [c]), D = u(() => $(a), [a]), H = r(
12
+ (e) => {
13
+ const m = p.includes(e) ? p.filter((X) => X !== e) : [...p, e];
14
+ E(m), t({
15
+ activity_types: m
16
+ });
17
+ },
18
+ [t, p]
19
+ ), _ = r(
20
+ (e) => {
21
+ y(e), t({
22
+ activity_tiles: e
23
+ });
24
+ },
25
+ [t]
26
+ ), k = r(
27
+ (e) => {
28
+ S(e), t({
29
+ activity_topics: e
30
+ });
31
+ },
32
+ [t]
33
+ ), C = r(() => {
34
+ s("grades");
35
+ }, [s]), j = r(() => {
36
+ s("tiles");
37
+ }, [s]), v = r(() => {
38
+ s("topics");
39
+ }, [s]);
40
+ return g(() => {
41
+ x(l(f));
42
+ }, [f]), g(() => {
43
+ y(l(c));
44
+ }, [c]), g(() => {
45
+ S(l(a));
46
+ }, [a]), g(() => {
47
+ E(l(i));
48
+ }, [i]), /* @__PURE__ */ h(B, { children: [
49
+ /* @__PURE__ */ o(b, { $renderAs: "eyebrow2", $color: "WHITE", children: "GRADE" }),
50
+ /* @__PURE__ */ h(
51
+ A,
52
+ {
53
+ $flexDirection: "row",
54
+ $justifyContent: "space-between",
55
+ $alignItems: "center",
56
+ $gutterX: 0.5,
57
+ $gapX: 0.25,
58
+ $marginBottomX: 0.5,
59
+ children: [
60
+ d.length ? /* @__PURE__ */ o(R, { $renderAs: "eyebrow2", $color: "WHITE", children: d.map((e, m) => /* @__PURE__ */ h("span", { children: [
61
+ Y[e],
62
+ m < d.length - 1 ? ", " : ""
63
+ ] }, e)) }) : /* @__PURE__ */ o(I, { color: "WHITE", onClick: C, label: "Select Grade" }),
64
+ d.length > 0 && /* @__PURE__ */ o(I, { color: "WHITE", onClick: C, label: "Edit" })
65
+ ]
66
+ }
67
+ ),
68
+ /* @__PURE__ */ o(b, { $renderAs: "eyebrow2", $color: "WHITE", children: "TYPE" }),
69
+ /* @__PURE__ */ o(A, { $flexDirection: "row", $flexWrap: !0, children: P.map((e) => /* @__PURE__ */ o(
70
+ M,
71
+ {
72
+ $width: "fit-content",
73
+ $renderAs: "secondary",
74
+ label: e,
75
+ $selected: p.includes(e),
76
+ shape: "square",
77
+ $size: "small",
78
+ onClick: () => H(e)
79
+ },
80
+ e
81
+ )) }),
82
+ /* @__PURE__ */ o(
83
+ w,
84
+ {
85
+ title: "TOPIC",
86
+ items: D,
87
+ selectedItems: G,
88
+ onChange: k,
89
+ openSelector: v
90
+ }
91
+ ),
92
+ /* @__PURE__ */ o(
93
+ w,
94
+ {
95
+ title: "TILE",
96
+ items: W,
97
+ onChange: _,
98
+ selectedItems: F,
99
+ openSelector: j
100
+ }
101
+ )
102
+ ] });
103
+ }, ee = L(q);
104
+ export {
105
+ ee as default
106
+ };
107
+ //# sourceMappingURL=filters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filters.tsx"],"sourcesContent":["import type { IFilterOption } from './api/get-puzzles';\nimport type { FiltersProps } from './puzzles-type';\n\nimport React, { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport TabComponent from '../../../ui/tab/tab';\nimport Text from '../../../ui/text/text';\nimport FilterSection from './filters-section';\nimport * as Styled from './puzzles-styled';\nimport { GRADE_DISPLAY_NAMES } from './utils';\n\nconst getAppliedFilters = (filters: IFilterOption[]): string[] => {\n return filters.filter(item => item.applied).map(item => item.name);\n};\n\nconst getAllFilters = (filters: IFilterOption[]): string[] => {\n return filters.map(item => item.name);\n};\n\nconst Filters: React.FC<FiltersProps> = props => {\n const { handleFiltersChange, filterGrades, filterTypes, filterTiles, filterTopics, togglePopup } =\n props;\n const [selectedGrades, setSelectedGrade] = useState<string[]>(getAppliedFilters(filterGrades));\n const [selectedTiles, setSelectedTiles] = useState<string[]>(getAppliedFilters(filterTiles));\n const [selectedTopics, setSelectedTopics] = useState<string[]>(getAppliedFilters(filterTopics));\n const [selectedTypes, setSelectedTypes] = useState<string[]>(getAppliedFilters(filterTypes));\n\n const allTypes = useMemo(() => getAllFilters(filterTypes), [filterTypes]);\n const allTiles = useMemo(() => getAllFilters(filterTiles), [filterTiles]);\n const allTopics = useMemo(() => getAllFilters(filterTopics), [filterTopics]);\n\n const handleTypeChange = useCallback(\n (ele: string) => {\n const newSelectedTypes = selectedTypes.includes(ele)\n ? selectedTypes.filter(type => type !== ele)\n : [...selectedTypes, ele];\n\n setSelectedTypes(newSelectedTypes);\n handleFiltersChange({\n activity_types: newSelectedTypes,\n });\n },\n [handleFiltersChange, selectedTypes],\n );\n\n const handleTileChange = useCallback(\n (selectedCodes: string[]) => {\n setSelectedTiles(selectedCodes);\n handleFiltersChange({\n activity_tiles: selectedCodes,\n });\n },\n [handleFiltersChange],\n );\n\n const handleTopicChange = useCallback(\n (selectedCodes: string[]) => {\n setSelectedTopics(selectedCodes);\n handleFiltersChange({\n activity_topics: selectedCodes,\n });\n },\n [handleFiltersChange],\n );\n\n const toggleGradePopup = useCallback(() => {\n togglePopup('grades');\n }, [togglePopup]);\n\n const toggleTilesPopup = useCallback(() => {\n togglePopup('tiles');\n }, [togglePopup]);\n\n const toggleTopicsPopup = useCallback(() => {\n togglePopup('topics');\n }, [togglePopup]);\n\n useEffect(() => {\n setSelectedGrade(getAppliedFilters(filterGrades));\n }, [filterGrades]);\n\n useEffect(() => {\n setSelectedTiles(getAppliedFilters(filterTiles));\n }, [filterTiles]);\n\n useEffect(() => {\n setSelectedTopics(getAppliedFilters(filterTopics));\n }, [filterTopics]);\n\n useEffect(() => {\n setSelectedTypes(getAppliedFilters(filterTypes));\n }, [filterTypes]);\n\n return (\n <>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n GRADE\n </Text>\n <FlexView\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $gutterX={0.5}\n $gapX={0.25}\n $marginBottomX={0.5}\n >\n {selectedGrades.length ? (\n <Styled.SelectedGrades $renderAs=\"eyebrow2\" $color=\"WHITE\">\n {selectedGrades.map((grade, index) => (\n <span key={grade}>\n {GRADE_DISPLAY_NAMES[grade]}\n {index < selectedGrades.length - 1 ? ', ' : ''}\n </span>\n ))}\n </Styled.SelectedGrades>\n ) : (\n <TextButton color=\"WHITE\" onClick={toggleGradePopup} label=\"Select Grade\" />\n )}\n {selectedGrades.length > 0 && (\n <TextButton color=\"WHITE\" onClick={toggleGradePopup} label=\"Edit\" />\n )}\n </FlexView>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n TYPE\n </Text>\n <FlexView $flexDirection=\"row\" $flexWrap>\n {allTypes.map((ele: string) => (\n <TabComponent\n key={ele}\n $width=\"fit-content\"\n $renderAs=\"secondary\"\n label={ele}\n $selected={selectedTypes.includes(ele)}\n shape=\"square\"\n $size=\"small\"\n onClick={() => handleTypeChange(ele)}\n />\n ))}\n </FlexView>\n <FilterSection\n title=\"TOPIC\"\n items={allTopics}\n selectedItems={selectedTopics}\n onChange={handleTopicChange}\n openSelector={toggleTopicsPopup}\n />\n <FilterSection\n title=\"TILE\"\n items={allTiles}\n onChange={handleTileChange}\n selectedItems={selectedTiles}\n openSelector={toggleTilesPopup}\n />\n </>\n );\n};\n\nexport default memo(Filters);\n"],"names":["getAppliedFilters","filters","item","getAllFilters","Filters","props","handleFiltersChange","filterGrades","filterTypes","filterTiles","filterTopics","togglePopup","selectedGrades","setSelectedGrade","useState","selectedTiles","setSelectedTiles","selectedTopics","setSelectedTopics","selectedTypes","setSelectedTypes","allTypes","useMemo","allTiles","allTopics","handleTypeChange","useCallback","ele","newSelectedTypes","type","handleTileChange","selectedCodes","handleTopicChange","toggleGradePopup","toggleTilesPopup","toggleTopicsPopup","useEffect","jsxs","Fragment","jsx","Text","FlexView","Styled.SelectedGrades","grade","index","GRADE_DISPLAY_NAMES","TextButton","TabComponent","FilterSection","Filters$1","memo"],"mappings":"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"}
@@ -0,0 +1,42 @@
1
+ import { useState as a, useRef as g, useCallback as C, useEffect as P } from "react";
2
+ import { getPuzzles as m } from "../api/get-puzzles.js";
3
+ const h = (c) => {
4
+ const [o, i] = a(
5
+ c ? { grades: [c] } : {}
6
+ ), [u, e] = a(!1), [f, z] = a(), t = g(null), n = C(async () => {
7
+ e(!0), t.current && t.current.abort();
8
+ const b = new AbortController();
9
+ t.current = b, await m({
10
+ id: "",
11
+ query: o,
12
+ meta: void 0,
13
+ abortSignal: t.current.signal
14
+ }).then((s) => {
15
+ if (s) {
16
+ const {
17
+ __CODE__: r
18
+ // isProcessingFailed
19
+ } = s;
20
+ if (!(r >= 400 && r < 500)) {
21
+ if (r !== 500) {
22
+ const { data: l } = s || {};
23
+ l && (z(l), e(!1));
24
+ }
25
+ }
26
+ }
27
+ }).catch(() => {
28
+ e(!1);
29
+ }), e(!1);
30
+ }, [o]);
31
+ return P(() => (n(), () => {
32
+ t.current && t.current.abort();
33
+ }), [n]), {
34
+ isPuzzlesProcessing: u,
35
+ puzzlesData: f,
36
+ setActivityFilters: i
37
+ };
38
+ };
39
+ export {
40
+ h as default
41
+ };
42
+ //# sourceMappingURL=use-fetch-cue-canvas-activity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-fetch-cue-canvas-activity.js","sources":["../../../../../../src/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.ts"],"sourcesContent":["import type { IGetPuzzles } from '../api/get-puzzles';\n\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\nimport { getPuzzles, type IPuzzlesResponses } from '../api/get-puzzles';\n\nconst useFetchCueCanvasActivity = (studentGrade?: string) => {\n const [activityFilters, setActivityFilters] = useState<IGetPuzzles>(\n studentGrade ? { grades: [studentGrade] } : {},\n );\n const [isPuzzlesProcessing, setIsPuzzlesProcessing] = useState(false);\n const [puzzlesData, setPuzzlesData] = useState<IPuzzlesResponses | undefined>();\n const abortControllerRef = useRef<AbortController | null>(null);\n\n const fetchResource = useCallback(async () => {\n setIsPuzzlesProcessing(true);\n\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n }\n\n const controller = new AbortController();\n\n abortControllerRef.current = controller;\n\n await getPuzzles({\n id: '',\n query: activityFilters,\n meta: undefined,\n abortSignal: abortControllerRef.current.signal,\n })\n .then(res => {\n if (res) {\n const {\n __CODE__,\n // isProcessingFailed\n } = res;\n\n if (__CODE__ >= 400 && __CODE__ < 500) {\n // onError(__ERROR__?.message ?? 'Error while fetching the resource');\n } else if (__CODE__ === 500) {\n // setIsPuzzlesFailed(isProcessingFailed);\n // setError('Internal server error, Please try again');\n } else {\n const { data } = res || {};\n\n if (data) {\n setPuzzlesData(data);\n setIsPuzzlesProcessing(false);\n }\n }\n }\n })\n .catch(() => {\n setIsPuzzlesProcessing(false);\n // setIsPuzzlesFailed(true);\n });\n setIsPuzzlesProcessing(false);\n }, [activityFilters]);\n\n useEffect(() => {\n fetchResource();\n\n return () => {\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n }\n };\n }, [fetchResource]);\n\n return {\n isPuzzlesProcessing,\n puzzlesData,\n setActivityFilters,\n };\n};\n\nexport default useFetchCueCanvasActivity;\n"],"names":["useFetchCueCanvasActivity","studentGrade","activityFilters","setActivityFilters","useState","isPuzzlesProcessing","setIsPuzzlesProcessing","puzzlesData","setPuzzlesData","abortControllerRef","useRef","fetchResource","useCallback","controller","getPuzzles","res","__CODE__","data","useEffect"],"mappings":";;AAMM,MAAAA,IAA4B,CAACC,MAA0B;AACrD,QAAA,CAACC,GAAiBC,CAAkB,IAAIC;AAAA,IAC5CH,IAAe,EAAE,QAAQ,CAACA,CAAY,MAAM,CAAC;AAAA,EAAA,GAEzC,CAACI,GAAqBC,CAAsB,IAAIF,EAAS,EAAK,GAC9D,CAACG,GAAaC,CAAc,IAAIJ,EAAwC,GACxEK,IAAqBC,EAA+B,IAAI,GAExDC,IAAgBC,EAAY,YAAY;AAC5C,IAAAN,EAAuB,EAAI,GAEvBG,EAAmB,WACrBA,EAAmB,QAAQ;AAGvB,UAAAI,IAAa,IAAI;AAEvB,IAAAJ,EAAmB,UAAUI,GAE7B,MAAMC,EAAW;AAAA,MACf,IAAI;AAAA,MACJ,OAAOZ;AAAA,MACP,MAAM;AAAA,MACN,aAAaO,EAAmB,QAAQ;AAAA,IAAA,CACzC,EACE,KAAK,CAAOM,MAAA;AACX,UAAIA,GAAK;AACD,cAAA;AAAA,UACJ,UAAAC;AAAA;AAAA,QAEE,IAAAD;AAEA,YAAA,EAAAC,KAAY,OAAOA,IAAW;AAElC,cAAWA,MAAa,KAGjB;AACL,kBAAM,EAAE,MAAAC,EAAA,IAASF,KAAO;AAExB,YAAIE,MACFT,EAAeS,CAAI,GACnBX,EAAuB,EAAK;AAAA,UAEhC;AAAA;AAAA,MACF;AAAA,IAAA,CACD,EACA,MAAM,MAAM;AACX,MAAAA,EAAuB,EAAK;AAAA,IAAA,CAE7B,GACHA,EAAuB,EAAK;AAAA,EAAA,GAC3B,CAACJ,CAAe,CAAC;AAEpB,SAAAgB,EAAU,OACMP,KAEP,MAAM;AACX,IAAIF,EAAmB,WACrBA,EAAmB,QAAQ;EAC7B,IAED,CAACE,CAAa,CAAC,GAEX;AAAA,IACL,qBAAAN;AAAA,IACA,aAAAE;AAAA,IACA,oBAAAJ;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,84 @@
1
+ import { jsxs as i, jsx as e } from "react/jsx-runtime";
2
+ import { memo as G, useEffect as O, useCallback as R } from "react";
3
+ import W from "styled-components";
4
+ import { ILLUSTRATIONS as H } from "../../../../assets/illustrations/illustrations.js";
5
+ import w from "../../../../assets/line-icons/icons/back.js";
6
+ import S from "../../../../assets/line-icons/icons/cross.js";
7
+ import P from "../../../ui/buttons/button/button.js";
8
+ import { Loader as B } from "../../../ui/buttons/button/button-styled.js";
9
+ import l from "../../../ui/buttons/clickable/clickable.js";
10
+ import t from "../../../ui/layout/flex-view.js";
11
+ import A from "../../../ui/text/text.js";
12
+ import { useCueCanvasActions as J } from "../../hooks/use-cue-canvas-actions.js";
13
+ import { useGetActivity as M } from "./api/get-puzzles.js";
14
+ import { MenuContainer as C } from "./puzzles-styled.js";
15
+ import { serializeData as N, getTags as o } from "./utils.js";
16
+ const V = W.iframe`
17
+ width: 100%;
18
+ height: 100%;
19
+ `, se = G((T) => {
20
+ const { launchPuzzleData: I, onMenuVisibilityChange: c, toggleMenu: m } = T, { node_id: f } = I || {}, { activeInstance: r, setHomeworkId: d, setActiveTool: p } = J(), {
21
+ get: u,
22
+ data: g,
23
+ isProcessed: k
24
+ } = M();
25
+ O(() => {
26
+ u(f);
27
+ }, [u, f]);
28
+ const {
29
+ activity_tiles: $,
30
+ activity_topics: h,
31
+ activity_types: y,
32
+ grades: b,
33
+ worksheet: x
34
+ } = g || {}, { instructions_ref: v, learnosity_activity_ref: n } = x || {}, X = R(async () => {
35
+ const a = n && await (await fetch(n)).json(), E = {
36
+ ...N(a)
37
+ };
38
+ m(), r == null || r.replaceCanvas(E), d(void 0), p("move");
39
+ }, [r, n, p, d, m]);
40
+ if (!g || !k)
41
+ return /* @__PURE__ */ i(C, { children: [
42
+ /* @__PURE__ */ e(t, { $gutterX: 1.5, $gapX: 1.5, children: /* @__PURE__ */ e(l, { onClick: c, label: "back", children: /* @__PURE__ */ e(w, { color: "WHITE" }) }) }),
43
+ /* @__PURE__ */ e(t, { $alignItems: "center", $justifyContent: "center", $height: "100%", children: /* @__PURE__ */ e(B, { src: H.LOADER, alt: "Loader", $size: "small" }) })
44
+ ] });
45
+ const D = b ? o(b, "grades") : [], _ = h ? o(h) : [], j = y ? o(y) : [], L = $ ? o($) : [], z = [..._, ...D, ...j, ...L];
46
+ return /* @__PURE__ */ i(C, { children: [
47
+ /* @__PURE__ */ i(
48
+ t,
49
+ {
50
+ $justifyContent: "space-between",
51
+ $alignItems: "center",
52
+ $flexDirection: "row",
53
+ $gutterX: 1,
54
+ $gapX: 0.5,
55
+ children: [
56
+ /* @__PURE__ */ e(l, { onClick: c, label: "back", children: /* @__PURE__ */ e(w, { color: "WHITE" }) }),
57
+ /* @__PURE__ */ i(t, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
58
+ /* @__PURE__ */ e(
59
+ P,
60
+ {
61
+ size: "small",
62
+ renderAs: "primary",
63
+ widthX: 12,
64
+ label: "Launch",
65
+ onClick: X
66
+ }
67
+ ),
68
+ /* @__PURE__ */ e(l, { onClick: c, label: "close filter menu", children: /* @__PURE__ */ e(S, { color: "WHITE" }) })
69
+ ] })
70
+ ]
71
+ }
72
+ ),
73
+ /* @__PURE__ */ i(t, { $flexDirection: "row", $flexColumnGapX: 1, $gapX: 1, $gutterX: 1, children: [
74
+ /* @__PURE__ */ e(A, { $renderAs: "ab1", $color: "GREY_2", children: "Tags:" }),
75
+ /* @__PURE__ */ e(t, { $flexDirection: "row", $flexColumnGapX: 1, $flexRowGapX: 0.5, $flexWrap: !0, children: z.map((a, s) => /* @__PURE__ */ e(t, { $background: "WHITE", $borderRadius: 16, $gapX: 0.25, $gutterX: 1, children: /* @__PURE__ */ e(A, { $renderAs: "ub2", children: a }, s) }, s)) })
76
+ ] }),
77
+ v && /* @__PURE__ */ e(V, { id: "launch_activity_iframe", src: v })
78
+ ] });
79
+ });
80
+ export {
81
+ V as Iframe,
82
+ se as default
83
+ };
84
+ //# sourceMappingURL=launch-puzzle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"launch-puzzle.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/launch-puzzle.tsx"],"sourcesContent":["import type { IPuzzlesResultData } from './api/get-puzzles';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect } from 'react';\nimport styled from 'styled-components';\n\nimport { ILLUSTRATIONS } from '../../../../assets/illustrations/illustrations';\nimport BackIcon from '../../../../assets/line-icons/icons/back';\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport Button from '../../../ui/buttons/button/button';\nimport { Loader } from '../../../ui/buttons/button/button-styled';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport { useCueCanvasActions } from '../../hooks/use-cue-canvas-actions';\nimport { useGetActivity } from './api/get-puzzles';\nimport * as Styled from './puzzles-styled';\nimport { getTags, serializeData } from './utils';\n\nexport const Iframe = styled.iframe`\n width: 100%;\n height: 100%;\n`;\n\ninterface ILaunchPuzzleProps {\n launchPuzzleData: IPuzzlesResultData;\n onMenuVisibilityChange: () => void;\n toggleMenu: () => void;\n}\n\nconst LaunchPuzzle: FC<ILaunchPuzzleProps> = memo(props => {\n const { launchPuzzleData, onMenuVisibilityChange, toggleMenu } = props;\n const { node_id: nodeId } = launchPuzzleData || {};\n const { activeInstance: cueCanvas, setHomeworkId, setActiveTool } = useCueCanvasActions();\n\n const {\n get: getWbActivity,\n data: wbActivityData,\n isProcessed: wbActivityDataProcessed,\n } = useGetActivity();\n\n useEffect(() => {\n getWbActivity(nodeId);\n }, [getWbActivity, nodeId]);\n const {\n activity_tiles: activityTiles,\n activity_topics: activityTopics,\n activity_types: activityTypes,\n grades: grades,\n worksheet,\n } = wbActivityData || {};\n const { instructions_ref: iframeSrc, learnosity_activity_ref: learnnosityActivityRef } =\n worksheet || {};\n\n const onLaunchActivityClick = useCallback(async () => {\n const jsonOBJ = learnnosityActivityRef && (await (await fetch(learnnosityActivityRef)).json());\n\n const newJSONObj = serializeData(jsonOBJ);\n const actionData = {\n ...newJSONObj,\n };\n\n toggleMenu();\n\n cueCanvas?.replaceCanvas(actionData);\n setHomeworkId(undefined);\n setActiveTool('move');\n }, [cueCanvas, learnnosityActivityRef, setActiveTool, setHomeworkId, toggleMenu]);\n\n if (!wbActivityData || !wbActivityDataProcessed) {\n return (\n <Styled.MenuContainer>\n <FlexView $gutterX={1.5} $gapX={1.5}>\n <Clickable onClick={onMenuVisibilityChange} label=\"back\">\n <BackIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n <FlexView $alignItems=\"center\" $justifyContent=\"center\" $height=\"100%\">\n <Loader src={ILLUSTRATIONS.LOADER} alt=\"Loader\" $size=\"small\" />\n </FlexView>\n </Styled.MenuContainer>\n );\n }\n\n const getGradesArr = grades ? getTags(grades, 'grades') : [];\n const getTopicsArr = activityTopics ? getTags(activityTopics) : [];\n const getTypesArr = activityTypes ? getTags(activityTypes) : [];\n const getTilesArr = activityTiles ? getTags(activityTiles) : [];\n\n const tagData: string[] = [...getTopicsArr, ...getGradesArr, ...getTypesArr, ...getTilesArr];\n\n return (\n <Styled.MenuContainer>\n <FlexView\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $flexDirection=\"row\"\n $gutterX={1}\n $gapX={0.5}\n >\n <Clickable onClick={onMenuVisibilityChange} label=\"back\">\n <BackIcon color=\"WHITE\" />\n </Clickable>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <Button\n size=\"small\"\n renderAs=\"primary\"\n widthX={12}\n label=\"Launch\"\n onClick={onLaunchActivityClick}\n />\n <Clickable onClick={onMenuVisibilityChange} label=\"close filter menu\">\n <CrossIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n </FlexView>\n <FlexView $flexDirection=\"row\" $flexColumnGapX={1} $gapX={1} $gutterX={1}>\n <Text $renderAs=\"ab1\" $color=\"GREY_2\">\n Tags:\n </Text>\n <FlexView $flexDirection=\"row\" $flexColumnGapX={1} $flexRowGapX={0.5} $flexWrap>\n {tagData.map((tag, index) => (\n <FlexView $background=\"WHITE\" $borderRadius={16} $gapX={0.25} $gutterX={1} key={index}>\n <Text $renderAs=\"ub2\" key={index}>\n {tag}\n </Text>\n </FlexView>\n ))}\n </FlexView>\n </FlexView>\n {iframeSrc && <Iframe id=\"launch_activity_iframe\" src={iframeSrc} />}\n </Styled.MenuContainer>\n );\n});\n\nexport default LaunchPuzzle;\n"],"names":["Iframe","styled","LaunchPuzzle","memo","props","launchPuzzleData","onMenuVisibilityChange","toggleMenu","nodeId","cueCanvas","setHomeworkId","setActiveTool","useCueCanvasActions","getWbActivity","wbActivityData","wbActivityDataProcessed","useGetActivity","useEffect","activityTiles","activityTopics","activityTypes","grades","worksheet","iframeSrc","learnnosityActivityRef","onLaunchActivityClick","useCallback","jsonOBJ","actionData","serializeData","jsxs","Styled.MenuContainer","jsx","FlexView","Clickable","BackIcon","Loader","ILLUSTRATIONS","getGradesArr","getTags","getTopicsArr","getTypesArr","getTilesArr","tagData","Button","CrossIcon","Text","tag","index"],"mappings":"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"}