@cuemath/leap 3.1.0-gg2 → 3.1.1-aa0

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 (395) 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 +86 -81
  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 +81 -67
  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/styles.js +5 -4
  96. package/dist/features/homework/styles.js.map +1 -1
  97. package/dist/features/hooks/use-debounce.js +16 -0
  98. package/dist/features/hooks/use-debounce.js.map +1 -0
  99. package/dist/features/milestone/create/comps/add-custom-chapter/course-catalog.js +38 -36
  100. package/dist/features/milestone/create/comps/add-custom-chapter/course-catalog.js.map +1 -1
  101. package/dist/features/milestone/create/comps/add-custom-chapter/hooks/use-catalog-helpers.js +24 -22
  102. package/dist/features/milestone/create/comps/add-custom-chapter/hooks/use-catalog-helpers.js.map +1 -1
  103. package/dist/features/milestone/create/comps/chapters-selection-step/chapter-selection-step-v2/chapter-category/chapter-category-container.js +23 -22
  104. package/dist/features/milestone/create/comps/chapters-selection-step/chapter-selection-step-v2/chapter-category/chapter-category-container.js.map +1 -1
  105. package/dist/features/milestone/create/comps/chapters-selection-step/utils.js +49 -47
  106. package/dist/features/milestone/create/comps/chapters-selection-step/utils.js.map +1 -1
  107. package/dist/features/milestone/create/comps/class-details-step/class-details-step.js +94 -87
  108. package/dist/features/milestone/create/comps/class-details-step/class-details-step.js.map +1 -1
  109. package/dist/features/milestone/create/comps/class-details-step/class-details-utils.js +13 -12
  110. package/dist/features/milestone/create/comps/class-details-step/class-details-utils.js.map +1 -1
  111. package/dist/features/milestone/create/comps/test-type-step/test-type-step.js +23 -21
  112. package/dist/features/milestone/create/comps/test-type-step/test-type-step.js.map +1 -1
  113. package/dist/features/milestone/create/milestone-create-helpers.js +165 -162
  114. package/dist/features/milestone/create/milestone-create-helpers.js.map +1 -1
  115. package/dist/features/trial-session/comps/pricing/india-pricing/index.js +96 -0
  116. package/dist/features/trial-session/comps/pricing/india-pricing/index.js.map +1 -0
  117. package/dist/features/trial-session/comps/pricing/india-pricing/india-pricing-styled.js +59 -0
  118. package/dist/features/trial-session/comps/pricing/india-pricing/india-pricing-styled.js.map +1 -0
  119. package/dist/features/trial-session/comps/pricing/pricing.js +36 -35
  120. package/dist/features/trial-session/comps/pricing/pricing.js.map +1 -1
  121. package/dist/features/ui/stepper/stepper.js +7 -7
  122. package/dist/features/worksheet/worksheet/hooks/use-s3-helper.js +22 -19
  123. package/dist/features/worksheet/worksheet/hooks/use-s3-helper.js.map +1 -1
  124. package/dist/index.d.ts +298 -247
  125. package/dist/index.js +184 -180
  126. package/dist/index.js.map +1 -1
  127. package/dist/static/accuracy-meter.99585cba.json +4218 -0
  128. package/dist/static/accuracy-needle.cd6e63ac.json +618 -0
  129. package/dist/static/achievement_bg.0d0555ac.png +0 -0
  130. package/dist/static/advance-mode-segment-lottie.51ff6707.json +1 -0
  131. package/dist/static/alarm-clock-orange.31fb90d9.svg +1 -0
  132. package/dist/static/alarm-clock-purple.06d4911c.svg +1 -0
  133. package/dist/static/alien-1.fc7ba696.svg +1 -0
  134. package/dist/static/alien-2.15fdda07.svg +1 -0
  135. package/dist/static/alien-3.2664a37f.svg +1 -0
  136. package/dist/static/alien-4.06ac66da.svg +1 -0
  137. package/dist/static/ashta.0d3926b2.png +0 -0
  138. package/dist/static/avatar-selected.860ee923.json +1 -0
  139. package/dist/static/awesome.8e1cf046.png +0 -0
  140. package/dist/static/badge_success.2f6c8e65.png +0 -0
  141. package/dist/static/beginner1x.489908a7.json +3508 -0
  142. package/dist/static/bg_empty_resources.63b187fd.png +0 -0
  143. package/dist/static/blue-clip.87cc4543.svg +1 -0
  144. package/dist/static/bobwave.5603c70b.gif +0 -0
  145. package/dist/static/book-green.20f6eed3.svg +1 -0
  146. package/dist/static/book-open-blue.d4f8d08c.svg +5 -0
  147. package/dist/static/book-orange.04bdc75e.svg +1 -0
  148. package/dist/static/book-yellow.c210ac06.svg +1 -0
  149. package/dist/static/bronze-1.da4e4b5f.json +4176 -0
  150. package/dist/static/bronze-2.97f9c639.json +4433 -0
  151. package/dist/static/bronze-3.6a433ebd.json +4786 -0
  152. package/dist/static/bullet-yellow.2f892d88.svg +1 -0
  153. package/dist/static/calendar-blue.e0d52d09.svg +1 -0
  154. package/dist/static/calendar-gray.1c72682a.svg +1 -0
  155. package/dist/static/calendar-green.a2b6a393.svg +1 -0
  156. package/dist/static/caution.5766a967.svg +1 -0
  157. package/dist/static/chapter-1.8a1683a0.svg +1 -0
  158. package/dist/static/chapter-10.c97de4a5.svg +1 -0
  159. package/dist/static/chapter-2.71ac6dfc.svg +1 -0
  160. package/dist/static/chapter-3.003fc901.svg +1 -0
  161. package/dist/static/chapter-4.8abbacd8.svg +1 -0
  162. package/dist/static/chapter-5.c774b439.svg +1 -0
  163. package/dist/static/chapter-6.cb5cf1cb.svg +1 -0
  164. package/dist/static/chapter-7.57b0beb4.svg +1 -0
  165. package/dist/static/chapter-8.68d36477.svg +1 -0
  166. package/dist/static/chapter-9.0c00e26f.svg +1 -0
  167. package/dist/static/chapter-completed.1241399b.json +497 -0
  168. package/dist/static/chapter-header-bg-2.c8d96894.svg +1 -0
  169. package/dist/static/chapter-header-bg.4ed173c2.svg +1 -0
  170. package/dist/static/chatva.d0c57a95.png +0 -0
  171. package/dist/static/circle-cuemath-logo-white.e9fafb91.svg +1 -0
  172. package/dist/static/circle-cuemath-logo.8bcb1ad4.svg +1 -0
  173. package/dist/static/circle-outercircle-bg.65f21460.svg +1 -0
  174. package/dist/static/circular-loader.a5a1a0a6.json +238 -0
  175. package/dist/static/clock-30min.eae818b8.json +1197 -0
  176. package/dist/static/clock-45min.df8adf51.json +1197 -0
  177. package/dist/static/clock-60min.2b48d875.json +1197 -0
  178. package/dist/static/clock-90min.3e557ed7.json +1407 -0
  179. package/dist/static/clock-orange.c144059b.svg +6 -0
  180. package/dist/static/color-1.45101b9a.json +4545 -0
  181. package/dist/static/color-2.ccdc7d0a.json +4828 -0
  182. package/dist/static/color-3.5e8e1422.json +5273 -0
  183. package/dist/static/community-bulb.3b42af21.svg +1 -0
  184. package/dist/static/competitive-arena.b9c40801.json +1 -0
  185. package/dist/static/congrats.75718de8.png +0 -0
  186. package/dist/static/cool.1893941c.png +0 -0
  187. package/dist/static/cosa.46c0c49b.png +0 -0
  188. package/dist/static/crosshair-circle.522a26ea.svg +1 -0
  189. package/dist/static/crown-overlay.11fb073c.svg +1 -0
  190. package/dist/static/crown.c18fa217.svg +1 -0
  191. package/dist/static/cuecoin-gold.bcb8085e.svg +1 -0
  192. package/dist/static/cuemath-app-qr-code.4beefe48.svg +1 -0
  193. package/dist/static/cuemath-app-qr-code.ba6cc09b.svg +1 -0
  194. package/dist/static/cuemath-app-qr-code.d0912fc7.png +0 -0
  195. package/dist/static/default-chapter.8ede1160.png +0 -0
  196. package/dist/static/desktop-with-purple-fill.dfec66cc.svg +1 -0
  197. package/dist/static/difficult.6846c064.json +2755 -0
  198. package/dist/static/dob.9ce3c15b.json +1 -0
  199. package/dist/static/doda.3103971c.png +0 -0
  200. package/dist/static/duration-30min-gray.f6442df4.svg +1 -0
  201. package/dist/static/duration-45min-gray.ad90fb23.svg +1 -0
  202. package/dist/static/duration-60min-gray.874e52a2.svg +1 -0
  203. package/dist/static/duration-90min-gray.32a04cef.svg +1 -0
  204. package/dist/static/dvi.fc7b32a5.png +0 -0
  205. package/dist/static/earth-green.e1329b7a.svg +1 -0
  206. package/dist/static/easy-rescheduling.3a6d1a00.gif +0 -0
  207. package/dist/static/easy.68242ddd.json +2658 -0
  208. package/dist/static/eka.b10a06fa.png +0 -0
  209. package/dist/static/elite-circle.3df58972.json +6876 -0
  210. package/dist/static/ellipse-clip.dfb25608.svg +1 -0
  211. package/dist/static/empty_mix_tests.1d251f07.png +0 -0
  212. package/dist/static/enrichment-mini.fc3c0f83.gif +0 -0
  213. package/dist/static/enrichment.571feac0.gif +0 -0
  214. package/dist/static/error-lottie.b3507a4b.json +5255 -0
  215. package/dist/static/error.cbe1ddde.json +1 -0
  216. package/dist/static/familiar1x.7c9c7f15.json +3046 -0
  217. package/dist/static/female-avatar.b8cd1012.svg +1 -0
  218. package/dist/static/fifteen-min-clock.0af4e303.json +715 -0
  219. package/dist/static/five-min-clock.6be5cc41.json +721 -0
  220. package/dist/static/game-play.4982b0cb.svg +1 -0
  221. package/dist/static/games.47abcb18.gif +0 -0
  222. package/dist/static/globe-with-blue-fill.beae6ca4.svg +1 -0
  223. package/dist/static/gold-1.ab2489fe.json +4176 -0
  224. package/dist/static/gold-2.34045826.json +4441 -0
  225. package/dist/static/gold-3.d704698b.json +4810 -0
  226. package/dist/static/grade-grid-background.b17b4ccb.svg +1 -0
  227. package/dist/static/grade.b3730524.json +1 -0
  228. package/dist/static/graduate-hat.4b49eb44.svg +1 -0
  229. package/dist/static/graduate-icon-pink.01fbfb1b.svg +1 -0
  230. package/dist/static/graduate-pink-filled-bg.c91e9c53.svg +1 -0
  231. package/dist/static/great.2a5dcc34.png +0 -0
  232. package/dist/static/green-balloon.67ac8587.svg +1 -0
  233. package/dist/static/green-face.1b4dd82f.svg +1 -0
  234. package/dist/static/hexo.eab4b9f5.png +0 -0
  235. package/dist/static/infinite-button-bg.5909225e.json +1 -0
  236. package/dist/static/infinite-button-symbol.aa31350c.json +1 -0
  237. package/dist/static/jigii-wave.150a6d18.gif +0 -0
  238. package/dist/static/key.d6846476.json +1 -0
  239. package/dist/static/kudos.b7e2aeb6.png +0 -0
  240. package/dist/static/learn.71b13323.json +1 -0
  241. package/dist/static/learned-shield-gray.1495b0d5.svg +1 -0
  242. package/dist/static/learned-shield-green.7c26b423.svg +1 -0
  243. package/dist/static/learning-plan.72d64a61.png +0 -0
  244. package/dist/static/learning-session.71cc8f22.gif +0 -0
  245. package/dist/static/learnt.870c5e38.svg +1 -0
  246. package/dist/static/lesson-overview-banner.f5404af6.png +0 -0
  247. package/dist/static/levelup-rings.b1055283.json +549 -0
  248. package/dist/static/like.cb492460.svg +1 -0
  249. package/dist/static/live-session.a0d25c78.svg +1 -0
  250. package/dist/static/loader-1.6524355e.svg +1 -0
  251. package/dist/static/loader.52f8c35c.svg +1 -0
  252. package/dist/static/locked.0c3b7577.svg +1 -0
  253. package/dist/static/mail.c30e8708.json +1 -0
  254. package/dist/static/maintenance.a26aca65.svg +1 -0
  255. package/dist/static/male-avatar.2febc9eb.svg +1 -0
  256. package/dist/static/mastered-badge.81f156fb.svg +1 -0
  257. package/dist/static/mastered-shield-gray.a58cbe19.svg +1 -0
  258. package/dist/static/mastered-shield-green.070fa4eb.svg +1 -0
  259. package/dist/static/max-wave.44e002c9.gif +0 -0
  260. package/dist/static/medium.94c3829b.json +2289 -0
  261. package/dist/static/mental-math.3c95f169.svg +1 -0
  262. package/dist/static/milestone-intro-1.281a354c.svg +1 -0
  263. package/dist/static/milestone-intro-2.19faee69.svg +1 -0
  264. package/dist/static/milestone-intro-3.6f6055d6.svg +1 -0
  265. package/dist/static/mistake.476d1aa7.svg +1 -0
  266. package/dist/static/no-info.f4bfe437.png +0 -0
  267. package/dist/static/node-custom-test-bg.d3b757be.svg +1 -0
  268. package/dist/static/node-learn-bg.b61f815c.svg +1 -0
  269. package/dist/static/node-practice-bg.16cbaf2a.svg +1 -0
  270. package/dist/static/node-project-bg.e6a33e28.svg +1 -0
  271. package/dist/static/node-puzzle-bg.3422135c.svg +1 -0
  272. package/dist/static/node-recap-bg.546154e4.svg +1 -0
  273. package/dist/static/node-test-prep-bg.42c0b9c4.svg +1 -0
  274. package/dist/static/node-video-bg.3df3f73a.svg +1 -0
  275. package/dist/static/nudge-tap.5cb30093.json +1057 -0
  276. package/dist/static/number-1-orange.cbf526ed.svg +1 -0
  277. package/dist/static/number-2-orange.6f29eb72.svg +1 -0
  278. package/dist/static/number-3-orange.58baf717.svg +1 -0
  279. package/dist/static/number-4-orange.5ed1ec5e.svg +1 -0
  280. package/dist/static/octo.3020bd93.png +0 -0
  281. package/dist/static/one-star-filled.b6084257.svg +1 -0
  282. package/dist/static/orange-face.5824c2e9.svg +1 -0
  283. package/dist/static/otp.2d08f874.json +1 -0
  284. package/dist/static/otp.a3029760.json +1 -0
  285. package/dist/static/parent-avatar.772d53e0.json +1 -0
  286. package/dist/static/people-with-orange-fill.3835b8f1.svg +1 -0
  287. package/dist/static/phone-number.0be312ea.json +1 -0
  288. package/dist/static/phone-number.84f55562.json +1 -0
  289. package/dist/static/play-icon.13baaa7d.svg +1 -0
  290. package/dist/static/play.68d16dec.svg +1 -0
  291. package/dist/static/point1.b53831de.json +2942 -0
  292. package/dist/static/point10.7b5e536d.json +3179 -0
  293. package/dist/static/point100.1df16f82.json +3196 -0
  294. package/dist/static/point15.fea00c32.json +3179 -0
  295. package/dist/static/point2.7cec6e24.json +1 -0
  296. package/dist/static/point20.c88d776d.json +3178 -0
  297. package/dist/static/point25.a18c346a.json +3178 -0
  298. package/dist/static/point3.f96fe7aa.json +1 -0
  299. package/dist/static/point30.c5224b0b.json +3202 -0
  300. package/dist/static/point35.fad343dd.json +3058 -0
  301. package/dist/static/point4.fe04fb83.json +1 -0
  302. package/dist/static/point40.10a16f72.json +3082 -0
  303. package/dist/static/point45.2ad7561f.json +3082 -0
  304. package/dist/static/point5.da40ed1f.json +2948 -0
  305. package/dist/static/point50.5718cb3d.json +3046 -0
  306. package/dist/static/point60.17380d9f.json +3076 -0
  307. package/dist/static/points-sum.360e63de.svg +1 -0
  308. package/dist/static/practice.158dd488.json +1 -0
  309. package/dist/static/practiced-shield-green.90278855.svg +1 -0
  310. package/dist/static/practiced-shield-grey.16cf4fe0.svg +1 -0
  311. package/dist/static/proficient-badge.1a6dbb72.svg +1 -0
  312. package/dist/static/proficient1x.fa6e7b80.json +3430 -0
  313. package/dist/static/profile-board.4f4a17e6.svg +1 -0
  314. package/dist/static/project.eb665827.json +1 -0
  315. package/dist/static/puzzle-student.de530364.svg +1 -0
  316. package/dist/static/puzzle.5aad5cf8.svg +1 -0
  317. package/dist/static/puzzle.b298c7e4.json +1 -0
  318. package/dist/static/puzzle_card_easy.7d9439b5.png +0 -0
  319. package/dist/static/puzzle_card_hard.185a19c4.png +0 -0
  320. package/dist/static/puzzle_card_medium.17daef9c.png +0 -0
  321. package/dist/static/puzzles.1e269965.gif +0 -0
  322. package/dist/static/random-mode-segment-lottie.79cf1c07.json +1 -0
  323. package/dist/static/recap.0dd2c1e2.json +1 -0
  324. package/dist/static/refund-policy-with-headphone.589398e0.svg +1 -0
  325. package/dist/static/refund-policy.912dbb4c.svg +1 -0
  326. package/dist/static/report-404.dd67785c.svg +1 -0
  327. package/dist/static/rocket-broken.1f86fa43.svg +1 -0
  328. package/dist/static/rocket-yellow.62d27e15.svg +1 -0
  329. package/dist/static/school-success-mini.f74a852f.gif +0 -0
  330. package/dist/static/school-success.f9669771.gif +0 -0
  331. package/dist/static/score.41971107.svg +1 -0
  332. package/dist/static/sequence-mode-segment-lottie.11ac49e9.json +1 -0
  333. package/dist/static/shared.3af01b49.png +0 -0
  334. package/dist/static/sheet-reference.9da7a09f.png +0 -0
  335. package/dist/static/silver-1.0396328a.json +4168 -0
  336. package/dist/static/silver-2.bf50615f.json +4433 -0
  337. package/dist/static/silver-3.13d66b84.json +4810 -0
  338. package/dist/static/skills.90ce4cbb.gif +0 -0
  339. package/dist/static/sleepy-boi.031a1165.json +1008 -0
  340. package/dist/static/smiley.49bb7d7c.svg +1 -0
  341. package/dist/static/speckie-wave.510639ce.gif +0 -0
  342. package/dist/static/spinner-white.639e0d87.json +122 -0
  343. package/dist/static/spiral_pattern.9fd3e6e9.png +0 -0
  344. package/dist/static/splash-screen.bbf567ce.json +2411 -0
  345. package/dist/static/star-orange-filled.a7ff9c8f.svg +1 -0
  346. package/dist/static/star-orange.a91a341f.svg +1 -0
  347. package/dist/static/star-with-green-fill.86877d41.svg +1 -0
  348. package/dist/static/stay-connected.371d3d9d.gif +0 -0
  349. package/dist/static/streak-green.b59bf4dd.svg +1 -0
  350. package/dist/static/streak-white.2cbdc9b8.svg +1 -0
  351. package/dist/static/student-avatar.524226bd.json +1 -0
  352. package/dist/static/table-mode-reveal.b44a82c3.json +1 -0
  353. package/dist/static/table-mode-star.b8a1d762.json +1 -0
  354. package/dist/static/table-segment-star.78e851d6.json +1 -0
  355. package/dist/static/target-achieved-text.053bd142.json +2830 -0
  356. package/dist/static/target-achieved-text.10db8475.json +1 -0
  357. package/dist/static/teacher-validation.7577ecdc.json +245 -0
  358. package/dist/static/tera-wave.2954a6a4.gif +0 -0
  359. package/dist/static/test-difficulty-easy.56df71dd.svg +1 -0
  360. package/dist/static/test-difficulty-hard.7250f1f4.svg +1 -0
  361. package/dist/static/test-difficulty-medium.2fd9686e.svg +1 -0
  362. package/dist/static/test-prep-mini.718e5734.gif +0 -0
  363. package/dist/static/test-prep.ea433f71.gif +0 -0
  364. package/dist/static/test.803d6036.json +1 -0
  365. package/dist/static/tetra.354ff2b9.png +0 -0
  366. package/dist/static/three-stars-filled.72b51f03.svg +1 -0
  367. package/dist/static/tick-green.a1654049.svg +1 -0
  368. package/dist/static/total-streak.d5ce7669.json +842 -0
  369. package/dist/static/total-time-spent.434005d3.json +200 -0
  370. package/dist/static/total-time.d979cbb9.json +24383 -0
  371. package/dist/static/tournament-ripple.e5c239a5.json +1047 -0
  372. package/dist/static/track-progress.c75b1031.gif +0 -0
  373. package/dist/static/trophy-blue-filled.7e2b40ab.svg +1 -0
  374. package/dist/static/trophy-blue.e684ba4c.svg +1 -0
  375. package/dist/static/trophy-circle.b7b23e36.svg +1 -0
  376. package/dist/static/trophy-green.6c0741c8.svg +10 -0
  377. package/dist/static/two-stars-filled.a51a14b4.svg +1 -0
  378. package/dist/static/up-arrow.a6946bd3.svg +1 -0
  379. package/dist/static/user-crown-grid-background.c2875a73.svg +1 -0
  380. package/dist/static/user-down.a06f2f94.svg +1 -0
  381. package/dist/static/user-pin.5f334465.svg +1 -0
  382. package/dist/static/user-profile-background.199977a9.svg +1 -0
  383. package/dist/static/user-type-selector-grid-bg.3c9c8ad6.svg +1 -0
  384. package/dist/static/user-type-selector-grid-bg.3ce8142d.svg +1 -0
  385. package/dist/static/user-type-selector-grid-bg.aad0b059.svg +1 -0
  386. package/dist/static/user-up.2aecbbae.svg +1 -0
  387. package/dist/static/username.9e034d51.json +1 -0
  388. package/dist/static/video.b41451e2.json +1 -0
  389. package/dist/static/vinnie-wave.10734dd5.gif +0 -0
  390. package/dist/static/way-forward.1428093e.gif +0 -0
  391. package/dist/static/wow.864fbb02.png +0 -0
  392. package/dist/static/yellow-face.b7525a33.svg +1 -0
  393. package/dist/static/your-goals.63ffbee5.gif +0 -0
  394. package/dist/static/zodasa.336c3bb0.png +0 -0
  395. package/package.json +3 -2
@@ -1,20 +1,21 @@
1
- var d = Object.defineProperty;
2
- var u = (r, t, e) => t in r ? d(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
3
- var s = (r, t, e) => u(r, typeof t != "symbol" ? t + "" : t, e);
1
+ var u = Object.defineProperty;
2
+ var g = (c, t, e) => t in c ? u(c, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : c[t] = e;
3
+ var s = (c, t, e) => g(c, typeof t != "symbol" ? t + "" : t, e);
4
4
  import v from "../../node_modules/lodash.debounce/index.js";
5
- import { removeTileButton as f, removeMask as g, checkTextOrEquationTool as y, getReverseMap as C, getToolAndSubtool as m } from "./cue-canvas-helpers.js";
6
- class b {
5
+ import { removeTileButton as f, removeMask as y, checkTextOrEquationTool as C, getReverseMap as m, getToolAndSubtool as T } from "./cue-canvas-helpers.js";
6
+ class k {
7
7
  constructor({
8
8
  onPublish: t,
9
9
  onSubscribe: e,
10
- onUpdateActiveTool: a,
11
- onUpdateHeight: n,
12
- uploadImageToS3: o,
13
- height: i,
14
- userId: l,
15
- canvasId: h,
16
- userType: c,
17
- renderAs: p
10
+ onUpdateActiveTool: i,
11
+ onUpdateHeight: o,
12
+ uploadImageToS3: a,
13
+ height: n,
14
+ userId: h,
15
+ canvasId: r,
16
+ userType: l,
17
+ renderAs: p,
18
+ updateCanvasConfig: d
18
19
  }) {
19
20
  s(this, "polycanvas");
20
21
  s(this, "publish");
@@ -28,22 +29,22 @@ class b {
28
29
  s(this, "fileInput", null);
29
30
  s(this, "debouncedViewportChange");
30
31
  s(this, "uploadImageToS3");
31
- s(this, "publishToChannel", (t, e, a) => {
32
+ s(this, "updateCanvasConfigChange");
33
+ s(this, "gridName");
34
+ s(this, "publishToChannel", (t) => {
32
35
  this.publish && this.publish({
33
36
  eventName: "cue_canvas_changed",
34
37
  eventPayload: {
35
38
  data: t,
36
39
  height: this.height,
37
40
  userId: this.userId,
38
- responseId: this.canvasId,
39
- gridName: e,
40
- dimension: a
41
+ responseId: this.canvasId
41
42
  }
42
43
  });
43
44
  });
44
45
  s(this, "onChange", (t) => {
45
- const a = Object.fromEntries(t.entries());
46
- y(a) && this.onUpdateActiveTool("move"), this.publishToChannel(a);
46
+ const i = Object.fromEntries(t.entries());
47
+ C(i) && this.onUpdateActiveTool("move"), this.publishToChannel(i);
47
48
  });
48
49
  s(this, "undo", () => {
49
50
  if (!this.polycanvas)
@@ -51,7 +52,7 @@ class b {
51
52
  const t = this.polycanvas.undo();
52
53
  if (!t)
53
54
  return;
54
- const e = C(t);
55
+ const e = m(t);
55
56
  this.onChange(e);
56
57
  });
57
58
  s(this, "redo", () => {
@@ -73,6 +74,7 @@ class b {
73
74
  const t = this.polycanvas.getViewport();
74
75
  this.polycanvas.setViewport(t.x, t.y, t.zoom * 0.9);
75
76
  });
77
+ s(this, "getCanvasAsImage", async () => this.polycanvas ? await this.polycanvas.image(3e3, 3e3, "png") : void 0);
76
78
  s(this, "downloadCanvasAsImage", async () => {
77
79
  if (!this.polycanvas) return;
78
80
  const t = await this.polycanvas.image(3e3, 3e3, "png");
@@ -80,96 +82,99 @@ class b {
80
82
  const e = document.createElement("a");
81
83
  e.href = t, e.download = `canvas-drawing-${Date.now()}.png`, e.click();
82
84
  });
83
- s(this, "uploadFileToCanvas", async (t) => new Promise((e, a) => {
84
- this.uploadImageToS3 ? e(this.uploadImageToS3(t)) : a(new Error("Upload function not provided"));
85
- }));
86
85
  s(this, "onViewPortChange", (t) => {
87
- if (!this.publish) return;
88
- const e = t;
89
- this.publishToChannel({}, void 0, e);
86
+ this.updateCanvasConfigChange && this.updateCanvasConfigChange({ dimesion: t });
90
87
  });
91
88
  s(this, "openFileUpload", () => {
92
- this.fileInput || (this.fileInput = document.createElement("input"), this.fileInput.type = "file", this.fileInput.accept = "image/*", this.fileInput.style.display = "none", this.fileInput.onchange = this.addImageToCanvas, document.body.appendChild(this.fileInput)), this.fileInput.click();
89
+ this.fileInput || (this.fileInput = document.createElement("input"), this.fileInput.type = "file", this.fileInput.accept = "image/*", this.fileInput.style.display = "none", this.fileInput.onchange = this.onSelectImage, document.body.appendChild(this.fileInput)), this.fileInput.click();
93
90
  });
94
- s(this, "addImageToCanvas", async (t) => {
95
- var h;
96
- const e = t.target, a = (h = e.files) == null ? void 0 : h[0];
97
- if (!a || !this.polycanvas || !this.uploadImageToS3) return;
98
- const n = await this.uploadImageToS3(a), o = this.polycanvas.getViewport(), i = {
91
+ s(this, "addImageToCanvas", (t) => {
92
+ if (!this.polycanvas) return;
93
+ const e = this.polycanvas.getViewport(), i = {
99
94
  name: "image",
100
- href: n,
101
- x: o.x + 88,
102
- y: o.y + 88
103
- }, l = this.polycanvas.add({
95
+ href: t,
96
+ x: e.x + 24,
97
+ y: e.y + 24,
98
+ width: 500
99
+ }, o = this.polycanvas.add({
104
100
  ...i
105
101
  });
106
102
  this.publishToChannel({
107
- [l]: [void 0, { ...i, status: "locked" }]
108
- }), e.value = "";
103
+ [o]: [void 0, { ...i, status: "locked" }]
104
+ });
109
105
  });
110
- s(this, "updateCanvasConfig", (t, e, a) => {
111
- this.polycanvas && (t > this.height && this.updateHeight(t), e && this.polycanvas.setViewport(e.x, e.y, e.zoom), a && this.polycanvas.setOptions({
112
- grid: a
113
- }));
106
+ s(this, "onSelectImage", async (t) => {
107
+ var a;
108
+ const e = t.target, i = (a = e.files) == null ? void 0 : a[0];
109
+ if (!i || !this.polycanvas || !this.uploadImageToS3) return;
110
+ const o = await this.uploadImageToS3(i);
111
+ o !== "error" && (this.addImageToCanvas(o), e.value = "");
114
112
  });
115
113
  s(this, "updateCanvas", ({ data: t, userId: e }) => {
116
- const a = this.userType === "TEACHER" || e === this.userId;
117
- Object.entries(t).forEach(([n, o]) => {
118
- var i, l, h;
119
- !o[0] && o[1] ? (i = this.polycanvas) == null || i.add({ ...o[1], cannotEdit: !a }, n) : o[0] && !o[1] ? (l = this.polycanvas) == null || l.delete(n) : o[0] && o[1] && ((h = this.polycanvas) == null || h.update(n, { ...o[1] }));
114
+ const i = this.userType === "TEACHER" || e === this.userId;
115
+ Object.entries(t).forEach(([o, a]) => {
116
+ var n, h, r;
117
+ !a[0] && a[1] ? ("name" in a[1] && a[1].name === "image" && (a[1].status = this.userType === "STUDENT" ? "locked" : void 0), (n = this.polycanvas) == null || n.add({ ...a[1], cannotEdit: !i }, o)) : a[0] && !a[1] ? (h = this.polycanvas) == null || h.delete(o) : a[0] && a[1] && (console.log("====here ", a[0], a[1]), (r = this.polycanvas) == null || r.update(o, { ...a[1] }));
120
118
  });
121
119
  });
122
120
  s(this, "toggleTiles", (t) => {
123
121
  var e;
124
122
  (e = this.polycanvas) == null || e.toggleSidebar(t);
125
123
  });
124
+ s(this, "setViewPort", ({ x: t, y: e, zoom: i }) => {
125
+ var o;
126
+ if (this.polycanvas) {
127
+ const a = (o = this.polycanvas) == null ? void 0 : o.getViewport();
128
+ if (a.x === t && a.y === e && a.zoom === i)
129
+ return;
130
+ this.polycanvas.setViewport(t, e, i);
131
+ }
132
+ });
126
133
  s(this, "resetViewPort", () => {
127
134
  this.polycanvas && this.polycanvas.resetViewport();
128
135
  });
129
136
  s(this, "changeGrid", (t) => {
130
- this.polycanvas && (this.polycanvas.setOptions({
137
+ !this.polycanvas || this.gridName === t || (this.polycanvas.setOptions({
131
138
  grid: t
132
- }), this.publishToChannel({}, t));
139
+ }), this.gridName = t, this.updateCanvasConfigChange && this.updateCanvasConfigChange({ gridName: t }));
133
140
  });
134
141
  s(this, "lockSelectedTiles", () => {
135
- var a, n;
136
- const { tiles: t } = ((a = this.polycanvas) == null ? void 0 : a.serialize()) || {}, e = ((n = this.polycanvas) == null ? void 0 : n.getSelection()) || [];
142
+ var i, o;
143
+ const { tiles: t } = ((i = this.polycanvas) == null ? void 0 : i.serialize()) || {}, e = ((o = this.polycanvas) == null ? void 0 : o.getSelection()) || [];
137
144
  if (e.length > 0 && t) {
138
- const o = {};
139
- e.forEach((i) => {
140
- var h, c, p;
141
- if (!((h = t[i]) != null && h.name)) return;
142
- const l = { ...t[i], status: "locked" };
143
- (c = this.polycanvas) == null || c.update(i, l), (p = t[i]) != null && p.name && (o[i] = [t[i], l]);
144
- }), this.publishToChannel(o);
145
+ const a = {};
146
+ e.forEach((n) => {
147
+ var r, l, p;
148
+ if (!((r = t[n]) != null && r.name)) return;
149
+ const h = { ...t[n], status: "locked" };
150
+ (l = this.polycanvas) == null || l.update(n, h), (p = t[n]) != null && p.name && (a[n] = [t[n], h]);
151
+ }), this.publishToChannel(a);
145
152
  }
146
153
  });
147
154
  s(this, "unlockAllTiles", () => {
148
155
  if (!this.polycanvas) return;
149
156
  const { tiles: t } = this.polycanvas.serialize(), e = {};
150
- t && Object.entries(t).length > 0 && (Object.entries(t).forEach(([a, n]) => {
151
- var i;
152
- if (n.status !== "locked") return;
153
- const o = { ...n, status: void 0 };
154
- (i = this.polycanvas) == null || i.update(a, o), e[a] = [n, o];
157
+ t && Object.entries(t).length > 0 && (Object.entries(t).forEach(([i, o]) => {
158
+ var n;
159
+ if (o.status !== "locked") return;
160
+ const a = { ...o, status: void 0 };
161
+ (n = this.polycanvas) == null || n.update(i, a), e[i] = [o, a];
155
162
  }), this.publishToChannel(e));
156
163
  });
157
164
  s(this, "replaceCanvas", (t) => {
158
165
  if (!this.polycanvas) return;
159
- const { data: e, gridName: a } = t;
160
- this.polycanvas.clear(), a && this.polycanvas.setOptions({
161
- grid: a
162
- }), Object.entries(e).forEach(([n, o]) => {
163
- var i;
164
- if (!o[0] && o[1]) {
165
- (i = this.polycanvas) == null || i.add({ ...o[1] }, n);
166
+ const { data: e, gridName: i } = t;
167
+ this.polycanvas.clear(), i && this.changeGrid(i), Object.entries(e).forEach(([o, a]) => {
168
+ var n;
169
+ if (!a[0] && a[1]) {
170
+ (n = this.polycanvas) == null || n.add({ ...a[1] }, o);
166
171
  return;
167
172
  }
168
- }), this.publishToChannel(e, a);
173
+ }), this.publishToChannel(e);
169
174
  });
170
175
  s(this, "setTool", (t) => {
171
176
  if (this.polycanvas) {
172
- const [e, a] = m(t);
177
+ const [e, i] = T(t);
173
178
  switch (e) {
174
179
  case "clearAll":
175
180
  this.clearCanvas();
@@ -204,7 +209,7 @@ class b {
204
209
  case "grid":
205
210
  break;
206
211
  default:
207
- this.polycanvas.setTool(e, a);
212
+ this.polycanvas.setTool(e, i);
208
213
  }
209
214
  }
210
215
  });
@@ -222,10 +227,10 @@ class b {
222
227
  */
223
228
  s(this, "update", (t) => {
224
229
  if (Array.isArray(t)) {
225
- const e = t.map((i) => i.height).filter(Boolean), a = Math.max(...e), n = t.map((i) => i.dimension).filter(Boolean)[t.length - 1], o = t.map((i) => i.gridName).filter(Boolean)[t.length - 1];
226
- this.updateCanvasConfig(a, n, o), t.forEach((i) => this.updateCanvas(i));
230
+ const e = t.map((o) => o.height).filter(Boolean), i = Math.max(...e);
231
+ i > this.height && this.updateHeight(i), t.forEach((o) => this.updateCanvas(o));
227
232
  } else
228
- this.updateCanvasConfig(t.height, t.dimension, t == null ? void 0 : t.gridName), this.updateCanvas(t);
233
+ t.height > this.height && this.updateHeight(t.height), this.updateCanvas(t);
229
234
  });
230
235
  s(this, "setColor", (t) => {
231
236
  this.polycanvas && this.polycanvas.setColor(t);
@@ -237,21 +242,21 @@ class b {
237
242
  s(this, "destroy", () => {
238
243
  this.polycanvas && (this.polycanvas.off("change", this.onChange), this.polycanvas.destroy(), this.debouncedViewportChange.cancel(), this.renderAs === "whiteboard" && this.userType === "TEACHER" && this.polycanvas.off("viewport", this.debouncedViewportChange), this.polycanvas = void 0, this.fileInput && this.fileInput.parentNode && (this.fileInput.parentNode.removeChild(this.fileInput), this.fileInput = null));
239
244
  });
240
- this.onUpdateHeight = n, this.onUpdateActiveTool = a, this.height = i, this.uploadImageToS3 = o, this.userId = l, this.canvasId = h, this.publish = t, this.userType = c, this.renderAs = p, this.debouncedViewportChange = v(this.onViewPortChange, 300), e == null || e(this.canvasId, this.update);
245
+ this.onUpdateHeight = o, this.onUpdateActiveTool = i, this.height = n, this.uploadImageToS3 = a, this.userId = h, this.canvasId = r, this.publish = t, this.userType = l, this.renderAs = p, this.debouncedViewportChange = v(this.onViewPortChange, 300), this.updateCanvasConfigChange = d, e == null || e(this.canvasId, this.update);
241
246
  }
242
- async create({ canvasElementRef: t, canvasConfig: e, canvasSetting: a, initialData: n }) {
247
+ async create({ canvasElementRef: t, canvasConfig: e, canvasSetting: i, initialData: o }) {
243
248
  if (!t.current)
244
249
  throw new Error("PolyCanvas: Div Element Not found for canvas");
245
250
  this.polycanvas = await window.Polypad.create(t.current, {
246
251
  initial: {
247
252
  options: e
248
253
  },
249
- ...a,
250
- imageUpload: this.renderAs === "whiteboard" && this.userType === "TEACHER" ? this.uploadFileToCanvas : void 0
251
- }), this.renderAs === "whiteboard" && this.userType === "TEACHER" && (this.polycanvas.toggleSidebar(!1), f(t), this.polycanvas.on("viewport", this.debouncedViewportChange)), g(t), this.polycanvas.on("change", this.onChange), n && this.update(n);
254
+ ...i,
255
+ imageUpload: this.renderAs === "whiteboard" && this.userType === "TEACHER" && this.uploadImageToS3 ? this.uploadImageToS3 : void 0
256
+ }), this.renderAs === "whiteboard" && this.userType === "TEACHER" && (this.polycanvas.toggleSidebar(!1), this.polycanvas.bindKeyboardEvents({}), f(t), this.polycanvas.on("viewport", this.debouncedViewportChange)), y(t), this.polycanvas.on("change", this.onChange), o && this.update(o);
252
257
  }
253
258
  }
254
259
  export {
255
- b as CueCanvasCore
260
+ k as CueCanvasCore
256
261
  };
257
262
  //# sourceMappingURL=cue-canvas-core.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cue-canvas-core.js","sources":["../../../src/features/cue-canvas/cue-canvas-core.ts"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type {\n IActionData,\n IViewport,\n TCueCanvasChangeData,\n TCueCanvasGridName,\n TCueCanvasTool,\n TPublish,\n TRenderAs,\n TCueCanvasChangeDataObject,\n IReplaceCanvas,\n ICueCanvasCoreProps,\n} from './types/cue-canvas';\nimport type { ICreateOptions } from './types/cue-canvas';\nimport type { IPolypad, IPolyPadInstance } from './types/polypad';\n\nimport debounce from 'lodash.debounce';\n\nimport {\n checkTextOrEquationTool,\n getReverseMap,\n getToolAndSubtool,\n removeMask,\n removeTileButton,\n} from './cue-canvas-helpers';\n\ndeclare global {\n interface Window {\n Polypad: IPolypad;\n }\n}\n\n/**\n * The CueCanvasCore class manages the canvas state and tool synchronization.\n * When text or equations are added, Polypad automatically switches to 'move' tool.\n * onUpdateActiveTool ensures the UI reflects this automatic tool change.\n */\n\nexport class CueCanvasCore {\n private polycanvas: IPolyPadInstance | undefined;\n private publish?: TPublish;\n private height: number;\n private onUpdateActiveTool: (tool: TCueCanvasTool) => void;\n private onUpdateHeight?: (height: number) => void;\n private userId: string;\n private canvasId: string;\n private userType: TUserTypes;\n private renderAs: TRenderAs;\n private fileInput: HTMLInputElement | null = null;\n private debouncedViewportChange: ReturnType<typeof debounce>;\n private uploadImageToS3?: (file: File) => string;\n\n constructor({\n onPublish,\n onSubscribe,\n onUpdateActiveTool,\n onUpdateHeight,\n uploadImageToS3,\n height,\n userId,\n canvasId,\n userType,\n renderAs,\n }: ICueCanvasCoreProps) {\n this.onUpdateHeight = onUpdateHeight;\n this.onUpdateActiveTool = onUpdateActiveTool;\n this.height = height;\n this.uploadImageToS3 = uploadImageToS3;\n this.userId = userId;\n this.canvasId = canvasId;\n this.publish = onPublish;\n this.userType = userType;\n this.renderAs = renderAs;\n this.debouncedViewportChange = debounce(this.onViewPortChange, 300);\n onSubscribe?.(this.canvasId, this.update);\n }\n\n async create({ canvasElementRef, canvasConfig, canvasSetting, initialData }: ICreateOptions) {\n if (!canvasElementRef.current) {\n throw new Error('PolyCanvas: Div Element Not found for canvas');\n }\n this.polycanvas = await window.Polypad.create(canvasElementRef.current, {\n initial: {\n options: canvasConfig,\n },\n ...canvasSetting,\n imageUpload:\n this.renderAs === 'whiteboard' && this.userType === 'TEACHER'\n ? this.uploadFileToCanvas\n : undefined,\n });\n\n if (this.renderAs === 'whiteboard' && this.userType === 'TEACHER') {\n this.polycanvas.toggleSidebar(false);\n\n removeTileButton(canvasElementRef);\n this.polycanvas.on('viewport', this.debouncedViewportChange);\n }\n\n removeMask(canvasElementRef);\n this.polycanvas.on('change', this.onChange);\n if (initialData) {\n this.update(initialData);\n }\n }\n\n private publishToChannel = (\n payload: TCueCanvasChangeDataObject,\n gridName?: TCueCanvasGridName,\n dimension?: IViewport,\n ) => {\n if (!this.publish) return;\n\n this.publish({\n eventName: 'cue_canvas_changed',\n eventPayload: {\n data: payload,\n height: this.height,\n userId: this.userId,\n responseId: this.canvasId,\n gridName,\n dimension,\n },\n });\n };\n\n private onChange = (e: unknown) => {\n const data = e as TCueCanvasChangeData;\n const payload = Object.fromEntries(data.entries());\n\n if (checkTextOrEquationTool(payload)) {\n this.onUpdateActiveTool('move');\n }\n\n this.publishToChannel(payload);\n };\n\n private undo = () => {\n if (!this.polycanvas) {\n return;\n }\n\n const data = this.polycanvas.undo() as TCueCanvasChangeData;\n\n if (!data) {\n return;\n }\n\n const undoData = getReverseMap(data);\n\n this.onChange(undoData);\n };\n\n private redo = () => {\n if (!this.polycanvas) {\n return;\n }\n\n const data = this.polycanvas.redo() as TCueCanvasChangeData;\n\n if (!data) {\n return;\n }\n\n this.onChange(data);\n };\n\n private clearCanvas = () => {\n if (this.polycanvas) {\n this.polycanvas.clear();\n }\n };\n\n private zoomIn = () => {\n if (!this.polycanvas) return;\n\n const viewPort = this.polycanvas.getViewport();\n\n this.polycanvas.setViewport(viewPort.x, viewPort.y, viewPort.zoom * 1.1);\n };\n\n private zoomOut = () => {\n if (!this.polycanvas) return;\n\n const viewPort = this.polycanvas.getViewport();\n\n this.polycanvas.setViewport(viewPort.x, viewPort.y, viewPort.zoom * 0.9);\n };\n\n private downloadCanvasAsImage = async () => {\n if (!this.polycanvas) return;\n\n const image = await this.polycanvas.image(3000, 3000, 'png');\n\n if (!image) return;\n\n const downloadLink = document.createElement('a');\n\n downloadLink.href = image;\n downloadLink.download = `canvas-drawing-${Date.now()}.png`;\n downloadLink.click();\n };\n\n private uploadFileToCanvas = async (file: File): Promise<string> => {\n return new Promise((resolve, reject) => {\n this.uploadImageToS3\n ? resolve(this.uploadImageToS3(file))\n : reject(new Error('Upload function not provided'));\n });\n };\n\n private onViewPortChange = (e: IViewport): void => {\n if (!this.publish) return;\n\n const data = e as IViewport;\n\n this.publishToChannel({}, undefined, data);\n };\n\n private openFileUpload = (): void => {\n if (!this.fileInput) {\n this.fileInput = document.createElement('input');\n this.fileInput.type = 'file';\n this.fileInput.accept = 'image/*';\n this.fileInput.style.display = 'none';\n this.fileInput.onchange = this.addImageToCanvas;\n document.body.appendChild(this.fileInput);\n }\n\n this.fileInput.click();\n };\n\n private addImageToCanvas = async (event: Event): Promise<void> => {\n const target = event.target as HTMLInputElement;\n const file = target.files?.[0];\n\n if (!file || !this.polycanvas || !this.uploadImageToS3) return;\n\n const imageBase64 = await this.uploadImageToS3(file);\n const viewPort = this.polycanvas.getViewport();\n const imgJson = {\n name: 'image',\n href: imageBase64,\n x: viewPort.x + 88,\n y: viewPort.y + 88,\n };\n\n const key = this.polycanvas.add({\n ...imgJson,\n });\n\n this.publishToChannel({\n [key]: [undefined, { ...imgJson, status: 'locked' }],\n });\n\n target.value = '';\n };\n\n private updateCanvasConfig = (\n height: number,\n dimension: IViewport | undefined,\n gridName: TCueCanvasGridName | undefined,\n ) => {\n if (!this.polycanvas) return;\n\n if (height > this.height) {\n this.updateHeight(height);\n }\n\n if (dimension) {\n this.polycanvas.setViewport(dimension.x, dimension.y, dimension.zoom);\n }\n\n if (gridName) {\n this.polycanvas.setOptions({\n grid: gridName,\n });\n }\n };\n\n private updateCanvas = ({ data, userId }: IActionData) => {\n const canEditStroke = this.userType === 'TEACHER' || userId === this.userId;\n\n Object.entries(data).forEach(([key, value]) => {\n if (!value[0] && value[1]) {\n this.polycanvas?.add({ ...value[1], cannotEdit: !canEditStroke }, key);\n } else if (value[0] && !value[1]) {\n this.polycanvas?.delete(key);\n } else if (value[0] && value[1]) {\n this.polycanvas?.update(key, { ...value[1] });\n }\n });\n };\n\n toggleTiles = (val: boolean) => {\n this.polycanvas?.toggleSidebar(val);\n };\n\n resetViewPort = () => {\n if (this.polycanvas) {\n this.polycanvas.resetViewport();\n }\n };\n\n changeGrid = (gridName: TCueCanvasGridName) => {\n if (!this.polycanvas) return;\n\n this.polycanvas.setOptions({\n grid: gridName,\n });\n\n this.publishToChannel({}, gridName);\n };\n\n lockSelectedTiles = () => {\n const { tiles: allTiles } = this.polycanvas?.serialize() || {};\n const selectedItems = this.polycanvas?.getSelection() || [];\n\n if (selectedItems.length > 0 && allTiles) {\n const lockedTiles: TCueCanvasChangeDataObject = {};\n\n selectedItems.forEach(key => {\n if (!allTiles[key]?.name) return;\n\n const updatedJson = { ...allTiles[key], status: 'locked' as const };\n\n this.polycanvas?.update(key, updatedJson);\n if (allTiles[key]?.name) lockedTiles[key] = [allTiles[key], updatedJson];\n });\n\n this.publishToChannel(lockedTiles);\n }\n };\n\n unlockAllTiles = () => {\n if (!this.polycanvas) return;\n\n const { tiles: allTiles } = this.polycanvas.serialize();\n const unlockedTiles: TCueCanvasChangeDataObject = {};\n\n if (allTiles && Object.entries(allTiles).length > 0) {\n Object.entries(allTiles).forEach(([key, item]) => {\n if (item.status !== 'locked') return;\n\n const updatedJson = { ...item, status: undefined };\n\n this.polycanvas?.update(key, updatedJson);\n unlockedTiles[key] = [item, updatedJson];\n });\n\n this.publishToChannel(unlockedTiles);\n }\n };\n\n replaceCanvas = (data: IReplaceCanvas) => {\n if (!this.polycanvas) return;\n\n const { data: canvasData, gridName } = data;\n\n this.polycanvas.clear();\n\n if (gridName) {\n this.polycanvas.setOptions({\n grid: gridName,\n });\n }\n\n Object.entries(canvasData).forEach(([key, value]) => {\n if (!value[0] && value[1]) {\n this.polycanvas?.add({ ...value[1] }, key);\n\n return;\n }\n });\n\n this.publishToChannel(canvasData, gridName);\n };\n\n setTool = (tool: TCueCanvasTool) => {\n if (this.polycanvas) {\n const [currTool, currSubTool] = getToolAndSubtool(tool);\n\n switch (currTool) {\n case 'clearAll':\n this.clearCanvas();\n break;\n case 'home':\n this.resetViewPort();\n break;\n case 'undo':\n this.undo();\n break;\n case 'redo':\n this.redo();\n break;\n case 'lock':\n this.lockSelectedTiles();\n break;\n case 'unlock':\n this.unlockAllTiles();\n break;\n case 'zoomIn':\n this.zoomIn();\n break;\n case 'zoomOut':\n this.zoomOut();\n break;\n case 'upload':\n this.openFileUpload();\n break;\n case 'download':\n this.downloadCanvasAsImage();\n break;\n case 'grid':\n break;\n default:\n this.polycanvas.setTool(currTool, currSubTool);\n }\n }\n };\n\n /**\n * The `update` method is called in two cases:\n * 1. When receiving initial data to update the canvas content.\n * 2. When receiving strokes from other peers to update the canvas content.\n * Each item can contain multiple actions, which are applied to the canvas.\n *\n * The method checks if the payload is an array or a single object.\n * If it's an array, it iterates over each item and updates the canvas accordingly.\n * If it's a single object, it directly updates the canvas.\n *\n * Additionally, if the payload contains a height greater than the current height of the canvas, the `updateHeight` method is called to update the canvas height.\n */\n update = (payload: IActionData | IActionData[]) => {\n if (Array.isArray(payload)) {\n const heights = payload.map(data => data.height).filter(Boolean);\n const maxHeight = Math.max(...heights);\n const lastDimension = payload.map(data => data.dimension).filter(Boolean)[payload.length - 1];\n const lastGrid = payload.map(data => data.gridName).filter(Boolean)[payload.length - 1];\n\n this.updateCanvasConfig(maxHeight, lastDimension, lastGrid);\n payload.forEach(item => this.updateCanvas(item));\n } else {\n this.updateCanvasConfig(payload.height, payload.dimension, payload?.gridName);\n this.updateCanvas(payload);\n }\n };\n\n setColor = (color: string) => {\n if (this.polycanvas) {\n this.polycanvas.setColor(color);\n }\n };\n\n updateHeight = (height: number) => {\n this.height = height;\n this.onUpdateHeight?.(height);\n };\n\n destroy = () => {\n if (this.polycanvas) {\n this.polycanvas.off('change', this.onChange);\n this.polycanvas.destroy();\n this.debouncedViewportChange.cancel();\n\n if (this.renderAs === 'whiteboard' && this.userType === 'TEACHER') {\n this.polycanvas.off('viewport', this.debouncedViewportChange);\n }\n this.polycanvas = undefined;\n\n if (this.fileInput && this.fileInput.parentNode) {\n this.fileInput.parentNode.removeChild(this.fileInput);\n this.fileInput = null;\n }\n }\n };\n}\n"],"names":["CueCanvasCore","onPublish","onSubscribe","onUpdateActiveTool","onUpdateHeight","uploadImageToS3","height","userId","canvasId","userType","renderAs","__publicField","payload","gridName","dimension","e","checkTextOrEquationTool","data","undoData","getReverseMap","viewPort","image","downloadLink","file","resolve","reject","event","target","_a","imageBase64","imgJson","key","canEditStroke","value","_b","_c","val","allTiles","selectedItems","lockedTiles","updatedJson","unlockedTiles","item","canvasData","tool","currTool","currSubTool","getToolAndSubtool","heights","maxHeight","lastDimension","lastGrid","color","debounce","canvasElementRef","canvasConfig","canvasSetting","initialData","removeTileButton","removeMask"],"mappings":"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"}
1
+ {"version":3,"file":"cue-canvas-core.js","sources":["../../../src/features/cue-canvas/cue-canvas-core.ts"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type {\n IActionData,\n IViewport,\n TCueCanvasChangeData,\n TCueCanvasGridName,\n TCueCanvasTool,\n TPublish,\n TRenderAs,\n TCueCanvasChangeDataObject,\n IReplaceCanvas,\n ICueCanvasCoreProps,\n TUpdateCanvasConfig,\n} from './types/cue-canvas';\nimport type { ICreateOptions } from './types/cue-canvas';\nimport type { IPolypad, IPolyPadInstance } from './types/polypad';\n\nimport { captureMessage } from '@sentry/browser';\nimport debounce from 'lodash.debounce';\n\nimport {\n checkTextOrEquationTool,\n getReverseMap,\n getToolAndSubtool,\n removeMask,\n removeTileButton,\n} from './cue-canvas-helpers';\n\ndeclare global {\n interface Window {\n Polypad: IPolypad;\n }\n}\n\n/**\n * The CueCanvasCore class manages the canvas state and tool synchronization.\n * When text or equations are added, Polypad automatically switches to 'move' tool.\n * onUpdateActiveTool ensures the UI reflects this automatic tool change.\n */\n\nexport class CueCanvasCore {\n private polycanvas: IPolyPadInstance | undefined;\n private publish?: TPublish;\n private height: number;\n private onUpdateActiveTool: (tool: TCueCanvasTool) => void;\n private onUpdateHeight?: (height: number) => void;\n private userId: string;\n private canvasId: string;\n private userType: TUserTypes;\n private renderAs: TRenderAs;\n private fileInput: HTMLInputElement | null = null;\n private debouncedViewportChange: ReturnType<typeof debounce>;\n private uploadImageToS3?: (file: File) => Promise<string>;\n private updateCanvasConfigChange?: TUpdateCanvasConfig;\n private gridName?: TCueCanvasGridName;\n\n constructor({\n onPublish,\n onSubscribe,\n onUpdateActiveTool,\n onUpdateHeight,\n uploadImageToS3,\n height,\n userId,\n canvasId,\n userType,\n renderAs,\n updateCanvasConfig,\n }: ICueCanvasCoreProps) {\n this.onUpdateHeight = onUpdateHeight;\n this.onUpdateActiveTool = onUpdateActiveTool;\n this.height = height;\n this.uploadImageToS3 = uploadImageToS3;\n this.userId = userId;\n this.canvasId = canvasId;\n this.publish = onPublish;\n this.userType = userType;\n this.renderAs = renderAs;\n this.debouncedViewportChange = debounce(this.onViewPortChange, 300);\n this.updateCanvasConfigChange = updateCanvasConfig;\n onSubscribe?.(this.canvasId, this.update);\n }\n\n async create({ canvasElementRef, canvasConfig, canvasSetting, initialData }: ICreateOptions) {\n if (!canvasElementRef.current) {\n throw new Error('PolyCanvas: Div Element Not found for canvas');\n }\n this.polycanvas = await window.Polypad.create(canvasElementRef.current, {\n initial: {\n options: canvasConfig,\n },\n ...canvasSetting,\n imageUpload:\n this.renderAs === 'whiteboard' && this.userType === 'TEACHER' && this.uploadImageToS3\n ? this.uploadImageToS3\n : undefined,\n });\n\n if (this.renderAs === 'whiteboard' && this.userType === 'TEACHER') {\n this.polycanvas.toggleSidebar(false);\n this.polycanvas.bindKeyboardEvents({});\n\n removeTileButton(canvasElementRef);\n this.polycanvas.on('viewport', this.debouncedViewportChange);\n }\n\n removeMask(canvasElementRef);\n this.polycanvas.on('change', this.onChange);\n if (initialData) {\n this.update(initialData);\n }\n }\n\n private publishToChannel = (payload: TCueCanvasChangeDataObject) => {\n if (!this.publish) return;\n\n this.publish({\n eventName: 'cue_canvas_changed',\n eventPayload: {\n data: payload,\n height: this.height,\n userId: this.userId,\n responseId: this.canvasId,\n },\n });\n };\n\n private onChange = (e: unknown) => {\n const data = e as TCueCanvasChangeData;\n const payload = Object.fromEntries(data.entries());\n\n if (checkTextOrEquationTool(payload)) {\n this.onUpdateActiveTool('move');\n }\n\n this.publishToChannel(payload);\n };\n\n private undo = () => {\n if (!this.polycanvas) {\n return;\n }\n\n const data = this.polycanvas.undo() as TCueCanvasChangeData;\n\n if (!data) {\n return;\n }\n\n const undoData = getReverseMap(data);\n\n this.onChange(undoData);\n };\n\n private redo = () => {\n if (!this.polycanvas) {\n return;\n }\n\n const data = this.polycanvas.redo() as TCueCanvasChangeData;\n\n if (!data) {\n return;\n }\n\n this.onChange(data);\n };\n\n clearCanvas = () => {\n if (this.polycanvas) {\n this.polycanvas.clear();\n }\n };\n\n private zoomIn = () => {\n if (!this.polycanvas) return;\n\n const viewPort = this.polycanvas.getViewport();\n\n this.polycanvas.setViewport(viewPort.x, viewPort.y, viewPort.zoom * 1.1);\n };\n\n private zoomOut = () => {\n if (!this.polycanvas) return;\n\n const viewPort = this.polycanvas.getViewport();\n\n this.polycanvas.setViewport(viewPort.x, viewPort.y, viewPort.zoom * 0.9);\n };\n\n getCanvasAsImage = async () => {\n if (!this.polycanvas) return;\n\n const image = await this.polycanvas.image(3000, 3000, 'png');\n\n return image;\n };\n\n private downloadCanvasAsImage = async () => {\n if (!this.polycanvas) return;\n\n const image = await this.polycanvas.image(3000, 3000, 'png');\n\n if (!image) return;\n\n const downloadLink = document.createElement('a');\n\n downloadLink.href = image;\n downloadLink.download = `canvas-drawing-${Date.now()}.png`;\n downloadLink.click();\n };\n\n private onViewPortChange = (e: IViewport): void => {\n if (!this.updateCanvasConfigChange) return;\n\n this.updateCanvasConfigChange({ dimesion: e });\n };\n\n private openFileUpload = (): void => {\n if (!this.fileInput) {\n this.fileInput = document.createElement('input');\n this.fileInput.type = 'file';\n this.fileInput.accept = 'image/*';\n this.fileInput.style.display = 'none';\n this.fileInput.onchange = this.onSelectImage;\n document.body.appendChild(this.fileInput);\n }\n\n this.fileInput.click();\n };\n\n addImageToCanvas = (imageUrl: string): void => {\n if (!this.polycanvas) return;\n\n const viewPort = this.polycanvas.getViewport();\n const imgJson = {\n name: 'image',\n href: imageUrl,\n x: viewPort.x + 24,\n y: viewPort.y + 24,\n width: 500,\n };\n\n const key = this.polycanvas.add({\n ...imgJson,\n });\n\n this.publishToChannel({\n [key]: [undefined, { ...imgJson, status: 'locked' }],\n });\n };\n\n private onSelectImage = async (event: Event): Promise<void> => {\n const target = event.target as HTMLInputElement;\n const file = target.files?.[0];\n\n if (!file || !this.polycanvas || !this.uploadImageToS3) return;\n\n const imageUrl = await this.uploadImageToS3(file);\n\n if (imageUrl === 'error') {\n return;\n }\n\n this.addImageToCanvas(imageUrl);\n\n target.value = '';\n };\n\n private updateCanvas = ({ data, userId }: IActionData) => {\n const canEditStroke = this.userType === 'TEACHER' || userId === this.userId;\n\n Object.entries(data).forEach(([key, value]) => {\n if (!value[0] && value[1]) {\n if ('name' in value[1] && value[1].name === 'image') {\n value[1].status = this.userType === 'STUDENT' ? 'locked' : undefined; // Lock only images for students\n }\n this.polycanvas?.add({ ...value[1], cannotEdit: !canEditStroke }, key);\n } else if (value[0] && !value[1]) {\n this.polycanvas?.delete(key);\n } else if (value[0] && value[1]) {\n console.log('====here ', value[0], value[1]);\n this.polycanvas?.update(key, { ...value[1] });\n }\n });\n };\n\n toggleTiles = (val: boolean) => {\n this.polycanvas?.toggleSidebar(val);\n };\n\n setViewPort = ({ x, y, zoom }: IViewport) => {\n if (this.polycanvas) {\n const cv = this.polycanvas?.getViewport();\n\n if (cv.x === x && cv.y === y && cv.zoom === zoom) {\n return; // No change needed\n }\n\n this.polycanvas.setViewport(x, y, zoom);\n }\n };\n\n resetViewPort = () => {\n if (this.polycanvas) {\n this.polycanvas.resetViewport();\n }\n };\n\n changeGrid = (gridName: TCueCanvasGridName) => {\n if (!this.polycanvas || this.gridName === gridName) return;\n\n this.polycanvas.setOptions({\n grid: gridName,\n });\n this.gridName = gridName;\n if (this.updateCanvasConfigChange) {\n this.updateCanvasConfigChange({ gridName: gridName });\n }\n };\n\n lockSelectedTiles = () => {\n const { tiles: allTiles } = this.polycanvas?.serialize() || {};\n const selectedItems = this.polycanvas?.getSelection() || [];\n\n if (selectedItems.length > 0 && allTiles) {\n const lockedTiles: TCueCanvasChangeDataObject = {};\n\n selectedItems.forEach(key => {\n if (!allTiles[key]?.name) return;\n\n const updatedJson = { ...allTiles[key], status: 'locked' as const };\n\n this.polycanvas?.update(key, updatedJson);\n if (allTiles[key]?.name) lockedTiles[key] = [allTiles[key], updatedJson];\n });\n\n this.publishToChannel(lockedTiles);\n }\n };\n\n unlockAllTiles = () => {\n if (!this.polycanvas) return;\n\n const { tiles: allTiles } = this.polycanvas.serialize();\n const unlockedTiles: TCueCanvasChangeDataObject = {};\n\n if (allTiles && Object.entries(allTiles).length > 0) {\n Object.entries(allTiles).forEach(([key, item]) => {\n if (item.status !== 'locked') return;\n\n const updatedJson = { ...item, status: undefined };\n\n this.polycanvas?.update(key, updatedJson);\n unlockedTiles[key] = [item, updatedJson];\n });\n\n this.publishToChannel(unlockedTiles);\n }\n };\n\n replaceCanvas = (data: IReplaceCanvas) => {\n if (!this.polycanvas) return;\n\n const { data: canvasData, gridName } = data;\n\n this.polycanvas.clear();\n if (gridName) {\n this.changeGrid(gridName);\n }\n\n Object.entries(canvasData).forEach(([key, value]) => {\n if (!value[0] && value[1]) {\n this.polycanvas?.add({ ...value[1] }, key);\n\n return;\n }\n });\n\n this.publishToChannel(canvasData);\n };\n\n setTool = (tool: TCueCanvasTool) => {\n if (this.polycanvas) {\n const [currTool, currSubTool] = getToolAndSubtool(tool);\n\n switch (currTool) {\n case 'clearAll':\n this.clearCanvas();\n break;\n case 'home':\n this.resetViewPort();\n break;\n case 'undo':\n this.undo();\n break;\n case 'redo':\n this.redo();\n break;\n case 'lock':\n this.lockSelectedTiles();\n break;\n case 'unlock':\n this.unlockAllTiles();\n break;\n case 'zoomIn':\n this.zoomIn();\n break;\n case 'zoomOut':\n this.zoomOut();\n break;\n case 'upload':\n this.openFileUpload();\n break;\n case 'download':\n this.downloadCanvasAsImage();\n break;\n case 'grid':\n break;\n default:\n this.polycanvas.setTool(currTool, currSubTool);\n }\n }\n };\n\n /**\n * The `update` method is called in two cases:\n * 1. When receiving initial data to update the canvas content.\n * 2. When receiving strokes from other peers to update the canvas content.\n * Each item can contain multiple actions, which are applied to the canvas.\n *\n * The method checks if the payload is an array or a single object.\n * If it's an array, it iterates over each item and updates the canvas accordingly.\n * If it's a single object, it directly updates the canvas.\n *\n * Additionally, if the payload contains a height greater than the current height of the canvas, the `updateHeight` method is called to update the canvas height.\n */\n update = (payload: IActionData | IActionData[]) => {\n if (Array.isArray(payload)) {\n const heights = payload.map(data => data.height).filter(Boolean);\n const maxHeight = Math.max(...heights);\n\n if (maxHeight > this.height) {\n this.updateHeight(maxHeight);\n }\n payload.forEach(item => this.updateCanvas(item));\n } else {\n if (payload.height > this.height) {\n this.updateHeight(payload.height);\n }\n this.updateCanvas(payload);\n }\n };\n\n setColor = (color: string) => {\n if (this.polycanvas) {\n this.polycanvas.setColor(color);\n }\n };\n\n updateHeight = (height: number) => {\n this.height = height;\n this.onUpdateHeight?.(height);\n };\n\n destroy = () => {\n if (this.polycanvas) {\n this.polycanvas.off('change', this.onChange);\n this.polycanvas.destroy();\n this.debouncedViewportChange.cancel();\n\n if (this.renderAs === 'whiteboard' && this.userType === 'TEACHER') {\n this.polycanvas.off('viewport', this.debouncedViewportChange);\n }\n this.polycanvas = undefined;\n\n if (this.fileInput && this.fileInput.parentNode) {\n this.fileInput.parentNode.removeChild(this.fileInput);\n this.fileInput = null;\n }\n }\n };\n}\n"],"names":["CueCanvasCore","onPublish","onSubscribe","onUpdateActiveTool","onUpdateHeight","uploadImageToS3","height","userId","canvasId","userType","renderAs","updateCanvasConfig","__publicField","payload","e","checkTextOrEquationTool","data","undoData","getReverseMap","viewPort","image","downloadLink","imageUrl","imgJson","key","event","target","file","_a","canEditStroke","value","_b","_c","val","x","y","zoom","cv","gridName","allTiles","selectedItems","lockedTiles","updatedJson","unlockedTiles","item","canvasData","tool","currTool","currSubTool","getToolAndSubtool","heights","maxHeight","color","debounce","canvasElementRef","canvasConfig","canvasSetting","initialData","removeTileButton","removeMask"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- const g = [
1
+ const T = [
2
2
  "none",
3
3
  "square2-grid",
4
4
  "square-checked",
@@ -8,7 +8,7 @@ const g = [
8
8
  "square-grid",
9
9
  "tri-grid",
10
10
  "tri2-grid"
11
- ], A = /* @__PURE__ */ new Set([
11
+ ], E = /* @__PURE__ */ new Set([
12
12
  "undo",
13
13
  "redo",
14
14
  "clearAll",
@@ -19,7 +19,7 @@ const g = [
19
19
  "zoomOut",
20
20
  "upload",
21
21
  "download"
22
- ]), E = (e) => {
22
+ ]), h = (e) => {
23
23
  var n;
24
24
  const t = (n = e.current) == null ? void 0 : n.shadowRoot;
25
25
  if (t) {
@@ -29,7 +29,7 @@ const g = [
29
29
  o == null || o.setAttribute("stroke", "transparent"), o == null || o.setAttribute("fill", "transparent"), o == null || o.removeAttribute("style");
30
30
  }
31
31
  }
32
- }, T = (e) => {
32
+ }, m = (e) => {
33
33
  var o;
34
34
  const t = (o = e.current) == null ? void 0 : o.shadowRoot, n = t == null ? void 0 : t.querySelector("x-pp-sidebar"), r = n == null ? void 0 : n.getElementsByClassName("tabs-header"), s = n == null ? void 0 : n.getElementsByClassName("tabs-body");
35
35
  if (n == null || n.setAttribute("style", "display: none;"), n == null || n.setAttribute("style", "height: 30px;"), r && r.length > 0) {
@@ -41,7 +41,7 @@ const g = [
41
41
  a.style.top = "48px";
42
42
  }
43
43
  n == null || n.setAttribute("style", "display: block;");
44
- }, p = (e, t, n, r) => n === "canvas" ? {
44
+ }, S = (e, t, n, r) => n === "canvas" ? {
45
45
  canvas: "notebook",
46
46
  canvasX: e,
47
47
  canvasY: t,
@@ -59,7 +59,7 @@ const g = [
59
59
  noCopyPaste: r === "STUDENT",
60
60
  noMusic: !0,
61
61
  noAudio: !0
62
- }, S = (e, t) => e === "canvas" ? {
62
+ }, y = (e, t) => e === "canvas" ? {
63
63
  sidebarTiles: !1,
64
64
  sidebarSettings: !1,
65
65
  settings: !1,
@@ -70,12 +70,12 @@ const g = [
70
70
  sidebarSettings: !1,
71
71
  settings: !1,
72
72
  toolbar: !1
73
- }, l = (e) => [e[1], e[0]], h = (e) => {
73
+ }, u = (e) => [e[1], e[0]], b = (e) => {
74
74
  const t = /* @__PURE__ */ new Map();
75
75
  return e.forEach((n, r) => {
76
- t.set(r, l(n));
76
+ t.set(r, u(n));
77
77
  }), t;
78
- }, m = (e) => {
78
+ }, f = (e) => {
79
79
  switch (e) {
80
80
  case "pen":
81
81
  return ["pen", "pen"];
@@ -90,7 +90,7 @@ const g = [
90
90
  default:
91
91
  return [e, void 0];
92
92
  }
93
- }, c = [
93
+ }, d = [
94
94
  "pen",
95
95
  "ruler",
96
96
  "marker",
@@ -111,7 +111,7 @@ const g = [
111
111
  "zoomOut",
112
112
  "upload",
113
113
  "download"
114
- ], i = [
114
+ ], g = [
115
115
  "pen",
116
116
  "ruler",
117
117
  "marker",
@@ -121,7 +121,7 @@ const g = [
121
121
  "undo",
122
122
  "redo",
123
123
  "download"
124
- ], u = [
124
+ ], p = [
125
125
  "pen",
126
126
  "ruler",
127
127
  "marker",
@@ -130,20 +130,26 @@ const g = [
130
130
  "move",
131
131
  "undo",
132
132
  "redo"
133
- ], d = ["pen", "ruler", "eraser", "move", "undo", "redo"], f = (e, t) => t === "whiteboard" ? e === "TEACHER" ? c : i : e === "TEACHER" ? u : d, v = (e) => e === "TEACHER" ? ["CANVAS_RED", "CANVAS_YELLOW", "CANVAS_GREEN"] : ["CANVAS_BLUE", "CANVAS_PURPLE", "CANVAS_PINK"], y = (e) => ["pen", "ruler", "marker", "highlighter"].includes(e), C = (e) => Object.values(e).some((t) => !!(!t[0] && t[1] && "name" in t[1] && (t[1].name === "text" || t[1].name === "equation")));
133
+ ], A = ["pen", "ruler", "eraser", "move", "undo", "redo"], C = (e, t) => t === "whiteboard" ? e === "TEACHER" ? d : g : e === "TEACHER" ? p : A, v = (e) => e === "TEACHER" ? ["CANVAS_RED", "CANVAS_YELLOW", "CANVAS_GREEN"] : ["CANVAS_BLUE", "CANVAS_PURPLE", "CANVAS_PINK"], R = (e) => ["pen", "ruler", "marker", "highlighter"].includes(e), O = (e) => Object.values(e).some((t) => !!(!t[0] && t[1] && "name" in t[1] && (t[1].name === "text" || t[1].name === "equation"))), N = (e) => {
134
+ const t = e.split(","), n = t[0] ?? "", r = t[1] ?? "", o = n.includes("base64") ? atob(r) : decodeURIComponent(r), a = n.match(/:(.*?);/), i = a ? a[1] : "application/octet-stream", l = new Uint8Array(o.length);
135
+ for (let c = 0; c < o.length; c++)
136
+ l[c] = o.charCodeAt(c);
137
+ return new Blob([l], { type: i });
138
+ };
134
139
  export {
135
- g as GRID_NAMES,
136
- A as STATELESS_TOOLS,
137
- C as checkTextOrEquationTool,
138
- p as getCanvasConfig,
139
- S as getCanvasSettings,
140
+ T as GRID_NAMES,
141
+ E as STATELESS_TOOLS,
142
+ O as checkTextOrEquationTool,
143
+ N as dataURIToBlob,
144
+ S as getCanvasConfig,
145
+ y as getCanvasSettings,
140
146
  v as getColorsForUser,
141
- y as getIsWritingTool,
142
- l as getReverseAction,
143
- h as getReverseMap,
144
- m as getToolAndSubtool,
145
- f as getUserTools,
146
- E as removeMask,
147
- T as removeTileButton
147
+ R as getIsWritingTool,
148
+ u as getReverseAction,
149
+ b as getReverseMap,
150
+ f as getToolAndSubtool,
151
+ C as getUserTools,
152
+ h as removeMask,
153
+ m as removeTileButton
148
154
  };
149
155
  //# sourceMappingURL=cue-canvas-helpers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cue-canvas-helpers.js","sources":["../../../src/features/cue-canvas/cue-canvas-helpers.ts"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type {\n TCueCanvasColors,\n TCueCanvasChangeData,\n TCueCanvasTool,\n TCueCanvasToolOption,\n TDrawingData,\n TRenderAs,\n TCueCanvasGridName,\n TCueCanvasChangeDataObject,\n} from './types/cue-canvas';\nimport type { IPolypadCreateOptions, IPolypadOptions } from './types/polypad';\n\nexport const GRID_NAMES: TCueCanvasGridName[] = [\n 'none',\n 'square2-grid',\n 'square-checked',\n 'square-dots',\n 'tri-dots',\n 'tri2-dots',\n 'square-grid',\n 'tri-grid',\n 'tri2-grid',\n];\n\nexport const STATELESS_TOOLS = new Set<TCueCanvasTool>([\n 'undo',\n 'redo',\n 'clearAll',\n 'home',\n 'lock',\n 'unlock',\n 'zoomIn',\n 'zoomOut',\n 'upload',\n 'download',\n]);\n\nexport const removeMask = (canvasElementRef: React.RefObject<HTMLDivElement>) => {\n const shadowRoot = canvasElementRef.current?.shadowRoot;\n\n if (shadowRoot) {\n const xPolypad = shadowRoot.querySelectorAll('x-polypad');\n\n if (xPolypad[0]) {\n const svgCanvas = xPolypad[0].querySelector('svg.canvas');\n const maskPath = svgCanvas?.querySelector('path.mask');\n\n maskPath?.setAttribute('stroke', 'transparent');\n maskPath?.setAttribute('fill', 'transparent');\n maskPath?.removeAttribute('style');\n }\n }\n\n return undefined;\n};\n\nexport const removeTileButton = (canvasElementRef: React.RefObject<HTMLDivElement>) => {\n const shadowRoot = canvasElementRef.current?.shadowRoot;\n const sidebar = shadowRoot?.querySelector('x-pp-sidebar') as HTMLElement;\n const tabsHeader = sidebar?.getElementsByClassName('tabs-header');\n const tabsBody = sidebar?.getElementsByClassName('tabs-body');\n\n sidebar?.setAttribute('style', 'display: none;');\n sidebar?.setAttribute('style', 'height: 30px;');\n\n if (tabsHeader && tabsHeader.length > 0) {\n const firstTabHeader = tabsHeader[0] as HTMLElement;\n\n firstTabHeader.style.display = 'none';\n }\n\n if (tabsBody && tabsBody.length > 0) {\n const firstTabBody = tabsBody[0] as HTMLElement;\n\n firstTabBody.style.top = '48px';\n }\n sidebar?.setAttribute('style', 'display: block;');\n};\n\nexport const getCanvasConfig = (\n width: number,\n height: number,\n renderAs: TRenderAs,\n userType: TUserTypes,\n): IPolypadOptions => {\n return renderAs === 'canvas'\n ? {\n canvas: 'notebook',\n canvasX: width,\n canvasY: height,\n noPinchPan: true,\n grid: 'none',\n background: 'transparent',\n noSnapping: true,\n }\n : {\n canvas: 'infinite',\n canvasX: width,\n canvasY: height,\n grid: 'none',\n noPinchPan: userType === 'STUDENT',\n noDeleting: userType === 'STUDENT',\n noCopyPaste: userType === 'STUDENT',\n noMusic: true,\n noAudio: true,\n };\n};\n\nexport const getCanvasSettings = (\n renderAs: TRenderAs,\n userType: TUserTypes,\n): IPolypadCreateOptions => {\n return renderAs === 'canvas'\n ? {\n sidebarTiles: false,\n sidebarSettings: false,\n settings: false,\n toolbar: false,\n canvasMargin: 0,\n }\n : {\n sidebarTiles: userType === 'TEACHER',\n sidebarSettings: false,\n settings: false,\n toolbar: false,\n };\n};\n\nexport const getReverseAction = (action: TDrawingData[]) => [action[1], action[0]];\n\nexport const getReverseMap = (data: TCueCanvasChangeData) => {\n const newData = new Map<string, TDrawingData[]>();\n\n data.forEach((value, key) => {\n newData.set(key, getReverseAction(value));\n });\n\n return newData;\n};\n\nexport const getToolAndSubtool = (\n tool: TCueCanvasTool,\n): [\n Exclude<TCueCanvasTool, 'marker' | 'highlighter' | 'ruler' | 'equation'>,\n TCueCanvasToolOption | undefined,\n] => {\n switch (tool) {\n case 'pen':\n return ['pen', 'pen'];\n case 'marker':\n return ['pen', 'marker'];\n case 'highlighter':\n return ['pen', 'highlighter'];\n case 'ruler':\n return ['pen', 'ruler'];\n case 'equation':\n return ['text', 'equation'];\n default:\n return [tool, undefined];\n }\n};\n\nconst TEACHER_WHITEBOARD_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'eraser',\n 'move',\n 'pan',\n 'clearAll',\n 'text',\n 'equation',\n 'grid',\n 'home',\n 'undo',\n 'redo',\n 'lock',\n 'unlock',\n 'zoomIn',\n 'zoomOut',\n 'upload',\n 'download',\n];\n\nconst STUDENT_WHITEBOARD_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'move',\n 'text',\n 'undo',\n 'redo',\n 'download',\n];\n\nconst TEACHER_DEFAULT_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'eraser',\n 'move',\n 'undo',\n 'redo',\n];\n\nconst STUDENT_DEFAULT_TOOLS: TCueCanvasTool[] = ['pen', 'ruler', 'eraser', 'move', 'undo', 'redo'];\n\nexport const getUserTools = (userType: TUserTypes, renderAs: TRenderAs): TCueCanvasTool[] => {\n if (renderAs === 'whiteboard') {\n return userType === 'TEACHER' ? TEACHER_WHITEBOARD_TOOLS : STUDENT_WHITEBOARD_TOOLS;\n }\n\n return userType === 'TEACHER' ? TEACHER_DEFAULT_TOOLS : STUDENT_DEFAULT_TOOLS;\n};\n\nexport const getColorsForUser = (userType: TUserTypes) => {\n return userType === 'TEACHER'\n ? (['CANVAS_RED', 'CANVAS_YELLOW', 'CANVAS_GREEN'] as TCueCanvasColors[])\n : (['CANVAS_BLUE', 'CANVAS_PURPLE', 'CANVAS_PINK'] as TCueCanvasColors[]);\n};\n\nexport const getIsWritingTool = (penTool: string) => {\n return ['pen', 'ruler', 'marker', 'highlighter'].includes(penTool);\n};\n\nexport const checkTextOrEquationTool = (payload: TCueCanvasChangeDataObject) => {\n return Object.values(payload).some(value => {\n if (\n !value[0] &&\n value[1] &&\n 'name' in value[1] &&\n (value[1].name === 'text' || value[1].name === 'equation')\n ) {\n return true;\n }\n\n return false;\n });\n};\n"],"names":["GRID_NAMES","STATELESS_TOOLS","removeMask","canvasElementRef","_a","shadowRoot","xPolypad","svgCanvas","maskPath","removeTileButton","sidebar","tabsHeader","tabsBody","firstTabHeader","firstTabBody","getCanvasConfig","width","height","renderAs","userType","getCanvasSettings","getReverseAction","action","getReverseMap","data","newData","value","key","getToolAndSubtool","tool","TEACHER_WHITEBOARD_TOOLS","STUDENT_WHITEBOARD_TOOLS","TEACHER_DEFAULT_TOOLS","STUDENT_DEFAULT_TOOLS","getUserTools","getColorsForUser","getIsWritingTool","penTool","checkTextOrEquationTool","payload"],"mappings":"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"}
1
+ {"version":3,"file":"cue-canvas-helpers.js","sources":["../../../src/features/cue-canvas/cue-canvas-helpers.ts"],"sourcesContent":["import type { TUserTypes } from '../ui/types';\nimport type {\n TCueCanvasColors,\n TCueCanvasChangeData,\n TCueCanvasTool,\n TCueCanvasToolOption,\n TDrawingData,\n TRenderAs,\n TCueCanvasGridName,\n TCueCanvasChangeDataObject,\n} from './types/cue-canvas';\nimport type { IPolypadCreateOptions, IPolypadOptions } from './types/polypad';\n\nexport const GRID_NAMES: TCueCanvasGridName[] = [\n 'none',\n 'square2-grid',\n 'square-checked',\n 'square-dots',\n 'tri-dots',\n 'tri2-dots',\n 'square-grid',\n 'tri-grid',\n 'tri2-grid',\n];\n\nexport const STATELESS_TOOLS = new Set<TCueCanvasTool>([\n 'undo',\n 'redo',\n 'clearAll',\n 'home',\n 'lock',\n 'unlock',\n 'zoomIn',\n 'zoomOut',\n 'upload',\n 'download',\n]);\n\nexport const removeMask = (canvasElementRef: React.RefObject<HTMLDivElement>) => {\n const shadowRoot = canvasElementRef.current?.shadowRoot;\n\n if (shadowRoot) {\n const xPolypad = shadowRoot.querySelectorAll('x-polypad');\n\n if (xPolypad[0]) {\n const svgCanvas = xPolypad[0].querySelector('svg.canvas');\n const maskPath = svgCanvas?.querySelector('path.mask');\n\n maskPath?.setAttribute('stroke', 'transparent');\n maskPath?.setAttribute('fill', 'transparent');\n maskPath?.removeAttribute('style');\n }\n }\n\n return undefined;\n};\n\nexport const removeTileButton = (canvasElementRef: React.RefObject<HTMLDivElement>) => {\n const shadowRoot = canvasElementRef.current?.shadowRoot;\n const sidebar = shadowRoot?.querySelector('x-pp-sidebar') as HTMLElement;\n const tabsHeader = sidebar?.getElementsByClassName('tabs-header');\n const tabsBody = sidebar?.getElementsByClassName('tabs-body');\n\n sidebar?.setAttribute('style', 'display: none;');\n sidebar?.setAttribute('style', 'height: 30px;');\n\n if (tabsHeader && tabsHeader.length > 0) {\n const firstTabHeader = tabsHeader[0] as HTMLElement;\n\n firstTabHeader.style.display = 'none';\n }\n\n if (tabsBody && tabsBody.length > 0) {\n const firstTabBody = tabsBody[0] as HTMLElement;\n\n firstTabBody.style.top = '48px';\n }\n sidebar?.setAttribute('style', 'display: block;');\n};\n\nexport const getCanvasConfig = (\n width: number,\n height: number,\n renderAs: TRenderAs,\n userType: TUserTypes,\n): IPolypadOptions => {\n return renderAs === 'canvas'\n ? {\n canvas: 'notebook',\n canvasX: width,\n canvasY: height,\n noPinchPan: true,\n grid: 'none',\n background: 'transparent',\n noSnapping: true,\n }\n : {\n canvas: 'infinite',\n canvasX: width,\n canvasY: height,\n grid: 'none',\n noPinchPan: userType === 'STUDENT',\n noDeleting: userType === 'STUDENT',\n noCopyPaste: userType === 'STUDENT',\n noMusic: true,\n noAudio: true,\n };\n};\n\nexport const getCanvasSettings = (\n renderAs: TRenderAs,\n userType: TUserTypes,\n): IPolypadCreateOptions => {\n return renderAs === 'canvas'\n ? {\n sidebarTiles: false,\n sidebarSettings: false,\n settings: false,\n toolbar: false,\n canvasMargin: 0,\n }\n : {\n sidebarTiles: userType === 'TEACHER',\n sidebarSettings: false,\n settings: false,\n toolbar: false,\n };\n};\n\nexport const getReverseAction = (action: TDrawingData[]) => [action[1], action[0]];\n\nexport const getReverseMap = (data: TCueCanvasChangeData) => {\n const newData = new Map<string, TDrawingData[]>();\n\n data.forEach((value, key) => {\n newData.set(key, getReverseAction(value));\n });\n\n return newData;\n};\n\nexport const getToolAndSubtool = (\n tool: TCueCanvasTool,\n): [\n Exclude<TCueCanvasTool, 'marker' | 'highlighter' | 'ruler' | 'equation'>,\n TCueCanvasToolOption | undefined,\n] => {\n switch (tool) {\n case 'pen':\n return ['pen', 'pen'];\n case 'marker':\n return ['pen', 'marker'];\n case 'highlighter':\n return ['pen', 'highlighter'];\n case 'ruler':\n return ['pen', 'ruler'];\n case 'equation':\n return ['text', 'equation'];\n default:\n return [tool, undefined];\n }\n};\n\nconst TEACHER_WHITEBOARD_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'eraser',\n 'move',\n 'pan',\n 'clearAll',\n 'text',\n 'equation',\n 'grid',\n 'home',\n 'undo',\n 'redo',\n 'lock',\n 'unlock',\n 'zoomIn',\n 'zoomOut',\n 'upload',\n 'download',\n];\n\nconst STUDENT_WHITEBOARD_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'move',\n 'text',\n 'undo',\n 'redo',\n 'download',\n];\n\nconst TEACHER_DEFAULT_TOOLS: TCueCanvasTool[] = [\n 'pen',\n 'ruler',\n 'marker',\n 'highlighter',\n 'eraser',\n 'move',\n 'undo',\n 'redo',\n];\n\nconst STUDENT_DEFAULT_TOOLS: TCueCanvasTool[] = ['pen', 'ruler', 'eraser', 'move', 'undo', 'redo'];\n\nexport const getUserTools = (userType: TUserTypes, renderAs: TRenderAs): TCueCanvasTool[] => {\n if (renderAs === 'whiteboard') {\n return userType === 'TEACHER' ? TEACHER_WHITEBOARD_TOOLS : STUDENT_WHITEBOARD_TOOLS;\n }\n\n return userType === 'TEACHER' ? TEACHER_DEFAULT_TOOLS : STUDENT_DEFAULT_TOOLS;\n};\n\nexport const getColorsForUser = (userType: TUserTypes) => {\n return userType === 'TEACHER'\n ? (['CANVAS_RED', 'CANVAS_YELLOW', 'CANVAS_GREEN'] as TCueCanvasColors[])\n : (['CANVAS_BLUE', 'CANVAS_PURPLE', 'CANVAS_PINK'] as TCueCanvasColors[]);\n};\n\nexport const getIsWritingTool = (penTool: string) => {\n return ['pen', 'ruler', 'marker', 'highlighter'].includes(penTool);\n};\n\nexport const checkTextOrEquationTool = (payload: TCueCanvasChangeDataObject) => {\n return Object.values(payload).some(value => {\n if (\n !value[0] &&\n value[1] &&\n 'name' in value[1] &&\n (value[1].name === 'text' || value[1].name === 'equation')\n ) {\n return true;\n }\n\n return false;\n });\n};\n\nexport const dataURIToBlob = (dataURI: string): Blob => {\n const parts = dataURI.split(',');\n const metadata = parts[0] ?? '';\n const base64Data = parts[1] ?? '';\n\n const isBase64 = metadata.includes('base64');\n const byteString = isBase64 ? atob(base64Data) : decodeURIComponent(base64Data);\n\n const mimeTypeMatch = metadata.match(/:(.*?);/);\n const mimeType = mimeTypeMatch ? mimeTypeMatch[1] : 'application/octet-stream';\n\n const byteArray = new Uint8Array(byteString.length);\n\n for (let i = 0; i < byteString.length; i++) {\n byteArray[i] = byteString.charCodeAt(i);\n }\n\n return new Blob([byteArray], { type: mimeType });\n};\n\nexport const jsonToBlob = (json: unknown) => {\n const data = JSON.stringify(json);\n\n return new Blob([data], {\n type: 'application/json',\n });\n};\n"],"names":["GRID_NAMES","STATELESS_TOOLS","removeMask","canvasElementRef","_a","shadowRoot","xPolypad","svgCanvas","maskPath","removeTileButton","sidebar","tabsHeader","tabsBody","firstTabHeader","firstTabBody","getCanvasConfig","width","height","renderAs","userType","getCanvasSettings","getReverseAction","action","getReverseMap","data","newData","value","key","getToolAndSubtool","tool","TEACHER_WHITEBOARD_TOOLS","STUDENT_WHITEBOARD_TOOLS","TEACHER_DEFAULT_TOOLS","STUDENT_DEFAULT_TOOLS","getUserTools","getColorsForUser","getIsWritingTool","penTool","checkTextOrEquationTool","payload","dataURIToBlob","dataURI","parts","metadata","base64Data","byteString","mimeTypeMatch","mimeType","byteArray","i"],"mappings":"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"}
@@ -1,23 +1,25 @@
1
- import { jsx as C } from "react/jsx-runtime";
2
- import { memo as u, useMemo as c, useState as o } from "react";
3
- import f from "./cue-canvas-context.js";
4
- import { getColorsForUser as p } from "./cue-canvas-helpers.js";
5
- const d = u(
6
- ({ children: n, userType: t }) => {
7
- const a = c(() => p(t), [t]), [e, i] = o(), [r, v] = o("pen"), [s, m] = o(a[0]), l = c(
1
+ import { jsx as d } from "react/jsx-runtime";
2
+ import { memo as f, useMemo as n, useState as o } from "react";
3
+ import p from "./cue-canvas-context.js";
4
+ import { getColorsForUser as x } from "./cue-canvas-helpers.js";
5
+ const I = f(
6
+ ({ children: a, userType: t }) => {
7
+ const i = n(() => x(t), [t]), [e, m] = o(), [r, v] = o("pen"), [s, l] = o(i[0]), [c, C] = o(), u = n(
8
8
  () => ({
9
9
  activeInstance: e,
10
- setActiveInstance: i,
10
+ setActiveInstance: m,
11
11
  activeTool: r,
12
12
  setActiveTool: v,
13
13
  activeColor: s,
14
- setActiveColor: m
14
+ setActiveColor: l,
15
+ homeworkId: c,
16
+ setHomeworkId: C
15
17
  }),
16
- [s, e, r]
18
+ [s, e, r, c]
17
19
  );
18
- return /* @__PURE__ */ C(f.Provider, { value: l, children: n });
20
+ return /* @__PURE__ */ d(p.Provider, { value: u, children: a });
19
21
  }
20
- ), g = d;
22
+ ), g = I;
21
23
  export {
22
24
  g as default
23
25
  };