@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.
- package/cdn/chunks/chunk-23JT53R2.js +1 -0
- package/cdn/chunks/chunk-26QYN3JJ.js +1482 -0
- package/cdn/chunks/chunk-2N2XIR3B.js +5 -0
- package/cdn/chunks/chunk-2OA2G5PN.js +5 -0
- package/cdn/chunks/chunk-2PXIZTCM.js +1 -0
- package/cdn/chunks/chunk-3H3ITD2Q.js +5 -0
- package/cdn/chunks/chunk-3HIY5HSB.js +1 -0
- package/cdn/chunks/chunk-3PVCPEFY.js +5 -0
- package/cdn/chunks/chunk-3WY3AI3D.js +1482 -0
- package/cdn/chunks/chunk-3YF52BZZ.js +41 -0
- package/cdn/chunks/chunk-3ZFHDJHW.js +3636 -0
- package/cdn/chunks/chunk-3ZLIRREM.js +1466 -0
- package/cdn/chunks/chunk-426N5A5I.js +1 -0
- package/cdn/chunks/chunk-453G3A34.js +8 -0
- package/cdn/chunks/chunk-4F3OLGZ4.js +5 -0
- package/cdn/chunks/chunk-4YPL4JG2.js +1 -0
- package/cdn/chunks/chunk-5ICSVSCW.js +1482 -0
- package/cdn/chunks/chunk-5WPKWVLA.js +1 -0
- package/cdn/chunks/chunk-63C5YDWF.js +1482 -0
- package/cdn/chunks/chunk-6FSYASNZ.js +1 -0
- package/cdn/chunks/chunk-6H26KONO.js +1482 -0
- package/cdn/chunks/chunk-6IY26BVE.js +23 -0
- package/cdn/chunks/chunk-6OUX6PKB.js +5 -0
- package/cdn/chunks/chunk-74FJHIJ5.js +8 -0
- package/cdn/chunks/chunk-77U2O27N.js +1 -0
- package/cdn/chunks/chunk-7AX6K3VW.js +1 -0
- package/cdn/chunks/chunk-7HEAECQ2.js +1466 -0
- package/cdn/chunks/chunk-7LCGB3GF.js +6 -0
- package/cdn/chunks/chunk-7NHDLON4.js +5 -0
- package/cdn/chunks/chunk-7T6OJ2OQ.js +1482 -0
- package/cdn/chunks/chunk-ARUVWWSO.js +5 -0
- package/cdn/chunks/chunk-B7NVY4AR.js +23 -0
- package/cdn/chunks/chunk-BFMN6REI.js +5 -0
- package/cdn/chunks/chunk-BGWSUBMK.js +1482 -0
- package/cdn/chunks/chunk-BSK7IIBZ.js +1 -0
- package/cdn/chunks/chunk-BUGBHX3F.js +5 -0
- package/cdn/chunks/chunk-BXEEPJPF.js +48 -0
- package/cdn/chunks/chunk-BXTNMGCF.js +1 -0
- package/cdn/chunks/chunk-C25DJHRW.js +5 -0
- package/cdn/chunks/chunk-C3XRHLQX.js +1 -0
- package/cdn/chunks/chunk-CGI4LREF.js +1 -0
- package/cdn/chunks/chunk-CLAUENYE.js +8 -0
- package/cdn/chunks/chunk-CYSQXIRZ.js +5 -0
- package/cdn/chunks/chunk-DD55IQIL.js +6 -0
- package/cdn/chunks/chunk-DHNKVZRG.js +1 -0
- package/cdn/chunks/chunk-DXF4ZBJ2.js +1 -0
- package/cdn/chunks/chunk-E2UBGM45.js +1 -0
- package/cdn/chunks/chunk-E6IOJ4MV.js +23 -0
- package/cdn/chunks/chunk-ECKBRC27.js +1482 -0
- package/cdn/chunks/chunk-ECLB2ECD.js +5 -0
- package/cdn/chunks/chunk-EINATJIA.js +1 -0
- package/cdn/chunks/chunk-EXMUQYL6.js +5 -0
- package/cdn/chunks/chunk-FDOVZYP4.js +5 -0
- package/cdn/chunks/chunk-FDV6POVV.js +6 -0
- package/cdn/chunks/chunk-FOE7HRKJ.js +10 -0
- package/cdn/chunks/chunk-FVIBMJDJ.js +5 -0
- package/cdn/chunks/chunk-G2DN6BDN.js +8 -0
- package/cdn/chunks/chunk-GBAAEAYK.js +5 -0
- package/cdn/chunks/chunk-GDRPZEZJ.js +5 -0
- package/cdn/chunks/chunk-GFXQHIPI.js +1482 -0
- package/cdn/chunks/chunk-GTSQO7SP.js +1 -0
- package/cdn/chunks/chunk-GVZHKB2Y.js +1482 -0
- package/cdn/chunks/chunk-GY74IPZ2.js +8 -0
- package/cdn/chunks/chunk-HA6MFZZU.js +48 -0
- package/cdn/chunks/chunk-HHALXPVF.js +5 -0
- package/cdn/chunks/chunk-HPX7CBTS.js +1 -0
- package/cdn/chunks/chunk-I3PDGPL6.js +48 -0
- package/cdn/chunks/chunk-I4G5VXGD.js +5 -0
- package/cdn/chunks/chunk-IJBHBPIR.js +1 -0
- package/cdn/chunks/chunk-IMHR3S57.js +1 -0
- package/cdn/chunks/chunk-IPISUVWE.js +8 -0
- package/cdn/chunks/chunk-J3NAMJRF.js +55 -0
- package/cdn/chunks/chunk-JG53AUXR.js +1 -0
- package/cdn/chunks/chunk-JHMA3APO.js +3638 -0
- package/cdn/chunks/chunk-JJNOTSC4.js +5 -0
- package/cdn/chunks/chunk-JVPQQZNX.js +5 -0
- package/cdn/chunks/chunk-JVW572MO.js +1 -0
- package/cdn/chunks/chunk-JYF2SOPC.js +6 -0
- package/cdn/chunks/chunk-K42MGICV.js +1 -0
- package/cdn/chunks/chunk-K7NB4LHE.js +1 -0
- package/cdn/chunks/chunk-KM5SOM7G.js +1482 -0
- package/cdn/chunks/chunk-KP6MWEDW.js +5 -0
- package/cdn/chunks/chunk-KWDCU3P6.js +1482 -0
- package/cdn/chunks/chunk-KY3OKCFK.js +8 -0
- package/cdn/chunks/chunk-KY6SSNGO.js +5 -0
- package/cdn/chunks/chunk-LO2NM3CE.js +1 -0
- package/cdn/chunks/chunk-LS3OPHR4.js +8 -0
- package/cdn/chunks/chunk-M544CJHK.js +5 -0
- package/cdn/chunks/chunk-M5UOISZJ.js +1482 -0
- package/cdn/chunks/chunk-MAPVFADC.js +5 -0
- package/cdn/chunks/chunk-MICRS5DH.js +8 -0
- package/cdn/chunks/chunk-MVGI4SNI.js +17 -0
- package/cdn/chunks/chunk-MYXD4BOJ.js +2 -0
- package/cdn/chunks/chunk-MZRZP33C.js +1 -0
- package/cdn/chunks/chunk-N4LMZHIZ.js +5 -0
- package/cdn/chunks/chunk-NHHA3O6Y.js +1 -0
- package/cdn/chunks/chunk-NJ3OVLBF.js +1 -0
- package/cdn/chunks/chunk-NVZTYSGS.js +1 -0
- package/cdn/chunks/chunk-NXQQIB7Y.js +5 -0
- package/cdn/chunks/chunk-ODYPYZCY.js +5 -0
- package/cdn/chunks/chunk-OENDUEU2.js +5 -0
- package/cdn/chunks/chunk-ON6ISIIV.js +1 -0
- package/cdn/chunks/chunk-OOEY4RSQ.js +1 -0
- package/cdn/chunks/chunk-OUQFWBVG.js +8 -0
- package/cdn/chunks/chunk-P5MQE2M6.js +5 -0
- package/cdn/chunks/chunk-PMYTST5N.js +17 -0
- package/cdn/chunks/chunk-PPSGCGRR.js +8 -0
- package/cdn/chunks/chunk-Q4EENVQD.js +1 -0
- package/cdn/chunks/chunk-Q64V7VQU.js +1 -0
- package/cdn/chunks/chunk-QCDT25GU.js +8 -0
- package/cdn/chunks/chunk-QYCLNTAQ.js +1 -0
- package/cdn/chunks/chunk-RKU2XDKG.js +2 -0
- package/cdn/chunks/chunk-RQSAQ6H4.js +1 -0
- package/cdn/chunks/chunk-RTVTE2XY.js +1482 -0
- package/cdn/chunks/chunk-SBACDLL6.js +73 -0
- package/cdn/chunks/chunk-SVVO2SFS.js +1 -0
- package/cdn/chunks/chunk-SVWD3DJK.js +1 -0
- package/cdn/chunks/chunk-TOK64KBR.js +5 -0
- package/cdn/chunks/chunk-V2NH5MXS.js +5 -0
- package/cdn/chunks/chunk-V3EJROZX.js +3649 -0
- package/cdn/chunks/chunk-VB3GRBCX.js +1 -0
- package/cdn/chunks/chunk-VNZCEVYY.js +24 -0
- package/cdn/chunks/chunk-VUJWHOI6.js +1482 -0
- package/cdn/chunks/chunk-WOKUXDJR.js +8 -0
- package/cdn/chunks/chunk-WPXZSIUM.js +5 -0
- package/cdn/chunks/chunk-WTUHCDEZ.js +10 -0
- package/cdn/chunks/chunk-X4FA36TC.js +1 -0
- package/cdn/chunks/chunk-XA25EXKN.js +1 -0
- package/cdn/chunks/chunk-XBLYTLX6.js +5 -0
- package/cdn/chunks/chunk-XH36X5UJ.js +1482 -0
- package/cdn/chunks/chunk-XHSJOTCJ.js +5 -0
- package/cdn/chunks/chunk-XJ2CFTZP.js +1 -0
- package/cdn/chunks/chunk-XLFLYMNJ.js +1482 -0
- package/cdn/chunks/chunk-XYWB7S55.js +1482 -0
- package/cdn/chunks/chunk-Y3BICHQ5.js +6 -0
- package/cdn/chunks/chunk-YEK2E3FB.js +8 -0
- package/cdn/chunks/chunk-YIRZSKIP.js +2 -0
- package/cdn/chunks/chunk-YM5QNYGZ.js +5 -0
- package/cdn/chunks/chunk-YOTJAW26.js +6 -0
- package/cdn/chunks/chunk-Z7KIJX7V.js +1482 -0
- package/cdn/chunks/chunk-ZCQFKXZ3.js +48 -0
- package/cdn/chunks/chunk-ZKOKGZBL.js +5 -0
- package/cdn/exports/computed-item.context.js +1 -1
- package/cdn/exports/computed.context.js +1 -1
- package/cdn/exports/config.context.js +1 -1
- package/cdn/exports/interaction.js +1 -1
- package/cdn/exports/item.context.js +1 -1
- package/cdn/exports/qti-assessment-item.context.js +1 -1
- package/cdn/exports/qti-condition-expression.js +1 -1
- package/cdn/exports/qti-expression.js +1 -1
- package/cdn/exports/qti.context.js +1 -0
- package/cdn/exports/session.context.js +1 -1
- package/cdn/exports/test.context.js +1 -1
- package/cdn/index.global.js +1 -1
- package/cdn/index.js +1 -1
- package/cdn/qti-components/index.js +1 -1
- package/cdn/qti-item/components/item-container.js +1 -1
- package/cdn/qti-item/components/item-correct-response-mode.js +10 -0
- package/cdn/qti-item/components/item-show-candidate-correction.js +8 -0
- package/cdn/qti-item/components/item-show-correct-response.js +1 -1
- package/cdn/qti-item/components/print-item-variables.js +1 -1
- package/cdn/qti-item/components/styles.js +1 -1
- package/cdn/qti-item/core/index.js +1 -1
- package/cdn/qti-loader/index.js +1 -1
- package/cdn/qti-test/components/index.js +1 -1
- package/cdn/qti-test/components/styles.js +1 -1
- package/cdn/qti-test/components/test-check-item.js +1 -1
- package/cdn/qti-test/components/test-container.js +1 -1
- package/cdn/qti-test/components/test-end-attempt.js +1 -1
- package/cdn/qti-test/components/test-item-link.js +1 -1
- package/cdn/qti-test/components/test-navigation.js +1 -1
- package/cdn/qti-test/components/test-next.js +1 -1
- package/cdn/qti-test/components/test-paging-buttons-stamp.js +1 -1
- package/cdn/qti-test/components/test-prev.js +1 -1
- package/cdn/qti-test/components/test-print-context.js +1 -1
- package/cdn/qti-test/components/test-print-item-variables.js +1 -1
- package/cdn/qti-test/components/test-scoring-buttons.js +1 -1
- package/cdn/qti-test/components/test-scoring-feedback.js +1 -1
- package/cdn/qti-test/components/test-section-buttons-stamp.js +1 -1
- package/cdn/qti-test/components/test-section-link.js +1 -1
- package/cdn/qti-test/components/test-show-correct-response.js +1 -1
- package/cdn/qti-test/components/test-stamp.js +1 -1
- package/cdn/qti-test/components/test-view-toggle.js +1 -1
- package/cdn/qti-test/components/test-view.js +1 -1
- package/cdn/qti-test/core/index.js +1 -1
- package/cdn/qti-transformers/index.js +1 -1
- package/dist/chunks/chunk-2EGQQQHL.js +31 -0
- package/dist/chunks/chunk-2EGQQQHL.js.map +1 -0
- package/dist/chunks/chunk-32TQEF77.js +142 -0
- package/dist/chunks/chunk-32TQEF77.js.map +1 -0
- package/dist/chunks/chunk-34THNRGC.js +8093 -0
- package/dist/chunks/chunk-34THNRGC.js.map +1 -0
- package/dist/chunks/chunk-3O3BVPXQ.js +8655 -0
- package/dist/chunks/chunk-3O3BVPXQ.js.map +1 -0
- package/dist/chunks/chunk-3SABVS4P.js +19 -0
- package/dist/chunks/chunk-3SABVS4P.js.map +1 -0
- package/dist/chunks/chunk-45FDEM7M.js +94 -0
- package/dist/chunks/chunk-45FDEM7M.js.map +1 -0
- package/dist/chunks/chunk-4A6SHFWN.js +8093 -0
- package/dist/chunks/chunk-4A6SHFWN.js.map +1 -0
- package/dist/chunks/chunk-4B4DRCXO.js +94 -0
- package/dist/chunks/chunk-4B4DRCXO.js.map +1 -0
- package/dist/chunks/chunk-4D3G23AV.js +94 -0
- package/dist/chunks/chunk-4D3G23AV.js.map +1 -0
- package/dist/chunks/chunk-565QP4OA.js +94 -0
- package/dist/chunks/chunk-565QP4OA.js.map +1 -0
- package/dist/chunks/chunk-5IYIGX6A.js +94 -0
- package/dist/chunks/chunk-5IYIGX6A.js.map +1 -0
- package/dist/chunks/chunk-5MAENJ2J.js +913 -0
- package/dist/chunks/chunk-5MAENJ2J.js.map +1 -0
- package/dist/chunks/chunk-6EQ4U5EP.js +142 -0
- package/dist/chunks/chunk-6EQ4U5EP.js.map +1 -0
- package/dist/chunks/chunk-6NLDLAQA.js +367 -0
- package/dist/chunks/chunk-6NLDLAQA.js.map +1 -0
- package/dist/chunks/chunk-6OB2U3VU.js +287 -0
- package/dist/chunks/chunk-6OB2U3VU.js.map +1 -0
- package/dist/chunks/chunk-7XIK3UQX.js +3628 -0
- package/dist/chunks/chunk-7XIK3UQX.js.map +1 -0
- package/dist/chunks/chunk-7Z7KA2QQ.js +142 -0
- package/dist/chunks/chunk-7Z7KA2QQ.js.map +1 -0
- package/dist/chunks/chunk-AH3ZDQHQ.js +913 -0
- package/dist/chunks/chunk-AH3ZDQHQ.js.map +1 -0
- package/dist/chunks/chunk-AVMYQQT2.js +94 -0
- package/dist/chunks/chunk-AVMYQQT2.js.map +1 -0
- package/dist/chunks/chunk-B2IUQFUU.js +913 -0
- package/dist/chunks/chunk-B2IUQFUU.js.map +1 -0
- package/dist/chunks/chunk-B2O3YM5H.js +8093 -0
- package/dist/chunks/chunk-B2O3YM5H.js.map +1 -0
- package/dist/chunks/chunk-BAZMB7Z3.js +8009 -0
- package/dist/chunks/chunk-BAZMB7Z3.js.map +1 -0
- package/dist/chunks/chunk-BXUNJ6XB.js +78 -0
- package/dist/chunks/chunk-BXUNJ6XB.js.map +1 -0
- package/dist/chunks/chunk-CTESMSQO.js +56 -0
- package/dist/chunks/chunk-CTESMSQO.js.map +1 -0
- package/dist/chunks/chunk-CVMIO3DA.js +913 -0
- package/dist/chunks/chunk-CVMIO3DA.js.map +1 -0
- package/dist/chunks/chunk-D2VLZ4I5.js +8755 -0
- package/dist/chunks/chunk-D2VLZ4I5.js.map +1 -0
- package/dist/chunks/chunk-DDSFGYAK.js +913 -0
- package/dist/chunks/chunk-DDSFGYAK.js.map +1 -0
- package/dist/chunks/chunk-DJUWVE3Q.js +8655 -0
- package/dist/chunks/chunk-DJUWVE3Q.js.map +1 -0
- package/dist/chunks/chunk-DJWEI2NH.js +502 -0
- package/dist/chunks/chunk-DJWEI2NH.js.map +1 -0
- package/dist/chunks/chunk-DPJNXSTI.js +19 -0
- package/dist/chunks/chunk-DPJNXSTI.js.map +1 -0
- package/dist/chunks/chunk-E6V3JHVT.js +31 -0
- package/dist/chunks/chunk-E6V3JHVT.js.map +1 -0
- package/dist/chunks/chunk-E7DT7SMT.js +8655 -0
- package/dist/chunks/chunk-E7DT7SMT.js.map +1 -0
- package/dist/chunks/chunk-EBODGAT7.js +113 -0
- package/dist/chunks/chunk-EBODGAT7.js.map +1 -0
- package/dist/chunks/chunk-EFY3NEXY.js +94 -0
- package/dist/chunks/chunk-EFY3NEXY.js.map +1 -0
- package/dist/chunks/chunk-EMOJR4QG.js +913 -0
- package/dist/chunks/chunk-EMOJR4QG.js.map +1 -0
- package/dist/chunks/chunk-EXBK4TXV.js +273 -0
- package/dist/chunks/chunk-EXBK4TXV.js.map +1 -0
- package/dist/chunks/chunk-F6RSPPVW.js +94 -0
- package/dist/chunks/chunk-F6RSPPVW.js.map +1 -0
- package/dist/chunks/chunk-FXO6HW6L.js +8084 -0
- package/dist/chunks/chunk-FXO6HW6L.js.map +1 -0
- package/dist/chunks/chunk-GFCOR6TX.js +146 -0
- package/dist/chunks/chunk-GFCOR6TX.js.map +1 -0
- package/dist/chunks/chunk-GIY6GNXQ.js +913 -0
- package/dist/chunks/chunk-GIY6GNXQ.js.map +1 -0
- package/dist/chunks/chunk-GMXDW4I3.js +913 -0
- package/dist/chunks/chunk-GMXDW4I3.js.map +1 -0
- package/dist/chunks/chunk-GQUBYVP3.js +913 -0
- package/dist/chunks/chunk-GQUBYVP3.js.map +1 -0
- package/dist/chunks/chunk-GT6TR4B6.js +94 -0
- package/dist/chunks/chunk-GT6TR4B6.js.map +1 -0
- package/dist/chunks/chunk-H67RKRFW.js +94 -0
- package/dist/chunks/chunk-H67RKRFW.js.map +1 -0
- package/dist/chunks/chunk-H6KHXSIO.js +8 -0
- package/dist/chunks/chunk-H6KHXSIO.js.map +1 -0
- package/dist/chunks/chunk-HEP5QRPW.js +94 -0
- package/dist/chunks/chunk-HEP5QRPW.js.map +1 -0
- package/dist/chunks/chunk-HYMSLOZ7.js +103 -0
- package/dist/chunks/chunk-HYMSLOZ7.js.map +1 -0
- package/dist/chunks/chunk-I5EA6DJB.js +92 -0
- package/dist/chunks/chunk-I5EA6DJB.js.map +1 -0
- package/dist/chunks/chunk-IAEGLQ4C.js +144 -0
- package/dist/chunks/chunk-IAEGLQ4C.js.map +1 -0
- package/dist/chunks/chunk-J2HZTWER.js +8093 -0
- package/dist/chunks/chunk-J2HZTWER.js.map +1 -0
- package/dist/chunks/chunk-JARLFKS7.js +913 -0
- package/dist/chunks/chunk-JARLFKS7.js.map +1 -0
- package/dist/chunks/chunk-JATNQ3KB.js +913 -0
- package/dist/chunks/chunk-JATNQ3KB.js.map +1 -0
- package/dist/chunks/chunk-KCTFNJO4.js +8748 -0
- package/dist/chunks/chunk-KCTFNJO4.js.map +1 -0
- package/dist/chunks/chunk-KJQYKXDV.js +173 -0
- package/dist/chunks/chunk-KJQYKXDV.js.map +1 -0
- package/dist/chunks/chunk-KXVYWSJU.js +8068 -0
- package/dist/chunks/chunk-KXVYWSJU.js.map +1 -0
- package/dist/chunks/chunk-LU5A5PN5.js +8084 -0
- package/dist/chunks/chunk-LU5A5PN5.js.map +1 -0
- package/dist/chunks/chunk-LUZGWGSR.js +913 -0
- package/dist/chunks/chunk-LUZGWGSR.js.map +1 -0
- package/dist/chunks/chunk-MI7IF36Z.js +367 -0
- package/dist/chunks/chunk-MI7IF36Z.js.map +1 -0
- package/dist/chunks/chunk-MOBVIJE2.js +913 -0
- package/dist/chunks/chunk-MOBVIJE2.js.map +1 -0
- package/dist/chunks/chunk-NBENQI27.js +273 -0
- package/dist/chunks/chunk-NBENQI27.js.map +1 -0
- package/dist/chunks/chunk-NEAO4XCM.js +913 -0
- package/dist/chunks/chunk-NEAO4XCM.js.map +1 -0
- package/dist/chunks/chunk-NJ5O743W.js +311 -0
- package/dist/chunks/chunk-NJ5O743W.js.map +1 -0
- package/dist/chunks/chunk-NMQ4USN7.js +913 -0
- package/dist/chunks/chunk-NMQ4USN7.js.map +1 -0
- package/dist/chunks/chunk-NPZ3WHOS.js +94 -0
- package/dist/chunks/chunk-NPZ3WHOS.js.map +1 -0
- package/dist/chunks/chunk-NRKCQIQS.js +8 -0
- package/dist/chunks/chunk-NRKCQIQS.js.map +1 -0
- package/dist/chunks/chunk-NRNSOUTF.js +913 -0
- package/dist/chunks/chunk-NRNSOUTF.js.map +1 -0
- package/dist/chunks/chunk-OBAABB63.js +8093 -0
- package/dist/chunks/chunk-OBAABB63.js.map +1 -0
- package/dist/chunks/chunk-OGAKPUCC.js +502 -0
- package/dist/chunks/chunk-OGAKPUCC.js.map +1 -0
- package/dist/chunks/chunk-OREGQJ7H.js +19 -0
- package/dist/chunks/chunk-OREGQJ7H.js.map +1 -0
- package/dist/chunks/chunk-RJZ4D6XM.js +88 -0
- package/dist/chunks/chunk-RJZ4D6XM.js.map +1 -0
- package/dist/chunks/chunk-RL3NBBKW.js +913 -0
- package/dist/chunks/chunk-RL3NBBKW.js.map +1 -0
- package/dist/chunks/chunk-S72IAWSO.js +8770 -0
- package/dist/chunks/chunk-S72IAWSO.js.map +1 -0
- package/dist/chunks/chunk-SDN2PXF7.js +94 -0
- package/dist/chunks/chunk-SDN2PXF7.js.map +1 -0
- package/dist/chunks/chunk-SRJF5RCP.js +8772 -0
- package/dist/chunks/chunk-SRJF5RCP.js.map +1 -0
- package/dist/chunks/chunk-SV356YP4.js +31 -0
- package/dist/chunks/chunk-SV356YP4.js.map +1 -0
- package/dist/chunks/chunk-TBHIUG43.js +19 -0
- package/dist/chunks/chunk-TBHIUG43.js.map +1 -0
- package/dist/chunks/chunk-TDIRV53C.js +3626 -0
- package/dist/chunks/chunk-TDIRV53C.js.map +1 -0
- package/dist/chunks/chunk-TJNZKBEN.js +88 -0
- package/dist/chunks/chunk-TJNZKBEN.js.map +1 -0
- package/dist/chunks/chunk-TU6COU44.js +82 -0
- package/dist/chunks/chunk-TU6COU44.js.map +1 -0
- package/dist/chunks/chunk-UHQVQBCL.js +89 -0
- package/dist/chunks/chunk-UHQVQBCL.js.map +1 -0
- package/dist/chunks/chunk-V7DSDBTC.js +142 -0
- package/dist/chunks/chunk-V7DSDBTC.js.map +1 -0
- package/dist/chunks/chunk-VCFCYQB4.js +315 -0
- package/dist/chunks/chunk-VCFCYQB4.js.map +1 -0
- package/dist/chunks/chunk-VEASE2VL.js +913 -0
- package/dist/chunks/chunk-VEASE2VL.js.map +1 -0
- package/dist/chunks/chunk-VHSCCVNF.js +8024 -0
- package/dist/chunks/chunk-VHSCCVNF.js.map +1 -0
- package/dist/chunks/chunk-VRR4ODZY.js +8009 -0
- package/dist/chunks/chunk-VRR4ODZY.js.map +1 -0
- package/dist/chunks/chunk-WFUXZ4UT.js +502 -0
- package/dist/chunks/chunk-WFUXZ4UT.js.map +1 -0
- package/dist/chunks/chunk-WUSKUUQL.js +3639 -0
- package/dist/chunks/chunk-WUSKUUQL.js.map +1 -0
- package/dist/chunks/chunk-WVB7FS2F.js +913 -0
- package/dist/chunks/chunk-WVB7FS2F.js.map +1 -0
- package/dist/chunks/chunk-WY5BKP4C.js +19 -0
- package/dist/chunks/chunk-WY5BKP4C.js.map +1 -0
- package/dist/chunks/chunk-XFJJETQG.js +913 -0
- package/dist/chunks/chunk-XFJJETQG.js.map +1 -0
- package/dist/chunks/chunk-XNMAPACM.js +19 -0
- package/dist/chunks/chunk-XNMAPACM.js.map +1 -0
- package/dist/chunks/chunk-Y2DMMGRW.js +8657 -0
- package/dist/chunks/chunk-Y2DMMGRW.js.map +1 -0
- package/dist/chunks/chunk-Y3UM2YVB.js +8025 -0
- package/dist/chunks/chunk-Y3UM2YVB.js.map +1 -0
- package/dist/chunks/chunk-Y4DXEVZM.js +8770 -0
- package/dist/chunks/chunk-Y4DXEVZM.js.map +1 -0
- package/dist/chunks/chunk-Y4VJXTG5.js +8754 -0
- package/dist/chunks/chunk-Y4VJXTG5.js.map +1 -0
- package/dist/chunks/chunk-YFTXNRNZ.js +913 -0
- package/dist/chunks/chunk-YFTXNRNZ.js.map +1 -0
- package/dist/chunks/chunk-YRVKKM47.js +365 -0
- package/dist/chunks/chunk-YRVKKM47.js.map +1 -0
- package/dist/chunks/chunk-YWEWSQJR.js +40 -0
- package/dist/chunks/chunk-YWEWSQJR.js.map +1 -0
- package/dist/chunks/chunk-Z3PFCZLH.js +913 -0
- package/dist/chunks/chunk-Z3PFCZLH.js.map +1 -0
- package/dist/chunks/chunk-ZB27F2HA.js +366 -0
- package/dist/chunks/chunk-ZB27F2HA.js.map +1 -0
- package/dist/exports/computed-item.context.d.ts +2 -1
- package/dist/exports/computed.context.d.ts +3 -2
- package/dist/exports/config.context.d.ts +3 -1
- package/dist/exports/config.context.js +1 -1
- package/dist/exports/expression-result.d.ts +2 -2
- package/dist/exports/interaction.d.ts +2 -1
- package/dist/exports/interaction.js +2 -1
- package/dist/exports/item.context.d.ts +2 -1
- package/dist/exports/qti-assessment-item.context.d.ts +2 -1
- package/dist/exports/qti-condition-expression.d.ts +2 -1
- package/dist/exports/qti-condition-expression.js +3 -2
- package/dist/exports/qti-expression.d.ts +2 -1
- package/dist/exports/qti-expression.js +2 -1
- package/dist/exports/qti-test.d.ts +4 -3
- package/dist/exports/qti.context.d.ts +14 -0
- package/dist/exports/qti.context.js +8 -0
- package/dist/exports/qti.context.js.map +1 -0
- package/dist/exports/session.context.d.ts +3 -2
- package/dist/exports/test.context.d.ts +2 -1
- package/dist/exports/variables.d.ts +2 -1
- package/dist/index.d.ts +5 -4
- package/dist/index.js +76 -56
- package/dist/item.css +28 -16
- package/dist/qti-components/index.d.ts +146 -3
- package/dist/qti-components/index.js +29 -7
- package/dist/qti-components-jsx.d.ts +3777 -1467
- package/dist/qti-item/components/item-container.js +3 -3
- package/dist/qti-item/components/item-correct-response-mode.d.ts +17 -0
- package/dist/qti-item/components/item-correct-response-mode.js +62 -0
- package/dist/qti-item/components/item-correct-response-mode.js.map +1 -0
- package/dist/qti-item/components/item-show-candidate-correction.d.ts +33 -0
- package/dist/qti-item/components/item-show-candidate-correction.js +88 -0
- package/dist/qti-item/components/item-show-candidate-correction.js.map +1 -0
- package/dist/qti-item/components/item-show-correct-response.d.ts +2 -1
- package/dist/qti-item/components/item-show-correct-response.js +1 -1
- package/dist/qti-item/components/print-item-variables.d.ts +2 -1
- package/dist/qti-item/core/index.d.ts +10 -3
- package/dist/qti-item/core/index.js +8 -7
- package/dist/qti-loader/index.d.ts +2 -1
- package/dist/qti-loader/index.js +2 -2
- package/dist/qti-response-declaration-B7a6N0wt.d.ts +1380 -0
- package/dist/qti-response-declaration-BTiPhwZv.d.ts +1370 -0
- package/dist/qti-response-declaration-Bthfzhwd.d.ts +1385 -0
- package/dist/qti-response-declaration-CIPGNbno.d.ts +1361 -0
- package/dist/qti-response-declaration-CNP03Vcb.d.ts +1386 -0
- package/dist/qti-response-declaration-CTRNB113.d.ts +1385 -0
- package/dist/qti-response-declaration-CXb5CI4-.d.ts +1361 -0
- package/dist/qti-response-declaration-Cbj7E4ND.d.ts +1372 -0
- package/dist/qti-response-declaration-DRNG6zLy.d.ts +1370 -0
- package/dist/qti-response-declaration-DuRT3sKx.d.ts +1380 -0
- package/dist/qti-response-declaration-GPP3SVur.d.ts +1372 -0
- package/dist/qti-response-declaration-xVcD4HvN.d.ts +1386 -0
- package/dist/qti-test/components/index.d.ts +3 -2
- package/dist/qti-test/components/index.js +33 -33
- package/dist/qti-test/components/test-container.js +3 -3
- package/dist/qti-test/components/test-navigation.d.ts +16 -3
- package/dist/qti-test/components/test-navigation.js +3 -2
- package/dist/qti-test/components/test-next.d.ts +3 -2
- package/dist/qti-test/components/test-next.js +1 -2
- package/dist/qti-test/components/test-prev.d.ts +3 -2
- package/dist/qti-test/components/test-prev.js +1 -2
- package/dist/qti-test/components/test-print-context.d.ts +3 -2
- package/dist/qti-test/components/test-print-item-variables.d.ts +3 -2
- package/dist/qti-test/components/test-scoring-buttons.d.ts +3 -2
- package/dist/qti-test/components/test-scoring-buttons.js +1 -1
- package/dist/qti-test/components/test-scoring-feedback.d.ts +3 -2
- package/dist/qti-test/components/test-scoring-feedback.js +1 -1
- package/dist/qti-test/components/test-show-correct-response.d.ts +3 -2
- package/dist/qti-test/components/test-view.js +2 -2
- package/dist/qti-test/core/index.d.ts +4 -3
- package/dist/qti-test/core/index.js +11 -10
- package/dist/qti-test-feedback-B0W2B5wQ.d.ts +91 -0
- package/dist/qti-test-feedback-B1kTnqnI.d.ts +91 -0
- package/dist/qti-test-feedback-BAUInn-q.d.ts +91 -0
- package/dist/qti-test-feedback-BWerRaNG.d.ts +91 -0
- package/dist/qti-test-feedback-BXdbgpY8.d.ts +91 -0
- package/dist/qti-test-feedback-Bbt2VWE1.d.ts +91 -0
- package/dist/qti-test-feedback-C-PQYZWl.d.ts +91 -0
- package/dist/qti-test-feedback-CuTA6S46.d.ts +91 -0
- package/dist/qti-test-feedback-DUxJARNH.d.ts +91 -0
- package/dist/qti-test-feedback-Ddb0QQyz.d.ts +91 -0
- package/dist/qti-test-feedback-SkEfQjOR.d.ts +91 -0
- package/dist/qti-test-feedback-TcrkevLg.d.ts +91 -0
- package/dist/qti-transformers/index.d.ts +17 -1
- package/dist/qti-transformers/index.js +1 -1
- package/dist/vscode.html-custom-data.json +162 -39
- 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":[]}
|