@citolab/qti-components 7.1.0 → 7.1.2
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-27WPPEWB.js +1 -0
- package/cdn/chunks/chunk-2HL3OFY7.js +1 -0
- package/cdn/chunks/chunk-33UT2QKP.js +5 -0
- package/cdn/chunks/chunk-3M3VWZCU.js +8 -0
- package/cdn/chunks/chunk-3QAOJL7Y.js +1007 -0
- package/cdn/chunks/chunk-3R4ZTZYA.js +5 -0
- package/cdn/chunks/chunk-6DWYLZ5E.js +5 -0
- package/cdn/chunks/chunk-6RVWXAM7.js +8 -0
- package/cdn/chunks/chunk-7HXSSTSU.js +1 -0
- package/cdn/chunks/chunk-7JXSJZV5.js +8 -0
- package/cdn/chunks/chunk-7QMIMK5V.js +5 -0
- package/cdn/chunks/chunk-7RLNGBXK.js +1 -0
- package/cdn/chunks/chunk-AHZ3W4YP.js +8 -0
- package/cdn/chunks/chunk-BGHD6LZP.js +1007 -0
- package/cdn/chunks/chunk-C73FEG6J.js +1 -0
- package/cdn/chunks/chunk-CFS5WXCD.js +1 -0
- package/cdn/chunks/chunk-CZDMOYYF.js +1 -0
- package/cdn/chunks/chunk-EBVKDAVL.js +5 -0
- package/cdn/chunks/chunk-EEFB2V7Q.js +27 -0
- package/cdn/chunks/chunk-ELZQC26E.js +5 -0
- package/cdn/chunks/chunk-EPOG3VSF.js +5 -0
- package/cdn/chunks/chunk-FDKTSUOQ.js +48 -0
- package/cdn/chunks/chunk-FJOHSSA3.js +1 -0
- package/cdn/chunks/chunk-G5YNM432.js +5 -0
- package/cdn/chunks/chunk-GIJVMMKY.js +1007 -0
- package/cdn/chunks/chunk-GNIERKRX.js +1007 -0
- package/cdn/chunks/chunk-GTHARXCW.js +10 -0
- package/cdn/chunks/chunk-IRLG6H7G.js +1 -0
- package/cdn/chunks/chunk-J3F2YSRA.js +1007 -0
- package/cdn/chunks/chunk-J4ISS5TZ.js +5 -0
- package/cdn/chunks/chunk-KBJYE746.js +5 -0
- package/cdn/chunks/chunk-KIH2VB5Z.js +1 -0
- package/cdn/chunks/chunk-KJJG5SSY.js +1 -0
- package/cdn/chunks/chunk-KLRM2GAU.js +8 -0
- package/cdn/chunks/chunk-KQT5S3DK.js +5 -0
- package/cdn/chunks/chunk-LDKKOMIK.js +3570 -0
- package/cdn/chunks/chunk-LDXZOGPY.js +10 -0
- package/cdn/chunks/chunk-LUVDXKE2.js +5 -0
- package/cdn/chunks/chunk-LZQKENA3.js +1 -0
- package/cdn/chunks/chunk-MGLK2Q6K.js +5 -0
- package/cdn/chunks/chunk-MK2CR5DP.js +1 -0
- package/cdn/chunks/chunk-N5JQAYOR.js +1 -0
- package/cdn/chunks/chunk-NJUBWVY3.js +10 -0
- package/cdn/chunks/chunk-NQKAQ6AU.js +1007 -0
- package/cdn/chunks/chunk-NW5VVFA5.js +5 -0
- package/cdn/chunks/chunk-OYUWBJSX.js +1 -0
- package/cdn/chunks/chunk-PBZODDGJ.js +1 -0
- package/cdn/chunks/chunk-PJFJOZNR.js +48 -0
- package/cdn/chunks/chunk-PMIMCEQ2.js +1 -0
- package/cdn/chunks/chunk-PYOOOJUP.js +3547 -0
- package/cdn/chunks/chunk-Q6HFDDZ4.js +1 -0
- package/cdn/chunks/chunk-QQR6POPY.js +1 -0
- package/cdn/chunks/chunk-QS2LH2IW.js +1007 -0
- package/cdn/chunks/chunk-QUFRWTHS.js +1 -0
- package/cdn/chunks/chunk-RJB5E47I.js +1 -0
- package/cdn/chunks/chunk-SFY52QPM.js +1 -0
- package/cdn/chunks/chunk-SUXBSENJ.js +48 -0
- package/cdn/chunks/chunk-SYO32O6X.js +1 -0
- package/cdn/chunks/chunk-TUWPPE7H.js +1 -0
- package/cdn/chunks/chunk-UHILPQTT.js +10 -0
- package/cdn/chunks/chunk-UOY4MCKX.js +6 -0
- package/cdn/chunks/chunk-VLCD4DFD.js +8 -0
- package/cdn/chunks/chunk-VRTU4ZV6.js +48 -0
- package/cdn/chunks/chunk-VXDODYB5.js +1007 -0
- package/cdn/chunks/chunk-W7GYEQJQ.js +1 -0
- package/cdn/chunks/chunk-WNI2D7SG.js +1 -0
- package/cdn/chunks/chunk-WNJ3YFMW.js +1 -0
- package/cdn/chunks/chunk-WRFAZSRX.js +1007 -0
- package/cdn/chunks/chunk-WTUTTA5R.js +1 -0
- package/cdn/chunks/chunk-WVVKSWZV.js +5 -0
- package/cdn/chunks/chunk-WXFIEBQR.js +0 -0
- package/cdn/chunks/chunk-X75XIXUI.js +10 -0
- package/cdn/chunks/chunk-XPI6OOWN.js +27 -0
- package/cdn/chunks/chunk-YBPCVJIX.js +10 -0
- package/cdn/chunks/chunk-YTSCJPU2.js +1007 -0
- package/cdn/chunks/chunk-YZQZGOYM.js +1 -0
- package/cdn/chunks/chunk-ZHVOZ7WZ.js +1007 -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-test/components/index.js +1 -1
- package/cdn/qti-test/components/test-navigation.js +1 -1
- package/cdn/qti-test/components/test-print-context.js +1 -0
- package/cdn/qti-test/components/test-print-item-variables copy.js +1 -0
- package/cdn/qti-test/components/test-print-item-variables.js +1 -1
- package/cdn/qti-test/components/test-print-item-variables.stories copy.js +233 -0
- package/cdn/qti-test/components/test-print-test-context.js +1 -0
- package/cdn/qti-test/components/test-view.js +1 -1
- package/cdn/qti-test/core/index.js +1 -1
- package/dist/chunks/chunk-2BVFKYAB.js +659 -0
- package/dist/chunks/chunk-2BVFKYAB.js.map +1 -0
- package/dist/chunks/chunk-2RXVRB7Z.js +659 -0
- package/dist/chunks/chunk-2RXVRB7Z.js.map +1 -0
- package/dist/chunks/chunk-2ZTRBYHP.js +660 -0
- package/dist/chunks/chunk-2ZTRBYHP.js.map +1 -0
- package/dist/chunks/chunk-36LEJZEY.js +87 -0
- package/dist/chunks/chunk-36LEJZEY.js.map +1 -0
- package/dist/chunks/chunk-373M5NVS.js +62 -0
- package/dist/chunks/chunk-373M5NVS.js.map +1 -0
- package/dist/chunks/chunk-3DEV5ARX.js +89 -0
- package/dist/chunks/chunk-3DEV5ARX.js.map +1 -0
- package/dist/chunks/chunk-3GCBMXXY.js +62 -0
- package/dist/chunks/chunk-3GCBMXXY.js.map +1 -0
- package/dist/chunks/chunk-3NH5KOQ4.js +89 -0
- package/dist/chunks/chunk-3NH5KOQ4.js.map +1 -0
- package/dist/chunks/chunk-4BDSKOGB.js +6873 -0
- package/dist/chunks/chunk-4BDSKOGB.js.map +1 -0
- package/dist/chunks/chunk-4BIRH5VP.js +99 -0
- package/dist/chunks/chunk-4BIRH5VP.js.map +1 -0
- package/dist/chunks/chunk-4O3EJ3SA.js +3884 -0
- package/dist/chunks/chunk-4O3EJ3SA.js.map +1 -0
- package/dist/chunks/chunk-4Z3IMDB5.js +84 -0
- package/dist/chunks/chunk-4Z3IMDB5.js.map +1 -0
- package/dist/chunks/chunk-6ITJ2I3A.js +82 -0
- package/dist/chunks/chunk-6ITJ2I3A.js.map +1 -0
- package/dist/chunks/chunk-75ZDJN64.js +32 -0
- package/dist/chunks/chunk-75ZDJN64.js.map +1 -0
- package/dist/chunks/chunk-76SJLOAE.js +84 -0
- package/dist/chunks/chunk-76SJLOAE.js.map +1 -0
- package/dist/chunks/chunk-7JS7FRDO.js +89 -0
- package/dist/chunks/chunk-7JS7FRDO.js.map +1 -0
- package/dist/chunks/chunk-7WL6TAJE.js +6872 -0
- package/dist/chunks/chunk-7WL6TAJE.js.map +1 -0
- package/dist/chunks/chunk-AD5H6KYS.js +78 -0
- package/dist/chunks/chunk-AD5H6KYS.js.map +1 -0
- package/dist/chunks/chunk-AQLCQATM.js +62 -0
- package/dist/chunks/chunk-AQLCQATM.js.map +1 -0
- package/dist/chunks/chunk-AWQHFFVL.js +659 -0
- package/dist/chunks/chunk-AWQHFFVL.js.map +1 -0
- package/dist/chunks/chunk-BLUHTHXX.js +6877 -0
- package/dist/chunks/chunk-BLUHTHXX.js.map +1 -0
- package/dist/chunks/chunk-BO6QD3VK.js +27 -0
- package/dist/chunks/chunk-BO6QD3VK.js.map +1 -0
- package/dist/chunks/chunk-BQ22JHXC.js +6877 -0
- package/dist/chunks/chunk-BQ22JHXC.js.map +1 -0
- package/dist/chunks/chunk-BWM6SEM3.js +659 -0
- package/dist/chunks/chunk-BWM6SEM3.js.map +1 -0
- package/dist/chunks/chunk-C2FVCRYJ.js +660 -0
- package/dist/chunks/chunk-C2FVCRYJ.js.map +1 -0
- package/dist/chunks/chunk-CIVMCP3W.js +78 -0
- package/dist/chunks/chunk-CIVMCP3W.js.map +1 -0
- package/dist/chunks/chunk-CJADUWEC.js +10 -0
- package/dist/chunks/chunk-CJADUWEC.js.map +1 -0
- package/dist/chunks/chunk-DCKLAFBL.js +79 -0
- package/dist/chunks/chunk-DCKLAFBL.js.map +1 -0
- package/dist/chunks/chunk-EHRC7LG6.js +3638 -0
- package/dist/chunks/chunk-EHRC7LG6.js.map +1 -0
- package/dist/chunks/chunk-ELXD2ZSR.js +218 -0
- package/dist/chunks/chunk-ELXD2ZSR.js.map +1 -0
- package/dist/chunks/chunk-EQUEIZJL.js +27 -0
- package/dist/chunks/chunk-EQUEIZJL.js.map +1 -0
- package/dist/chunks/chunk-EREPAU3B.js +80 -0
- package/dist/chunks/chunk-EREPAU3B.js.map +1 -0
- package/dist/chunks/chunk-EXOIDEQ6.js +660 -0
- package/dist/chunks/chunk-EXOIDEQ6.js.map +1 -0
- package/dist/chunks/chunk-FFF7WZJF.js +33 -0
- package/dist/chunks/chunk-FFF7WZJF.js.map +1 -0
- package/dist/chunks/chunk-FJJMZEPV.js +95 -0
- package/dist/chunks/chunk-FJJMZEPV.js.map +1 -0
- package/dist/chunks/chunk-G5DLHZE2.js +659 -0
- package/dist/chunks/chunk-G5DLHZE2.js.map +1 -0
- package/dist/chunks/chunk-HD63HGFY.js +52 -0
- package/dist/chunks/chunk-HD63HGFY.js.map +1 -0
- package/dist/chunks/chunk-HUKKTEBP.js +99 -0
- package/dist/chunks/chunk-HUKKTEBP.js.map +1 -0
- package/dist/chunks/chunk-HXGGGOV2.js +86 -0
- package/dist/chunks/chunk-HXGGGOV2.js.map +1 -0
- package/dist/chunks/chunk-HZYAIUVZ.js +6872 -0
- package/dist/chunks/chunk-HZYAIUVZ.js.map +1 -0
- package/dist/chunks/chunk-IT744RXI.js +75 -0
- package/dist/chunks/chunk-IT744RXI.js.map +1 -0
- package/dist/chunks/chunk-IXVOEGNZ.js +87 -0
- package/dist/chunks/chunk-IXVOEGNZ.js.map +1 -0
- package/dist/chunks/chunk-JEM74SR3.js +85 -0
- package/dist/chunks/chunk-JEM74SR3.js.map +1 -0
- package/dist/chunks/chunk-JP22YLJ6.js +219 -0
- package/dist/chunks/chunk-JP22YLJ6.js.map +1 -0
- package/dist/chunks/chunk-JVGOS45U.js +660 -0
- package/dist/chunks/chunk-JVGOS45U.js.map +1 -0
- package/dist/chunks/chunk-JWVGRAWQ.js +6872 -0
- package/dist/chunks/chunk-JWVGRAWQ.js.map +1 -0
- package/dist/chunks/chunk-JWX6ZOZ6.js +86 -0
- package/dist/chunks/chunk-JWX6ZOZ6.js.map +1 -0
- package/dist/chunks/chunk-JZMZLOTW.js +32 -0
- package/dist/chunks/chunk-JZMZLOTW.js.map +1 -0
- package/dist/chunks/chunk-KS3SCUUO.js +92 -0
- package/dist/chunks/chunk-KS3SCUUO.js.map +1 -0
- package/dist/chunks/chunk-LOPCNZ26.js +95 -0
- package/dist/chunks/chunk-LOPCNZ26.js.map +1 -0
- package/dist/chunks/chunk-LSNOL7NJ.js +6872 -0
- package/dist/chunks/chunk-LSNOL7NJ.js.map +1 -0
- package/dist/chunks/chunk-M4E2ACHZ.js +75 -0
- package/dist/chunks/chunk-M4E2ACHZ.js.map +1 -0
- package/dist/chunks/chunk-MQS7RZFR.js +85 -0
- package/dist/chunks/chunk-MQS7RZFR.js.map +1 -0
- package/dist/chunks/chunk-N3JFTFIL.js +79 -0
- package/dist/chunks/chunk-N3JFTFIL.js.map +1 -0
- package/dist/chunks/chunk-OSMLF3OH.js +6868 -0
- package/dist/chunks/chunk-OSMLF3OH.js.map +1 -0
- package/dist/chunks/chunk-OWWUE3LK.js +660 -0
- package/dist/chunks/chunk-OWWUE3LK.js.map +1 -0
- package/dist/chunks/chunk-P36CLOLO.js +27 -0
- package/dist/chunks/chunk-P36CLOLO.js.map +1 -0
- package/dist/chunks/chunk-PL32YWZA.js +30 -0
- package/dist/chunks/chunk-PL32YWZA.js.map +1 -0
- package/dist/chunks/chunk-Q5JLRHTY.js +659 -0
- package/dist/chunks/chunk-Q5JLRHTY.js.map +1 -0
- package/dist/chunks/chunk-RB227QQP.js +659 -0
- package/dist/chunks/chunk-RB227QQP.js.map +1 -0
- package/dist/chunks/chunk-TC5ZLAPV.js +218 -0
- package/dist/chunks/chunk-TC5ZLAPV.js.map +1 -0
- package/dist/chunks/chunk-TRSEENUK.js +45 -0
- package/dist/chunks/chunk-TRSEENUK.js.map +1 -0
- package/dist/chunks/chunk-U7VUCT7D.js +659 -0
- package/dist/chunks/chunk-U7VUCT7D.js.map +1 -0
- package/dist/chunks/chunk-UEX52I7G.js +1 -0
- package/dist/chunks/chunk-UEX52I7G.js.map +1 -0
- package/dist/chunks/chunk-UFRDMBKM.js +43 -0
- package/dist/chunks/chunk-UFRDMBKM.js.map +1 -0
- package/dist/chunks/chunk-USJXIVR4.js +6872 -0
- package/dist/chunks/chunk-USJXIVR4.js.map +1 -0
- package/dist/chunks/chunk-UZ4QB5IO.js +10 -0
- package/dist/chunks/chunk-UZ4QB5IO.js.map +1 -0
- package/dist/chunks/chunk-V2EYNAG4.js +659 -0
- package/dist/chunks/chunk-V2EYNAG4.js.map +1 -0
- package/dist/chunks/chunk-WJBYWKIF.js +32 -0
- package/dist/chunks/chunk-WJBYWKIF.js.map +1 -0
- package/dist/chunks/chunk-WOVQFPIV.js +6872 -0
- package/dist/chunks/chunk-WOVQFPIV.js.map +1 -0
- package/dist/chunks/chunk-WPUMEBSF.js +33 -0
- package/dist/chunks/chunk-WPUMEBSF.js.map +1 -0
- package/dist/chunks/chunk-WVVYYP6F.js +218 -0
- package/dist/chunks/chunk-WVVYYP6F.js.map +1 -0
- package/dist/chunks/chunk-XSHHCMRC.js +217 -0
- package/dist/chunks/chunk-XSHHCMRC.js.map +1 -0
- package/dist/chunks/chunk-XZTGFLMB.js +6872 -0
- package/dist/chunks/chunk-XZTGFLMB.js.map +1 -0
- package/dist/chunks/chunk-ZBMTSE6Q.js +660 -0
- package/dist/chunks/chunk-ZBMTSE6Q.js.map +1 -0
- package/dist/chunks/chunk-ZMTMIG3C.js +77 -0
- package/dist/chunks/chunk-ZMTMIG3C.js.map +1 -0
- package/dist/chunks/chunk-ZSR4X4I6.js +638 -0
- package/dist/chunks/chunk-ZSR4X4I6.js.map +1 -0
- package/dist/exports/interaction.js +1 -1
- package/dist/exports/session.context.d.ts +1 -1
- package/dist/exports/session.context.js +3 -1
- package/dist/exports/test.context.d.ts +2 -1
- package/dist/exports/test.context.js +3 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.js +20 -12
- package/dist/qti-components/index.js +2 -2
- package/dist/qti-components-jsx.d.ts +35 -2
- package/dist/qti-response-declaration-5PnLgbOQ.d.ts +1143 -0
- package/dist/qti-response-declaration-PJkGU8F8.d.ts +1151 -0
- package/dist/qti-test/components/index.d.ts +2 -1
- package/dist/qti-test/components/index.js +13 -9
- package/dist/qti-test/components/test-navigation.d.ts +1 -1
- package/dist/qti-test/components/test-navigation.js +3 -3
- package/dist/qti-test/components/test-print-context.d.ts +20 -0
- package/dist/qti-test/components/test-print-context.js +9 -0
- package/dist/qti-test/components/test-print-context.js.map +1 -0
- package/dist/qti-test/components/test-print-item-variables copy.js +86 -0
- package/dist/qti-test/components/test-print-item-variables copy.js.map +1 -0
- package/dist/qti-test/components/test-print-item-variables.d.ts +2 -2
- package/dist/qti-test/components/test-print-item-variables.js +1 -1
- package/dist/qti-test/components/test-print-item-variables.stories copy.js +9731 -0
- package/dist/qti-test/components/test-print-item-variables.stories copy.js.map +1 -0
- package/dist/qti-test/components/test-print-test-context.js +86 -0
- package/dist/qti-test/components/test-print-test-context.js.map +1 -0
- package/dist/qti-test/components/test-view.js +2 -2
- package/dist/qti-test/core/index.d.ts +3 -3
- package/dist/qti-test/core/index.js +15 -3
- package/dist/qti-test-feedback-BuFBq7JH.d.ts +97 -0
- package/dist/qti-test-feedback-CZsPCqSt.d.ts +97 -0
- package/dist/qti-test-feedback-CaNdRC7L.d.ts +96 -0
- package/dist/qti-test-part-BIeEZIWw.d.ts +85 -0
- package/dist/qti-test-part-C_jSX7Zz.d.ts +85 -0
- package/dist/vscode.html-custom-data.json +17 -6
- package/package.json +1 -1
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import {
|
|
2
|
+
__decorateClass
|
|
3
|
+
} from "./chunk-H2JE6IVU.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/exports/interaction.ts
|
|
6
|
+
import { property, state } from "lit/decorators.js";
|
|
7
|
+
import { LitElement } from "lit";
|
|
8
|
+
var Interaction = class extends LitElement {
|
|
9
|
+
constructor() {
|
|
10
|
+
super();
|
|
11
|
+
this.disabled = false;
|
|
12
|
+
this.readonly = false;
|
|
13
|
+
this._internals = this.attachInternals();
|
|
14
|
+
}
|
|
15
|
+
get correctResponse() {
|
|
16
|
+
return this._correctResponse;
|
|
17
|
+
}
|
|
18
|
+
set correctResponse(val) {
|
|
19
|
+
this._correctResponse = val;
|
|
20
|
+
}
|
|
21
|
+
reportValidity() {
|
|
22
|
+
return this._internals.reportValidity();
|
|
23
|
+
}
|
|
24
|
+
reset() {
|
|
25
|
+
this.value = "";
|
|
26
|
+
}
|
|
27
|
+
attributeChangedCallback(name, _old, value) {
|
|
28
|
+
this.value = null;
|
|
29
|
+
}
|
|
30
|
+
toggleCorrectResponse(responseVariable, show) {
|
|
31
|
+
this.correctResponse = show ? responseVariable?.correctResponse : responseVariable.cardinality === "single" ? "" : [];
|
|
32
|
+
}
|
|
33
|
+
connectedCallback() {
|
|
34
|
+
super.connectedCallback();
|
|
35
|
+
this.dispatchEvent(
|
|
36
|
+
new CustomEvent("qti-register-interaction", {
|
|
37
|
+
bubbles: true,
|
|
38
|
+
composed: true,
|
|
39
|
+
cancelable: false,
|
|
40
|
+
detail: {
|
|
41
|
+
interactionElement: this,
|
|
42
|
+
responseIdentifier: this.responseIdentifier
|
|
43
|
+
}
|
|
44
|
+
})
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
saveResponse(value) {
|
|
48
|
+
this.dispatchEvent(
|
|
49
|
+
new CustomEvent("qti-interaction-response", {
|
|
50
|
+
bubbles: true,
|
|
51
|
+
composed: true,
|
|
52
|
+
cancelable: false,
|
|
53
|
+
detail: {
|
|
54
|
+
responseIdentifier: this.responseIdentifier,
|
|
55
|
+
response: Array.isArray(value) ? [...value] : value
|
|
56
|
+
}
|
|
57
|
+
})
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
Interaction.formAssociated = true;
|
|
62
|
+
__decorateClass([
|
|
63
|
+
property({ type: String, attribute: "response-identifier" })
|
|
64
|
+
], Interaction.prototype, "responseIdentifier", 2);
|
|
65
|
+
__decorateClass([
|
|
66
|
+
property({ reflect: true, type: Boolean })
|
|
67
|
+
], Interaction.prototype, "disabled", 2);
|
|
68
|
+
__decorateClass([
|
|
69
|
+
property({ reflect: true, type: Boolean })
|
|
70
|
+
], Interaction.prototype, "readonly", 2);
|
|
71
|
+
__decorateClass([
|
|
72
|
+
state()
|
|
73
|
+
], Interaction.prototype, "_correctResponse", 2);
|
|
74
|
+
|
|
75
|
+
export {
|
|
76
|
+
Interaction
|
|
77
|
+
};
|
|
78
|
+
//# sourceMappingURL=chunk-AD5H6KYS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lib/exports/interaction.ts"],"sourcesContent":["import { property, state } from 'lit/decorators.js';\nimport { LitElement } from 'lit';\n\nimport type { ResponseVariable } from './variables';\nimport type { IInteraction } from './interaction.interface';\n\nexport abstract class Interaction extends LitElement implements IInteraction {\n static formAssociated = true;\n\n @property({ type: String, attribute: 'response-identifier' }) responseIdentifier;\n\n @property({ reflect: true, type: Boolean }) disabled = false;\n\n @property({ reflect: true, type: Boolean }) readonly = false;\n\n @state()\n protected _correctResponse: string | string[];\n protected _internals: ElementInternals;\n\n constructor() {\n super();\n this._internals = this.attachInternals();\n }\n get correctResponse(): Readonly<string | string[]> {\n return this._correctResponse;\n }\n set correctResponse(val: Readonly<string | string[]>) {\n this._correctResponse = val as string | string[];\n }\n abstract validate(): boolean;\n\n public reportValidity(): boolean {\n return this._internals.reportValidity();\n }\n\n public reset(): void {\n this.value = '';\n }\n\n attributeChangedCallback(name: string, _old: string | null, value: string | null): void {\n // changing attributes in lit is not a thing, they are defined in the QTI XML and will never change\n // except in storybook where we can change the value of the attribute\n // this can make the internal state out of sync with the attribute\n // so we reset the value to null to force the internal state to be reset\n this.value = null;\n }\n\n abstract get value(): string | string[] | null;\n abstract set value(val: string | string[] | null);\n\n public toggleCorrectResponse(responseVariable: ResponseVariable, show: boolean) {\n this.correctResponse = show\n ? responseVariable?.correctResponse\n : responseVariable.cardinality === 'single'\n ? ''\n : [];\n }\n\n public override connectedCallback() {\n super.connectedCallback();\n\n this.dispatchEvent(\n new CustomEvent('qti-register-interaction', {\n bubbles: true,\n composed: true,\n cancelable: false,\n detail: {\n interactionElement: this,\n responseIdentifier: this.responseIdentifier\n }\n })\n );\n }\n\n public saveResponse(value: string | string[]) {\n this.dispatchEvent(\n new CustomEvent('qti-interaction-response', {\n bubbles: true,\n composed: true,\n cancelable: false,\n detail: {\n responseIdentifier: this.responseIdentifier,\n response: Array.isArray(value) ? [...value] : value\n }\n })\n );\n }\n}\n"],"mappings":";;;;;AAAA,SAAS,UAAU,aAAa;AAChC,SAAS,kBAAkB;AAKpB,IAAe,cAAf,cAAmC,WAAmC;AAAA,EAa3E,cAAc;AACZ,UAAM;AAToC,oBAAW;AAEX,oBAAW;AAQrD,SAAK,aAAa,KAAK,gBAAgB;AAAA,EACzC;AAAA,EACA,IAAI,kBAA+C;AACjD,WAAO,KAAK;AAAA,EACd;AAAA,EACA,IAAI,gBAAgB,KAAkC;AACpD,SAAK,mBAAmB;AAAA,EAC1B;AAAA,EAGO,iBAA0B;AAC/B,WAAO,KAAK,WAAW,eAAe;AAAA,EACxC;AAAA,EAEO,QAAc;AACnB,SAAK,QAAQ;AAAA,EACf;AAAA,EAEA,yBAAyB,MAAc,MAAqB,OAA4B;AAKtF,SAAK,QAAQ;AAAA,EACf;AAAA,EAKO,sBAAsB,kBAAoC,MAAe;AAC9E,SAAK,kBAAkB,OACnB,kBAAkB,kBAClB,iBAAiB,gBAAgB,WAC/B,KACA,CAAC;AAAA,EACT;AAAA,EAEgB,oBAAoB;AAClC,UAAM,kBAAkB;AAExB,SAAK;AAAA,MACH,IAAI,YAAY,4BAA4B;AAAA,QAC1C,SAAS;AAAA,QACT,UAAU;AAAA,QACV,YAAY;AAAA,QACZ,QAAQ;AAAA,UACN,oBAAoB;AAAA,UACpB,oBAAoB,KAAK;AAAA,QAC3B;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAAA,EAEO,aAAa,OAA0B;AAC5C,SAAK;AAAA,MACH,IAAI,YAAY,4BAA4B;AAAA,QAC1C,SAAS;AAAA,QACT,UAAU;AAAA,QACV,YAAY;AAAA,QACZ,QAAQ;AAAA,UACN,oBAAoB,KAAK;AAAA,UACzB,UAAU,MAAM,QAAQ,KAAK,IAAI,CAAC,GAAG,KAAK,IAAI;AAAA,QAChD;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAjFsB,YACb,iBAAiB;AAEsC;AAAA,EAA7D,SAAS,EAAE,MAAM,QAAQ,WAAW,sBAAsB,CAAC;AAAA,GAHxC,YAG0C;AAElB;AAAA,EAA3C,SAAS,EAAE,SAAS,MAAM,MAAM,QAAQ,CAAC;AAAA,GALtB,YAKwB;AAEA;AAAA,EAA3C,SAAS,EAAE,SAAS,MAAM,MAAM,QAAQ,CAAC;AAAA,GAPtB,YAOwB;AAGlC;AAAA,EADT,MAAM;AAAA,GATa,YAUV;","names":[]}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import {
|
|
2
|
+
computedContext
|
|
3
|
+
} from "./chunk-6Z5YR5U2.js";
|
|
4
|
+
import {
|
|
5
|
+
__decorateClass
|
|
6
|
+
} from "./chunk-H2JE6IVU.js";
|
|
7
|
+
|
|
8
|
+
// src/lib/qti-test/components/test-print-item-variables.ts
|
|
9
|
+
import { html, LitElement } from "lit";
|
|
10
|
+
import { consume } from "@lit/context";
|
|
11
|
+
import { customElement } from "lit/decorators.js";
|
|
12
|
+
var TestPrintVariables = class extends LitElement {
|
|
13
|
+
render() {
|
|
14
|
+
const activeItem = this.computedContext?.testParts.flatMap((testPart) => testPart.sections.flatMap((section) => section.items)).find((item) => item.active);
|
|
15
|
+
if (!activeItem || !activeItem.variables) return html``;
|
|
16
|
+
const responseVariables = activeItem.variables.filter((v) => v.type === "response");
|
|
17
|
+
const outcomeVariables = activeItem.variables.filter((v) => v.type === "outcome");
|
|
18
|
+
const renderTable = (variables, title) => html`
|
|
19
|
+
<h3>${title}</h3>
|
|
20
|
+
<table border="1">
|
|
21
|
+
<thead>
|
|
22
|
+
<tr>
|
|
23
|
+
<th>Identifier</th>
|
|
24
|
+
<th>Value</th>
|
|
25
|
+
<th>Cardinality</th>
|
|
26
|
+
<th>Base Type</th>
|
|
27
|
+
<th>Correct Response / Mappings</th>
|
|
28
|
+
</tr>
|
|
29
|
+
</thead>
|
|
30
|
+
<tbody>
|
|
31
|
+
${variables.map((v) => {
|
|
32
|
+
const correctResponse = v.correctResponse ? Array.isArray(v.correctResponse) ? v.correctResponse.join(", ") : v.correctResponse : "";
|
|
33
|
+
const mapEntries = v.mapping?.mapEntries?.map((m) => `${m.mapKey}=${m.mappedValue}pt`).join(", ") || "";
|
|
34
|
+
return html`
|
|
35
|
+
<tr>
|
|
36
|
+
<td>${v.identifier}</td>
|
|
37
|
+
<td>${Array.isArray(v.value) ? v.value.join(", ") : v.value}</td>
|
|
38
|
+
<td>${v.cardinality}</td>
|
|
39
|
+
<td>${v.baseType}</td>
|
|
40
|
+
<td>${correctResponse || mapEntries}</td>
|
|
41
|
+
</tr>
|
|
42
|
+
`;
|
|
43
|
+
})}
|
|
44
|
+
</tbody>
|
|
45
|
+
</table>
|
|
46
|
+
`;
|
|
47
|
+
return html`
|
|
48
|
+
${renderTable(responseVariables, "Response Variables")} ${renderTable(outcomeVariables, "Outcome Variables")}
|
|
49
|
+
`;
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
__decorateClass([
|
|
53
|
+
consume({ context: computedContext, subscribe: true })
|
|
54
|
+
], TestPrintVariables.prototype, "computedContext", 2);
|
|
55
|
+
TestPrintVariables = __decorateClass([
|
|
56
|
+
customElement("test-print-item-variables")
|
|
57
|
+
], TestPrintVariables);
|
|
58
|
+
|
|
59
|
+
export {
|
|
60
|
+
TestPrintVariables
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=chunk-AQLCQATM.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/lib/qti-test/components/test-print-item-variables.ts"],"sourcesContent":["import { html, LitElement } from 'lit';\nimport { consume } from '@lit/context';\nimport { customElement } from 'lit/decorators.js';\n\nimport { computedContext } from '../../exports/computed.context';\n\nimport type { ResponseVariable } from '../../exports/variables';\nimport type { ComputedContext } from '../../exports/computed.context';\n\n@customElement('test-print-item-variables')\nexport class TestPrintVariables extends LitElement {\n @consume({ context: computedContext, subscribe: true })\n public computedContext?: ComputedContext;\n\n render() {\n const activeItem = this.computedContext?.testParts\n .flatMap(testPart => testPart.sections.flatMap(section => section.items))\n .find(item => item.active);\n\n if (!activeItem || !activeItem.variables) return html``;\n\n const responseVariables: ResponseVariable[] = activeItem.variables.filter(v => v.type === 'response');\n const outcomeVariables = activeItem.variables.filter(v => v.type === 'outcome');\n\n const renderTable = (variables: ResponseVariable[], title: string) => html`\n <h3>${title}</h3>\n <table border=\"1\">\n <thead>\n <tr>\n <th>Identifier</th>\n <th>Value</th>\n <th>Cardinality</th>\n <th>Base Type</th>\n <th>Correct Response / Mappings</th>\n </tr>\n </thead>\n <tbody>\n ${variables.map(v => {\n const correctResponse = v.correctResponse\n ? Array.isArray(v.correctResponse)\n ? v.correctResponse.join(', ')\n : v.correctResponse\n : '';\n\n const mapEntries = v.mapping?.mapEntries?.map(m => `${m.mapKey}=${m.mappedValue}pt`).join(', ') || '';\n\n return html`\n <tr>\n <td>${v.identifier}</td>\n <td>${Array.isArray(v.value) ? v.value.join(', ') : v.value}</td>\n <td>${v.cardinality}</td>\n <td>${v.baseType}</td>\n <td>${correctResponse || mapEntries}</td>\n </tr>\n `;\n })}\n </tbody>\n </table>\n `;\n\n return html`\n ${renderTable(responseVariables, 'Response Variables')} ${renderTable(outcomeVariables, 'Outcome Variables')}\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'test-print-item-variables': TestPrintVariables;\n }\n}\n"],"mappings":";;;;;;;;AAAA,SAAS,MAAM,kBAAkB;AACjC,SAAS,eAAe;AACxB,SAAS,qBAAqB;AAQvB,IAAM,qBAAN,cAAiC,WAAW;AAAA,EAIjD,SAAS;AACP,UAAM,aAAa,KAAK,iBAAiB,UACtC,QAAQ,cAAY,SAAS,SAAS,QAAQ,aAAW,QAAQ,KAAK,CAAC,EACvE,KAAK,UAAQ,KAAK,MAAM;AAE3B,QAAI,CAAC,cAAc,CAAC,WAAW,UAAW,QAAO;AAEjD,UAAM,oBAAwC,WAAW,UAAU,OAAO,OAAK,EAAE,SAAS,UAAU;AACpG,UAAM,mBAAmB,WAAW,UAAU,OAAO,OAAK,EAAE,SAAS,SAAS;AAE9E,UAAM,cAAc,CAAC,WAA+B,UAAkB;AAAA,YAC9D,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAYL,UAAU,IAAI,OAAK;AACnB,YAAM,kBAAkB,EAAE,kBACtB,MAAM,QAAQ,EAAE,eAAe,IAC7B,EAAE,gBAAgB,KAAK,IAAI,IAC3B,EAAE,kBACJ;AAEJ,YAAM,aAAa,EAAE,SAAS,YAAY,IAAI,OAAK,GAAG,EAAE,MAAM,IAAI,EAAE,WAAW,IAAI,EAAE,KAAK,IAAI,KAAK;AAEnG,aAAO;AAAA;AAAA,sBAEG,EAAE,UAAU;AAAA,sBACZ,MAAM,QAAQ,EAAE,KAAK,IAAI,EAAE,MAAM,KAAK,IAAI,IAAI,EAAE,KAAK;AAAA,sBACrD,EAAE,WAAW;AAAA,sBACb,EAAE,QAAQ;AAAA,sBACV,mBAAmB,UAAU;AAAA;AAAA;AAAA,IAGzC,CAAC,CAAC;AAAA;AAAA;AAAA;AAKR,WAAO;AAAA,QACH,YAAY,mBAAmB,oBAAoB,CAAC,IAAI,YAAY,kBAAkB,mBAAmB,CAAC;AAAA;AAAA,EAEhH;AACF;AApDS;AAAA,EADN,QAAQ,EAAE,SAAS,iBAAiB,WAAW,KAAK,CAAC;AAAA,GAD3C,mBAEJ;AAFI,qBAAN;AAAA,EADN,cAAc,2BAA2B;AAAA,GAC7B;","names":[]}
|