@citolab/qti-components 7.3.18 → 7.3.20

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 (473) hide show
  1. package/cdn/chunks/chunk-23JT53R2.js +1 -0
  2. package/cdn/chunks/chunk-26QYN3JJ.js +1482 -0
  3. package/cdn/chunks/chunk-2N2XIR3B.js +5 -0
  4. package/cdn/chunks/chunk-2OA2G5PN.js +5 -0
  5. package/cdn/chunks/chunk-2PXIZTCM.js +1 -0
  6. package/cdn/chunks/chunk-3H3ITD2Q.js +5 -0
  7. package/cdn/chunks/chunk-3HIY5HSB.js +1 -0
  8. package/cdn/chunks/chunk-3PVCPEFY.js +5 -0
  9. package/cdn/chunks/chunk-3WY3AI3D.js +1482 -0
  10. package/cdn/chunks/chunk-3YF52BZZ.js +41 -0
  11. package/cdn/chunks/chunk-3ZFHDJHW.js +3636 -0
  12. package/cdn/chunks/chunk-3ZLIRREM.js +1466 -0
  13. package/cdn/chunks/chunk-426N5A5I.js +1 -0
  14. package/cdn/chunks/chunk-453G3A34.js +8 -0
  15. package/cdn/chunks/chunk-4F3OLGZ4.js +5 -0
  16. package/cdn/chunks/chunk-4YPL4JG2.js +1 -0
  17. package/cdn/chunks/chunk-5ICSVSCW.js +1482 -0
  18. package/cdn/chunks/chunk-5WPKWVLA.js +1 -0
  19. package/cdn/chunks/chunk-63C5YDWF.js +1482 -0
  20. package/cdn/chunks/chunk-6FSYASNZ.js +1 -0
  21. package/cdn/chunks/chunk-6H26KONO.js +1482 -0
  22. package/cdn/chunks/chunk-6IY26BVE.js +23 -0
  23. package/cdn/chunks/chunk-6OUX6PKB.js +5 -0
  24. package/cdn/chunks/chunk-74FJHIJ5.js +8 -0
  25. package/cdn/chunks/chunk-77U2O27N.js +1 -0
  26. package/cdn/chunks/chunk-7AX6K3VW.js +1 -0
  27. package/cdn/chunks/chunk-7HEAECQ2.js +1466 -0
  28. package/cdn/chunks/chunk-7LCGB3GF.js +6 -0
  29. package/cdn/chunks/chunk-7NHDLON4.js +5 -0
  30. package/cdn/chunks/chunk-7T6OJ2OQ.js +1482 -0
  31. package/cdn/chunks/chunk-ARUVWWSO.js +5 -0
  32. package/cdn/chunks/chunk-B7NVY4AR.js +23 -0
  33. package/cdn/chunks/chunk-BFMN6REI.js +5 -0
  34. package/cdn/chunks/chunk-BGWSUBMK.js +1482 -0
  35. package/cdn/chunks/chunk-BSK7IIBZ.js +1 -0
  36. package/cdn/chunks/chunk-BUGBHX3F.js +5 -0
  37. package/cdn/chunks/chunk-BXEEPJPF.js +48 -0
  38. package/cdn/chunks/chunk-BXTNMGCF.js +1 -0
  39. package/cdn/chunks/chunk-C25DJHRW.js +5 -0
  40. package/cdn/chunks/chunk-C3XRHLQX.js +1 -0
  41. package/cdn/chunks/chunk-CGI4LREF.js +1 -0
  42. package/cdn/chunks/chunk-CLAUENYE.js +8 -0
  43. package/cdn/chunks/chunk-CYSQXIRZ.js +5 -0
  44. package/cdn/chunks/chunk-DD55IQIL.js +6 -0
  45. package/cdn/chunks/chunk-DHNKVZRG.js +1 -0
  46. package/cdn/chunks/chunk-DXF4ZBJ2.js +1 -0
  47. package/cdn/chunks/chunk-E2UBGM45.js +1 -0
  48. package/cdn/chunks/chunk-E6IOJ4MV.js +23 -0
  49. package/cdn/chunks/chunk-ECKBRC27.js +1482 -0
  50. package/cdn/chunks/chunk-ECLB2ECD.js +5 -0
  51. package/cdn/chunks/chunk-EINATJIA.js +1 -0
  52. package/cdn/chunks/chunk-EXMUQYL6.js +5 -0
  53. package/cdn/chunks/chunk-FDOVZYP4.js +5 -0
  54. package/cdn/chunks/chunk-FDV6POVV.js +6 -0
  55. package/cdn/chunks/chunk-FOE7HRKJ.js +10 -0
  56. package/cdn/chunks/chunk-FVIBMJDJ.js +5 -0
  57. package/cdn/chunks/chunk-G2DN6BDN.js +8 -0
  58. package/cdn/chunks/chunk-GBAAEAYK.js +5 -0
  59. package/cdn/chunks/chunk-GDRPZEZJ.js +5 -0
  60. package/cdn/chunks/chunk-GFXQHIPI.js +1482 -0
  61. package/cdn/chunks/chunk-GTSQO7SP.js +1 -0
  62. package/cdn/chunks/chunk-GVZHKB2Y.js +1482 -0
  63. package/cdn/chunks/chunk-GY74IPZ2.js +8 -0
  64. package/cdn/chunks/chunk-HA6MFZZU.js +48 -0
  65. package/cdn/chunks/chunk-HHALXPVF.js +5 -0
  66. package/cdn/chunks/chunk-HPX7CBTS.js +1 -0
  67. package/cdn/chunks/chunk-I3PDGPL6.js +48 -0
  68. package/cdn/chunks/chunk-I4G5VXGD.js +5 -0
  69. package/cdn/chunks/chunk-IJBHBPIR.js +1 -0
  70. package/cdn/chunks/chunk-IMHR3S57.js +1 -0
  71. package/cdn/chunks/chunk-IPISUVWE.js +8 -0
  72. package/cdn/chunks/chunk-J3NAMJRF.js +55 -0
  73. package/cdn/chunks/chunk-JG53AUXR.js +1 -0
  74. package/cdn/chunks/chunk-JHMA3APO.js +3638 -0
  75. package/cdn/chunks/chunk-JJNOTSC4.js +5 -0
  76. package/cdn/chunks/chunk-JVPQQZNX.js +5 -0
  77. package/cdn/chunks/chunk-JVW572MO.js +1 -0
  78. package/cdn/chunks/chunk-JYF2SOPC.js +6 -0
  79. package/cdn/chunks/chunk-K42MGICV.js +1 -0
  80. package/cdn/chunks/chunk-K7NB4LHE.js +1 -0
  81. package/cdn/chunks/chunk-KM5SOM7G.js +1482 -0
  82. package/cdn/chunks/chunk-KP6MWEDW.js +5 -0
  83. package/cdn/chunks/chunk-KWDCU3P6.js +1482 -0
  84. package/cdn/chunks/chunk-KY3OKCFK.js +8 -0
  85. package/cdn/chunks/chunk-KY6SSNGO.js +5 -0
  86. package/cdn/chunks/chunk-LO2NM3CE.js +1 -0
  87. package/cdn/chunks/chunk-LS3OPHR4.js +8 -0
  88. package/cdn/chunks/chunk-M544CJHK.js +5 -0
  89. package/cdn/chunks/chunk-M5UOISZJ.js +1482 -0
  90. package/cdn/chunks/chunk-MAPVFADC.js +5 -0
  91. package/cdn/chunks/chunk-MICRS5DH.js +8 -0
  92. package/cdn/chunks/chunk-MVGI4SNI.js +17 -0
  93. package/cdn/chunks/chunk-MYXD4BOJ.js +2 -0
  94. package/cdn/chunks/chunk-MZRZP33C.js +1 -0
  95. package/cdn/chunks/chunk-N4LMZHIZ.js +5 -0
  96. package/cdn/chunks/chunk-NHHA3O6Y.js +1 -0
  97. package/cdn/chunks/chunk-NJ3OVLBF.js +1 -0
  98. package/cdn/chunks/chunk-NVZTYSGS.js +1 -0
  99. package/cdn/chunks/chunk-NXQQIB7Y.js +5 -0
  100. package/cdn/chunks/chunk-ODYPYZCY.js +5 -0
  101. package/cdn/chunks/chunk-OENDUEU2.js +5 -0
  102. package/cdn/chunks/chunk-ON6ISIIV.js +1 -0
  103. package/cdn/chunks/chunk-OOEY4RSQ.js +1 -0
  104. package/cdn/chunks/chunk-OUQFWBVG.js +8 -0
  105. package/cdn/chunks/chunk-P5MQE2M6.js +5 -0
  106. package/cdn/chunks/chunk-PMYTST5N.js +17 -0
  107. package/cdn/chunks/chunk-PPSGCGRR.js +8 -0
  108. package/cdn/chunks/chunk-Q4EENVQD.js +1 -0
  109. package/cdn/chunks/chunk-Q64V7VQU.js +1 -0
  110. package/cdn/chunks/chunk-QCDT25GU.js +8 -0
  111. package/cdn/chunks/chunk-QYCLNTAQ.js +1 -0
  112. package/cdn/chunks/chunk-RKU2XDKG.js +2 -0
  113. package/cdn/chunks/chunk-RQSAQ6H4.js +1 -0
  114. package/cdn/chunks/chunk-RTVTE2XY.js +1482 -0
  115. package/cdn/chunks/chunk-SBACDLL6.js +73 -0
  116. package/cdn/chunks/chunk-SVVO2SFS.js +1 -0
  117. package/cdn/chunks/chunk-SVWD3DJK.js +1 -0
  118. package/cdn/chunks/chunk-TOK64KBR.js +5 -0
  119. package/cdn/chunks/chunk-V2NH5MXS.js +5 -0
  120. package/cdn/chunks/chunk-V3EJROZX.js +3649 -0
  121. package/cdn/chunks/chunk-VB3GRBCX.js +1 -0
  122. package/cdn/chunks/chunk-VNZCEVYY.js +24 -0
  123. package/cdn/chunks/chunk-VUJWHOI6.js +1482 -0
  124. package/cdn/chunks/chunk-WOKUXDJR.js +8 -0
  125. package/cdn/chunks/chunk-WPXZSIUM.js +5 -0
  126. package/cdn/chunks/chunk-WTUHCDEZ.js +10 -0
  127. package/cdn/chunks/chunk-X4FA36TC.js +1 -0
  128. package/cdn/chunks/chunk-XA25EXKN.js +1 -0
  129. package/cdn/chunks/chunk-XBLYTLX6.js +5 -0
  130. package/cdn/chunks/chunk-XH36X5UJ.js +1482 -0
  131. package/cdn/chunks/chunk-XHSJOTCJ.js +5 -0
  132. package/cdn/chunks/chunk-XJ2CFTZP.js +1 -0
  133. package/cdn/chunks/chunk-XLFLYMNJ.js +1482 -0
  134. package/cdn/chunks/chunk-XYWB7S55.js +1482 -0
  135. package/cdn/chunks/chunk-Y3BICHQ5.js +6 -0
  136. package/cdn/chunks/chunk-YEK2E3FB.js +8 -0
  137. package/cdn/chunks/chunk-YIRZSKIP.js +2 -0
  138. package/cdn/chunks/chunk-YM5QNYGZ.js +5 -0
  139. package/cdn/chunks/chunk-YOTJAW26.js +6 -0
  140. package/cdn/chunks/chunk-Z7KIJX7V.js +1482 -0
  141. package/cdn/chunks/chunk-ZCQFKXZ3.js +48 -0
  142. package/cdn/chunks/chunk-ZKOKGZBL.js +5 -0
  143. package/cdn/exports/computed-item.context.js +1 -1
  144. package/cdn/exports/computed.context.js +1 -1
  145. package/cdn/exports/config.context.js +1 -1
  146. package/cdn/exports/interaction.js +1 -1
  147. package/cdn/exports/item.context.js +1 -1
  148. package/cdn/exports/qti-assessment-item.context.js +1 -1
  149. package/cdn/exports/qti-condition-expression.js +1 -1
  150. package/cdn/exports/qti-expression.js +1 -1
  151. package/cdn/exports/qti.context.js +1 -0
  152. package/cdn/exports/session.context.js +1 -1
  153. package/cdn/exports/test.context.js +1 -1
  154. package/cdn/index.global.js +1 -1
  155. package/cdn/index.js +1 -1
  156. package/cdn/qti-components/index.js +1 -1
  157. package/cdn/qti-item/components/item-container.js +1 -1
  158. package/cdn/qti-item/components/item-correct-response-mode.js +10 -0
  159. package/cdn/qti-item/components/item-show-candidate-correction.js +8 -0
  160. package/cdn/qti-item/components/item-show-correct-response.js +1 -1
  161. package/cdn/qti-item/components/print-item-variables.js +1 -1
  162. package/cdn/qti-item/components/styles.js +1 -1
  163. package/cdn/qti-item/core/index.js +1 -1
  164. package/cdn/qti-loader/index.js +1 -1
  165. package/cdn/qti-test/components/index.js +1 -1
  166. package/cdn/qti-test/components/styles.js +1 -1
  167. package/cdn/qti-test/components/test-check-item.js +1 -1
  168. package/cdn/qti-test/components/test-container.js +1 -1
  169. package/cdn/qti-test/components/test-end-attempt.js +1 -1
  170. package/cdn/qti-test/components/test-item-link.js +1 -1
  171. package/cdn/qti-test/components/test-navigation.js +1 -1
  172. package/cdn/qti-test/components/test-next.js +1 -1
  173. package/cdn/qti-test/components/test-paging-buttons-stamp.js +1 -1
  174. package/cdn/qti-test/components/test-prev.js +1 -1
  175. package/cdn/qti-test/components/test-print-context.js +1 -1
  176. package/cdn/qti-test/components/test-print-item-variables.js +1 -1
  177. package/cdn/qti-test/components/test-scoring-buttons.js +1 -1
  178. package/cdn/qti-test/components/test-scoring-feedback.js +1 -1
  179. package/cdn/qti-test/components/test-section-buttons-stamp.js +1 -1
  180. package/cdn/qti-test/components/test-section-link.js +1 -1
  181. package/cdn/qti-test/components/test-show-correct-response.js +1 -1
  182. package/cdn/qti-test/components/test-stamp.js +1 -1
  183. package/cdn/qti-test/components/test-view-toggle.js +1 -1
  184. package/cdn/qti-test/components/test-view.js +1 -1
  185. package/cdn/qti-test/core/index.js +1 -1
  186. package/cdn/qti-transformers/index.js +1 -1
  187. package/dist/chunks/chunk-2EGQQQHL.js +31 -0
  188. package/dist/chunks/chunk-2EGQQQHL.js.map +1 -0
  189. package/dist/chunks/chunk-32TQEF77.js +142 -0
  190. package/dist/chunks/chunk-32TQEF77.js.map +1 -0
  191. package/dist/chunks/chunk-34THNRGC.js +8093 -0
  192. package/dist/chunks/chunk-34THNRGC.js.map +1 -0
  193. package/dist/chunks/chunk-3O3BVPXQ.js +8655 -0
  194. package/dist/chunks/chunk-3O3BVPXQ.js.map +1 -0
  195. package/dist/chunks/chunk-3SABVS4P.js +19 -0
  196. package/dist/chunks/chunk-3SABVS4P.js.map +1 -0
  197. package/dist/chunks/chunk-45FDEM7M.js +94 -0
  198. package/dist/chunks/chunk-45FDEM7M.js.map +1 -0
  199. package/dist/chunks/chunk-4A6SHFWN.js +8093 -0
  200. package/dist/chunks/chunk-4A6SHFWN.js.map +1 -0
  201. package/dist/chunks/chunk-4B4DRCXO.js +94 -0
  202. package/dist/chunks/chunk-4B4DRCXO.js.map +1 -0
  203. package/dist/chunks/chunk-4D3G23AV.js +94 -0
  204. package/dist/chunks/chunk-4D3G23AV.js.map +1 -0
  205. package/dist/chunks/chunk-565QP4OA.js +94 -0
  206. package/dist/chunks/chunk-565QP4OA.js.map +1 -0
  207. package/dist/chunks/chunk-5IYIGX6A.js +94 -0
  208. package/dist/chunks/chunk-5IYIGX6A.js.map +1 -0
  209. package/dist/chunks/chunk-5MAENJ2J.js +913 -0
  210. package/dist/chunks/chunk-5MAENJ2J.js.map +1 -0
  211. package/dist/chunks/chunk-6EQ4U5EP.js +142 -0
  212. package/dist/chunks/chunk-6EQ4U5EP.js.map +1 -0
  213. package/dist/chunks/chunk-6NLDLAQA.js +367 -0
  214. package/dist/chunks/chunk-6NLDLAQA.js.map +1 -0
  215. package/dist/chunks/chunk-6OB2U3VU.js +287 -0
  216. package/dist/chunks/chunk-6OB2U3VU.js.map +1 -0
  217. package/dist/chunks/chunk-7XIK3UQX.js +3628 -0
  218. package/dist/chunks/chunk-7XIK3UQX.js.map +1 -0
  219. package/dist/chunks/chunk-7Z7KA2QQ.js +142 -0
  220. package/dist/chunks/chunk-7Z7KA2QQ.js.map +1 -0
  221. package/dist/chunks/chunk-AH3ZDQHQ.js +913 -0
  222. package/dist/chunks/chunk-AH3ZDQHQ.js.map +1 -0
  223. package/dist/chunks/chunk-AVMYQQT2.js +94 -0
  224. package/dist/chunks/chunk-AVMYQQT2.js.map +1 -0
  225. package/dist/chunks/chunk-B2IUQFUU.js +913 -0
  226. package/dist/chunks/chunk-B2IUQFUU.js.map +1 -0
  227. package/dist/chunks/chunk-B2O3YM5H.js +8093 -0
  228. package/dist/chunks/chunk-B2O3YM5H.js.map +1 -0
  229. package/dist/chunks/chunk-BAZMB7Z3.js +8009 -0
  230. package/dist/chunks/chunk-BAZMB7Z3.js.map +1 -0
  231. package/dist/chunks/chunk-BXUNJ6XB.js +78 -0
  232. package/dist/chunks/chunk-BXUNJ6XB.js.map +1 -0
  233. package/dist/chunks/chunk-CTESMSQO.js +56 -0
  234. package/dist/chunks/chunk-CTESMSQO.js.map +1 -0
  235. package/dist/chunks/chunk-CVMIO3DA.js +913 -0
  236. package/dist/chunks/chunk-CVMIO3DA.js.map +1 -0
  237. package/dist/chunks/chunk-D2VLZ4I5.js +8755 -0
  238. package/dist/chunks/chunk-D2VLZ4I5.js.map +1 -0
  239. package/dist/chunks/chunk-DDSFGYAK.js +913 -0
  240. package/dist/chunks/chunk-DDSFGYAK.js.map +1 -0
  241. package/dist/chunks/chunk-DJUWVE3Q.js +8655 -0
  242. package/dist/chunks/chunk-DJUWVE3Q.js.map +1 -0
  243. package/dist/chunks/chunk-DJWEI2NH.js +502 -0
  244. package/dist/chunks/chunk-DJWEI2NH.js.map +1 -0
  245. package/dist/chunks/chunk-DPJNXSTI.js +19 -0
  246. package/dist/chunks/chunk-DPJNXSTI.js.map +1 -0
  247. package/dist/chunks/chunk-E6V3JHVT.js +31 -0
  248. package/dist/chunks/chunk-E6V3JHVT.js.map +1 -0
  249. package/dist/chunks/chunk-E7DT7SMT.js +8655 -0
  250. package/dist/chunks/chunk-E7DT7SMT.js.map +1 -0
  251. package/dist/chunks/chunk-EBODGAT7.js +113 -0
  252. package/dist/chunks/chunk-EBODGAT7.js.map +1 -0
  253. package/dist/chunks/chunk-EFY3NEXY.js +94 -0
  254. package/dist/chunks/chunk-EFY3NEXY.js.map +1 -0
  255. package/dist/chunks/chunk-EMOJR4QG.js +913 -0
  256. package/dist/chunks/chunk-EMOJR4QG.js.map +1 -0
  257. package/dist/chunks/chunk-EXBK4TXV.js +273 -0
  258. package/dist/chunks/chunk-EXBK4TXV.js.map +1 -0
  259. package/dist/chunks/chunk-F6RSPPVW.js +94 -0
  260. package/dist/chunks/chunk-F6RSPPVW.js.map +1 -0
  261. package/dist/chunks/chunk-FXO6HW6L.js +8084 -0
  262. package/dist/chunks/chunk-FXO6HW6L.js.map +1 -0
  263. package/dist/chunks/chunk-GFCOR6TX.js +146 -0
  264. package/dist/chunks/chunk-GFCOR6TX.js.map +1 -0
  265. package/dist/chunks/chunk-GIY6GNXQ.js +913 -0
  266. package/dist/chunks/chunk-GIY6GNXQ.js.map +1 -0
  267. package/dist/chunks/chunk-GMXDW4I3.js +913 -0
  268. package/dist/chunks/chunk-GMXDW4I3.js.map +1 -0
  269. package/dist/chunks/chunk-GQUBYVP3.js +913 -0
  270. package/dist/chunks/chunk-GQUBYVP3.js.map +1 -0
  271. package/dist/chunks/chunk-GT6TR4B6.js +94 -0
  272. package/dist/chunks/chunk-GT6TR4B6.js.map +1 -0
  273. package/dist/chunks/chunk-H67RKRFW.js +94 -0
  274. package/dist/chunks/chunk-H67RKRFW.js.map +1 -0
  275. package/dist/chunks/chunk-H6KHXSIO.js +8 -0
  276. package/dist/chunks/chunk-H6KHXSIO.js.map +1 -0
  277. package/dist/chunks/chunk-HEP5QRPW.js +94 -0
  278. package/dist/chunks/chunk-HEP5QRPW.js.map +1 -0
  279. package/dist/chunks/chunk-HYMSLOZ7.js +103 -0
  280. package/dist/chunks/chunk-HYMSLOZ7.js.map +1 -0
  281. package/dist/chunks/chunk-I5EA6DJB.js +92 -0
  282. package/dist/chunks/chunk-I5EA6DJB.js.map +1 -0
  283. package/dist/chunks/chunk-IAEGLQ4C.js +144 -0
  284. package/dist/chunks/chunk-IAEGLQ4C.js.map +1 -0
  285. package/dist/chunks/chunk-J2HZTWER.js +8093 -0
  286. package/dist/chunks/chunk-J2HZTWER.js.map +1 -0
  287. package/dist/chunks/chunk-JARLFKS7.js +913 -0
  288. package/dist/chunks/chunk-JARLFKS7.js.map +1 -0
  289. package/dist/chunks/chunk-JATNQ3KB.js +913 -0
  290. package/dist/chunks/chunk-JATNQ3KB.js.map +1 -0
  291. package/dist/chunks/chunk-KCTFNJO4.js +8748 -0
  292. package/dist/chunks/chunk-KCTFNJO4.js.map +1 -0
  293. package/dist/chunks/chunk-KJQYKXDV.js +173 -0
  294. package/dist/chunks/chunk-KJQYKXDV.js.map +1 -0
  295. package/dist/chunks/chunk-KXVYWSJU.js +8068 -0
  296. package/dist/chunks/chunk-KXVYWSJU.js.map +1 -0
  297. package/dist/chunks/chunk-LU5A5PN5.js +8084 -0
  298. package/dist/chunks/chunk-LU5A5PN5.js.map +1 -0
  299. package/dist/chunks/chunk-LUZGWGSR.js +913 -0
  300. package/dist/chunks/chunk-LUZGWGSR.js.map +1 -0
  301. package/dist/chunks/chunk-MI7IF36Z.js +367 -0
  302. package/dist/chunks/chunk-MI7IF36Z.js.map +1 -0
  303. package/dist/chunks/chunk-MOBVIJE2.js +913 -0
  304. package/dist/chunks/chunk-MOBVIJE2.js.map +1 -0
  305. package/dist/chunks/chunk-NBENQI27.js +273 -0
  306. package/dist/chunks/chunk-NBENQI27.js.map +1 -0
  307. package/dist/chunks/chunk-NEAO4XCM.js +913 -0
  308. package/dist/chunks/chunk-NEAO4XCM.js.map +1 -0
  309. package/dist/chunks/chunk-NJ5O743W.js +311 -0
  310. package/dist/chunks/chunk-NJ5O743W.js.map +1 -0
  311. package/dist/chunks/chunk-NMQ4USN7.js +913 -0
  312. package/dist/chunks/chunk-NMQ4USN7.js.map +1 -0
  313. package/dist/chunks/chunk-NPZ3WHOS.js +94 -0
  314. package/dist/chunks/chunk-NPZ3WHOS.js.map +1 -0
  315. package/dist/chunks/chunk-NRKCQIQS.js +8 -0
  316. package/dist/chunks/chunk-NRKCQIQS.js.map +1 -0
  317. package/dist/chunks/chunk-NRNSOUTF.js +913 -0
  318. package/dist/chunks/chunk-NRNSOUTF.js.map +1 -0
  319. package/dist/chunks/chunk-OBAABB63.js +8093 -0
  320. package/dist/chunks/chunk-OBAABB63.js.map +1 -0
  321. package/dist/chunks/chunk-OGAKPUCC.js +502 -0
  322. package/dist/chunks/chunk-OGAKPUCC.js.map +1 -0
  323. package/dist/chunks/chunk-OREGQJ7H.js +19 -0
  324. package/dist/chunks/chunk-OREGQJ7H.js.map +1 -0
  325. package/dist/chunks/chunk-RJZ4D6XM.js +88 -0
  326. package/dist/chunks/chunk-RJZ4D6XM.js.map +1 -0
  327. package/dist/chunks/chunk-RL3NBBKW.js +913 -0
  328. package/dist/chunks/chunk-RL3NBBKW.js.map +1 -0
  329. package/dist/chunks/chunk-S72IAWSO.js +8770 -0
  330. package/dist/chunks/chunk-S72IAWSO.js.map +1 -0
  331. package/dist/chunks/chunk-SDN2PXF7.js +94 -0
  332. package/dist/chunks/chunk-SDN2PXF7.js.map +1 -0
  333. package/dist/chunks/chunk-SRJF5RCP.js +8772 -0
  334. package/dist/chunks/chunk-SRJF5RCP.js.map +1 -0
  335. package/dist/chunks/chunk-SV356YP4.js +31 -0
  336. package/dist/chunks/chunk-SV356YP4.js.map +1 -0
  337. package/dist/chunks/chunk-TBHIUG43.js +19 -0
  338. package/dist/chunks/chunk-TBHIUG43.js.map +1 -0
  339. package/dist/chunks/chunk-TDIRV53C.js +3626 -0
  340. package/dist/chunks/chunk-TDIRV53C.js.map +1 -0
  341. package/dist/chunks/chunk-TJNZKBEN.js +88 -0
  342. package/dist/chunks/chunk-TJNZKBEN.js.map +1 -0
  343. package/dist/chunks/chunk-TU6COU44.js +82 -0
  344. package/dist/chunks/chunk-TU6COU44.js.map +1 -0
  345. package/dist/chunks/chunk-UHQVQBCL.js +89 -0
  346. package/dist/chunks/chunk-UHQVQBCL.js.map +1 -0
  347. package/dist/chunks/chunk-V7DSDBTC.js +142 -0
  348. package/dist/chunks/chunk-V7DSDBTC.js.map +1 -0
  349. package/dist/chunks/chunk-VCFCYQB4.js +315 -0
  350. package/dist/chunks/chunk-VCFCYQB4.js.map +1 -0
  351. package/dist/chunks/chunk-VEASE2VL.js +913 -0
  352. package/dist/chunks/chunk-VEASE2VL.js.map +1 -0
  353. package/dist/chunks/chunk-VHSCCVNF.js +8024 -0
  354. package/dist/chunks/chunk-VHSCCVNF.js.map +1 -0
  355. package/dist/chunks/chunk-VRR4ODZY.js +8009 -0
  356. package/dist/chunks/chunk-VRR4ODZY.js.map +1 -0
  357. package/dist/chunks/chunk-WFUXZ4UT.js +502 -0
  358. package/dist/chunks/chunk-WFUXZ4UT.js.map +1 -0
  359. package/dist/chunks/chunk-WUSKUUQL.js +3639 -0
  360. package/dist/chunks/chunk-WUSKUUQL.js.map +1 -0
  361. package/dist/chunks/chunk-WVB7FS2F.js +913 -0
  362. package/dist/chunks/chunk-WVB7FS2F.js.map +1 -0
  363. package/dist/chunks/chunk-WY5BKP4C.js +19 -0
  364. package/dist/chunks/chunk-WY5BKP4C.js.map +1 -0
  365. package/dist/chunks/chunk-XFJJETQG.js +913 -0
  366. package/dist/chunks/chunk-XFJJETQG.js.map +1 -0
  367. package/dist/chunks/chunk-XNMAPACM.js +19 -0
  368. package/dist/chunks/chunk-XNMAPACM.js.map +1 -0
  369. package/dist/chunks/chunk-Y2DMMGRW.js +8657 -0
  370. package/dist/chunks/chunk-Y2DMMGRW.js.map +1 -0
  371. package/dist/chunks/chunk-Y3UM2YVB.js +8025 -0
  372. package/dist/chunks/chunk-Y3UM2YVB.js.map +1 -0
  373. package/dist/chunks/chunk-Y4DXEVZM.js +8770 -0
  374. package/dist/chunks/chunk-Y4DXEVZM.js.map +1 -0
  375. package/dist/chunks/chunk-Y4VJXTG5.js +8754 -0
  376. package/dist/chunks/chunk-Y4VJXTG5.js.map +1 -0
  377. package/dist/chunks/chunk-YFTXNRNZ.js +913 -0
  378. package/dist/chunks/chunk-YFTXNRNZ.js.map +1 -0
  379. package/dist/chunks/chunk-YRVKKM47.js +365 -0
  380. package/dist/chunks/chunk-YRVKKM47.js.map +1 -0
  381. package/dist/chunks/chunk-YWEWSQJR.js +40 -0
  382. package/dist/chunks/chunk-YWEWSQJR.js.map +1 -0
  383. package/dist/chunks/chunk-Z3PFCZLH.js +913 -0
  384. package/dist/chunks/chunk-Z3PFCZLH.js.map +1 -0
  385. package/dist/chunks/chunk-ZB27F2HA.js +366 -0
  386. package/dist/chunks/chunk-ZB27F2HA.js.map +1 -0
  387. package/dist/exports/computed-item.context.d.ts +2 -1
  388. package/dist/exports/computed.context.d.ts +3 -2
  389. package/dist/exports/config.context.d.ts +3 -1
  390. package/dist/exports/config.context.js +1 -1
  391. package/dist/exports/expression-result.d.ts +2 -2
  392. package/dist/exports/interaction.d.ts +2 -1
  393. package/dist/exports/interaction.js +2 -1
  394. package/dist/exports/item.context.d.ts +2 -1
  395. package/dist/exports/qti-assessment-item.context.d.ts +2 -1
  396. package/dist/exports/qti-condition-expression.d.ts +2 -1
  397. package/dist/exports/qti-condition-expression.js +3 -2
  398. package/dist/exports/qti-expression.d.ts +2 -1
  399. package/dist/exports/qti-expression.js +2 -1
  400. package/dist/exports/qti-test.d.ts +4 -3
  401. package/dist/exports/qti.context.d.ts +14 -0
  402. package/dist/exports/qti.context.js +8 -0
  403. package/dist/exports/qti.context.js.map +1 -0
  404. package/dist/exports/session.context.d.ts +3 -2
  405. package/dist/exports/test.context.d.ts +2 -1
  406. package/dist/exports/variables.d.ts +2 -1
  407. package/dist/index.d.ts +5 -4
  408. package/dist/index.js +76 -56
  409. package/dist/item.css +28 -16
  410. package/dist/qti-components/index.d.ts +146 -3
  411. package/dist/qti-components/index.js +29 -7
  412. package/dist/qti-components-jsx.d.ts +3777 -1467
  413. package/dist/qti-item/components/item-container.js +3 -3
  414. package/dist/qti-item/components/item-correct-response-mode.d.ts +17 -0
  415. package/dist/qti-item/components/item-correct-response-mode.js +62 -0
  416. package/dist/qti-item/components/item-correct-response-mode.js.map +1 -0
  417. package/dist/qti-item/components/item-show-candidate-correction.d.ts +33 -0
  418. package/dist/qti-item/components/item-show-candidate-correction.js +88 -0
  419. package/dist/qti-item/components/item-show-candidate-correction.js.map +1 -0
  420. package/dist/qti-item/components/item-show-correct-response.d.ts +2 -1
  421. package/dist/qti-item/components/item-show-correct-response.js +1 -1
  422. package/dist/qti-item/components/print-item-variables.d.ts +2 -1
  423. package/dist/qti-item/core/index.d.ts +10 -3
  424. package/dist/qti-item/core/index.js +8 -7
  425. package/dist/qti-loader/index.d.ts +2 -1
  426. package/dist/qti-loader/index.js +2 -2
  427. package/dist/qti-response-declaration-B7a6N0wt.d.ts +1380 -0
  428. package/dist/qti-response-declaration-BTiPhwZv.d.ts +1370 -0
  429. package/dist/qti-response-declaration-Bthfzhwd.d.ts +1385 -0
  430. package/dist/qti-response-declaration-CIPGNbno.d.ts +1361 -0
  431. package/dist/qti-response-declaration-CNP03Vcb.d.ts +1386 -0
  432. package/dist/qti-response-declaration-CTRNB113.d.ts +1385 -0
  433. package/dist/qti-response-declaration-CXb5CI4-.d.ts +1361 -0
  434. package/dist/qti-response-declaration-Cbj7E4ND.d.ts +1372 -0
  435. package/dist/qti-response-declaration-DRNG6zLy.d.ts +1370 -0
  436. package/dist/qti-response-declaration-DuRT3sKx.d.ts +1380 -0
  437. package/dist/qti-response-declaration-GPP3SVur.d.ts +1372 -0
  438. package/dist/qti-response-declaration-xVcD4HvN.d.ts +1386 -0
  439. package/dist/qti-test/components/index.d.ts +3 -2
  440. package/dist/qti-test/components/index.js +33 -33
  441. package/dist/qti-test/components/test-container.js +3 -3
  442. package/dist/qti-test/components/test-navigation.d.ts +16 -3
  443. package/dist/qti-test/components/test-navigation.js +3 -2
  444. package/dist/qti-test/components/test-next.d.ts +3 -2
  445. package/dist/qti-test/components/test-next.js +1 -2
  446. package/dist/qti-test/components/test-prev.d.ts +3 -2
  447. package/dist/qti-test/components/test-prev.js +1 -2
  448. package/dist/qti-test/components/test-print-context.d.ts +3 -2
  449. package/dist/qti-test/components/test-print-item-variables.d.ts +3 -2
  450. package/dist/qti-test/components/test-scoring-buttons.d.ts +3 -2
  451. package/dist/qti-test/components/test-scoring-buttons.js +1 -1
  452. package/dist/qti-test/components/test-scoring-feedback.d.ts +3 -2
  453. package/dist/qti-test/components/test-scoring-feedback.js +1 -1
  454. package/dist/qti-test/components/test-show-correct-response.d.ts +3 -2
  455. package/dist/qti-test/components/test-view.js +2 -2
  456. package/dist/qti-test/core/index.d.ts +4 -3
  457. package/dist/qti-test/core/index.js +11 -10
  458. package/dist/qti-test-feedback-B0W2B5wQ.d.ts +91 -0
  459. package/dist/qti-test-feedback-B1kTnqnI.d.ts +91 -0
  460. package/dist/qti-test-feedback-BAUInn-q.d.ts +91 -0
  461. package/dist/qti-test-feedback-BWerRaNG.d.ts +91 -0
  462. package/dist/qti-test-feedback-BXdbgpY8.d.ts +91 -0
  463. package/dist/qti-test-feedback-Bbt2VWE1.d.ts +91 -0
  464. package/dist/qti-test-feedback-C-PQYZWl.d.ts +91 -0
  465. package/dist/qti-test-feedback-CuTA6S46.d.ts +91 -0
  466. package/dist/qti-test-feedback-DUxJARNH.d.ts +91 -0
  467. package/dist/qti-test-feedback-Ddb0QQyz.d.ts +91 -0
  468. package/dist/qti-test-feedback-SkEfQjOR.d.ts +91 -0
  469. package/dist/qti-test-feedback-TcrkevLg.d.ts +91 -0
  470. package/dist/qti-transformers/index.d.ts +17 -1
  471. package/dist/qti-transformers/index.js +1 -1
  472. package/dist/vscode.html-custom-data.json +162 -39
  473. package/package.json +62 -65
@@ -0,0 +1,92 @@
1
+ // src/lib/decorators/live-query.ts
2
+ function liveQuery(querySelector, options) {
3
+ let observer;
4
+ let previousElements = [];
5
+ const resolvedOptions = {
6
+ waitUntilFirstUpdate: false,
7
+ ...options
8
+ };
9
+ return (proto, decoratedFnName) => {
10
+ const { connectedCallback, disconnectedCallback } = proto;
11
+ const getElements = function() {
12
+ if (typeof querySelector === "function") {
13
+ return querySelector.call(this);
14
+ } else if (querySelector && querySelector.trim() !== "") {
15
+ return Array.from(this.querySelectorAll(querySelector)).concat(
16
+ Array.from(this.shadowRoot?.querySelectorAll(querySelector) || [])
17
+ );
18
+ }
19
+ return [];
20
+ };
21
+ const checkForChanges = function() {
22
+ if (typeof querySelector === "function") {
23
+ const currentElements = getElements.call(this);
24
+ const addedElements = currentElements.filter((el) => !previousElements.includes(el));
25
+ const removedElements = previousElements.filter((el) => !currentElements.includes(el));
26
+ if (addedElements.length > 0 || removedElements.length > 0) {
27
+ this[decoratedFnName](addedElements, removedElements);
28
+ previousElements = [...currentElements];
29
+ }
30
+ }
31
+ };
32
+ proto.connectedCallback = function() {
33
+ connectedCallback.call(this);
34
+ const startWatching = () => {
35
+ if (typeof querySelector === "function") {
36
+ const initialElements = getElements.call(this);
37
+ previousElements = [...initialElements];
38
+ if (initialElements.length > 0) {
39
+ this[decoratedFnName](initialElements, []);
40
+ }
41
+ console.log(`LiveQuery: Watching elements with function selector in ${this.localName}`);
42
+ observer = new MutationObserver(() => {
43
+ checkForChanges.call(this);
44
+ });
45
+ observer.observe(this, { childList: true, subtree: true, attributes: true });
46
+ } else if (querySelector && querySelector.trim() !== "") {
47
+ const callback = (mutationList) => {
48
+ const elementsToWatch = getElements.call(this);
49
+ for (const mutation of mutationList) {
50
+ const addedNodes = Array.from(mutation.addedNodes).filter(
51
+ (node) => node.nodeType === Node.ELEMENT_NODE
52
+ );
53
+ const removedNodes = Array.from(mutation.removedNodes).filter(
54
+ (node) => node.nodeType === Node.ELEMENT_NODE
55
+ );
56
+ const relevantAdded = addedNodes.filter((n) => elementsToWatch.includes(n));
57
+ const relevantRemoved = removedNodes.filter((n) => elementsToWatch.includes(n));
58
+ if (mutation.type === "childList" && (relevantAdded.length > 0 || relevantRemoved.length > 0)) {
59
+ this[decoratedFnName](relevantAdded, relevantRemoved);
60
+ }
61
+ }
62
+ };
63
+ observer = new MutationObserver(callback);
64
+ observer.observe(this, { childList: true, subtree: true });
65
+ const elementsAdded = getElements.call(this);
66
+ if (elementsAdded.length > 0) {
67
+ this[decoratedFnName](elementsAdded, []);
68
+ }
69
+ }
70
+ };
71
+ if (resolvedOptions.waitUntilFirstUpdate) {
72
+ this.updateComplete.then(() => {
73
+ startWatching();
74
+ });
75
+ } else {
76
+ startWatching();
77
+ }
78
+ };
79
+ proto.disconnectedCallback = function() {
80
+ disconnectedCallback.call(this);
81
+ if (observer) {
82
+ observer.disconnect();
83
+ }
84
+ previousElements = [];
85
+ };
86
+ };
87
+ }
88
+
89
+ export {
90
+ liveQuery
91
+ };
92
+ //# sourceMappingURL=chunk-I5EA6DJB.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/decorators/live-query.ts"],"sourcesContent":["// @liveQuery decorator\n//\n// Runs when observed elements change in the DOM\n//\n// Usage:\n//\n// @liveQuery('selector')\n// handleElementChange(added, removed) {\n// ...\n// }\n//\n// @liveQuery(() => [...elements])\n// handleElementChange(added, removed) {\n// ...\n// }\nimport type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\ntype NonUndefined<A> = A extends undefined ? never : A;\ntype UpdateHandlerFunctionKeys<T extends object> = {\n [K in keyof T]-?: NonUndefined<T[K]> extends UpdateHandler ? K : never;\n}[keyof T];\n\ninterface LiveQueryOptions {\n /**\n * If true, will only start watching after the initial update/render\n */\n waitUntilFirstUpdate?: boolean;\n}\n\n// Type for selector - can be string or function returning elements\ntype ElementSelector = string | (() => HTMLElement[]);\n\nexport function liveQuery(querySelector: ElementSelector, options?: LiveQueryOptions) {\n let observer: MutationObserver;\n let previousElements: HTMLElement[] = [];\n const resolvedOptions: Required<LiveQueryOptions> = {\n waitUntilFirstUpdate: false,\n ...options\n };\n\n return <ElemClass extends LitElement>(\n proto: ElemClass,\n decoratedFnName: UpdateHandlerFunctionKeys<ElemClass>\n ): void => {\n const { connectedCallback, disconnectedCallback } = proto;\n\n // Helper function to get elements based on selector type\n const getElements = function (this: ElemClass): HTMLElement[] {\n if (typeof querySelector === 'function') {\n // For function selectors, call the function in the context of 'this'\n return querySelector.call(this);\n } else if (querySelector && querySelector.trim() !== '') {\n // For string selectors, use querySelectorAll\n return Array.from(this.querySelectorAll(querySelector)).concat(\n Array.from(this.shadowRoot?.querySelectorAll(querySelector) || [])\n ) as HTMLElement[];\n }\n return [];\n };\n\n // Helper function to check for changes when using function selectors\n const checkForChanges = function (this: ElemClass) {\n if (typeof querySelector === 'function') {\n const currentElements = getElements.call(this);\n const addedElements = currentElements.filter(el => !previousElements.includes(el));\n const removedElements = previousElements.filter(el => !currentElements.includes(el));\n\n if (addedElements.length > 0 || removedElements.length > 0) {\n (this[decoratedFnName] as unknown as UpdateHandler)(addedElements, removedElements);\n previousElements = [...currentElements];\n }\n }\n };\n\n proto.connectedCallback = function (this: ElemClass) {\n connectedCallback.call(this);\n\n const startWatching = () => {\n if (typeof querySelector === 'function') {\n // For function selectors, we need to poll for changes since we can't use MutationObserver directly\n\n const initialElements = getElements.call(this);\n previousElements = [...initialElements];\n\n // Trigger initial callback\n if (initialElements.length > 0) {\n (this[decoratedFnName] as unknown as UpdateHandler)(initialElements, []);\n }\n console.log(`LiveQuery: Watching elements with function selector in ${this.localName}`);\n // Set up MutationObserver to trigger checks when DOM changes\n observer = new MutationObserver(() => {\n checkForChanges.call(this);\n });\n observer.observe(this, { childList: true, subtree: true, attributes: true });\n } else if (querySelector && querySelector.trim() !== '') {\n // Original string selector logic\n const callback = (mutationList: MutationRecord[]) => {\n const elementsToWatch = getElements.call(this);\n\n for (const mutation of mutationList) {\n const addedNodes = Array.from(mutation.addedNodes).filter(\n node => node.nodeType === Node.ELEMENT_NODE\n ) as Element[];\n const removedNodes = Array.from(mutation.removedNodes).filter(\n node => node.nodeType === Node.ELEMENT_NODE\n ) as Element[];\n\n const relevantAdded = addedNodes.filter(n => elementsToWatch.includes(n as HTMLElement));\n const relevantRemoved = removedNodes.filter(n => elementsToWatch.includes(n as HTMLElement));\n\n if (mutation.type === 'childList' && (relevantAdded.length > 0 || relevantRemoved.length > 0)) {\n (this[decoratedFnName] as unknown as UpdateHandler)(relevantAdded, relevantRemoved);\n }\n }\n };\n\n observer = new MutationObserver(callback);\n observer.observe(this, { childList: true, subtree: true });\n\n // Trigger initial callback\n const elementsAdded = getElements.call(this);\n if (elementsAdded.length > 0) {\n (this[decoratedFnName] as unknown as UpdateHandler)(elementsAdded, []);\n }\n }\n };\n\n if (resolvedOptions.waitUntilFirstUpdate) {\n // Wait for the first update to complete before starting to watch\n this.updateComplete.then(() => {\n startWatching();\n });\n } else {\n startWatching();\n }\n };\n\n proto.disconnectedCallback = function (this: ElemClass) {\n disconnectedCallback.call(this);\n if (observer) {\n observer.disconnect();\n }\n previousElements = [];\n };\n };\n}\n"],"mappings":";AAiCO,SAAS,UAAU,eAAgC,SAA4B;AACpF,MAAI;AACJ,MAAI,mBAAkC,CAAC;AACvC,QAAM,kBAA8C;AAAA,IAClD,sBAAsB;AAAA,IACtB,GAAG;AAAA,EACL;AAEA,SAAO,CACL,OACA,oBACS;AACT,UAAM,EAAE,mBAAmB,qBAAqB,IAAI;AAGpD,UAAM,cAAc,WAA0C;AAC5D,UAAI,OAAO,kBAAkB,YAAY;AAEvC,eAAO,cAAc,KAAK,IAAI;AAAA,MAChC,WAAW,iBAAiB,cAAc,KAAK,MAAM,IAAI;AAEvD,eAAO,MAAM,KAAK,KAAK,iBAAiB,aAAa,CAAC,EAAE;AAAA,UACtD,MAAM,KAAK,KAAK,YAAY,iBAAiB,aAAa,KAAK,CAAC,CAAC;AAAA,QACnE;AAAA,MACF;AACA,aAAO,CAAC;AAAA,IACV;AAGA,UAAM,kBAAkB,WAA2B;AACjD,UAAI,OAAO,kBAAkB,YAAY;AACvC,cAAM,kBAAkB,YAAY,KAAK,IAAI;AAC7C,cAAM,gBAAgB,gBAAgB,OAAO,QAAM,CAAC,iBAAiB,SAAS,EAAE,CAAC;AACjF,cAAM,kBAAkB,iBAAiB,OAAO,QAAM,CAAC,gBAAgB,SAAS,EAAE,CAAC;AAEnF,YAAI,cAAc,SAAS,KAAK,gBAAgB,SAAS,GAAG;AAC1D,UAAC,KAAK,eAAe,EAA+B,eAAe,eAAe;AAClF,6BAAmB,CAAC,GAAG,eAAe;AAAA,QACxC;AAAA,MACF;AAAA,IACF;AAEA,UAAM,oBAAoB,WAA2B;AACnD,wBAAkB,KAAK,IAAI;AAE3B,YAAM,gBAAgB,MAAM;AAC1B,YAAI,OAAO,kBAAkB,YAAY;AAGvC,gBAAM,kBAAkB,YAAY,KAAK,IAAI;AAC7C,6BAAmB,CAAC,GAAG,eAAe;AAGtC,cAAI,gBAAgB,SAAS,GAAG;AAC9B,YAAC,KAAK,eAAe,EAA+B,iBAAiB,CAAC,CAAC;AAAA,UACzE;AACA,kBAAQ,IAAI,0DAA0D,KAAK,SAAS,EAAE;AAEtF,qBAAW,IAAI,iBAAiB,MAAM;AACpC,4BAAgB,KAAK,IAAI;AAAA,UAC3B,CAAC;AACD,mBAAS,QAAQ,MAAM,EAAE,WAAW,MAAM,SAAS,MAAM,YAAY,KAAK,CAAC;AAAA,QAC7E,WAAW,iBAAiB,cAAc,KAAK,MAAM,IAAI;AAEvD,gBAAM,WAAW,CAAC,iBAAmC;AACnD,kBAAM,kBAAkB,YAAY,KAAK,IAAI;AAE7C,uBAAW,YAAY,cAAc;AACnC,oBAAM,aAAa,MAAM,KAAK,SAAS,UAAU,EAAE;AAAA,gBACjD,UAAQ,KAAK,aAAa,KAAK;AAAA,cACjC;AACA,oBAAM,eAAe,MAAM,KAAK,SAAS,YAAY,EAAE;AAAA,gBACrD,UAAQ,KAAK,aAAa,KAAK;AAAA,cACjC;AAEA,oBAAM,gBAAgB,WAAW,OAAO,OAAK,gBAAgB,SAAS,CAAgB,CAAC;AACvF,oBAAM,kBAAkB,aAAa,OAAO,OAAK,gBAAgB,SAAS,CAAgB,CAAC;AAE3F,kBAAI,SAAS,SAAS,gBAAgB,cAAc,SAAS,KAAK,gBAAgB,SAAS,IAAI;AAC7F,gBAAC,KAAK,eAAe,EAA+B,eAAe,eAAe;AAAA,cACpF;AAAA,YACF;AAAA,UACF;AAEA,qBAAW,IAAI,iBAAiB,QAAQ;AACxC,mBAAS,QAAQ,MAAM,EAAE,WAAW,MAAM,SAAS,KAAK,CAAC;AAGzD,gBAAM,gBAAgB,YAAY,KAAK,IAAI;AAC3C,cAAI,cAAc,SAAS,GAAG;AAC5B,YAAC,KAAK,eAAe,EAA+B,eAAe,CAAC,CAAC;AAAA,UACvE;AAAA,QACF;AAAA,MACF;AAEA,UAAI,gBAAgB,sBAAsB;AAExC,aAAK,eAAe,KAAK,MAAM;AAC7B,wBAAc;AAAA,QAChB,CAAC;AAAA,MACH,OAAO;AACL,sBAAc;AAAA,MAChB;AAAA,IACF;AAEA,UAAM,uBAAuB,WAA2B;AACtD,2BAAqB,KAAK,IAAI;AAC9B,UAAI,UAAU;AACZ,iBAAS,WAAW;AAAA,MACtB;AACA,yBAAmB,CAAC;AAAA,IACtB;AAAA,EACF;AACF;","names":[]}
@@ -0,0 +1,144 @@
1
+ import {
2
+ itemContext
3
+ } from "./chunk-NJNQOQUU.js";
4
+ import {
5
+ qtiContext
6
+ } from "./chunk-H6KHXSIO.js";
7
+ import {
8
+ __decorateClass
9
+ } from "./chunk-H2JE6IVU.js";
10
+
11
+ // src/lib/exports/qti-expression.ts
12
+ import { consume } from "@lit/context";
13
+ import { css, html, LitElement } from "lit";
14
+ import { state } from "lit/decorators.js";
15
+ var QtiExpression = class extends LitElement {
16
+ constructor() {
17
+ super(...arguments);
18
+ this.getVariables = () => (
19
+ // FIXME: if this itself is multiple, this will never enter the qti-multiple switch
20
+ // See this example here: https://github.com/1EdTech/qti-examples/blob/master/qtiv3-examples/packaging/items/Example05-feedbackBlock-adaptive.xml
21
+ Array.from(this.children).map((e) => {
22
+ console.debug("getVariables", e.tagName.toLowerCase());
23
+ switch (e.tagName.toLowerCase()) {
24
+ case "qti-base-value": {
25
+ return {
26
+ baseType: e.getAttribute("base-type"),
27
+ value: e.textContent.trim(),
28
+ cardinality: "single"
29
+ };
30
+ }
31
+ case "qti-variable": {
32
+ const identifier = e.getAttribute("identifier") || "";
33
+ if (identifier === "QTI_CONTEXT") {
34
+ if (!this.qtiContext?.QTI_CONTEXT) {
35
+ console.warn("QTI_CONTEXT not available");
36
+ return {
37
+ identifier: "QTI_CONTEXT",
38
+ baseType: "record",
39
+ value: this.qtiContext.QTI_CONTEXT,
40
+ cardinality: "record",
41
+ type: "context"
42
+ };
43
+ }
44
+ return {
45
+ identifier: "QTI_CONTEXT",
46
+ baseType: "record",
47
+ value: this.qtiContext.QTI_CONTEXT,
48
+ cardinality: "record",
49
+ type: "context"
50
+ };
51
+ }
52
+ const variable = this.context.variables.find((v) => v.identifier === identifier) || null;
53
+ return variable;
54
+ }
55
+ case "qti-multiple": {
56
+ const multiple = e;
57
+ const values = multiple.getResult();
58
+ console.debug("values", values);
59
+ if (values?.length > 0) {
60
+ return {
61
+ identifier: "",
62
+ baseType: values[0].baseType,
63
+ value: values.map((v) => v.value),
64
+ cardinality: "multiple",
65
+ type: "response"
66
+ };
67
+ }
68
+ return null;
69
+ }
70
+ case "qti-ordered": {
71
+ const multiple = e;
72
+ const values = multiple.getResult();
73
+ if (values?.length > 0) {
74
+ return {
75
+ identifier: "",
76
+ baseType: values[0].baseType,
77
+ value: values.map((v) => v.value),
78
+ cardinality: "ordered",
79
+ type: "response"
80
+ };
81
+ }
82
+ return null;
83
+ }
84
+ case "qti-correct": {
85
+ const identifier = e.getAttribute("identifier") || "";
86
+ const responseVariable = this.context.variables.find((v) => v.identifier === identifier) || null;
87
+ return {
88
+ baseType: responseVariable.baseType,
89
+ value: responseVariable.correctResponse,
90
+ cardinality: responseVariable.cardinality
91
+ };
92
+ }
93
+ default: {
94
+ try {
95
+ const expression = e;
96
+ const value = expression.getResult();
97
+ return {
98
+ baseType: "integer",
99
+ value: value?.toString() || null,
100
+ cardinality: "single"
101
+ };
102
+ } catch (error) {
103
+ console.warn("default not sufficient");
104
+ }
105
+ return null;
106
+ }
107
+ }
108
+ }).filter((v) => v !== null)
109
+ );
110
+ }
111
+ render() {
112
+ return html`<pre>${JSON.stringify(this.result, null, 2)}</pre>
113
+ <slot></slot>`;
114
+ }
115
+ calculate() {
116
+ this.result = this.getResult();
117
+ return this.result;
118
+ }
119
+ getResult() {
120
+ throw new Error("Not implemented");
121
+ }
122
+ };
123
+ // hide the slot with css
124
+ QtiExpression.styles = css`
125
+ slot {
126
+ display: none;
127
+ }
128
+ `;
129
+ __decorateClass([
130
+ state()
131
+ ], QtiExpression.prototype, "result", 2);
132
+ __decorateClass([
133
+ consume({ context: itemContext, subscribe: true }),
134
+ state()
135
+ ], QtiExpression.prototype, "context", 2);
136
+ __decorateClass([
137
+ consume({ context: qtiContext, subscribe: true }),
138
+ state()
139
+ ], QtiExpression.prototype, "qtiContext", 2);
140
+
141
+ export {
142
+ QtiExpression
143
+ };
144
+ //# sourceMappingURL=chunk-IAEGLQ4C.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/exports/qti-expression.ts"],"sourcesContent":["import { consume } from '@lit/context';\nimport { css, html, LitElement } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport { itemContext } from './qti-assessment-item.context';\nimport { qtiContext } from './qti.context';\n\nimport type { QtiContext, QtiContextType } from './qti.context';\nimport type { ResponseVariable, VariableDeclaration } from './variables';\nimport type { QtiMultiple } from '../qti-components/qti-response-processing/qti-expression/qti-multiple/qti-multiple';\nimport type { QtiOrdered } from '../qti-components/qti-response-processing/qti-expression/qti-ordered/qti-ordered';\nimport type { ItemContext } from './item.context';\n\nexport interface QtiExpressionBase<T> {\n // get assessmentItem(): QtiAssessmentItem;\n\n // getVariables(): VariableDeclaration<number | string | (number | string)[] | null>[];\n calculate(): Readonly<T>;\n}\n\nexport abstract class QtiExpression<T> extends LitElement implements QtiExpressionBase<T> {\n @state()\n protected result: any;\n\n // hide the slot with css\n static styles = css`\n slot {\n display: none;\n }\n `;\n\n override render() {\n return html`<pre>${JSON.stringify(this.result, null, 2)}</pre>\n <slot></slot>`;\n }\n\n public calculate(): Readonly<T> {\n this.result = this.getResult();\n return this.result;\n }\n\n protected getResult(): Readonly<T> {\n throw new Error('Not implemented');\n }\n\n @consume({ context: itemContext, subscribe: true })\n @state()\n protected context?: ItemContext;\n\n @consume({ context: qtiContext, subscribe: true })\n @state()\n protected qtiContext?: QtiContext;\n\n getVariables = (): (ResponseVariable | VariableDeclaration<QtiContextType>)[] =>\n // FIXME: if this itself is multiple, this will never enter the qti-multiple switch\n // See this example here: https://github.com/1EdTech/qti-examples/blob/master/qtiv3-examples/packaging/items/Example05-feedbackBlock-adaptive.xml\n\n Array.from(this.children)\n .map((e: Element) => {\n console.debug('getVariables', e.tagName.toLowerCase());\n switch (e.tagName.toLowerCase()) {\n case 'qti-base-value': {\n return {\n baseType: e.getAttribute('base-type'),\n value: e.textContent.trim(),\n cardinality: 'single'\n } as ResponseVariable;\n }\n case 'qti-variable': {\n const identifier = e.getAttribute('identifier') || '';\n\n // Special handling for QTI_CONTEXT\n if (identifier === 'QTI_CONTEXT') {\n if (!this.qtiContext?.QTI_CONTEXT) {\n console.warn('QTI_CONTEXT not available');\n return {\n identifier: 'QTI_CONTEXT',\n baseType: 'record',\n value: this.qtiContext.QTI_CONTEXT,\n cardinality: 'record',\n type: 'context'\n } as VariableDeclaration<QtiContextType>;\n }\n return {\n identifier: 'QTI_CONTEXT',\n baseType: 'record',\n value: this.qtiContext.QTI_CONTEXT,\n cardinality: 'record',\n type: 'context'\n } as VariableDeclaration<QtiContextType>;\n }\n\n const variable = this.context.variables.find(v => v.identifier === identifier) || null;\n return variable;\n }\n case 'qti-multiple': {\n const multiple = e as QtiMultiple;\n\n const values = multiple.getResult();\n console.debug('values', values);\n if (values?.length > 0) {\n return {\n identifier: '',\n baseType: values[0].baseType,\n value: values.map(v => v.value),\n cardinality: 'multiple',\n type: 'response'\n } as ResponseVariable;\n }\n return null;\n }\n case 'qti-ordered': {\n const multiple = e as QtiOrdered;\n const values = multiple.getResult();\n if (values?.length > 0) {\n return {\n identifier: '',\n baseType: values[0].baseType,\n value: values.map(v => v.value),\n cardinality: 'ordered',\n type: 'response'\n } as ResponseVariable;\n }\n return null;\n }\n case 'qti-correct': {\n const identifier = e.getAttribute('identifier') || '';\n const responseVariable: ResponseVariable =\n this.context.variables.find(v => v.identifier === identifier) || null;\n return {\n baseType: responseVariable.baseType,\n value: responseVariable.correctResponse,\n cardinality: responseVariable.cardinality\n } as ResponseVariable;\n }\n default: {\n // added for use of qti-equal-rounded\n try {\n const expression = e as QtiExpression<number>;\n const value = expression.getResult();\n return {\n baseType: 'integer',\n value: value?.toString() || null,\n cardinality: 'single'\n } as ResponseVariable;\n } catch (error) {\n console.warn('default not sufficient');\n }\n return null;\n }\n }\n })\n .filter(v => v !== null);\n}\n"],"mappings":"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","names":[]}