@citolab/qti-components 7.1.5 → 7.2.0

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 (378) hide show
  1. package/cdn/chunks/chunk-2GVQHMFN.js +5 -0
  2. package/cdn/chunks/chunk-34TLO462.js +1 -0
  3. package/cdn/chunks/chunk-3AUZHOWF.js +5 -0
  4. package/cdn/chunks/chunk-3BTFQ7WO.js +5 -0
  5. package/cdn/chunks/chunk-3G52PPHF.js +1 -0
  6. package/cdn/chunks/chunk-3T7FMZJJ.js +5 -0
  7. package/cdn/chunks/chunk-3WMAQ764.js +23 -0
  8. package/cdn/chunks/chunk-3XYZ63C3.js +1 -0
  9. package/cdn/chunks/chunk-43VY76CQ.js +5 -0
  10. package/cdn/chunks/chunk-4VDQDT6F.js +1 -0
  11. package/cdn/chunks/chunk-4XDZ5XHU.js +1007 -0
  12. package/cdn/chunks/chunk-52V4Q43H.js +5 -0
  13. package/cdn/chunks/chunk-5DVS53XB.js +1007 -0
  14. package/cdn/chunks/chunk-6BZPFYLZ.js +1 -0
  15. package/cdn/chunks/chunk-7B6HAKFL.js +1 -0
  16. package/cdn/chunks/chunk-7BENQ76L.js +1 -0
  17. package/cdn/chunks/chunk-A6PJTNI7.js +23 -0
  18. package/cdn/chunks/chunk-AFBSMLI4.js +5 -0
  19. package/cdn/chunks/chunk-AU2GM346.js +23 -0
  20. package/cdn/chunks/chunk-B345O2HX.js +1 -0
  21. package/cdn/chunks/chunk-B3RMHCUZ.js +1 -0
  22. package/cdn/chunks/chunk-BFPXRWNH.js +5 -0
  23. package/cdn/chunks/chunk-BGBABJCL.js +5 -0
  24. package/cdn/chunks/chunk-BKSBIZJA.js +5 -0
  25. package/cdn/chunks/chunk-BWG4B5VP.js +0 -0
  26. package/cdn/chunks/chunk-C25LH4KA.js +1 -0
  27. package/cdn/chunks/chunk-CDCBI3YD.js +1 -0
  28. package/cdn/chunks/chunk-CQPD5NPM.js +1 -0
  29. package/cdn/chunks/chunk-CS6UCV2Q.js +5 -0
  30. package/cdn/chunks/chunk-D3C4N6YO.js +8 -0
  31. package/cdn/chunks/chunk-D74A6CWS.js +8 -0
  32. package/cdn/chunks/chunk-DFZQWABG.js +5 -0
  33. package/cdn/chunks/chunk-DHZMASGY.js +5 -0
  34. package/cdn/chunks/chunk-EZ7OIK2M.js +1007 -0
  35. package/cdn/chunks/chunk-F2WLIUYH.js +5 -0
  36. package/cdn/chunks/chunk-F3ZZJBV2.js +5 -0
  37. package/cdn/chunks/chunk-FCH2GIHD.js +1 -0
  38. package/cdn/chunks/chunk-FKUEIENC.js +5 -0
  39. package/cdn/chunks/chunk-FMCWO2FJ.js +17 -0
  40. package/cdn/chunks/chunk-FQW2YR3J.js +1 -0
  41. package/cdn/chunks/chunk-FVEUVB2H.js +23 -0
  42. package/cdn/chunks/chunk-GMF365YO.js +16 -0
  43. package/cdn/chunks/chunk-GWRXCQHZ.js +23 -0
  44. package/cdn/chunks/chunk-HAXNBTTE.js +1 -0
  45. package/cdn/chunks/chunk-HEAJ2NEA.js +1007 -0
  46. package/cdn/chunks/chunk-HKBOCCDM.js +5 -0
  47. package/cdn/chunks/chunk-HRLTVAPZ.js +5 -0
  48. package/cdn/chunks/chunk-HZ5STZXK.js +5 -0
  49. package/cdn/chunks/chunk-I5HGXKPD.js +1007 -0
  50. package/cdn/chunks/chunk-IELXBBZK.js +5 -0
  51. package/cdn/chunks/chunk-IHL5T5GX.js +5 -0
  52. package/cdn/chunks/chunk-J2M4UG43.js +1 -0
  53. package/cdn/chunks/chunk-JAMSX45C.js +1 -0
  54. package/cdn/chunks/chunk-JEPI46VU.js +5 -0
  55. package/cdn/chunks/chunk-JSQUXTN4.js +1033 -0
  56. package/cdn/chunks/chunk-JXDOR5ZC.js +1 -0
  57. package/cdn/chunks/chunk-JZCJOPJ4.js +1007 -0
  58. package/cdn/chunks/chunk-KKEW6E2D.js +5 -0
  59. package/cdn/chunks/chunk-L4UTGAI5.js +5 -0
  60. package/cdn/chunks/chunk-LMLG3NBM.js +5 -0
  61. package/cdn/chunks/chunk-MM2ZXHVH.js +5 -0
  62. package/cdn/chunks/chunk-NQQE76LE.js +1 -0
  63. package/cdn/chunks/chunk-O6CWZJXT.js +28 -0
  64. package/cdn/chunks/chunk-OSEDGNNB.js +1007 -0
  65. package/cdn/chunks/chunk-PJFHT7NY.js +5 -0
  66. package/cdn/chunks/chunk-PKWOG7OF.js +5 -0
  67. package/cdn/chunks/chunk-PTG4PTFS.js +5 -0
  68. package/cdn/chunks/chunk-QIRSCGXH.js +1007 -0
  69. package/cdn/chunks/chunk-RIPDQPTC.js +5 -0
  70. package/cdn/chunks/chunk-RO5THFZ6.js +5 -0
  71. package/cdn/chunks/chunk-SQ3RENJ6.js +5 -0
  72. package/cdn/chunks/chunk-SUOAWPV7.js +23 -0
  73. package/cdn/chunks/chunk-T43NJLH5.js +5 -0
  74. package/cdn/chunks/chunk-TIH5N4LQ.js +1007 -0
  75. package/cdn/chunks/chunk-TOUJRNTD.js +1007 -0
  76. package/cdn/chunks/chunk-TSMKXWWV.js +5 -0
  77. package/cdn/chunks/chunk-TU4L55WU.js +5 -0
  78. package/cdn/chunks/chunk-UDPQY4OA.js +1007 -0
  79. package/cdn/chunks/chunk-ULI6NOVG.js +23 -0
  80. package/cdn/chunks/chunk-UTEMKKYS.js +1 -0
  81. package/cdn/chunks/chunk-UV3CSMRU.js +5 -0
  82. package/cdn/chunks/chunk-V2RDHKE2.js +5 -0
  83. package/cdn/chunks/chunk-VQLIWL6K.js +5 -0
  84. package/cdn/chunks/chunk-VZEUFE5C.js +3455 -0
  85. package/cdn/chunks/chunk-W5B2MLGL.js +1 -0
  86. package/cdn/chunks/chunk-WJGOCWFB.js +1 -0
  87. package/cdn/chunks/chunk-WLQN7SVZ.js +1033 -0
  88. package/cdn/chunks/chunk-WUX2JPB5.js +17 -0
  89. package/cdn/chunks/chunk-X7FRU3B6.js +5 -0
  90. package/cdn/chunks/chunk-XS46RWY6.js +5 -0
  91. package/cdn/chunks/chunk-XTNESJMB.js +5 -0
  92. package/cdn/chunks/chunk-Y2EDF22E.js +16 -0
  93. package/cdn/chunks/chunk-YE4ZNHXG.js +23 -0
  94. package/cdn/chunks/chunk-YMFPA4QO.js +5 -0
  95. package/cdn/chunks/chunk-YRK3ZLQP.js +1033 -0
  96. package/cdn/index.global.js +1 -1
  97. package/cdn/index.js +1 -1
  98. package/cdn/qti-components/index.js +1 -1
  99. package/cdn/qti-item/components/item-container.js +1 -1
  100. package/cdn/qti-item/core/index.js +1 -1
  101. package/cdn/qti-loader/index.js +1 -1
  102. package/cdn/qti-test/components/index.js +1 -1
  103. package/cdn/qti-test/components/test-container.js +1 -1
  104. package/cdn/qti-test/components/test-navigation.js +1 -1
  105. package/cdn/qti-test/components/test-next.js +1 -1
  106. package/cdn/qti-test/components/test-scoring-buttons.js +1 -1
  107. package/cdn/qti-test/components/test-scoring-feedback.js +1 -1
  108. package/cdn/qti-test/components/test-show-correct-response.js +1 -1
  109. package/cdn/qti-test/components/test-stamp.js +1 -0
  110. package/cdn/qti-test/components/test-view-toggle.js +1 -1
  111. package/cdn/qti-test/core/index.js +1 -1
  112. package/cdn/qti-transformers/index.js +1 -1
  113. package/dist/chunks/chunk-2GPGOKL6.js +94 -0
  114. package/dist/chunks/chunk-2GPGOKL6.js.map +1 -0
  115. package/dist/chunks/chunk-2J22QBLB.js +94 -0
  116. package/dist/chunks/chunk-2J22QBLB.js.map +1 -0
  117. package/dist/chunks/chunk-34F2DVNP.js +85 -0
  118. package/dist/chunks/chunk-34F2DVNP.js.map +1 -0
  119. package/dist/chunks/chunk-3TM6VQEG.js +375 -0
  120. package/dist/chunks/chunk-3TM6VQEG.js.map +1 -0
  121. package/dist/chunks/chunk-3YVVZ2MO.js +374 -0
  122. package/dist/chunks/chunk-3YVVZ2MO.js.map +1 -0
  123. package/dist/chunks/chunk-46RFKXS6.js +94 -0
  124. package/dist/chunks/chunk-46RFKXS6.js.map +1 -0
  125. package/dist/chunks/chunk-47BWT37I.js +94 -0
  126. package/dist/chunks/chunk-47BWT37I.js.map +1 -0
  127. package/dist/chunks/chunk-4EXSIVXY.js +68 -0
  128. package/dist/chunks/chunk-4EXSIVXY.js.map +1 -0
  129. package/dist/chunks/chunk-4JL6LXWC.js +94 -0
  130. package/dist/chunks/chunk-4JL6LXWC.js.map +1 -0
  131. package/dist/chunks/chunk-4TQ3YR2O.js +31 -0
  132. package/dist/chunks/chunk-4TQ3YR2O.js.map +1 -0
  133. package/dist/chunks/chunk-4VEH63K4.js +854 -0
  134. package/dist/chunks/chunk-4VEH63K4.js.map +1 -0
  135. package/dist/chunks/chunk-5FKTC6XV.js +99 -0
  136. package/dist/chunks/chunk-5FKTC6XV.js.map +1 -0
  137. package/dist/chunks/chunk-5SZAGP4N.js +863 -0
  138. package/dist/chunks/chunk-5SZAGP4N.js.map +1 -0
  139. package/dist/chunks/chunk-64EQ3AQ4.js +240 -0
  140. package/dist/chunks/chunk-64EQ3AQ4.js.map +1 -0
  141. package/dist/chunks/chunk-6MECYIS2.js +94 -0
  142. package/dist/chunks/chunk-6MECYIS2.js.map +1 -0
  143. package/dist/chunks/chunk-6T5ICOX2.js +94 -0
  144. package/dist/chunks/chunk-6T5ICOX2.js.map +1 -0
  145. package/dist/chunks/chunk-6ZK4ZDQA.js +94 -0
  146. package/dist/chunks/chunk-6ZK4ZDQA.js.map +1 -0
  147. package/dist/chunks/chunk-7KTTLJUH.js +45 -0
  148. package/dist/chunks/chunk-7KTTLJUH.js.map +1 -0
  149. package/dist/chunks/chunk-7LFQ6D75.js +95 -0
  150. package/dist/chunks/chunk-7LFQ6D75.js.map +1 -0
  151. package/dist/chunks/chunk-7T5WVG7T.js +853 -0
  152. package/dist/chunks/chunk-7T5WVG7T.js.map +1 -0
  153. package/dist/chunks/chunk-A5IAS5VV.js +54 -0
  154. package/dist/chunks/chunk-A5IAS5VV.js.map +1 -0
  155. package/dist/chunks/chunk-A5W753FL.js +92 -0
  156. package/dist/chunks/chunk-A5W753FL.js.map +1 -0
  157. package/dist/chunks/chunk-ABDJRZ2V.js +78 -0
  158. package/dist/chunks/chunk-ABDJRZ2V.js.map +1 -0
  159. package/dist/chunks/chunk-AN33KA5S.js +94 -0
  160. package/dist/chunks/chunk-AN33KA5S.js.map +1 -0
  161. package/dist/chunks/chunk-B2SP77UV.js +818 -0
  162. package/dist/chunks/chunk-B2SP77UV.js.map +1 -0
  163. package/dist/chunks/chunk-BB7V3D2X.js +250 -0
  164. package/dist/chunks/chunk-BB7V3D2X.js.map +1 -0
  165. package/dist/chunks/chunk-BJAP2552.js +6893 -0
  166. package/dist/chunks/chunk-BJAP2552.js.map +1 -0
  167. package/dist/chunks/chunk-BSPLGP2R.js +627 -0
  168. package/dist/chunks/chunk-BSPLGP2R.js.map +1 -0
  169. package/dist/chunks/chunk-BWUEY6V5.js +818 -0
  170. package/dist/chunks/chunk-BWUEY6V5.js.map +1 -0
  171. package/dist/chunks/chunk-C7YUIKFQ.js +249 -0
  172. package/dist/chunks/chunk-C7YUIKFQ.js.map +1 -0
  173. package/dist/chunks/chunk-CIZ7HKZC.js +42 -0
  174. package/dist/chunks/chunk-CIZ7HKZC.js.map +1 -0
  175. package/dist/chunks/chunk-CJSBOJOH.js +6888 -0
  176. package/dist/chunks/chunk-CJSBOJOH.js.map +1 -0
  177. package/dist/chunks/chunk-CYB63HHS.js +31 -0
  178. package/dist/chunks/chunk-CYB63HHS.js.map +1 -0
  179. package/dist/chunks/chunk-DFSZKFKS.js +43 -0
  180. package/dist/chunks/chunk-DFSZKFKS.js.map +1 -0
  181. package/dist/chunks/chunk-DNRSH4DB.js +854 -0
  182. package/dist/chunks/chunk-DNRSH4DB.js.map +1 -0
  183. package/dist/chunks/chunk-DPDCXMHW.js +81 -0
  184. package/dist/chunks/chunk-DPDCXMHW.js.map +1 -0
  185. package/dist/chunks/chunk-DQ62VQEH.js +627 -0
  186. package/dist/chunks/chunk-DQ62VQEH.js.map +1 -0
  187. package/dist/chunks/chunk-E4G74EVO.js +99 -0
  188. package/dist/chunks/chunk-E4G74EVO.js.map +1 -0
  189. package/dist/chunks/chunk-EA7DHOYO.js +6903 -0
  190. package/dist/chunks/chunk-EA7DHOYO.js.map +1 -0
  191. package/dist/chunks/chunk-EAFJQRTV.js +56 -0
  192. package/dist/chunks/chunk-EAFJQRTV.js.map +1 -0
  193. package/dist/chunks/chunk-EL4TPH56.js +94 -0
  194. package/dist/chunks/chunk-EL4TPH56.js.map +1 -0
  195. package/dist/chunks/chunk-FI6LX4IS.js +853 -0
  196. package/dist/chunks/chunk-FI6LX4IS.js.map +1 -0
  197. package/dist/chunks/chunk-FORIPEB2.js +241 -0
  198. package/dist/chunks/chunk-FORIPEB2.js.map +1 -0
  199. package/dist/chunks/chunk-G3TG4ADZ.js +8 -0
  200. package/dist/chunks/chunk-G3TG4ADZ.js.map +1 -0
  201. package/dist/chunks/chunk-H4XZSMVR.js +375 -0
  202. package/dist/chunks/chunk-H4XZSMVR.js.map +1 -0
  203. package/dist/chunks/chunk-H6O2X4MD.js +42 -0
  204. package/dist/chunks/chunk-H6O2X4MD.js.map +1 -0
  205. package/dist/chunks/chunk-H7W3RQS4.js +627 -0
  206. package/dist/chunks/chunk-H7W3RQS4.js.map +1 -0
  207. package/dist/chunks/chunk-HMHM2W7Z.js +241 -0
  208. package/dist/chunks/chunk-HMHM2W7Z.js.map +1 -0
  209. package/dist/chunks/chunk-I3RHYDUK.js +6917 -0
  210. package/dist/chunks/chunk-I3RHYDUK.js.map +1 -0
  211. package/dist/chunks/chunk-IHNLBY62.js +42 -0
  212. package/dist/chunks/chunk-IHNLBY62.js.map +1 -0
  213. package/dist/chunks/chunk-ILA6BNIO.js +31 -0
  214. package/dist/chunks/chunk-ILA6BNIO.js.map +1 -0
  215. package/dist/chunks/chunk-JFZF77EN.js +31 -0
  216. package/dist/chunks/chunk-JFZF77EN.js.map +1 -0
  217. package/dist/chunks/chunk-JOQ2E6SE.js +92 -0
  218. package/dist/chunks/chunk-JOQ2E6SE.js.map +1 -0
  219. package/dist/chunks/chunk-JQBEZ43O.js +240 -0
  220. package/dist/chunks/chunk-JQBEZ43O.js.map +1 -0
  221. package/dist/chunks/chunk-JQQ755AG.js +854 -0
  222. package/dist/chunks/chunk-JQQ755AG.js.map +1 -0
  223. package/dist/chunks/chunk-JRDTY7YA.js +627 -0
  224. package/dist/chunks/chunk-JRDTY7YA.js.map +1 -0
  225. package/dist/chunks/chunk-JU7QJQ6F.js +853 -0
  226. package/dist/chunks/chunk-JU7QJQ6F.js.map +1 -0
  227. package/dist/chunks/chunk-K6LM7XK5.js +94 -0
  228. package/dist/chunks/chunk-K6LM7XK5.js.map +1 -0
  229. package/dist/chunks/chunk-K6PU3ZO4.js +853 -0
  230. package/dist/chunks/chunk-K6PU3ZO4.js.map +1 -0
  231. package/dist/chunks/chunk-KD26ZB2H.js +3445 -0
  232. package/dist/chunks/chunk-KD26ZB2H.js.map +1 -0
  233. package/dist/chunks/chunk-KGL6SIOD.js +6893 -0
  234. package/dist/chunks/chunk-KGL6SIOD.js.map +1 -0
  235. package/dist/chunks/chunk-KIRLKN6I.js +68 -0
  236. package/dist/chunks/chunk-KIRLKN6I.js.map +1 -0
  237. package/dist/chunks/chunk-L74KEUIS.js +94 -0
  238. package/dist/chunks/chunk-L74KEUIS.js.map +1 -0
  239. package/dist/chunks/chunk-LEXNKJYF.js +6888 -0
  240. package/dist/chunks/chunk-LEXNKJYF.js.map +1 -0
  241. package/dist/chunks/chunk-LVE5GKDT.js +94 -0
  242. package/dist/chunks/chunk-LVE5GKDT.js.map +1 -0
  243. package/dist/chunks/chunk-LVZHVB7F.js +31 -0
  244. package/dist/chunks/chunk-LVZHVB7F.js.map +1 -0
  245. package/dist/chunks/chunk-MGLNBEW4.js +33 -0
  246. package/dist/chunks/chunk-MGLNBEW4.js.map +1 -0
  247. package/dist/chunks/chunk-MS7YRGNG.js +56 -0
  248. package/dist/chunks/chunk-MS7YRGNG.js.map +1 -0
  249. package/dist/chunks/chunk-N25ZKAHQ.js +50 -0
  250. package/dist/chunks/chunk-N25ZKAHQ.js.map +1 -0
  251. package/dist/chunks/chunk-N46CJQRI.js +94 -0
  252. package/dist/chunks/chunk-N46CJQRI.js.map +1 -0
  253. package/dist/chunks/chunk-N4QWREF4.js +375 -0
  254. package/dist/chunks/chunk-N4QWREF4.js.map +1 -0
  255. package/dist/chunks/chunk-NM3JA4DH.js +6893 -0
  256. package/dist/chunks/chunk-NM3JA4DH.js.map +1 -0
  257. package/dist/chunks/chunk-NOHVLBCB.js +371 -0
  258. package/dist/chunks/chunk-NOHVLBCB.js.map +1 -0
  259. package/dist/chunks/chunk-NQSOVEFB.js +31 -0
  260. package/dist/chunks/chunk-NQSOVEFB.js.map +1 -0
  261. package/dist/chunks/chunk-OA7AFFCB.js +866 -0
  262. package/dist/chunks/chunk-OA7AFFCB.js.map +1 -0
  263. package/dist/chunks/chunk-OLNSD7FR.js +31 -0
  264. package/dist/chunks/chunk-OLNSD7FR.js.map +1 -0
  265. package/dist/chunks/chunk-OREE4FRY.js +42 -0
  266. package/dist/chunks/chunk-OREE4FRY.js.map +1 -0
  267. package/dist/chunks/chunk-P66WO2Q5.js +870 -0
  268. package/dist/chunks/chunk-P66WO2Q5.js.map +1 -0
  269. package/dist/chunks/chunk-PKOIFI5C.js +853 -0
  270. package/dist/chunks/chunk-PKOIFI5C.js.map +1 -0
  271. package/dist/chunks/chunk-QFV3VHZ4.js +43 -0
  272. package/dist/chunks/chunk-QFV3VHZ4.js.map +1 -0
  273. package/dist/chunks/chunk-QTKNSVUO.js +854 -0
  274. package/dist/chunks/chunk-QTKNSVUO.js.map +1 -0
  275. package/dist/chunks/chunk-RSGEN2FF.js +6917 -0
  276. package/dist/chunks/chunk-RSGEN2FF.js.map +1 -0
  277. package/dist/chunks/chunk-S6XGFD5B.js +6893 -0
  278. package/dist/chunks/chunk-S6XGFD5B.js.map +1 -0
  279. package/dist/chunks/chunk-SOT463MH.js +68 -0
  280. package/dist/chunks/chunk-SOT463MH.js.map +1 -0
  281. package/dist/chunks/chunk-SZMR2BFI.js +94 -0
  282. package/dist/chunks/chunk-SZMR2BFI.js.map +1 -0
  283. package/dist/chunks/chunk-TDKYWAGB.js +50 -0
  284. package/dist/chunks/chunk-TDKYWAGB.js.map +1 -0
  285. package/dist/chunks/chunk-TDNCAAAT.js +627 -0
  286. package/dist/chunks/chunk-TDNCAAAT.js.map +1 -0
  287. package/dist/chunks/chunk-TVOHUHS4.js +94 -0
  288. package/dist/chunks/chunk-TVOHUHS4.js.map +1 -0
  289. package/dist/chunks/chunk-UE3R54FP.js +853 -0
  290. package/dist/chunks/chunk-UE3R54FP.js.map +1 -0
  291. package/dist/chunks/chunk-UUEOV5NM.js +1 -0
  292. package/dist/chunks/chunk-UUEOV5NM.js.map +1 -0
  293. package/dist/chunks/chunk-UZRIKXLU.js +94 -0
  294. package/dist/chunks/chunk-UZRIKXLU.js.map +1 -0
  295. package/dist/chunks/chunk-VAYGVW5R.js +6903 -0
  296. package/dist/chunks/chunk-VAYGVW5R.js.map +1 -0
  297. package/dist/chunks/chunk-VEWD22O5.js +383 -0
  298. package/dist/chunks/chunk-VEWD22O5.js.map +1 -0
  299. package/dist/chunks/chunk-VF32HLF4.js +81 -0
  300. package/dist/chunks/chunk-VF32HLF4.js.map +1 -0
  301. package/dist/chunks/chunk-VY7QNZVM.js +6893 -0
  302. package/dist/chunks/chunk-VY7QNZVM.js.map +1 -0
  303. package/dist/chunks/chunk-W4FWEMCO.js +871 -0
  304. package/dist/chunks/chunk-W4FWEMCO.js.map +1 -0
  305. package/dist/chunks/chunk-W5VRVGBL.js +81 -0
  306. package/dist/chunks/chunk-W5VRVGBL.js.map +1 -0
  307. package/dist/chunks/chunk-WDGXLQLI.js +94 -0
  308. package/dist/chunks/chunk-WDGXLQLI.js.map +1 -0
  309. package/dist/chunks/chunk-WTTOJHIM.js +371 -0
  310. package/dist/chunks/chunk-WTTOJHIM.js.map +1 -0
  311. package/dist/chunks/chunk-WZZOX7S2.js +853 -0
  312. package/dist/chunks/chunk-WZZOX7S2.js.map +1 -0
  313. package/dist/chunks/chunk-X2G652U7.js +6903 -0
  314. package/dist/chunks/chunk-X2G652U7.js.map +1 -0
  315. package/dist/chunks/chunk-XKQP4R6O.js +380 -0
  316. package/dist/chunks/chunk-XKQP4R6O.js.map +1 -0
  317. package/dist/chunks/chunk-Z3SN77PI.js +31 -0
  318. package/dist/chunks/chunk-Z3SN77PI.js.map +1 -0
  319. package/dist/chunks/chunk-ZECYUSVI.js +43 -0
  320. package/dist/chunks/chunk-ZECYUSVI.js.map +1 -0
  321. package/dist/chunks/chunk-ZSPVMGE5.js +94 -0
  322. package/dist/chunks/chunk-ZSPVMGE5.js.map +1 -0
  323. package/dist/chunks/chunk-ZTXBJYUG.js +94 -0
  324. package/dist/chunks/chunk-ZTXBJYUG.js.map +1 -0
  325. package/dist/exports/computed-item.context.d.ts +1 -1
  326. package/dist/exports/computed.context.d.ts +1 -1
  327. package/dist/exports/interaction.d.ts +1 -1
  328. package/dist/exports/item.context.d.ts +1 -1
  329. package/dist/exports/qti-assessment-item.context.d.ts +1 -1
  330. package/dist/exports/qti-condition-expression.d.ts +1 -1
  331. package/dist/exports/qti-expression.d.ts +1 -1
  332. package/dist/exports/session.context.d.ts +2 -2
  333. package/dist/exports/test.context.d.ts +1 -1
  334. package/dist/exports/variables.d.ts +1 -1
  335. package/dist/index.d.ts +7 -2
  336. package/dist/index.js +39 -23
  337. package/dist/item.css +26 -130
  338. package/dist/qti-components/index.d.ts +2 -2
  339. package/dist/qti-components/index.js +2 -2
  340. package/dist/qti-components-jsx.d.ts +84 -2
  341. package/dist/qti-item/components/item-container.js +3 -3
  342. package/dist/qti-item/components/item-show-correct-response.d.ts +1 -1
  343. package/dist/qti-item/components/print-item-variables.d.ts +1 -1
  344. package/dist/qti-item/core/index.d.ts +1 -1
  345. package/dist/qti-item/core/index.js +3 -3
  346. package/dist/qti-loader/index.d.ts +1 -1
  347. package/dist/qti-loader/index.js +2 -2
  348. package/dist/qti-response-declaration-C3kpm650.d.ts +1171 -0
  349. package/dist/qti-test/components/index.d.ts +7 -2
  350. package/dist/qti-test/components/index.js +29 -13
  351. package/dist/qti-test/components/test-container.js +3 -3
  352. package/dist/qti-test/components/test-navigation.d.ts +3 -2
  353. package/dist/qti-test/components/test-navigation.js +1 -1
  354. package/dist/qti-test/components/test-next.d.ts +1 -1
  355. package/dist/qti-test/components/test-next.js +1 -1
  356. package/dist/qti-test/components/test-prev.d.ts +1 -1
  357. package/dist/qti-test/components/test-print-context.d.ts +1 -1
  358. package/dist/qti-test/components/test-print-item-variables.d.ts +1 -1
  359. package/dist/qti-test/components/test-scoring-buttons.d.ts +2 -1
  360. package/dist/qti-test/components/test-scoring-buttons.js +1 -1
  361. package/dist/qti-test/components/test-scoring-feedback.d.ts +9 -1273
  362. package/dist/qti-test/components/test-scoring-feedback.js +4 -60
  363. package/dist/qti-test/components/test-scoring-feedback.js.map +1 -1
  364. package/dist/qti-test/components/test-show-correct-response.d.ts +1 -1
  365. package/dist/qti-test/components/test-show-correct-response.js +1 -1
  366. package/dist/qti-test/components/test-stamp.d.ts +18 -0
  367. package/dist/qti-test/components/test-stamp.js +9 -0
  368. package/dist/qti-test/components/test-stamp.js.map +1 -0
  369. package/dist/qti-test/components/test-view-toggle.d.ts +2 -2
  370. package/dist/qti-test/components/test-view-toggle.js +1 -1
  371. package/dist/qti-test/core/index.d.ts +4 -4
  372. package/dist/qti-test/core/index.js +3 -3
  373. package/dist/qti-test-feedback-CG8nrjhS.d.ts +98 -0
  374. package/dist/qti-test-feedback-R38tNXBH.d.ts +98 -0
  375. package/dist/qti-transformers/index.d.ts +4 -1
  376. package/dist/qti-transformers/index.js +1 -1
  377. package/dist/vscode.html-custom-data.json +32 -7
  378. package/package.json +4 -4
@@ -0,0 +1,866 @@
1
+ import {
2
+ INITIAL_SESSION_CONTEXT,
3
+ sessionContext
4
+ } from "./chunk-UZ4QB5IO.js";
5
+ import {
6
+ INITIAL_TEST_CONTEXT,
7
+ testContext
8
+ } from "./chunk-CJADUWEC.js";
9
+ import {
10
+ QtiModalFeedback
11
+ } from "./chunk-RSGEN2FF.js";
12
+ import {
13
+ qtiTransformItem
14
+ } from "./chunk-VEWD22O5.js";
15
+ import {
16
+ __decorateClass
17
+ } from "./chunk-H2JE6IVU.js";
18
+
19
+ // src/lib/qti-test/core/qti-test.ts
20
+ import { html } from "lit";
21
+ import { customElement } from "lit/decorators.js";
22
+
23
+ // src/lib/qti-test/core/mixins/test-navigation.mixin.ts
24
+ import { property } from "lit/decorators.js";
25
+ var NavigationErrorType = /* @__PURE__ */ ((NavigationErrorType2) => {
26
+ NavigationErrorType2["ITEM_NOT_FOUND"] = "item-not-found";
27
+ NavigationErrorType2["SECTION_NOT_FOUND"] = "section-not-found";
28
+ NavigationErrorType2["LOAD_ERROR"] = "load-error";
29
+ NavigationErrorType2["NETWORK_ERROR"] = "network-error";
30
+ NavigationErrorType2["TIMEOUT_ERROR"] = "timeout-error";
31
+ return NavigationErrorType2;
32
+ })(NavigationErrorType || {});
33
+ var TestNavigationMixin = (superClass) => {
34
+ class TestNavigationClass extends superClass {
35
+ constructor(...args) {
36
+ super(...args);
37
+ this.navigate = null;
38
+ this.cacheTransform = false;
39
+ this.requestTimeout = 3e4;
40
+ this.showLoadingIndicators = true;
41
+ this._activeRequests = [];
42
+ this._navigationInProgress = false;
43
+ this._lastError = null;
44
+ this._lastNavigationRequestId = null;
45
+ this._targetNavigation = null;
46
+ this.addEventListener(
47
+ "qti-request-navigation",
48
+ async ({ detail }) => {
49
+ if (!detail?.id) return;
50
+ const navigationRequestId = `nav_${Date.now()}_${Math.random()}`;
51
+ this._lastNavigationRequestId = navigationRequestId;
52
+ try {
53
+ this._navigationInProgress = true;
54
+ this._lastError = null;
55
+ this._dispatchStatusEvent({ loading: true, type: detail.type, id: detail.id });
56
+ this._cancelActiveRequests();
57
+ this._targetNavigation = { type: detail.type, id: detail.id };
58
+ if (detail.type === "item") {
59
+ await this._navigateToItem(detail.id);
60
+ } else if (detail.type === "section") {
61
+ await this._navigateToSection(detail.id);
62
+ }
63
+ if (this._lastNavigationRequestId !== navigationRequestId) {
64
+ console.log("Navigation was superseded by a newer request");
65
+ return;
66
+ }
67
+ } catch (error) {
68
+ if (this._lastNavigationRequestId === navigationRequestId) {
69
+ const navError = this._normalizeError(error, detail.type, detail.id);
70
+ this._lastError = navError;
71
+ this._dispatchErrorEvent(navError);
72
+ console.error(`Navigation error (${navError.type}):`, navError.message, navError.details);
73
+ }
74
+ } finally {
75
+ if (this._lastNavigationRequestId === navigationRequestId) {
76
+ this._navigationInProgress = false;
77
+ this._dispatchStatusEvent({ loading: false, type: detail.type, id: detail.id });
78
+ }
79
+ }
80
+ }
81
+ );
82
+ this.addEventListener("qti-assessment-test-connected", (e) => {
83
+ this._testElement = e.detail;
84
+ this._initializeNavigation();
85
+ });
86
+ }
87
+ /**
88
+ * Initialize navigation when test is first connected
89
+ */
90
+ _initializeNavigation() {
91
+ let id;
92
+ if (this.navigate === "section") {
93
+ id = this._testElement.querySelector("qti-assessment-section")?.identifier;
94
+ }
95
+ if (this.navigate === "item") {
96
+ id = this.sessionContext.navItemId ?? this._testElement.querySelector("qti-assessment-item-ref")?.identifier;
97
+ }
98
+ if (id) {
99
+ this.dispatchEvent(
100
+ new CustomEvent("qti-request-navigation", {
101
+ detail: { type: this.navigate === "section" ? "section" : "item", id },
102
+ bubbles: true,
103
+ composed: true
104
+ })
105
+ );
106
+ }
107
+ }
108
+ navigateTo(type, id) {
109
+ if (!id) {
110
+ id = this._testElement?.querySelector("qti-assessment-item-ref")?.identifier;
111
+ }
112
+ this.dispatchEvent(
113
+ new CustomEvent("qti-request-navigation", {
114
+ detail: { type, id },
115
+ bubbles: true,
116
+ composed: true
117
+ })
118
+ );
119
+ }
120
+ /**
121
+ * Navigates to a specific item
122
+ */
123
+ async _navigateToItem(itemId) {
124
+ const itemRefEl = this._testElement?.querySelector(
125
+ `qti-assessment-item-ref[identifier="${itemId}"]`
126
+ );
127
+ if (!itemRefEl) {
128
+ throw {
129
+ type: "item-not-found" /* ITEM_NOT_FOUND */,
130
+ message: `Item with identifier "${itemId}" not found.`,
131
+ itemId
132
+ };
133
+ }
134
+ const navPartId = itemRefEl.closest("qti-test-part")?.identifier;
135
+ const navSectionId = itemRefEl.closest("qti-assessment-section")?.identifier;
136
+ this.sessionContext = {
137
+ ...this.sessionContext,
138
+ navPartId,
139
+ navSectionId,
140
+ navItemId: itemId,
141
+ navItemLoading: true
142
+ };
143
+ console.log("Navigating to item:", itemId);
144
+ try {
145
+ await this._loadItems([itemId]);
146
+ } finally {
147
+ this.sessionContext = {
148
+ ...this.sessionContext,
149
+ navItemLoading: false
150
+ };
151
+ }
152
+ }
153
+ /**
154
+ * Navigates to a specific section
155
+ */
156
+ async _navigateToSection(sectionId) {
157
+ const sectionRefEl = this._testElement?.querySelector(
158
+ `qti-assessment-section[identifier="${sectionId}"]`
159
+ );
160
+ if (!sectionRefEl) {
161
+ throw {
162
+ type: "section-not-found" /* SECTION_NOT_FOUND */,
163
+ message: `Section with identifier "${sectionId}" not found.`,
164
+ sectionId
165
+ };
166
+ }
167
+ const navPartId = sectionRefEl.closest("qti-test-part")?.identifier;
168
+ this.sessionContext = {
169
+ ...this.sessionContext,
170
+ navPartId,
171
+ navSectionId: sectionId,
172
+ navItemId: null,
173
+ navItemLoading: true
174
+ };
175
+ try {
176
+ const itemIds = this._getSectionItemIds(sectionId);
177
+ await this._loadItems(itemIds);
178
+ } finally {
179
+ this.sessionContext = {
180
+ ...this.sessionContext,
181
+ navItemLoading: false
182
+ };
183
+ }
184
+ }
185
+ /**
186
+ * Normalize different error types into a consistent NavigationError format
187
+ */
188
+ _normalizeError(error, navigationType, id) {
189
+ if (error && error.type && Object.values(NavigationErrorType).includes(error.type)) {
190
+ return error;
191
+ }
192
+ if (error instanceof DOMException && error.name === "AbortError") {
193
+ return {
194
+ type: "network-error" /* NETWORK_ERROR */,
195
+ message: "Navigation was cancelled because a new navigation was requested.",
196
+ details: error
197
+ };
198
+ }
199
+ if (error.name === "TimeoutError" || error.message && error.message.includes("timeout")) {
200
+ return {
201
+ type: "timeout-error" /* TIMEOUT_ERROR */,
202
+ message: "Request timed out. Please check your network connection.",
203
+ details: error
204
+ };
205
+ }
206
+ if (error instanceof TypeError && error.message.includes("network")) {
207
+ return {
208
+ type: "network-error" /* NETWORK_ERROR */,
209
+ message: "A network error occurred. Please check your connection.",
210
+ details: error
211
+ };
212
+ }
213
+ return {
214
+ type: "load-error" /* LOAD_ERROR */,
215
+ message: `Failed to load ${navigationType}: ${id}`,
216
+ details: error,
217
+ itemId: navigationType === "item" ? id : void 0,
218
+ sectionId: navigationType === "section" ? id : void 0
219
+ };
220
+ }
221
+ /**
222
+ * Dispatch error event to notify the UI
223
+ */
224
+ _dispatchErrorEvent(error) {
225
+ this.dispatchEvent(
226
+ new CustomEvent("qti-navigation-error", {
227
+ detail: error,
228
+ bubbles: true,
229
+ composed: true
230
+ })
231
+ );
232
+ }
233
+ /**
234
+ * Dispatch status event to indicate loading state
235
+ */
236
+ _dispatchStatusEvent(status) {
237
+ if (this.showLoadingIndicators) {
238
+ this.dispatchEvent(
239
+ new CustomEvent("qti-navigation-status", {
240
+ detail: status,
241
+ bubbles: true,
242
+ composed: true
243
+ })
244
+ );
245
+ }
246
+ }
247
+ /**
248
+ * Cancels all active HTTP requests
249
+ */
250
+ _cancelActiveRequests() {
251
+ if (this._activeRequests.length > 0) {
252
+ console.info(`Cancelling ${this._activeRequests.length} pending requests`);
253
+ this._activeRequests.forEach((request) => {
254
+ if (request && request.readyState !== 4) {
255
+ request.abort();
256
+ }
257
+ });
258
+ this._activeRequests = [];
259
+ }
260
+ }
261
+ /**
262
+ * Load items with improved error handling and timeout
263
+ */
264
+ async _loadItems(itemIds) {
265
+ if (!this._testElement || itemIds.length === 0) return;
266
+ const itemRefEls = itemIds.map(
267
+ (id) => this._testElement.querySelector(`qti-assessment-item-ref[identifier="${id}"]`)
268
+ );
269
+ const missingItems = itemRefEls.reduce((missing, el, index) => {
270
+ if (!el) missing.push(itemIds[index]);
271
+ return missing;
272
+ }, []);
273
+ if (missingItems.length > 0) {
274
+ const error = {
275
+ type: "item-not-found" /* ITEM_NOT_FOUND */,
276
+ message: `One or more items not found: ${missingItems.join(", ")}`,
277
+ details: { missingItems }
278
+ };
279
+ throw error;
280
+ }
281
+ this._clearLoadedItems();
282
+ const itemLoadPromises = itemRefEls.map(async (itemRef) => {
283
+ if (!itemRef) return null;
284
+ const timeoutPromise = new Promise((_, reject) => {
285
+ setTimeout(() => {
286
+ reject({
287
+ name: "TimeoutError",
288
+ message: `Request for item ${itemRef.identifier} timed out after ${this.requestTimeout}ms`
289
+ });
290
+ }, this.requestTimeout);
291
+ });
292
+ try {
293
+ const { promise, request } = qtiTransformItem(this.cacheTransform).load(itemRef.href);
294
+ if (request instanceof XMLHttpRequest) {
295
+ this._activeRequests.push(request);
296
+ }
297
+ const apiResult = await Promise.race([promise, timeoutPromise]);
298
+ return {
299
+ itemRef,
300
+ doc: apiResult.htmlDoc(),
301
+ request
302
+ };
303
+ } catch (error) {
304
+ if (error instanceof DOMException && error.name === "AbortError" || error && error.name === "TimeoutError") {
305
+ console.log(
306
+ `Request for item ${itemRef.identifier} was ${error.name === "TimeoutError" ? "timed out" : "aborted"}`
307
+ );
308
+ return null;
309
+ }
310
+ error.itemId = itemRef.identifier;
311
+ throw error;
312
+ }
313
+ });
314
+ try {
315
+ const results = await Promise.all(itemLoadPromises);
316
+ const validResults = results.filter((result) => result !== null);
317
+ validResults.forEach(({ itemRef, doc }) => {
318
+ if (itemRef && doc) itemRef.xmlDoc = doc;
319
+ });
320
+ this._activeRequests = [];
321
+ requestAnimationFrame(() => {
322
+ this.dispatchEvent(
323
+ new CustomEvent("qti-test-loaded", {
324
+ detail: validResults.map(({ itemRef }) => ({
325
+ identifier: itemRef?.identifier,
326
+ element: itemRef
327
+ })),
328
+ bubbles: true,
329
+ composed: true
330
+ })
331
+ );
332
+ });
333
+ if (validResults.length === 0 && itemIds.length > 0) {
334
+ throw {
335
+ type: "load-error" /* LOAD_ERROR */,
336
+ message: "All item requests failed to load",
337
+ details: { itemIds }
338
+ };
339
+ }
340
+ return validResults;
341
+ } catch (error) {
342
+ console.error("Error loading items:", error);
343
+ throw error;
344
+ }
345
+ }
346
+ /**
347
+ * Gets all item IDs in a section
348
+ */
349
+ _getSectionItemIds(navSectionId) {
350
+ const sectionRefEl = this._testElement?.querySelector(
351
+ `qti-assessment-section[identifier="${navSectionId}"]`
352
+ );
353
+ if (!sectionRefEl) {
354
+ throw {
355
+ type: "section-not-found" /* SECTION_NOT_FOUND */,
356
+ message: `Section with identifier "${navSectionId}" not found.`,
357
+ sectionId: navSectionId
358
+ };
359
+ }
360
+ return Array.from(
361
+ this._testElement.querySelectorAll(
362
+ `qti-assessment-section[identifier="${navSectionId}"] > qti-assessment-item-ref`
363
+ )
364
+ ).map((itemRef) => itemRef.identifier);
365
+ }
366
+ /**
367
+ * Clears all loaded items
368
+ */
369
+ _clearLoadedItems() {
370
+ const itemRefEls = this._testElement?.querySelectorAll(
371
+ `qti-assessment-test qti-assessment-item-ref`
372
+ );
373
+ Array.from(itemRefEls || []).forEach((itemElement) => {
374
+ itemElement.xmlDoc = null;
375
+ });
376
+ }
377
+ /**
378
+ * Retry the last failed navigation
379
+ */
380
+ retryNavigation() {
381
+ if (this._lastError) {
382
+ const type = this._lastError.itemId ? "item" : "section";
383
+ const id = this._lastError.itemId || this._lastError.sectionId;
384
+ if (id) {
385
+ this.dispatchEvent(
386
+ new CustomEvent("qti-request-navigation", {
387
+ detail: { type, id },
388
+ bubbles: true,
389
+ composed: true
390
+ })
391
+ );
392
+ }
393
+ } else if (this._targetNavigation) {
394
+ this.dispatchEvent(
395
+ new CustomEvent("qti-request-navigation", {
396
+ detail: this._targetNavigation,
397
+ bubbles: true,
398
+ composed: true
399
+ })
400
+ );
401
+ }
402
+ }
403
+ }
404
+ __decorateClass([
405
+ property({ type: String })
406
+ ], TestNavigationClass.prototype, "navigate", 2);
407
+ __decorateClass([
408
+ property({ type: Boolean, attribute: "cache-transform" })
409
+ ], TestNavigationClass.prototype, "cacheTransform", 2);
410
+ __decorateClass([
411
+ property({ type: Number })
412
+ ], TestNavigationClass.prototype, "requestTimeout", 2);
413
+ __decorateClass([
414
+ property({ type: Boolean })
415
+ ], TestNavigationClass.prototype, "showLoadingIndicators", 2);
416
+ return TestNavigationClass;
417
+ };
418
+
419
+ // src/lib/qti-test/core/mixins/test-view.mixin.ts
420
+ var TestViewMixin = (superClass) => {
421
+ class TestViewClass extends superClass {
422
+ constructor(...args) {
423
+ super(...args);
424
+ this.sessionContext = { ...this.sessionContext, view: "candidate" };
425
+ this.addEventListener("on-test-switch-view", (e) => {
426
+ this.sessionContext = { ...this.sessionContext, view: e.detail };
427
+ this._updateElementView();
428
+ });
429
+ this.addEventListener("qti-assessment-test-connected", () => {
430
+ this._updateElementView();
431
+ });
432
+ this.addEventListener("qti-assessment-item-connected", (e) => {
433
+ this._updateElementView();
434
+ this._setCorrectResponseVisibility(e.detail);
435
+ });
436
+ }
437
+ willUpdate(changedProperties) {
438
+ super.willUpdate(changedProperties);
439
+ if (changedProperties.has("sessionContext")) {
440
+ this._updateElementView();
441
+ }
442
+ }
443
+ // Method to handle view updates for elements based on the current context view
444
+ _updateElementView() {
445
+ if (this._testElement) {
446
+ const viewElements = Array.from(this._testElement.querySelectorAll("[view]"));
447
+ viewElements.forEach((element) => {
448
+ element.classList.toggle("show", element.getAttribute("view") === this.sessionContext.view);
449
+ });
450
+ const assessmentItemRef = this._testElement.querySelector(
451
+ `qti-assessment-item-ref[identifier="${this.sessionContext.navItemId}"]`
452
+ );
453
+ const assessmentItem = assessmentItemRef?.assessmentItem;
454
+ if (assessmentItem) {
455
+ assessmentItem.showCorrectResponse(this.sessionContext.view === "scorer");
456
+ }
457
+ }
458
+ }
459
+ // Event handler for connected QTI assessment items
460
+ _setCorrectResponseVisibility(assessmentItem) {
461
+ assessmentItem.showCorrectResponse(this.sessionContext.view === "scorer");
462
+ }
463
+ }
464
+ return TestViewClass;
465
+ };
466
+
467
+ // src/lib/qti-test/core/test-base.ts
468
+ import { provide } from "@lit/context";
469
+ import { LitElement } from "lit";
470
+ import { property as property2 } from "lit/decorators.js";
471
+ var TestBase = class extends LitElement {
472
+ constructor() {
473
+ super();
474
+ this.testContext = INITIAL_TEST_CONTEXT;
475
+ this.sessionContext = INITIAL_SESSION_CONTEXT;
476
+ /**
477
+ * Updates the variables of an assessment item in the test context.
478
+ * - Matches the assessment item with the corresponding test context item.
479
+ * - If the item is not found, logs a warning.
480
+ * - Updates variables in the test context if exactly one variable exists.
481
+ * - Otherwise, syncs the assessment item's variables with the test context.
482
+ *
483
+ * @param assessmentItem - The assessment item to update.
484
+ */
485
+ this._updateItemInTestContext = (assessmentItem) => {
486
+ const context = assessmentItem._context;
487
+ const identifier = context.identifier;
488
+ const fullVariables = context.variables;
489
+ const itemContext = this.testContext.items.find((i) => i?.identifier === identifier);
490
+ if (!itemContext) {
491
+ console.warn(`Item IDs between assessment.xml and item.xml should match: ${identifier} is not found!`);
492
+ return;
493
+ }
494
+ if (itemContext.variables?.length === 1) {
495
+ this._updateItemVariablesInTestContext(identifier, fullVariables);
496
+ } else {
497
+ assessmentItem.variables = [...itemContext.variables || []];
498
+ }
499
+ };
500
+ this.addEventListener("qti-assessment-test-connected", (e) => {
501
+ this.testContext = INITIAL_TEST_CONTEXT;
502
+ this.sessionContext = INITIAL_SESSION_CONTEXT;
503
+ if (this.testContext && this.testContext.items.length > 0) return;
504
+ this._testElement = e.detail;
505
+ const items = Array.from(this._testElement.querySelectorAll("qti-assessment-item-ref")).map((itemRef) => {
506
+ return {
507
+ href: itemRef.href,
508
+ identifier: itemRef.identifier,
509
+ category: itemRef.category,
510
+ variables: [
511
+ {
512
+ identifier: "completionStatus",
513
+ value: "not_attempted",
514
+ type: "outcome"
515
+ }
516
+ ]
517
+ };
518
+ });
519
+ this.testContext = { ...this.testContext, items };
520
+ });
521
+ this.addEventListener("qti-assessment-item-connected", (e) => {
522
+ const assessmentItem = e.detail;
523
+ const assessmentRefId = assessmentItem.closest("qti-assessment-item-ref")?.identifier;
524
+ if (assessmentRefId) {
525
+ assessmentItem.assessmentItemRefId = assessmentRefId;
526
+ }
527
+ this._updateItemInTestContext(e.detail);
528
+ });
529
+ this.addEventListener("qti-item-context-updated", (e) => {
530
+ this._updateItemVariablesInTestContext(e.detail.itemContext.identifier, e.detail.itemContext.variables);
531
+ });
532
+ }
533
+ _updateItemVariablesInTestContext(identifier, variables) {
534
+ this.testContext = {
535
+ ...this.testContext,
536
+ // Spread existing test context properties
537
+ items: this.testContext.items.map((itemContext) => {
538
+ if (itemContext.identifier !== identifier) {
539
+ return itemContext;
540
+ }
541
+ return {
542
+ ...itemContext,
543
+ // Keep other properties of the item context
544
+ variables: variables.map((variable) => {
545
+ const matchingVariable = itemContext.variables.find((v) => v.identifier === variable.identifier);
546
+ return matchingVariable ? { ...matchingVariable, ...variable } : variable;
547
+ })
548
+ };
549
+ })
550
+ };
551
+ this.dispatchEvent(
552
+ new CustomEvent("qti-test-context-updated", { detail: this.testContext, bubbles: false, composed: false })
553
+ );
554
+ }
555
+ };
556
+ __decorateClass([
557
+ property2({ attribute: false, type: Object }),
558
+ provide({ context: testContext })
559
+ ], TestBase.prototype, "testContext", 2);
560
+ __decorateClass([
561
+ property2({ attribute: false, type: Object }),
562
+ provide({ context: sessionContext })
563
+ ], TestBase.prototype, "sessionContext", 2);
564
+
565
+ // src/lib/qti-test/core/mixins/test-processing.mixin.ts
566
+ var TestProcessingMixin = (superClass) => {
567
+ class TestProcessingElement extends superClass {
568
+ constructor(...args) {
569
+ super(...args);
570
+ this.addEventListener("qti-register-variable", (e) => {
571
+ this.testContext = {
572
+ ...this.testContext,
573
+ testOutcomeVariables: [...this.testContext.testOutcomeVariables || [], e.detail.variable]
574
+ };
575
+ e.stopPropagation();
576
+ });
577
+ this.addEventListener(
578
+ "qti-set-outcome-value",
579
+ (e) => {
580
+ const { outcomeIdentifier, value } = e.detail;
581
+ this.updateOutcomeVariable(outcomeIdentifier, value);
582
+ e.stopPropagation();
583
+ }
584
+ );
585
+ }
586
+ outcomeProcessing() {
587
+ const outcomeProcessor = this.querySelector("qti-outcome-processing");
588
+ if (!outcomeProcessor) return false;
589
+ outcomeProcessor?.process();
590
+ return true;
591
+ }
592
+ /* --------------------------- ENABLED WHEN UNIT TESTING OUTCOME PROCESSING ------------------------------------ */
593
+ updateOutcomeVariable(identifier, value) {
594
+ const outcomeVariable = this.getOutcome(identifier);
595
+ if (!outcomeVariable) {
596
+ console.warn(`Can not set qti-outcome-identifier: ${identifier}, it is not available`);
597
+ return;
598
+ }
599
+ this.testContext = {
600
+ ...this.testContext,
601
+ testOutcomeVariables: this.testContext.testOutcomeVariables?.map((v) => {
602
+ if (v.identifier !== identifier) {
603
+ return v;
604
+ }
605
+ return {
606
+ ...v,
607
+ value: outcomeVariable.cardinality === "single" ? value : [...v.value, value]
608
+ };
609
+ })
610
+ };
611
+ }
612
+ getOutcome(identifier) {
613
+ return this.getVariable(identifier);
614
+ }
615
+ getVariable(identifier) {
616
+ return this.testContext.testOutcomeVariables?.find((v) => v.identifier === identifier) || null;
617
+ }
618
+ /* --------------------------- ENABLED WHEN UNIT TESTING OUTCOME PROCESSING ------------------------------------ */
619
+ }
620
+ return TestProcessingElement;
621
+ };
622
+
623
+ // src/lib/qti-test/core/qti-test.ts
624
+ var QtiTest = class extends TestNavigationMixin(TestViewMixin(TestProcessingMixin(TestBase))) {
625
+ // export class QtiTest extends TestLoaderMixin(TestNavigationMixin(TestViewMixin(TestBase))) {
626
+ /**
627
+ * Renders the component's template.
628
+ * Provides a default `<slot>` for content projection.
629
+ */
630
+ async connectedCallback() {
631
+ super.connectedCallback();
632
+ await this.updateComplete;
633
+ this.dispatchEvent(new CustomEvent("qti-test-connected", { detail: this }));
634
+ }
635
+ render() {
636
+ return html`<slot></slot>`;
637
+ }
638
+ };
639
+ QtiTest = __decorateClass([
640
+ customElement("qti-test")
641
+ ], QtiTest);
642
+
643
+ // src/lib/qti-test/core/qti-assessment-test/qti-assessment-item-ref.ts
644
+ import { LitElement as LitElement2 } from "lit";
645
+ import { property as property3 } from "lit/decorators.js";
646
+ import { prepareTemplate } from "stampino";
647
+ var stringToBooleanConverter = {
648
+ fromAttribute(value) {
649
+ return value === "true";
650
+ },
651
+ toAttribute(value) {
652
+ return value ? "true" : "false";
653
+ }
654
+ };
655
+ var QtiAssessmentItemRef = class extends LitElement2 {
656
+ constructor() {
657
+ super(...arguments);
658
+ // @consume({ context: computedContext, subscribe: true })
659
+ // private computedContext: ComputedContext;
660
+ this.weigths = /* @__PURE__ */ new Map();
661
+ }
662
+ // the XMLDocument
663
+ createRenderRoot() {
664
+ return this;
665
+ }
666
+ get assessmentItem() {
667
+ return this.renderRoot?.querySelector("qti-assessment-item");
668
+ }
669
+ async connectedCallback() {
670
+ super.connectedCallback();
671
+ const templateElement = this.getRootNode().host.closest("qti-test").querySelector("template[item-ref]");
672
+ if (templateElement) this.myTemplate = prepareTemplate(templateElement);
673
+ await this.updateComplete;
674
+ this.dispatchEvent(
675
+ new CustomEvent("qti-assessment-item-ref-connected", {
676
+ bubbles: true,
677
+ composed: true,
678
+ detail: { identifier: this.identifier, href: this.href, category: this.category }
679
+ })
680
+ );
681
+ }
682
+ render() {
683
+ return this.myTemplate ? this.myTemplate({ xmlDoc: this.xmlDoc }) : this.xmlDoc;
684
+ }
685
+ };
686
+ __decorateClass([
687
+ property3({ type: String })
688
+ ], QtiAssessmentItemRef.prototype, "category", 2);
689
+ __decorateClass([
690
+ property3({ type: String })
691
+ ], QtiAssessmentItemRef.prototype, "identifier", 2);
692
+ __decorateClass([
693
+ property3({ type: Boolean, converter: stringToBooleanConverter })
694
+ ], QtiAssessmentItemRef.prototype, "required", 2);
695
+ __decorateClass([
696
+ property3({ type: Boolean, converter: stringToBooleanConverter })
697
+ ], QtiAssessmentItemRef.prototype, "fixed", 2);
698
+ __decorateClass([
699
+ property3({ type: String })
700
+ ], QtiAssessmentItemRef.prototype, "href", 2);
701
+ __decorateClass([
702
+ property3({ type: Object, attribute: false })
703
+ ], QtiAssessmentItemRef.prototype, "xmlDoc", 2);
704
+ if (!customElements.get("qti-assessment-item-ref")) {
705
+ customElements.define("qti-assessment-item-ref", QtiAssessmentItemRef);
706
+ }
707
+
708
+ // src/lib/qti-test/core/qti-assessment-test/qti-assessment-section.ts
709
+ import { consume } from "@lit/context";
710
+ import { html as html2, LitElement as LitElement3 } from "lit";
711
+ import { property as property4 } from "lit/decorators.js";
712
+ var stringToBooleanConverter2 = {
713
+ fromAttribute(value) {
714
+ return value === "true";
715
+ },
716
+ toAttribute(value) {
717
+ return value ? "true" : "false";
718
+ }
719
+ };
720
+ var QtiAssessmentSection = class extends LitElement3 {
721
+ async connectedCallback() {
722
+ super.connectedCallback();
723
+ await this.updateComplete;
724
+ this.dispatchEvent(
725
+ new Event("qti-assessment-section-connected", {
726
+ bubbles: true,
727
+ composed: true
728
+ })
729
+ );
730
+ }
731
+ render() {
732
+ return html2`<slot name="qti-rubric-block"></slot><slot></slot>`;
733
+ }
734
+ };
735
+ __decorateClass([
736
+ property4({ type: String })
737
+ ], QtiAssessmentSection.prototype, "identifier", 2);
738
+ __decorateClass([
739
+ property4({ type: String })
740
+ ], QtiAssessmentSection.prototype, "required", 2);
741
+ __decorateClass([
742
+ property4({ type: Boolean, converter: stringToBooleanConverter2 })
743
+ ], QtiAssessmentSection.prototype, "fixed", 2);
744
+ __decorateClass([
745
+ property4({ type: String })
746
+ ], QtiAssessmentSection.prototype, "title", 2);
747
+ __decorateClass([
748
+ property4({ type: Boolean, converter: stringToBooleanConverter2 })
749
+ ], QtiAssessmentSection.prototype, "visible", 2);
750
+ __decorateClass([
751
+ property4({ type: Boolean, converter: stringToBooleanConverter2, attribute: "keep-together" })
752
+ ], QtiAssessmentSection.prototype, "keepTogether", 2);
753
+ __decorateClass([
754
+ consume({ context: testContext, subscribe: true })
755
+ ], QtiAssessmentSection.prototype, "_testContext", 2);
756
+ if (!customElements.get("qti-assessment-section")) {
757
+ customElements.define("qti-assessment-section", QtiAssessmentSection);
758
+ }
759
+
760
+ // src/lib/qti-test/core/qti-assessment-test/qti-assessment-test.ts
761
+ import { consume as consume2 } from "@lit/context";
762
+ import { html as html3, LitElement as LitElement4 } from "lit";
763
+ import { customElement as customElement2, property as property5 } from "lit/decorators.js";
764
+ var QtiAssessmentTest = class extends LitElement4 {
765
+ async connectedCallback() {
766
+ super.connectedCallback();
767
+ await this.updateComplete;
768
+ this.dispatchEvent(
769
+ new CustomEvent("qti-assessment-test-connected", {
770
+ detail: this,
771
+ bubbles: true,
772
+ composed: true
773
+ })
774
+ );
775
+ }
776
+ render() {
777
+ return html3` <slot></slot>`;
778
+ }
779
+ };
780
+ __decorateClass([
781
+ property5({ type: String })
782
+ ], QtiAssessmentTest.prototype, "identifier", 2);
783
+ __decorateClass([
784
+ property5({ type: String })
785
+ ], QtiAssessmentTest.prototype, "title", 2);
786
+ __decorateClass([
787
+ consume2({ context: testContext, subscribe: true })
788
+ ], QtiAssessmentTest.prototype, "_testContext", 2);
789
+ QtiAssessmentTest = __decorateClass([
790
+ customElement2("qti-assessment-test")
791
+ ], QtiAssessmentTest);
792
+
793
+ // src/lib/qti-test/core/qti-assessment-test/qti-test-part.ts
794
+ import { html as html4, LitElement as LitElement5 } from "lit";
795
+ import { customElement as customElement3, property as property6 } from "lit/decorators.js";
796
+ var QtiTestPart = class extends LitElement5 {
797
+ constructor() {
798
+ super(...arguments);
799
+ this.identifier = "";
800
+ this.title = "";
801
+ this.class = "";
802
+ this.NavigationMode = "nonlinear";
803
+ this.submissionMode = "individual";
804
+ }
805
+ async connectedCallback() {
806
+ super.connectedCallback();
807
+ await this.updateComplete;
808
+ this.dispatchEvent(
809
+ new Event("qti-test-part-connected", {
810
+ bubbles: true,
811
+ composed: true
812
+ })
813
+ );
814
+ }
815
+ render() {
816
+ return html4` <slot></slot>`;
817
+ }
818
+ };
819
+ __decorateClass([
820
+ property6({ type: String })
821
+ ], QtiTestPart.prototype, "identifier", 2);
822
+ __decorateClass([
823
+ property6({ type: String })
824
+ ], QtiTestPart.prototype, "title", 2);
825
+ __decorateClass([
826
+ property6({ type: String })
827
+ ], QtiTestPart.prototype, "class", 2);
828
+ __decorateClass([
829
+ property6({ type: String, attribute: "navigation-mode" })
830
+ ], QtiTestPart.prototype, "NavigationMode", 2);
831
+ __decorateClass([
832
+ property6({ type: String, attribute: "submission-mode" })
833
+ ], QtiTestPart.prototype, "submissionMode", 2);
834
+ QtiTestPart = __decorateClass([
835
+ customElement3("qti-test-part")
836
+ ], QtiTestPart);
837
+ if (!customElements.get("qti-test-part")) {
838
+ customElements.define("qti-test-part", QtiTestPart);
839
+ }
840
+
841
+ // src/lib/qti-test/core/qti-assessment-test/qti-test-feedback.ts
842
+ import { customElement as customElement4 } from "lit/decorators.js";
843
+ import { css, html as html5 } from "lit";
844
+ var QtiTestFeedback = class extends QtiModalFeedback {
845
+ render() {
846
+ return html5``;
847
+ }
848
+ };
849
+ QtiTestFeedback.styles = css`
850
+ :host {
851
+ color: gray;
852
+ }
853
+ `;
854
+ QtiTestFeedback = __decorateClass([
855
+ customElement4("qti-test-feedback")
856
+ ], QtiTestFeedback);
857
+
858
+ export {
859
+ QtiTest,
860
+ QtiAssessmentItemRef,
861
+ QtiAssessmentSection,
862
+ QtiAssessmentTest,
863
+ QtiTestPart,
864
+ QtiTestFeedback
865
+ };
866
+ //# sourceMappingURL=chunk-OA7AFFCB.js.map