@citolab/qti-components 6.9.1-beta.81 → 7.0.1
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/index.global.js +277 -0
- package/cdn/index.min.cjs +4489 -0
- package/cdn/index.min.js +4489 -0
- package/dist/custom-element-eslint-rules.js +25 -19
- package/dist/item.css +172 -5
- package/dist/qti-components/index.cjs +660 -465
- package/dist/qti-components/index.cjs.map +1 -0
- package/dist/qti-components/index.d.cts +4 -4
- package/dist/qti-components/index.d.ts +4 -4
- package/dist/qti-components/index.js +615 -423
- package/dist/qti-components/index.js.map +1 -0
- package/dist/qti-components-jsx.d.ts +398 -64
- package/dist/qti-item/index.cjs +2 -3
- package/dist/qti-item/index.cjs.map +1 -0
- package/dist/qti-item/index.d.cts +1 -1
- package/dist/qti-item/index.d.ts +1 -1
- package/dist/qti-item/index.js +2 -3
- package/dist/qti-item/index.js.map +1 -0
- package/dist/qti-loader/index.cjs +5 -6
- package/dist/qti-loader/index.cjs.map +1 -0
- package/dist/qti-loader/index.d.cts +1 -1
- package/dist/qti-loader/index.d.ts +1 -1
- package/dist/qti-loader/index.js +5 -6
- package/dist/qti-loader/index.js.map +1 -0
- package/dist/{qti-simple-choice-DC5DJota.d.cts → qti-simple-choice-CynLWb8d.d.cts} +74 -26
- package/dist/{qti-simple-choice-DC5DJota.d.ts → qti-simple-choice-CynLWb8d.d.ts} +74 -26
- package/dist/qti-test/index.cjs +4632 -0
- package/dist/qti-test/index.cjs.map +1 -0
- package/dist/qti-test/index.d.cts +304 -0
- package/dist/qti-test/index.d.ts +304 -0
- package/dist/qti-test/index.js +4599 -0
- package/dist/qti-test/index.js.map +1 -0
- package/dist/qti-transformers/index.cjs +5 -6
- package/dist/qti-transformers/index.cjs.map +1 -0
- package/dist/qti-transformers/index.js +5 -6
- package/dist/qti-transformers/index.js.map +1 -0
- package/dist/vscode.css-custom-data.json +28 -0
- package/dist/vscode.html-custom-data.json +179 -230
- package/package.json +96 -67
- package/dist/custom-elements.json +0 -24168
- package/dist/index.global.js +0 -226
- package/dist/index.js +0 -7860
- package/dist/index.min.js +0 -952
- /package/{LICENSE → LICENSE.md} +0 -0
- /package/{readme.md → README.md} +0 -0
|
@@ -1,23 +1,5 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
|
-
var __defProps = Object.defineProperties;
|
|
3
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
5
|
-
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
8
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
9
|
-
var __spreadValues = (a, b) => {
|
|
10
|
-
for (var prop in b || (b = {}))
|
|
11
|
-
if (__hasOwnProp.call(b, prop))
|
|
12
|
-
__defNormalProp(a, prop, b[prop]);
|
|
13
|
-
if (__getOwnPropSymbols)
|
|
14
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
15
|
-
if (__propIsEnum.call(b, prop))
|
|
16
|
-
__defNormalProp(a, prop, b[prop]);
|
|
17
|
-
}
|
|
18
|
-
return a;
|
|
19
|
-
};
|
|
20
|
-
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
21
3
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
22
4
|
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
23
5
|
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
@@ -34,9 +16,10 @@ import { customElement, property } from "lit/decorators.js";
|
|
|
34
16
|
|
|
35
17
|
// src/lib/decorators/watch.ts
|
|
36
18
|
function watch(propertyName, options) {
|
|
37
|
-
const resolvedOptions =
|
|
38
|
-
waitUntilFirstUpdate: false
|
|
39
|
-
|
|
19
|
+
const resolvedOptions = {
|
|
20
|
+
waitUntilFirstUpdate: false,
|
|
21
|
+
...options
|
|
22
|
+
};
|
|
40
23
|
return (proto, decoratedFnName) => {
|
|
41
24
|
const { update } = proto;
|
|
42
25
|
const watchedProperties = Array.isArray(propertyName) ? propertyName : [propertyName];
|
|
@@ -93,11 +76,11 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
93
76
|
identifier: this.getAttribute("identifier"),
|
|
94
77
|
variables: itemContextVariables
|
|
95
78
|
};
|
|
96
|
-
this._initialContext =
|
|
79
|
+
this._initialContext = { ...this._context, variables: this._context.variables };
|
|
97
80
|
this._feedbackElements = [];
|
|
98
81
|
this._interactionElements = [];
|
|
99
82
|
this.addEventListener("qti-register-variable", (e) => {
|
|
100
|
-
this._context =
|
|
83
|
+
this._context = { ...this._context, variables: [...this._context.variables, e.detail.variable] };
|
|
101
84
|
this._initialContext = this._context;
|
|
102
85
|
e.stopPropagation();
|
|
103
86
|
});
|
|
@@ -113,6 +96,7 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
113
96
|
});
|
|
114
97
|
this.addEventListener("end-attempt", (e) => {
|
|
115
98
|
const { responseIdentifier, countAttempt } = e.detail;
|
|
99
|
+
this.validate();
|
|
116
100
|
this.updateResponseVariable(responseIdentifier, "true");
|
|
117
101
|
this.processResponse(countAttempt);
|
|
118
102
|
});
|
|
@@ -128,26 +112,29 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
128
112
|
this.addEventListener("qti-interaction-response", this.handleUpdateResponseVariable);
|
|
129
113
|
}
|
|
130
114
|
get variables() {
|
|
131
|
-
return this._context.variables.map((v) =>
|
|
115
|
+
return this._context.variables.map((v) => ({
|
|
132
116
|
identifier: v.identifier,
|
|
133
117
|
value: v.value,
|
|
134
|
-
type: v.type
|
|
135
|
-
|
|
118
|
+
type: v.type,
|
|
119
|
+
// add externalscored, a fixed prop to the test, so the testcontext can read and decide how to score this item
|
|
120
|
+
...v.type === "outcome" && v.identifier === "SCORE" ? { externalScored: v.externalScored } : {}
|
|
121
|
+
}));
|
|
136
122
|
}
|
|
137
123
|
set variables(value) {
|
|
138
124
|
if (!Array.isArray(value) || value.some((v) => !("identifier" in v))) {
|
|
139
125
|
console.warn("variables property should be an array of VariableDeclaration");
|
|
140
126
|
return;
|
|
141
127
|
}
|
|
142
|
-
this._context =
|
|
128
|
+
this._context = {
|
|
129
|
+
...this._context,
|
|
143
130
|
variables: this._context.variables.map((variable) => {
|
|
144
131
|
const matchingValue = value.find((v) => v.identifier === variable.identifier);
|
|
145
132
|
if (matchingValue) {
|
|
146
|
-
return
|
|
133
|
+
return { ...variable, ...matchingValue };
|
|
147
134
|
}
|
|
148
135
|
return variable;
|
|
149
136
|
})
|
|
150
|
-
}
|
|
137
|
+
};
|
|
151
138
|
this._context.variables.forEach((variable) => {
|
|
152
139
|
if (variable.type === "response") {
|
|
153
140
|
const interactionElement = this._interactionElements.find(
|
|
@@ -207,7 +194,7 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
207
194
|
}
|
|
208
195
|
}
|
|
209
196
|
processResponse(countNumAttempts = true) {
|
|
210
|
-
|
|
197
|
+
this.validate();
|
|
211
198
|
const responseProcessor = this.querySelector("qti-response-processing");
|
|
212
199
|
if (!responseProcessor) {
|
|
213
200
|
return false;
|
|
@@ -222,7 +209,7 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
222
209
|
if (countNumAttempts) {
|
|
223
210
|
this.updateOutcomeVariable(
|
|
224
211
|
"numAttempts",
|
|
225
|
-
(+
|
|
212
|
+
(+this._context.variables.find((v) => v.identifier === "numAttempts")?.value + 1).toString()
|
|
226
213
|
);
|
|
227
214
|
}
|
|
228
215
|
this._emit("qti-response-processed");
|
|
@@ -246,9 +233,10 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
246
233
|
this.updateResponseVariable(responseIdentifier, response);
|
|
247
234
|
}
|
|
248
235
|
updateResponseVariable(identifier, value) {
|
|
249
|
-
this._context =
|
|
250
|
-
|
|
251
|
-
|
|
236
|
+
this._context = {
|
|
237
|
+
...this._context,
|
|
238
|
+
variables: this._context.variables.map((v) => v.identifier !== identifier ? v : { ...v, value })
|
|
239
|
+
};
|
|
252
240
|
this._emit("qti-interaction-changed", {
|
|
253
241
|
item: this.identifier,
|
|
254
242
|
responseIdentifier: identifier,
|
|
@@ -259,32 +247,39 @@ var QtiAssessmentItem = class extends LitElement {
|
|
|
259
247
|
}
|
|
260
248
|
}
|
|
261
249
|
updateOutcomeVariable(identifier, value) {
|
|
262
|
-
var _a;
|
|
263
250
|
const outcomeVariable = this.getOutcome(identifier);
|
|
264
251
|
if (!outcomeVariable) {
|
|
265
252
|
console.warn(`Can not set qti-outcome-identifier: ${identifier}, it is not available`);
|
|
266
253
|
return;
|
|
267
254
|
}
|
|
268
|
-
this._context =
|
|
255
|
+
this._context = {
|
|
256
|
+
...this._context,
|
|
269
257
|
variables: this._context.variables.map((v) => {
|
|
270
258
|
if (v.identifier !== identifier) {
|
|
271
259
|
return v;
|
|
272
260
|
}
|
|
273
|
-
return
|
|
261
|
+
return {
|
|
262
|
+
...v,
|
|
274
263
|
value: outcomeVariable.cardinality === "single" ? value : [...v.value, value]
|
|
275
|
-
}
|
|
264
|
+
};
|
|
276
265
|
})
|
|
277
|
-
}
|
|
266
|
+
};
|
|
278
267
|
this._feedbackElements.forEach((fe) => fe.checkShowFeedback(identifier));
|
|
279
268
|
this._emit("qti-outcome-changed", {
|
|
280
269
|
item: this.identifier,
|
|
281
270
|
outcomeIdentifier: identifier,
|
|
282
|
-
value:
|
|
271
|
+
value: this._context.variables.find((v) => v.identifier === identifier)?.value
|
|
283
272
|
});
|
|
284
273
|
}
|
|
274
|
+
validate() {
|
|
275
|
+
if (this._interactionElements.every((interactionElement) => interactionElement.validate())) return true;
|
|
276
|
+
if (this._interactionElements.some((interactionElement) => interactionElement.validate())) return false;
|
|
277
|
+
return null;
|
|
278
|
+
}
|
|
285
279
|
_getCompletionStatus() {
|
|
286
|
-
|
|
287
|
-
if (
|
|
280
|
+
const valid = this.validate();
|
|
281
|
+
if (valid === true) return "completed";
|
|
282
|
+
if (valid === false) return "incomplete";
|
|
288
283
|
return "not_attempted";
|
|
289
284
|
}
|
|
290
285
|
_emit(name, detail = null) {
|
|
@@ -429,7 +424,6 @@ function setLocation(xmlFragment, location) {
|
|
|
429
424
|
location += "/";
|
|
430
425
|
}
|
|
431
426
|
xmlFragment.querySelectorAll("[src],[href],[primary-path]").forEach((elWithSrc) => {
|
|
432
|
-
var _a;
|
|
433
427
|
let attr = "";
|
|
434
428
|
if (elWithSrc.getAttribute("src")) {
|
|
435
429
|
attr = "src";
|
|
@@ -440,7 +434,7 @@ function setLocation(xmlFragment, location) {
|
|
|
440
434
|
if (elWithSrc.getAttribute("primary-path")) {
|
|
441
435
|
attr = "primary-path";
|
|
442
436
|
}
|
|
443
|
-
const attrValue =
|
|
437
|
+
const attrValue = elWithSrc.getAttribute(attr)?.trim();
|
|
444
438
|
if (!attrValue.startsWith("data:") && !attrValue.startsWith("http")) {
|
|
445
439
|
const newSrcValue = location + encodeURI(attrValue);
|
|
446
440
|
elWithSrc.setAttribute(attr, newSrcValue);
|
|
@@ -463,7 +457,7 @@ var qtiTransformItem = () => {
|
|
|
463
457
|
let xmlFragment;
|
|
464
458
|
const api = {
|
|
465
459
|
async load(uri, cancelPreviousRequest = false) {
|
|
466
|
-
return new Promise((resolve
|
|
460
|
+
return new Promise((resolve) => {
|
|
467
461
|
loadXML(uri, cancelPreviousRequest).then((xml2) => {
|
|
468
462
|
xmlFragment = xml2;
|
|
469
463
|
api.path(uri.substring(0, uri.lastIndexOf("/")));
|
|
@@ -574,7 +568,6 @@ var QtiAssessmentStimulusRef = class extends LitElement2 {
|
|
|
574
568
|
* @param stimulusRef - The element to which the stimulus will be appended.
|
|
575
569
|
*/
|
|
576
570
|
async updateStimulusRef(stimulusRef) {
|
|
577
|
-
const path = this.href.substring(0, this.href.lastIndexOf("/"));
|
|
578
571
|
const stimulus = await qtiTransformItem().load(this.href).then((api) => api.htmlDoc());
|
|
579
572
|
if (stimulus) {
|
|
580
573
|
const elements = stimulus.querySelectorAll("qti-stimulus-body, qti-stylesheet");
|
|
@@ -824,8 +817,7 @@ var QtiOutcomeDeclaration = class extends QtiVariableDeclaration {
|
|
|
824
817
|
this.externalScored = null;
|
|
825
818
|
}
|
|
826
819
|
render() {
|
|
827
|
-
|
|
828
|
-
const value = (_b = (_a = this.itemContext) == null ? void 0 : _a.variables.find((v) => v.identifier === this.identifier)) == null ? void 0 : _b.value;
|
|
820
|
+
const value = this.itemContext?.variables.find((v) => v.identifier === this.identifier)?.value;
|
|
829
821
|
return html6`${JSON.stringify(value, null, 2)}`;
|
|
830
822
|
}
|
|
831
823
|
get interpolationTable() {
|
|
@@ -901,8 +893,7 @@ import { css as css3, html as html7 } from "lit";
|
|
|
901
893
|
import { customElement as customElement8, property as property5, state as state2 } from "lit/decorators.js";
|
|
902
894
|
var QtiResponseDeclaration = class extends QtiVariableDeclaration {
|
|
903
895
|
render() {
|
|
904
|
-
|
|
905
|
-
const value = (_b = (_a = this.itemContext) == null ? void 0 : _a.variables.find((v) => v.identifier === this.identifier)) == null ? void 0 : _b.value;
|
|
896
|
+
const value = this.itemContext?.variables.find((v) => v.identifier === this.identifier)?.value;
|
|
906
897
|
return html7`${JSON.stringify(value, null, 2)}`;
|
|
907
898
|
}
|
|
908
899
|
connectedCallback() {
|
|
@@ -1005,7 +996,7 @@ QtiContentBody = __decorateClass([
|
|
|
1005
996
|
import { LitElement as LitElement10, css as css4, html as html9 } from "lit";
|
|
1006
997
|
import { customElement as customElement11, property as property6 } from "lit/decorators.js";
|
|
1007
998
|
var QtiRubricBlock = class extends LitElement10 {
|
|
1008
|
-
handleclassNamesChange(
|
|
999
|
+
handleclassNamesChange() {
|
|
1009
1000
|
const classNames = this.classNames.split(" ");
|
|
1010
1001
|
classNames.forEach((className) => {
|
|
1011
1002
|
switch (className) {
|
|
@@ -1104,7 +1095,7 @@ var QtiFeedback = class extends LitElement11 {
|
|
|
1104
1095
|
if (Array.isArray(outcomeVariable.value)) {
|
|
1105
1096
|
isFound = outcomeVariable.value.includes(this.identifier);
|
|
1106
1097
|
} else {
|
|
1107
|
-
isFound = !IsNullOrUndefined(this.identifier) && !IsNullOrUndefined(outcomeVariable
|
|
1098
|
+
isFound = !IsNullOrUndefined(this.identifier) && !IsNullOrUndefined(outcomeVariable?.value) && this.identifier === outcomeVariable.value || false;
|
|
1108
1099
|
}
|
|
1109
1100
|
this.showFeedback(isFound);
|
|
1110
1101
|
}
|
|
@@ -1205,10 +1196,8 @@ import { LitElement as LitElement12 } from "lit";
|
|
|
1205
1196
|
var Interaction = class extends LitElement12 {
|
|
1206
1197
|
constructor() {
|
|
1207
1198
|
super();
|
|
1208
|
-
this.responseIdentifier = "";
|
|
1209
1199
|
this.disabled = false;
|
|
1210
1200
|
this.readonly = false;
|
|
1211
|
-
this._correctResponse = "";
|
|
1212
1201
|
this._internals = this.attachInternals();
|
|
1213
1202
|
}
|
|
1214
1203
|
reportValidity() {
|
|
@@ -1269,7 +1258,7 @@ var QtiExtendedTextInteraction = class extends Interaction {
|
|
|
1269
1258
|
this._rows = 5;
|
|
1270
1259
|
this._value = "";
|
|
1271
1260
|
}
|
|
1272
|
-
handleclassNamesChange(
|
|
1261
|
+
handleclassNamesChange(_, classes) {
|
|
1273
1262
|
const classNames = classes.split(" ");
|
|
1274
1263
|
let rowsSet = false;
|
|
1275
1264
|
classNames.forEach((className) => {
|
|
@@ -1353,7 +1342,7 @@ var QtiExtendedTextInteraction = class extends Interaction {
|
|
|
1353
1342
|
@keydown="${(event) => event.stopImmediatePropagation()}"
|
|
1354
1343
|
@keyup="${this.textChanged}"
|
|
1355
1344
|
@change="${this.textChanged}"
|
|
1356
|
-
@blur="${(
|
|
1345
|
+
@blur="${(_) => {
|
|
1357
1346
|
this.reportValidity();
|
|
1358
1347
|
}}"
|
|
1359
1348
|
placeholder="${ifDefined(this.placeholderText ? this.placeholderText : void 0)}"
|
|
@@ -1369,7 +1358,6 @@ var QtiExtendedTextInteraction = class extends Interaction {
|
|
|
1369
1358
|
this.setEmptyAttribute(input.value);
|
|
1370
1359
|
if (this._value !== input.value) {
|
|
1371
1360
|
this.value = input.value;
|
|
1372
|
-
const isValid = this.validate();
|
|
1373
1361
|
this.saveResponse(input.value);
|
|
1374
1362
|
}
|
|
1375
1363
|
}
|
|
@@ -1542,7 +1530,7 @@ var QtiTextEntryInteraction = class extends Interaction {
|
|
|
1542
1530
|
name="${this.responseIdentifier}"
|
|
1543
1531
|
spellcheck="false"
|
|
1544
1532
|
autocomplete="off"
|
|
1545
|
-
@blur="${(
|
|
1533
|
+
@blur="${(_) => {
|
|
1546
1534
|
this.reportValidity();
|
|
1547
1535
|
}}"
|
|
1548
1536
|
@keydown="${(event) => event.stopImmediatePropagation()}"
|
|
@@ -1565,7 +1553,6 @@ var QtiTextEntryInteraction = class extends Interaction {
|
|
|
1565
1553
|
this.setEmptyAttribute(input.value);
|
|
1566
1554
|
if (this._value !== input.value) {
|
|
1567
1555
|
this.value = input.value;
|
|
1568
|
-
const isValid = this.validate();
|
|
1569
1556
|
this.saveResponse(input.value);
|
|
1570
1557
|
}
|
|
1571
1558
|
}
|
|
@@ -1732,8 +1719,10 @@ var ChoicesMixin = (superClass, selector) => {
|
|
|
1732
1719
|
}
|
|
1733
1720
|
_setInputType(choiceElement) {
|
|
1734
1721
|
this._internals.ariaLabel = this.maxChoices === 1 ? "radio-group" : "checkbox-group";
|
|
1735
|
-
|
|
1736
|
-
choiceElement.internals.
|
|
1722
|
+
const role = this.maxChoices === 1 ? "radio" : "checkbox";
|
|
1723
|
+
choiceElement.internals.role = role;
|
|
1724
|
+
choiceElement.internals.states.delete(role === "radio" ? "checkbox" : "radio");
|
|
1725
|
+
choiceElement.internals.states.add(role);
|
|
1737
1726
|
}
|
|
1738
1727
|
_choiceElementSelectedHandler(event) {
|
|
1739
1728
|
this._toggleChoiceChecked(event.target);
|
|
@@ -1747,8 +1736,7 @@ var ChoicesMixin = (superClass, selector) => {
|
|
|
1747
1736
|
this._handleChoiceSelection();
|
|
1748
1737
|
}
|
|
1749
1738
|
_setChoiceChecked(choice, checked) {
|
|
1750
|
-
|
|
1751
|
-
if ((_a = choice.internals) == null ? void 0 : _a.states) {
|
|
1739
|
+
if (choice.internals?.states) {
|
|
1752
1740
|
if (checked) {
|
|
1753
1741
|
choice.internals.states.add("--checked");
|
|
1754
1742
|
choice.internals.ariaChecked = "true";
|
|
@@ -1895,7 +1883,7 @@ var QtiInlineChoiceInteraction = class extends Interaction {
|
|
|
1895
1883
|
return selectedOption ? selectedOption.value !== "" : false;
|
|
1896
1884
|
}
|
|
1897
1885
|
reset() {
|
|
1898
|
-
this.options = this.options.map((option, i) =>
|
|
1886
|
+
this.options = this.options.map((option, i) => ({ ...option, selected: i === 0 }));
|
|
1899
1887
|
}
|
|
1900
1888
|
set value(value) {
|
|
1901
1889
|
this.options = this.options.map((option) => {
|
|
@@ -1917,7 +1905,7 @@ var QtiInlineChoiceInteraction = class extends Interaction {
|
|
|
1917
1905
|
}
|
|
1918
1906
|
choiceSelected(event) {
|
|
1919
1907
|
const selectedOptionValue = event.target.value;
|
|
1920
|
-
this.options = this.options.map((option) =>
|
|
1908
|
+
this.options = this.options.map((option) => ({ ...option, selected: option.value === selectedOptionValue }));
|
|
1921
1909
|
this.saveResponse(selectedOptionValue);
|
|
1922
1910
|
}
|
|
1923
1911
|
};
|
|
@@ -1956,24 +1944,20 @@ var ShuffleMixin = (superClass, selector) => {
|
|
|
1956
1944
|
class ShuffleElement extends superClass {
|
|
1957
1945
|
constructor() {
|
|
1958
1946
|
super(...arguments);
|
|
1959
|
-
this.
|
|
1960
|
-
}
|
|
1961
|
-
set shuffle(value) {
|
|
1962
|
-
const oldValue = this._shuffle;
|
|
1963
|
-
this._shuffle = value;
|
|
1964
|
-
if (value) {
|
|
1965
|
-
this._shuffleChoices();
|
|
1966
|
-
} else {
|
|
1967
|
-
this._resetShuffleChoices();
|
|
1968
|
-
}
|
|
1969
|
-
this.requestUpdate("shuffle", oldValue);
|
|
1970
|
-
}
|
|
1971
|
-
get shuffle() {
|
|
1972
|
-
return this._shuffle;
|
|
1947
|
+
this.shuffle = "false";
|
|
1973
1948
|
}
|
|
1949
|
+
// Defaults to 'false'
|
|
1974
1950
|
connectedCallback() {
|
|
1975
1951
|
super.connectedCallback();
|
|
1976
|
-
|
|
1952
|
+
this._applyShuffle();
|
|
1953
|
+
}
|
|
1954
|
+
updated(changedProperties) {
|
|
1955
|
+
if (changedProperties.has("shuffle")) {
|
|
1956
|
+
this._applyShuffle();
|
|
1957
|
+
}
|
|
1958
|
+
}
|
|
1959
|
+
_applyShuffle() {
|
|
1960
|
+
if (this.shuffle === "true") {
|
|
1977
1961
|
this._shuffleChoices();
|
|
1978
1962
|
} else {
|
|
1979
1963
|
this._resetShuffleChoices();
|
|
@@ -1981,69 +1965,42 @@ var ShuffleMixin = (superClass, selector) => {
|
|
|
1981
1965
|
}
|
|
1982
1966
|
_shuffleChoices() {
|
|
1983
1967
|
const choices = Array.from(this.querySelectorAll(selector));
|
|
1984
|
-
const
|
|
1985
|
-
const
|
|
1986
|
-
|
|
1987
|
-
if (choice.hasAttribute("fixed")) {
|
|
1988
|
-
fixedElements.push({ element: choice, index });
|
|
1989
|
-
} else {
|
|
1990
|
-
nonFixedElements.push(choice);
|
|
1991
|
-
}
|
|
1992
|
-
});
|
|
1993
|
-
if (nonFixedElements.length <= 1) {
|
|
1968
|
+
const fixedChoices = choices.filter((choice) => choice.hasAttribute("fixed"));
|
|
1969
|
+
const nonFixedChoices = choices.filter((choice) => !choice.hasAttribute("fixed"));
|
|
1970
|
+
if (nonFixedChoices.length <= 1) {
|
|
1994
1971
|
console.warn("Shuffling is not possible with fewer than 2 non-fixed elements.");
|
|
1995
1972
|
return;
|
|
1996
1973
|
}
|
|
1997
|
-
|
|
1998
|
-
|
|
1999
|
-
let
|
|
2000
|
-
|
|
2001
|
-
|
|
2002
|
-
|
|
2003
|
-
for (let i = nonFixedElements.length - 1; i > 0; i--) {
|
|
1974
|
+
const originalOrder = [...nonFixedChoices];
|
|
1975
|
+
let shuffled = false;
|
|
1976
|
+
let attempts = 0;
|
|
1977
|
+
while (!shuffled && attempts < 10) {
|
|
1978
|
+
attempts++;
|
|
1979
|
+
for (let i = nonFixedChoices.length - 1; i > 0; i--) {
|
|
2004
1980
|
const j = Math.floor(Math.random() * (i + 1));
|
|
2005
|
-
[
|
|
1981
|
+
[nonFixedChoices[i], nonFixedChoices[j]] = [nonFixedChoices[j], nonFixedChoices[i]];
|
|
2006
1982
|
}
|
|
2007
|
-
|
|
2008
|
-
if (isShuffled) break;
|
|
1983
|
+
shuffled = !nonFixedChoices.every((choice, index) => choice === originalOrder[index]);
|
|
2009
1984
|
}
|
|
2010
|
-
if (!
|
|
1985
|
+
if (!shuffled) {
|
|
2011
1986
|
console.warn("Failed to shuffle the choices after multiple attempts.");
|
|
2012
1987
|
}
|
|
2013
1988
|
let order = 1;
|
|
2014
|
-
|
|
2015
|
-
|
|
2016
|
-
choice.style.setProperty("order", String(order++));
|
|
2017
|
-
} else {
|
|
2018
|
-
const nonFixedChoice = nonFixedElements.shift();
|
|
2019
|
-
nonFixedChoice.style.setProperty("order", String(order++));
|
|
2020
|
-
}
|
|
1989
|
+
[...fixedChoices, ...nonFixedChoices].forEach((choice) => {
|
|
1990
|
+
choice.style.setProperty("order", String(order++));
|
|
2021
1991
|
});
|
|
2022
1992
|
}
|
|
2023
1993
|
_resetShuffleChoices() {
|
|
2024
|
-
|
|
2025
|
-
choices.forEach((choice, index) => {
|
|
1994
|
+
this.querySelectorAll(selector).forEach((choice) => {
|
|
2026
1995
|
choice.style.setProperty("order", "initial");
|
|
2027
1996
|
});
|
|
2028
1997
|
}
|
|
2029
1998
|
}
|
|
2030
1999
|
__decorateClass([
|
|
2031
|
-
property13({
|
|
2032
|
-
|
|
2033
|
-
reflect: true,
|
|
2034
|
-
converter: stringToBooleanConverter
|
|
2035
|
-
})
|
|
2036
|
-
], ShuffleElement.prototype, "shuffle", 1);
|
|
2000
|
+
property13({ type: String, reflect: true })
|
|
2001
|
+
], ShuffleElement.prototype, "shuffle", 2);
|
|
2037
2002
|
return ShuffleElement;
|
|
2038
2003
|
};
|
|
2039
|
-
var stringToBooleanConverter = {
|
|
2040
|
-
fromAttribute(value) {
|
|
2041
|
-
return value === "true";
|
|
2042
|
-
},
|
|
2043
|
-
toAttribute(value) {
|
|
2044
|
-
return value ? "true" : "false";
|
|
2045
|
-
}
|
|
2046
|
-
};
|
|
2047
2004
|
|
|
2048
2005
|
// src/lib/qti-components/qti-interaction/internal/vocabulary/vocabulary-mixin.ts
|
|
2049
2006
|
import { property as property14 } from "lit/decorators.js";
|
|
@@ -2063,8 +2020,7 @@ var VocabularyMixin = (superClass, selector) => {
|
|
|
2063
2020
|
this._addLabels();
|
|
2064
2021
|
}
|
|
2065
2022
|
get class() {
|
|
2066
|
-
|
|
2067
|
-
return ((_a = this._classes) == null ? void 0 : _a.join(" ")) || "";
|
|
2023
|
+
return this._classes?.join(" ") || "";
|
|
2068
2024
|
}
|
|
2069
2025
|
updated(_changedProperties) {
|
|
2070
2026
|
super.updated(_changedProperties);
|
|
@@ -2177,8 +2133,8 @@ var QtiChoiceInteraction = class extends VocabularyMixin(
|
|
|
2177
2133
|
}
|
|
2178
2134
|
render() {
|
|
2179
2135
|
return html17`
|
|
2180
|
-
<slot name="prompt"></slot><slot part="slot"></slot>
|
|
2181
|
-
<div role="alert" id="validationMessage"></div>
|
|
2136
|
+
<slot part="prompt" name="prompt"></slot><slot part="slot"></slot>
|
|
2137
|
+
<div part="message" role="alert" id="validationMessage"></div>
|
|
2182
2138
|
`;
|
|
2183
2139
|
}
|
|
2184
2140
|
};
|
|
@@ -2191,9 +2147,9 @@ QtiChoiceInteraction = __decorateClass([
|
|
|
2191
2147
|
], QtiChoiceInteraction);
|
|
2192
2148
|
|
|
2193
2149
|
// src/lib/qti-components/qti-outcome-processing/qti-outcome-processing.ts
|
|
2194
|
-
import { css as css12, html as html18, LitElement as
|
|
2150
|
+
import { css as css12, html as html18, LitElement as LitElement13 } from "lit";
|
|
2195
2151
|
import { customElement as customElement20 } from "lit/decorators.js";
|
|
2196
|
-
var QtiOutcomeProcessing = class extends
|
|
2152
|
+
var QtiOutcomeProcessing = class extends LitElement13 {
|
|
2197
2153
|
render() {
|
|
2198
2154
|
return html18`<slot></slot>`;
|
|
2199
2155
|
}
|
|
@@ -2222,7 +2178,7 @@ var QtiOutcomeProcessingProcessor = class {
|
|
|
2222
2178
|
};
|
|
2223
2179
|
|
|
2224
2180
|
// src/lib/qti-components/qti-response-processing/qti-response-processing/qti-response-processing.ts
|
|
2225
|
-
import { css as css13, html as html19, LitElement as
|
|
2181
|
+
import { css as css13, html as html19, LitElement as LitElement14 } from "lit";
|
|
2226
2182
|
import { customElement as customElement21 } from "lit/decorators.js";
|
|
2227
2183
|
|
|
2228
2184
|
// src/lib/qti-components/internal/template-strings.ts
|
|
@@ -2280,11 +2236,13 @@ var mapResponsePoint = `<qti-response-processing>
|
|
|
2280
2236
|
</qti-response-processing>`;
|
|
2281
2237
|
|
|
2282
2238
|
// src/lib/qti-components/qti-response-processing/qti-response-processing/qti-response-processing.ts
|
|
2283
|
-
var QtiResponseProcessing = class extends
|
|
2239
|
+
var QtiResponseProcessing = class extends LitElement14 {
|
|
2284
2240
|
render() {
|
|
2285
2241
|
return html19`<slot></slot>`;
|
|
2286
2242
|
}
|
|
2287
2243
|
process() {
|
|
2244
|
+
const assessmentItem = this.closest("qti-assessment-item");
|
|
2245
|
+
if (!assessmentItem) return;
|
|
2288
2246
|
const rules = [...this.children];
|
|
2289
2247
|
for (const rule of rules) {
|
|
2290
2248
|
rule.process();
|
|
@@ -2330,8 +2288,8 @@ import { property as property16 } from "lit/decorators.js";
|
|
|
2330
2288
|
|
|
2331
2289
|
// src/lib/qti-components/qti-response-processing/qti-rule/qti-rule.ts
|
|
2332
2290
|
import { customElement as customElement22 } from "lit/decorators.js";
|
|
2333
|
-
import { html as html20, LitElement as
|
|
2334
|
-
var QtiRule = class extends
|
|
2291
|
+
import { html as html20, LitElement as LitElement15 } from "lit";
|
|
2292
|
+
var QtiRule = class extends LitElement15 {
|
|
2335
2293
|
render() {
|
|
2336
2294
|
return html20`<slot></slot>`;
|
|
2337
2295
|
}
|
|
@@ -2431,13 +2389,12 @@ var QtiSetOutcomeValueRule = class {
|
|
|
2431
2389
|
customElements.define("qti-set-outcome-value", QtiSetOutcomeValue);
|
|
2432
2390
|
|
|
2433
2391
|
// src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-else.ts
|
|
2434
|
-
import { LitElement as
|
|
2435
|
-
var QtiResponseElse = class extends
|
|
2392
|
+
import { LitElement as LitElement16, html as html22 } from "lit";
|
|
2393
|
+
var QtiResponseElse = class extends LitElement16 {
|
|
2436
2394
|
render() {
|
|
2437
2395
|
return html22`<slot></slot>`;
|
|
2438
2396
|
}
|
|
2439
2397
|
calculate() {
|
|
2440
|
-
const result = true;
|
|
2441
2398
|
return true;
|
|
2442
2399
|
}
|
|
2443
2400
|
getSubRules() {
|
|
@@ -2483,9 +2440,9 @@ customElements.define("qti-response-else-if", QtiResponseElseIf);
|
|
|
2483
2440
|
|
|
2484
2441
|
// src/lib/qti-components/qti-response-processing/qti-expression/qti-expression.ts
|
|
2485
2442
|
import { consume as consume4 } from "@lit/context";
|
|
2486
|
-
import { css as css14, html as html24, LitElement as
|
|
2443
|
+
import { css as css14, html as html24, LitElement as LitElement17 } from "lit";
|
|
2487
2444
|
import { state as state8 } from "lit/decorators.js";
|
|
2488
|
-
var QtiExpression = class extends
|
|
2445
|
+
var QtiExpression = class extends LitElement17 {
|
|
2489
2446
|
constructor() {
|
|
2490
2447
|
super(...arguments);
|
|
2491
2448
|
this.getVariables = () => (
|
|
@@ -2849,7 +2806,7 @@ var QtiGt = class extends QtiExpression {
|
|
|
2849
2806
|
const values = this.getVariables();
|
|
2850
2807
|
const value1 = values[0];
|
|
2851
2808
|
const value2 = values[1];
|
|
2852
|
-
if (value1.baseType ===
|
|
2809
|
+
if ((value1.baseType === "integer" || value1.baseType === "float") && (value2.baseType === "integer" || value2.baseType === "float")) {
|
|
2853
2810
|
return +value1.value > +value2.value;
|
|
2854
2811
|
} else {
|
|
2855
2812
|
console.error("unexpected baseType or cardinality in qti gt");
|
|
@@ -2868,7 +2825,7 @@ var QtiGte = class extends QtiConditionExpression {
|
|
|
2868
2825
|
const values = this.getVariables();
|
|
2869
2826
|
const value1 = values[0];
|
|
2870
2827
|
const value2 = values[1];
|
|
2871
|
-
if (value1.baseType ===
|
|
2828
|
+
if ((value1.baseType === "integer" || value1.baseType === "float") && (value2.baseType === "integer" || value2.baseType === "float")) {
|
|
2872
2829
|
return +value1.value >= +value2.value;
|
|
2873
2830
|
} else {
|
|
2874
2831
|
console.error("unexpected baseType or cardinality in qti gte");
|
|
@@ -2905,7 +2862,7 @@ var QtiLt = class extends QtiExpression {
|
|
|
2905
2862
|
const values = this.getVariables();
|
|
2906
2863
|
const value1 = values[0];
|
|
2907
2864
|
const value2 = values[1];
|
|
2908
|
-
if (value1.baseType ===
|
|
2865
|
+
if ((value1.baseType === "integer" || value1.baseType === "float") && (value2.baseType === "integer" || value2.baseType === "float")) {
|
|
2909
2866
|
return +value1.value < +value2.value;
|
|
2910
2867
|
} else {
|
|
2911
2868
|
console.error("unexpected baseType or cardinality in qti lt");
|
|
@@ -2924,7 +2881,7 @@ var QtiLte = class extends QtiConditionExpression {
|
|
|
2924
2881
|
const values = this.getVariables();
|
|
2925
2882
|
const value1 = values[0];
|
|
2926
2883
|
const value2 = values[1];
|
|
2927
|
-
if (value1.baseType ===
|
|
2884
|
+
if ((value1.baseType === "integer" || value1.baseType === "float") && (value2.baseType === "integer" || value2.baseType === "float")) {
|
|
2928
2885
|
return +value1.value <= +value2.value;
|
|
2929
2886
|
} else {
|
|
2930
2887
|
console.error("unexpected baseType or cardinality in qti lte");
|
|
@@ -2975,8 +2932,8 @@ customElements.define("qti-map-response", QtiMapResponse);
|
|
|
2975
2932
|
|
|
2976
2933
|
// src/lib/qti-components/qti-response-processing/qti-expression/qti-mapping/qti-mapping.ts
|
|
2977
2934
|
import { property as property21 } from "lit/decorators.js";
|
|
2978
|
-
import { LitElement as
|
|
2979
|
-
var QtiMapping = class extends
|
|
2935
|
+
import { LitElement as LitElement18 } from "lit";
|
|
2936
|
+
var QtiMapping = class extends LitElement18 {
|
|
2980
2937
|
constructor() {
|
|
2981
2938
|
super(...arguments);
|
|
2982
2939
|
this.defaultValue = 0;
|
|
@@ -3021,7 +2978,6 @@ var QtiMatch = class _QtiMatch extends QtiExpression {
|
|
|
3021
2978
|
return null;
|
|
3022
2979
|
}
|
|
3023
2980
|
static match(valueToMap, correctValueInfo) {
|
|
3024
|
-
var _a;
|
|
3025
2981
|
switch (correctValueInfo.cardinality) {
|
|
3026
2982
|
case "single": {
|
|
3027
2983
|
if (valueToMap.value === null) return false;
|
|
@@ -3030,7 +2986,7 @@ var QtiMatch = class _QtiMatch extends QtiExpression {
|
|
|
3030
2986
|
return false;
|
|
3031
2987
|
}
|
|
3032
2988
|
return ScoringHelper.compareSingleValues(
|
|
3033
|
-
|
|
2989
|
+
valueToMap.value?.toString(),
|
|
3034
2990
|
correctValueInfo.value.toString(),
|
|
3035
2991
|
correctValueInfo.baseType
|
|
3036
2992
|
);
|
|
@@ -3099,7 +3055,7 @@ var QtiMember = class extends QtiExpression {
|
|
|
3099
3055
|
console.warn("The member operator takes two sub-expressions");
|
|
3100
3056
|
}
|
|
3101
3057
|
const [value1, value2] = values;
|
|
3102
|
-
if (!(value1.baseType === value2.baseType)) {
|
|
3058
|
+
if (!(value1.baseType === value2.baseType || value1.baseType === "integer" && value2.baseType === "float" || value1.baseType === "float" && value2.baseType === "integer")) {
|
|
3103
3059
|
console.warn("Which must both have the same base-type");
|
|
3104
3060
|
}
|
|
3105
3061
|
if (!(value2.cardinality === "multiple" || value2.cardinality === "ordered")) {
|
|
@@ -3209,12 +3165,11 @@ customElements.define("qti-ordered", QtiOrdered);
|
|
|
3209
3165
|
|
|
3210
3166
|
// src/lib/qti-components/qti-response-processing/qti-expression/qti-printed-variable/qti-printed-variable.ts
|
|
3211
3167
|
import { consume as consume5 } from "@lit/context";
|
|
3212
|
-
import { LitElement as
|
|
3168
|
+
import { LitElement as LitElement19, html as html26 } from "lit";
|
|
3213
3169
|
import { property as property22, state as state9 } from "lit/decorators.js";
|
|
3214
|
-
var QtiPrintedVariable = class extends
|
|
3170
|
+
var QtiPrintedVariable = class extends LitElement19 {
|
|
3215
3171
|
render() {
|
|
3216
|
-
|
|
3217
|
-
const value = (_b = (_a = this.context) == null ? void 0 : _a.variables.find((v) => v.identifier === this.identifier)) == null ? void 0 : _b.value;
|
|
3172
|
+
const value = this.context?.variables.find((v) => v.identifier === this.identifier)?.value;
|
|
3218
3173
|
return html26`${JSON.stringify(value, null, 2)}`;
|
|
3219
3174
|
}
|
|
3220
3175
|
calculate() {
|
|
@@ -3252,6 +3207,40 @@ var QtiProduct = class extends QtiExpression {
|
|
|
3252
3207
|
};
|
|
3253
3208
|
customElements.define("qti-product", QtiProduct);
|
|
3254
3209
|
|
|
3210
|
+
// src/lib/qti-components/qti-response-processing/qti-expression/qti-subtract/qti-subtract.ts
|
|
3211
|
+
var QtiSubtract = class extends qtiSubtractMixin(QtiExpression) {
|
|
3212
|
+
getResult() {
|
|
3213
|
+
const value = this.calculateChildren(Array.from(this.children));
|
|
3214
|
+
return value;
|
|
3215
|
+
}
|
|
3216
|
+
};
|
|
3217
|
+
function qtiSubtractMixin(Base) {
|
|
3218
|
+
return class MockQtiSubtract extends Base {
|
|
3219
|
+
calculateChildren(children) {
|
|
3220
|
+
const values = children.map((expression) => {
|
|
3221
|
+
if (!expression.calculate) {
|
|
3222
|
+
console.error("Element doesn't implement QtiConditionExpression");
|
|
3223
|
+
return null;
|
|
3224
|
+
}
|
|
3225
|
+
const value = expression.calculate();
|
|
3226
|
+
if (Number.isNaN(value)) {
|
|
3227
|
+
console.error("Unexpected value in qti-subtract, expected number");
|
|
3228
|
+
return null;
|
|
3229
|
+
}
|
|
3230
|
+
return Number(value);
|
|
3231
|
+
});
|
|
3232
|
+
if (values.some((value) => value === null)) {
|
|
3233
|
+
console.error("One or more child expressions returned invalid values");
|
|
3234
|
+
return 0;
|
|
3235
|
+
}
|
|
3236
|
+
return values[0] - values[1];
|
|
3237
|
+
}
|
|
3238
|
+
};
|
|
3239
|
+
}
|
|
3240
|
+
|
|
3241
|
+
// src/lib/qti-components/qti-response-processing/qti-expression/qti-subtract/index.ts
|
|
3242
|
+
customElements.define("qti-subtract", QtiSubtract);
|
|
3243
|
+
|
|
3255
3244
|
// src/lib/qti-components/qti-response-processing/qti-expression/qti-string-match/qti-string-match.ts
|
|
3256
3245
|
import { property as property23 } from "lit/decorators.js";
|
|
3257
3246
|
var QtiStringMatch = class extends QtiExpression {
|
|
@@ -3351,7 +3340,7 @@ var QtiPortableCustomInteraction = class extends Interaction {
|
|
|
3351
3340
|
};
|
|
3352
3341
|
this.getResolvablePathString = (path, basePath) => {
|
|
3353
3342
|
path = path.replace(/\.js$/, "");
|
|
3354
|
-
return
|
|
3343
|
+
return path?.toLocaleLowerCase().startsWith("http") || !basePath ? path : this.removeDoubleSlashes(`${basePath}/${path}`);
|
|
3355
3344
|
};
|
|
3356
3345
|
this.getResolvablePath = (path, basePath) => {
|
|
3357
3346
|
return Array.isArray(path) ? path.map((p) => this.getResolvablePathString(p, basePath)) : this.getResolvablePathString(path, basePath);
|
|
@@ -3398,7 +3387,7 @@ var QtiPortableCustomInteraction = class extends Interaction {
|
|
|
3398
3387
|
validate() {
|
|
3399
3388
|
return true;
|
|
3400
3389
|
}
|
|
3401
|
-
set value(
|
|
3390
|
+
set value(_) {
|
|
3402
3391
|
}
|
|
3403
3392
|
get value() {
|
|
3404
3393
|
return this.rawResponse;
|
|
@@ -3425,7 +3414,7 @@ var QtiPortableCustomInteraction = class extends Interaction {
|
|
|
3425
3414
|
if (el) {
|
|
3426
3415
|
let properties = {};
|
|
3427
3416
|
for (const child of el.children) {
|
|
3428
|
-
properties =
|
|
3417
|
+
properties = { ...properties, ...getPropertyValue(child) };
|
|
3429
3418
|
}
|
|
3430
3419
|
return properties;
|
|
3431
3420
|
}
|
|
@@ -3433,7 +3422,7 @@ var QtiPortableCustomInteraction = class extends Interaction {
|
|
|
3433
3422
|
for (const properties of a) {
|
|
3434
3423
|
const key = properties.getAttribute("key");
|
|
3435
3424
|
if (!key) {
|
|
3436
|
-
config =
|
|
3425
|
+
config = { ...config, ...getChildProperties(properties) };
|
|
3437
3426
|
}
|
|
3438
3427
|
return config;
|
|
3439
3428
|
}
|
|
@@ -3586,12 +3575,8 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3586
3575
|
// Flag to ensure dragstart event is dispatched once
|
|
3587
3576
|
this.rootNode = null;
|
|
3588
3577
|
// Root node for boundary calculations
|
|
3589
|
-
this.
|
|
3590
|
-
// To keep track of the currently focused draggable element
|
|
3591
|
-
this.focusableDropZones = [];
|
|
3578
|
+
this.allDropzones = [];
|
|
3592
3579
|
// All dropzones for keyboard navigation
|
|
3593
|
-
this.currentDropZoneIndex = -1;
|
|
3594
|
-
// Index for tabbing through drop zones
|
|
3595
3580
|
this.dataTransfer = {
|
|
3596
3581
|
data: {},
|
|
3597
3582
|
setData(type, val) {
|
|
@@ -3625,28 +3610,21 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3625
3610
|
document.addEventListener("touchend", this.handleTouchEnd.bind(this), { passive: false });
|
|
3626
3611
|
document.addEventListener("mouseup", this.handleTouchEnd.bind(this), { passive: false });
|
|
3627
3612
|
document.addEventListener("touchcancel", this.handleTouchCancel.bind(this), { passive: false });
|
|
3628
|
-
document.addEventListener("keydown", this.handleKeyDown.bind(this));
|
|
3629
|
-
document.addEventListener("keyup", this.handleKeyUp.bind(this));
|
|
3630
3613
|
}
|
|
3631
3614
|
addDraggableElements(draggables) {
|
|
3632
3615
|
draggables.forEach((el) => {
|
|
3633
3616
|
el.setAttribute("tabindex", "0");
|
|
3634
|
-
el.addEventListener("focus", () => this.focusedElement = el);
|
|
3635
|
-
el.addEventListener("blur", () => this.focusedElement = null);
|
|
3636
3617
|
el.addEventListener("touchstart", this.handleTouchStart.bind(this), { passive: false });
|
|
3637
3618
|
el.addEventListener("mousedown", this.handleTouchStart.bind(this), { passive: false });
|
|
3638
3619
|
});
|
|
3639
3620
|
}
|
|
3640
|
-
|
|
3641
|
-
|
|
3642
|
-
|
|
3643
|
-
|
|
3644
|
-
|
|
3645
|
-
|
|
3646
|
-
|
|
3647
|
-
// // el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });
|
|
3648
|
-
// });
|
|
3649
|
-
// }
|
|
3621
|
+
getInteraction(el) {
|
|
3622
|
+
let parent = el;
|
|
3623
|
+
while (parent && !parent.tagName.toLocaleLowerCase().endsWith("-interaction")) {
|
|
3624
|
+
parent = parent.parentElement;
|
|
3625
|
+
}
|
|
3626
|
+
return parent;
|
|
3627
|
+
}
|
|
3650
3628
|
handleTouchStart(e) {
|
|
3651
3629
|
this.touchStartTime = Date.now();
|
|
3652
3630
|
const { x, y } = this.getEventCoordinates(e);
|
|
@@ -3673,6 +3651,11 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3673
3651
|
}
|
|
3674
3652
|
handleTouchMove(e) {
|
|
3675
3653
|
if (this.isDraggable && this.dragSource) {
|
|
3654
|
+
const interaction = this.getInteraction(this.dragSource);
|
|
3655
|
+
this.allDropzones = [
|
|
3656
|
+
...Array.from(interaction.querySelectorAll("[dropzone]")),
|
|
3657
|
+
...Array.from(interaction.shadowRoot?.querySelectorAll("[dropzone]"))
|
|
3658
|
+
];
|
|
3676
3659
|
const { x, y } = this.getEventCoordinates(e);
|
|
3677
3660
|
const currentTouch = { clientX: x, clientY: y };
|
|
3678
3661
|
if (this.calculateDragDistance(currentTouch) >= this.MIN_DRAG_DISTANCE) {
|
|
@@ -3681,6 +3664,20 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3681
3664
|
}
|
|
3682
3665
|
this.createDragClone(e, currentTouch);
|
|
3683
3666
|
e.preventDefault();
|
|
3667
|
+
const closestDropzone = this.findClosestDropzone();
|
|
3668
|
+
this.currentDropTarget = closestDropzone;
|
|
3669
|
+
if (closestDropzone !== this.lastTarget) {
|
|
3670
|
+
if (this.lastTarget) {
|
|
3671
|
+
this.dispatchCustomEvent(this.lastTarget, "dragleave");
|
|
3672
|
+
}
|
|
3673
|
+
if (closestDropzone) {
|
|
3674
|
+
this.dispatchCustomEvent(closestDropzone, "dragenter");
|
|
3675
|
+
}
|
|
3676
|
+
this.lastTarget = closestDropzone;
|
|
3677
|
+
}
|
|
3678
|
+
if (this.lastTarget) {
|
|
3679
|
+
this.dispatchCustomEvent(this.lastTarget, "dragover");
|
|
3680
|
+
}
|
|
3684
3681
|
}
|
|
3685
3682
|
}
|
|
3686
3683
|
createDragClone(e, currentTouch) {
|
|
@@ -3716,7 +3713,7 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3716
3713
|
}
|
|
3717
3714
|
}
|
|
3718
3715
|
}
|
|
3719
|
-
const dropTarget = this.
|
|
3716
|
+
const dropTarget = this.currentDropTarget;
|
|
3720
3717
|
if (dropTarget !== this.lastTarget) {
|
|
3721
3718
|
this.dispatchCustomEvent(dropTarget, "dragenter");
|
|
3722
3719
|
this.dispatchCustomEvent(this.lastTarget, "dragleave");
|
|
@@ -3726,7 +3723,7 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3726
3723
|
if (this.currentDropTarget) this.dispatchCustomEvent(dropTarget, "dragover");
|
|
3727
3724
|
}
|
|
3728
3725
|
handleTouchEnd(e) {
|
|
3729
|
-
|
|
3726
|
+
this.allDropzones = [];
|
|
3730
3727
|
this.touchEndTriggered = true;
|
|
3731
3728
|
this.isDraggable = false;
|
|
3732
3729
|
let dropFound = false;
|
|
@@ -3737,13 +3734,59 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3737
3734
|
} else if (this.isDragging) {
|
|
3738
3735
|
const dragEndEvent = new CustomEvent("dragend", { bubbles: true, cancelable: true });
|
|
3739
3736
|
dragEndEvent["dataTransfer"] = { dropEffect: "none" };
|
|
3740
|
-
|
|
3737
|
+
this.dragSource?.dispatchEvent(dragEndEvent);
|
|
3741
3738
|
}
|
|
3742
3739
|
this.resetDragState(dropFound);
|
|
3743
3740
|
}
|
|
3744
3741
|
handleTouchCancel(e) {
|
|
3745
3742
|
this.resetDragState();
|
|
3746
3743
|
}
|
|
3744
|
+
findClosestDropzone() {
|
|
3745
|
+
if (!this.dragSource || this.allDropzones.length === 0) return null;
|
|
3746
|
+
const dragRect = this.dragSource.getBoundingClientRect();
|
|
3747
|
+
const dragCorners = this.getCorners(dragRect);
|
|
3748
|
+
const dragCenter = this.getCenter(dragRect);
|
|
3749
|
+
let closestDropzone = null;
|
|
3750
|
+
let minDistance = Infinity;
|
|
3751
|
+
for (const dropzone of this.allDropzones) {
|
|
3752
|
+
const dropRect = dropzone.getBoundingClientRect();
|
|
3753
|
+
const dropCorners = this.getCorners(dropRect);
|
|
3754
|
+
const dropCenter = this.getCenter(dropRect);
|
|
3755
|
+
const cornerDistance = this.calculateTotalCornerDistance(dragCorners, dropCorners) / this.getRectDiagonal(dropRect);
|
|
3756
|
+
const centerDistance = this.calculateDistance(dragCenter, dropCenter);
|
|
3757
|
+
const totalDistance = cornerDistance * 0.5 + centerDistance * 0.5;
|
|
3758
|
+
if (totalDistance < minDistance) {
|
|
3759
|
+
minDistance = totalDistance;
|
|
3760
|
+
closestDropzone = dropzone;
|
|
3761
|
+
}
|
|
3762
|
+
}
|
|
3763
|
+
return closestDropzone;
|
|
3764
|
+
}
|
|
3765
|
+
getCenter(rect) {
|
|
3766
|
+
return {
|
|
3767
|
+
x: rect.left + rect.width / 2,
|
|
3768
|
+
y: rect.top + rect.height / 2
|
|
3769
|
+
};
|
|
3770
|
+
}
|
|
3771
|
+
getRectDiagonal(rect) {
|
|
3772
|
+
return Math.sqrt(rect.width ** 2 + rect.height ** 2);
|
|
3773
|
+
}
|
|
3774
|
+
getCorners(rect) {
|
|
3775
|
+
return {
|
|
3776
|
+
topLeft: { x: rect.left, y: rect.top },
|
|
3777
|
+
topRight: { x: rect.right, y: rect.top },
|
|
3778
|
+
bottomLeft: { x: rect.left, y: rect.bottom },
|
|
3779
|
+
bottomRight: { x: rect.right, y: rect.bottom }
|
|
3780
|
+
};
|
|
3781
|
+
}
|
|
3782
|
+
calculateTotalCornerDistance(cornersA, cornersB) {
|
|
3783
|
+
return this.calculateDistance(cornersA.topLeft, cornersB.topLeft) + this.calculateDistance(cornersA.topRight, cornersB.topRight) + this.calculateDistance(cornersA.bottomLeft, cornersB.bottomLeft) + this.calculateDistance(cornersA.bottomRight, cornersB.bottomRight);
|
|
3784
|
+
}
|
|
3785
|
+
calculateDistance(pointA, pointB) {
|
|
3786
|
+
const dx = pointA.x - pointB.x;
|
|
3787
|
+
const dy = pointA.y - pointB.y;
|
|
3788
|
+
return Math.sqrt(dx * dx + dy * dy);
|
|
3789
|
+
}
|
|
3747
3790
|
findDropTarget(event) {
|
|
3748
3791
|
const { x, y } = this.getEventCoordinates(event);
|
|
3749
3792
|
return this.getDropTargetAtPoint(document, x, y);
|
|
@@ -3775,41 +3818,6 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3775
3818
|
}
|
|
3776
3819
|
return null;
|
|
3777
3820
|
}
|
|
3778
|
-
handleKeyDown(e) {
|
|
3779
|
-
if (this.focusedElement) {
|
|
3780
|
-
if (e.key === " " && !this.isDragging) {
|
|
3781
|
-
e.preventDefault();
|
|
3782
|
-
this.isDraggable = true;
|
|
3783
|
-
this.dragSource = this.focusedElement;
|
|
3784
|
-
this.isDragging = true;
|
|
3785
|
-
this.collectDropZones();
|
|
3786
|
-
this.dispatchCustomEvent(this.dragSource, "dragstart");
|
|
3787
|
-
} else if (e.key === "Tab" && this.isDragging) {
|
|
3788
|
-
e.preventDefault();
|
|
3789
|
-
this.moveToNextDropZone();
|
|
3790
|
-
}
|
|
3791
|
-
}
|
|
3792
|
-
}
|
|
3793
|
-
handleKeyUp(e) {
|
|
3794
|
-
if (e.key === " " && this.isDragging && this.currentDropTarget) {
|
|
3795
|
-
e.preventDefault();
|
|
3796
|
-
this.dispatchCustomEvent(this.currentDropTarget, "drop");
|
|
3797
|
-
this.dispatchCustomEvent(this.dragSource, "dragend");
|
|
3798
|
-
this.resetDragState(true);
|
|
3799
|
-
}
|
|
3800
|
-
}
|
|
3801
|
-
collectDropZones() {
|
|
3802
|
-
this.focusableDropZones = Array.from(document.querySelectorAll("[dropzone]"));
|
|
3803
|
-
this.currentDropZoneIndex = -1;
|
|
3804
|
-
}
|
|
3805
|
-
moveToNextDropZone() {
|
|
3806
|
-
if (this.focusableDropZones.length === 0) return;
|
|
3807
|
-
this.currentDropZoneIndex = (this.currentDropZoneIndex + 1) % this.focusableDropZones.length;
|
|
3808
|
-
const nextDropZone = this.focusableDropZones[this.currentDropZoneIndex];
|
|
3809
|
-
nextDropZone.focus();
|
|
3810
|
-
this.currentDropTarget = nextDropZone;
|
|
3811
|
-
this.dispatchCustomEvent(nextDropZone, "dragenter");
|
|
3812
|
-
}
|
|
3813
3821
|
getEventCoordinates(event, page = false) {
|
|
3814
3822
|
const touch = event.touches ? event.touches[0] : event;
|
|
3815
3823
|
return {
|
|
@@ -3839,26 +3847,6 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3839
3847
|
this.dragClone.style.top = `${boundedTop}px`;
|
|
3840
3848
|
});
|
|
3841
3849
|
}
|
|
3842
|
-
applyTransformBoundaries(deltaX, deltaY) {
|
|
3843
|
-
let boundaryRect;
|
|
3844
|
-
if (this.rootNode instanceof ShadowRoot) {
|
|
3845
|
-
boundaryRect = this.rootNode.host.getBoundingClientRect();
|
|
3846
|
-
} else if (this.rootNode instanceof Document) {
|
|
3847
|
-
boundaryRect = document.documentElement.getBoundingClientRect();
|
|
3848
|
-
} else {
|
|
3849
|
-
boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);
|
|
3850
|
-
}
|
|
3851
|
-
const elementRect = this.dragSource.getBoundingClientRect();
|
|
3852
|
-
const elementWidth = elementRect.width;
|
|
3853
|
-
const elementHeight = elementRect.height;
|
|
3854
|
-
const newLeft = elementRect.left + deltaX;
|
|
3855
|
-
const newTop = elementRect.top + deltaY;
|
|
3856
|
-
const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));
|
|
3857
|
-
const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));
|
|
3858
|
-
const boundedDeltaX = boundedLeft - elementRect.left;
|
|
3859
|
-
const boundedDeltaY = boundedTop - elementRect.top;
|
|
3860
|
-
return { boundedDeltaX, boundedDeltaY };
|
|
3861
|
-
}
|
|
3862
3850
|
applyBoundaries(newLeft, newTop, element) {
|
|
3863
3851
|
let boundaryRect;
|
|
3864
3852
|
if (this.rootNode instanceof ShadowRoot) {
|
|
@@ -3887,11 +3875,10 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3887
3875
|
element.dispatchEvent(event);
|
|
3888
3876
|
}
|
|
3889
3877
|
resetDragState(dropFound = false) {
|
|
3890
|
-
var _a;
|
|
3891
3878
|
if (this.isDragging) {
|
|
3892
3879
|
if (this.useDragClone) {
|
|
3893
3880
|
this.dragSource.style.opacity = "1.0";
|
|
3894
|
-
|
|
3881
|
+
this.dragClone?.parentElement.removeChild(this.dragClone);
|
|
3895
3882
|
} else {
|
|
3896
3883
|
if (!dropFound) this.dragSource.style.transform = "translate(0, 0)";
|
|
3897
3884
|
this.dragSource.style.zIndex = "";
|
|
@@ -3907,6 +3894,7 @@ var TouchDragAndDrop = class _TouchDragAndDrop {
|
|
|
3907
3894
|
this.touchStartTime = 0;
|
|
3908
3895
|
this.touchStartPoint = null;
|
|
3909
3896
|
this.touchEndTriggered = false;
|
|
3897
|
+
this.allDropzones = [];
|
|
3910
3898
|
this.dataTransfer = {
|
|
3911
3899
|
data: {},
|
|
3912
3900
|
setData(type, val) {
|
|
@@ -3993,43 +3981,53 @@ var DroppablesMixin = (superClass, useShadowRoot, droppablesSelector) => {
|
|
|
3993
3981
|
droppable.removeEventListener("drop", this.dropHandler);
|
|
3994
3982
|
}
|
|
3995
3983
|
disconnectedCallback() {
|
|
3996
|
-
var _a;
|
|
3997
3984
|
if (this.isMatchTabular()) return;
|
|
3998
3985
|
super.disconnectedCallback();
|
|
3999
|
-
|
|
3986
|
+
this.observer?.disconnect();
|
|
4000
3987
|
}
|
|
4001
3988
|
dragenterHandler(ev) {
|
|
4002
3989
|
ev.preventDefault();
|
|
4003
3990
|
}
|
|
4004
3991
|
dragoverHandler(ev) {
|
|
3992
|
+
const responseIdentifierDraggable = ev.dataTransfer.getData("responseIdentifier");
|
|
4005
3993
|
ev.preventDefault();
|
|
4006
|
-
this.
|
|
4007
|
-
|
|
3994
|
+
if (responseIdentifierDraggable === this.responseIdentifier) {
|
|
3995
|
+
this.activateDroppable(ev.currentTarget);
|
|
3996
|
+
ev.dataTransfer.dropEffect = "move";
|
|
3997
|
+
}
|
|
4008
3998
|
return false;
|
|
4009
3999
|
}
|
|
4010
4000
|
activateDroppable(droppable) {
|
|
4001
|
+
this._internals.states.delete("--dragzone-active");
|
|
4011
4002
|
droppable.setAttribute("active", "");
|
|
4012
4003
|
}
|
|
4013
4004
|
async dropHandler(ev) {
|
|
4014
4005
|
ev.preventDefault();
|
|
4015
4006
|
const droppable = ev.currentTarget;
|
|
4016
4007
|
const identifier = ev.dataTransfer.getData("text");
|
|
4017
|
-
const
|
|
4008
|
+
const responseIdentifierDraggable = ev.dataTransfer.getData("responseIdentifier");
|
|
4009
|
+
const draggable = this.findDraggable(responseIdentifierDraggable, identifier);
|
|
4018
4010
|
if (!draggable) return false;
|
|
4019
|
-
if (draggable && !this.isValidDrop(droppable, draggable)) {
|
|
4011
|
+
if (draggable && !this.isValidDrop(droppable, draggable, responseIdentifierDraggable)) {
|
|
4020
4012
|
draggable.style.transform = "translate(0, 0)";
|
|
4021
4013
|
return false;
|
|
4022
4014
|
}
|
|
4023
4015
|
await this.moveDraggableToDroppable(draggable, droppable);
|
|
4024
|
-
this.deactivateDroppable(droppable);
|
|
4016
|
+
this.deactivateDroppable(droppable, false);
|
|
4025
4017
|
return false;
|
|
4026
4018
|
}
|
|
4027
|
-
findDraggable(identifier) {
|
|
4019
|
+
findDraggable(responseIdentifier, identifier) {
|
|
4028
4020
|
if (!identifier) return null;
|
|
4029
|
-
|
|
4021
|
+
if (responseIdentifier === this.responseIdentifier) {
|
|
4022
|
+
return this.querySelector(`[identifier=${identifier}]`) || this.shadowRoot.querySelector(`[identifier=${identifier}]`);
|
|
4023
|
+
} else {
|
|
4024
|
+
const assessmentItem = this.closest("qti-assessment-item");
|
|
4025
|
+
const interaction = assessmentItem.querySelector(`[response-identifier=${responseIdentifier}]`);
|
|
4026
|
+
return interaction.querySelector(`[identifier=${identifier}]`);
|
|
4027
|
+
}
|
|
4030
4028
|
}
|
|
4031
|
-
isValidDrop(droppable, draggable) {
|
|
4032
|
-
return
|
|
4029
|
+
isValidDrop(droppable, draggable, responseIdentifierDraggable) {
|
|
4030
|
+
return this.responseIdentifier === responseIdentifierDraggable;
|
|
4033
4031
|
}
|
|
4034
4032
|
async moveDraggableToDroppable(draggable, droppable) {
|
|
4035
4033
|
const moveElement = () => {
|
|
@@ -4045,7 +4043,10 @@ var DroppablesMixin = (superClass, useShadowRoot, droppablesSelector) => {
|
|
|
4045
4043
|
const transition = document.startViewTransition(moveElement);
|
|
4046
4044
|
await transition.finished;
|
|
4047
4045
|
}
|
|
4048
|
-
deactivateDroppable(droppable) {
|
|
4046
|
+
deactivateDroppable(droppable, makeDragzoneActive = true) {
|
|
4047
|
+
if (makeDragzoneActive) {
|
|
4048
|
+
this._internals.states.add("--dragzone-active");
|
|
4049
|
+
}
|
|
4049
4050
|
droppable.removeAttribute("active");
|
|
4050
4051
|
}
|
|
4051
4052
|
dragleaveHandler(ev) {
|
|
@@ -4133,11 +4134,12 @@ import { property as property26 } from "lit/decorators.js";
|
|
|
4133
4134
|
// src/lib/decorators/live-query.ts
|
|
4134
4135
|
function liveQuery(querySelector, options) {
|
|
4135
4136
|
let observer;
|
|
4136
|
-
const resolvedOptions =
|
|
4137
|
+
const resolvedOptions = {
|
|
4138
|
+
...options
|
|
4139
|
+
};
|
|
4137
4140
|
return (proto, decoratedFnName) => {
|
|
4138
4141
|
const { connectedCallback, disconnectedCallback } = proto;
|
|
4139
4142
|
proto.connectedCallback = function() {
|
|
4140
|
-
var _a;
|
|
4141
4143
|
connectedCallback.call(this);
|
|
4142
4144
|
const callback = (mutationList) => {
|
|
4143
4145
|
const elementsToWatch = Array.from(this.querySelectorAll(querySelector));
|
|
@@ -4151,7 +4153,7 @@ function liveQuery(querySelector, options) {
|
|
|
4151
4153
|
};
|
|
4152
4154
|
observer = new MutationObserver(callback);
|
|
4153
4155
|
observer.observe(this, { childList: true, subtree: true });
|
|
4154
|
-
const elementsAdded =
|
|
4156
|
+
const elementsAdded = this.querySelectorAll(querySelector) ?? [];
|
|
4155
4157
|
this[decoratedFnName](Array.from(elementsAdded), []);
|
|
4156
4158
|
};
|
|
4157
4159
|
proto.disconnectedCallback = function() {
|
|
@@ -4182,11 +4184,19 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4182
4184
|
this.handleDragStart = (ev) => {
|
|
4183
4185
|
const target = ev.currentTarget;
|
|
4184
4186
|
ev.dataTransfer.setData("text", target.getAttribute("identifier"));
|
|
4187
|
+
if (this.responseIdentifier) {
|
|
4188
|
+
ev.dataTransfer.setData("responseIdentifier", this.responseIdentifier);
|
|
4189
|
+
}
|
|
4190
|
+
this._internals.states.add("--dragzone-enabled");
|
|
4185
4191
|
target.setAttribute("dragging", "");
|
|
4186
|
-
this.
|
|
4192
|
+
this.activateDragLocation();
|
|
4193
|
+
this.activateDroppables(target);
|
|
4187
4194
|
};
|
|
4188
4195
|
this.handleDragEnd = async (ev) => {
|
|
4189
4196
|
ev.preventDefault();
|
|
4197
|
+
this._internals.states.delete("--dragzone-enabled");
|
|
4198
|
+
this._internals.states.delete("--dragzone-active");
|
|
4199
|
+
this.deactivateDragLocation();
|
|
4190
4200
|
this.deactivateDroppables();
|
|
4191
4201
|
const draggable = ev.currentTarget;
|
|
4192
4202
|
draggable.removeAttribute("dragging");
|
|
@@ -4197,38 +4207,6 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4197
4207
|
}
|
|
4198
4208
|
}
|
|
4199
4209
|
};
|
|
4200
|
-
// MH: This method is just to make sure this can be tested.
|
|
4201
|
-
// because I can't get the dropEffect to be 'move' in the test
|
|
4202
|
-
this.checkForMoveTestItem = (ev) => {
|
|
4203
|
-
if (!ev.dataTransfer.items) {
|
|
4204
|
-
return Promise.resolve(false);
|
|
4205
|
-
}
|
|
4206
|
-
return new Promise((resolve) => {
|
|
4207
|
-
let hasMoveTestItem = false;
|
|
4208
|
-
const items = Array.from(ev.dataTransfer.items);
|
|
4209
|
-
const pending = items.length;
|
|
4210
|
-
if (pending === 0) {
|
|
4211
|
-
resolve(false);
|
|
4212
|
-
return;
|
|
4213
|
-
}
|
|
4214
|
-
items.forEach((item) => {
|
|
4215
|
-
if (item.kind === "string" && item.type === "text") {
|
|
4216
|
-
item.getAsString((data) => {
|
|
4217
|
-
if (data === "move-test") {
|
|
4218
|
-
hasMoveTestItem = true;
|
|
4219
|
-
}
|
|
4220
|
-
if (pending === 0) {
|
|
4221
|
-
resolve(hasMoveTestItem);
|
|
4222
|
-
}
|
|
4223
|
-
});
|
|
4224
|
-
} else {
|
|
4225
|
-
if (pending === 0) {
|
|
4226
|
-
resolve(hasMoveTestItem);
|
|
4227
|
-
}
|
|
4228
|
-
}
|
|
4229
|
-
});
|
|
4230
|
-
});
|
|
4231
|
-
};
|
|
4232
4210
|
}
|
|
4233
4211
|
handleDraggablesChange(dragsAdded, dragsRemoved) {
|
|
4234
4212
|
if (this.isMatchTabular()) return;
|
|
@@ -4280,16 +4258,56 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4280
4258
|
this.droppables = Array.from(
|
|
4281
4259
|
useShadowRootForDroppables ? this.shadowRoot.querySelectorAll(droppablesSelector) : this.querySelectorAll(droppablesSelector)
|
|
4282
4260
|
);
|
|
4261
|
+
const choicesContainerWidth = this.dataset.choicesContainerWidth;
|
|
4262
|
+
if (choicesContainerWidth) {
|
|
4263
|
+
this.droppables.forEach((d) => {
|
|
4264
|
+
d.style.width = `${choicesContainerWidth}px`;
|
|
4265
|
+
d.style.boxSizing = `border-box`;
|
|
4266
|
+
});
|
|
4267
|
+
}
|
|
4268
|
+
}
|
|
4269
|
+
getDragContainers() {
|
|
4270
|
+
const draggleble = Array.from(this.querySelectorAll(`[part='drags']`) || []);
|
|
4271
|
+
const dragglebleShadow = this.shadowRoot ? Array.from(this.shadowRoot.querySelectorAll(`[part='drags']`) || []) : [];
|
|
4272
|
+
return draggleble.concat(dragglebleShadow);
|
|
4273
|
+
}
|
|
4274
|
+
activateDroppables(target) {
|
|
4275
|
+
const dragContainers = this.getDragContainers();
|
|
4276
|
+
dragContainers.forEach((d) => {
|
|
4277
|
+
d.setAttribute("enabled", "");
|
|
4278
|
+
d.setAttribute("dropzone", "move");
|
|
4279
|
+
if (d.hasAttribute("disabled")) {
|
|
4280
|
+
if (d.contains(target) || d.shadowRoot && d.shadowRoot.contains(target)) {
|
|
4281
|
+
d.removeAttribute("disabled");
|
|
4282
|
+
d.setAttribute("dropzone", "move");
|
|
4283
|
+
}
|
|
4284
|
+
}
|
|
4285
|
+
});
|
|
4286
|
+
this.droppables.forEach((d) => {
|
|
4287
|
+
d.setAttribute("enabled", "");
|
|
4288
|
+
if (d.hasAttribute("disabled")) {
|
|
4289
|
+
if (d.contains(target) || d.shadowRoot && d.shadowRoot.contains(target)) {
|
|
4290
|
+
d.removeAttribute("disabled");
|
|
4291
|
+
d.setAttribute("dropzone", "move");
|
|
4292
|
+
}
|
|
4293
|
+
}
|
|
4294
|
+
});
|
|
4283
4295
|
}
|
|
4284
|
-
|
|
4285
|
-
this.
|
|
4296
|
+
activateDragLocation() {
|
|
4297
|
+
this._internals.states.add("--dragzone-enabled");
|
|
4298
|
+
}
|
|
4299
|
+
deactivateDragLocation() {
|
|
4300
|
+
this._internals.states.delete("--dragzone-enabled");
|
|
4286
4301
|
}
|
|
4287
4302
|
deactivateDroppables() {
|
|
4303
|
+
const dragContainers = this.getDragContainers();
|
|
4304
|
+
dragContainers.forEach((d) => {
|
|
4305
|
+
d.removeAttribute("enabled");
|
|
4306
|
+
});
|
|
4288
4307
|
this.droppables.forEach((d) => d.removeAttribute("enabled"));
|
|
4289
4308
|
}
|
|
4290
4309
|
async wasDropped(ev) {
|
|
4291
|
-
|
|
4292
|
-
return ev.dataTransfer.dropEffect !== "none" || hasMoveTestItem;
|
|
4310
|
+
return ev.dataTransfer.dropEffect !== "none";
|
|
4293
4311
|
}
|
|
4294
4312
|
wasMoved(ev) {
|
|
4295
4313
|
return ev.dataTransfer.dropEffect === "move";
|
|
@@ -4312,6 +4330,35 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4312
4330
|
moveDraggable(draggable, parent, index);
|
|
4313
4331
|
});
|
|
4314
4332
|
}
|
|
4333
|
+
validate() {
|
|
4334
|
+
const validAssociations = this.getValidAssociations();
|
|
4335
|
+
let isValid = true;
|
|
4336
|
+
let validityMessage = "";
|
|
4337
|
+
if (this.maxAssociations > 0 && validAssociations > this.maxAssociations) {
|
|
4338
|
+
isValid = false;
|
|
4339
|
+
validityMessage = this.dataset.maxSelectionsMessage || `You've selected too many associations. Maximum allowed is ${this.maxAssociations}.`;
|
|
4340
|
+
} else if (this.minAssociations > 0 && validAssociations < this.minAssociations) {
|
|
4341
|
+
isValid = false;
|
|
4342
|
+
validityMessage = this.dataset.minSelectionsMessage || `You haven't selected enough associations. Minimum required is ${this.minAssociations}.`;
|
|
4343
|
+
}
|
|
4344
|
+
const lastElementChild = this.lastElementChild;
|
|
4345
|
+
this._internals.setValidity(isValid ? {} : { customError: true }, validityMessage, lastElementChild);
|
|
4346
|
+
this.reportValidity();
|
|
4347
|
+
return isValid;
|
|
4348
|
+
}
|
|
4349
|
+
reportValidity() {
|
|
4350
|
+
const validationMessageElement = this.shadowRoot.querySelector("#validationMessage");
|
|
4351
|
+
if (validationMessageElement) {
|
|
4352
|
+
if (!this._internals.validity.valid) {
|
|
4353
|
+
validationMessageElement.textContent = this._internals.validationMessage;
|
|
4354
|
+
validationMessageElement.style.display = "block";
|
|
4355
|
+
} else {
|
|
4356
|
+
validationMessageElement.textContent = "";
|
|
4357
|
+
validationMessageElement.style.display = "none";
|
|
4358
|
+
}
|
|
4359
|
+
}
|
|
4360
|
+
return this._internals.validity.valid;
|
|
4361
|
+
}
|
|
4315
4362
|
checkMaxAssociations() {
|
|
4316
4363
|
this.droppables.forEach((d, index) => {
|
|
4317
4364
|
const maxMatch = +(d.getAttribute("match-max") || 1);
|
|
@@ -4338,7 +4385,16 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4338
4385
|
set value(value) {
|
|
4339
4386
|
if (this.isMatchTabular()) return;
|
|
4340
4387
|
this.resetDroppables();
|
|
4341
|
-
value
|
|
4388
|
+
value?.forEach((entry) => this.placeResponse(entry));
|
|
4389
|
+
if (Array.isArray(value)) {
|
|
4390
|
+
const formData = new FormData();
|
|
4391
|
+
value.forEach((response) => {
|
|
4392
|
+
formData.append(this.responseIdentifier, response);
|
|
4393
|
+
});
|
|
4394
|
+
this._internals.setFormValue(formData);
|
|
4395
|
+
} else {
|
|
4396
|
+
this._internals.setFormValue(value);
|
|
4397
|
+
}
|
|
4342
4398
|
}
|
|
4343
4399
|
placeResponse(response) {
|
|
4344
4400
|
const [dropId, ...dragIds] = response.split(" ").reverse();
|
|
@@ -4366,14 +4422,11 @@ var DragDropInteractionMixin = (superClass, draggablesSelector, useShadowRootFor
|
|
|
4366
4422
|
await transition.finished;
|
|
4367
4423
|
}
|
|
4368
4424
|
}
|
|
4369
|
-
validate() {
|
|
4370
|
-
const validAssociations = this.getValidAssociations();
|
|
4371
|
-
return this.minAssociations <= 0 || this.minAssociations <= validAssociations;
|
|
4372
|
-
}
|
|
4373
4425
|
getValidAssociations() {
|
|
4374
4426
|
return this.droppables.filter((d) => d.childElementCount > 0).length;
|
|
4375
4427
|
}
|
|
4376
4428
|
saveResponse() {
|
|
4429
|
+
this.validate();
|
|
4377
4430
|
const response = this.collectResponseData();
|
|
4378
4431
|
this.dispatchEvent(
|
|
4379
4432
|
new CustomEvent("qti-interaction-response", {
|
|
@@ -4481,9 +4534,10 @@ var QtiAssociateInteraction = class extends DragDropInteractionMixin(
|
|
|
4481
4534
|
<div part="drop-container">
|
|
4482
4535
|
${this._childrenMap.length > 0 && Array.from(Array(Math.ceil(this._childrenMap.length / 2)).keys()).map(
|
|
4483
4536
|
(_, index) => html28`<div part="associables-container">
|
|
4484
|
-
|
|
4485
|
-
|
|
4486
|
-
|
|
4537
|
+
<div name="left${index}" part="drop-list" class="dl" identifier="droplist${index}_left"></div>
|
|
4538
|
+
<div name="right${index}" part="drop-list" class="dl" identifier="droplist${index}_right"></div>
|
|
4539
|
+
</div>
|
|
4540
|
+
<div role="alert" id="validationMessage"></div>`
|
|
4487
4541
|
)}
|
|
4488
4542
|
</div>`;
|
|
4489
4543
|
}
|
|
@@ -4524,7 +4578,7 @@ var QtiCustomInteraction = class extends Interaction {
|
|
|
4524
4578
|
// is embedded in an iframe and coming from another domain
|
|
4525
4579
|
// Therefor we need to use the new CES API to communicates via the broadcast API
|
|
4526
4580
|
setupCES() {
|
|
4527
|
-
const iframe = this.shadowRoot.querySelector("#pciContainer"),
|
|
4581
|
+
const iframe = this.shadowRoot.querySelector("#pciContainer"), iframeDoc = iframe.contentDocument;
|
|
4528
4582
|
window.addEventListener("message", this.handlePostMessage);
|
|
4529
4583
|
iframeDoc.open();
|
|
4530
4584
|
iframeDoc.write(`
|
|
@@ -4681,12 +4735,12 @@ var QtiEndAttemptInteraction = class extends Interaction {
|
|
|
4681
4735
|
get value() {
|
|
4682
4736
|
return "";
|
|
4683
4737
|
}
|
|
4684
|
-
set value(
|
|
4738
|
+
set value(_) {
|
|
4685
4739
|
}
|
|
4686
4740
|
render() {
|
|
4687
4741
|
return html30`<button ?disabled=${this.disabled} part="button" @click=${this.endAttempt}>${this.title}</button>`;
|
|
4688
4742
|
}
|
|
4689
|
-
endAttempt(
|
|
4743
|
+
endAttempt(_) {
|
|
4690
4744
|
this.dispatchEvent(
|
|
4691
4745
|
new CustomEvent("end-attempt", {
|
|
4692
4746
|
bubbles: true,
|
|
@@ -4707,11 +4761,99 @@ QtiEndAttemptInteraction = __decorateClass([
|
|
|
4707
4761
|
], QtiEndAttemptInteraction);
|
|
4708
4762
|
|
|
4709
4763
|
// src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.ts
|
|
4710
|
-
import {
|
|
4764
|
+
import { html as html31 } from "lit";
|
|
4711
4765
|
import { customElement as customElement27 } from "lit/decorators.js";
|
|
4766
|
+
|
|
4767
|
+
// src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.styles.ts
|
|
4768
|
+
import { css as css16 } from "lit";
|
|
4769
|
+
var qti_gap_match_interaction_styles_default = css16`
|
|
4770
|
+
:host {
|
|
4771
|
+
display: flex;
|
|
4772
|
+
align-items: flex-start;
|
|
4773
|
+
flex-direction: column;
|
|
4774
|
+
flex-wrap: wrap;
|
|
4775
|
+
gap: 0.5rem;
|
|
4776
|
+
}
|
|
4777
|
+
|
|
4778
|
+
:host(.qti-choices-top) {
|
|
4779
|
+
flex-direction: column;
|
|
4780
|
+
}
|
|
4781
|
+
:host(.qti-choices-bottom) {
|
|
4782
|
+
flex-direction: column-reverse;
|
|
4783
|
+
}
|
|
4784
|
+
:host(.qti-choices-left) {
|
|
4785
|
+
flex-direction: row;
|
|
4786
|
+
}
|
|
4787
|
+
:host(.qti-choices-right) {
|
|
4788
|
+
flex-direction: row-reverse;
|
|
4789
|
+
}
|
|
4790
|
+
/* [part='drops'] , */
|
|
4791
|
+
[name='prompt'] {
|
|
4792
|
+
width: 100%;
|
|
4793
|
+
}
|
|
4794
|
+
[name='drags'] {
|
|
4795
|
+
display: flex;
|
|
4796
|
+
align-items: flex-start;
|
|
4797
|
+
flex: 1;
|
|
4798
|
+
border: 2px solid transparent;
|
|
4799
|
+
padding: 0.3rem;
|
|
4800
|
+
border-radius: 0.3rem;
|
|
4801
|
+
gap: 0.5rem;
|
|
4802
|
+
}
|
|
4803
|
+
`;
|
|
4804
|
+
|
|
4805
|
+
// src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.ts
|
|
4712
4806
|
var QtiGapMatchInteraction = class extends DragDropInteractionMixin(Interaction, "qti-gap-text", false, "qti-gap") {
|
|
4807
|
+
constructor() {
|
|
4808
|
+
super(...arguments);
|
|
4809
|
+
this.observer = null;
|
|
4810
|
+
this.resizeObserver = null;
|
|
4811
|
+
}
|
|
4713
4812
|
render() {
|
|
4714
|
-
return html31`<slot name="prompt"> </slot
|
|
4813
|
+
return html31`<slot name="prompt"> </slot>
|
|
4814
|
+
<slot part="drags" name="drags"></slot>
|
|
4815
|
+
<slot part="drops"></slot>
|
|
4816
|
+
<div role="alert" id="validationMessage"></div>`;
|
|
4817
|
+
}
|
|
4818
|
+
firstUpdated(_changedProperties) {
|
|
4819
|
+
super.firstUpdated(_changedProperties);
|
|
4820
|
+
this.updateMinDimensionsForDrowZones();
|
|
4821
|
+
this.observer = new MutationObserver(() => this.updateMinDimensionsForDrowZones());
|
|
4822
|
+
this.observer.observe(this, { childList: true, subtree: true });
|
|
4823
|
+
this.resizeObserver = new ResizeObserver(() => this.updateMinDimensionsForDrowZones());
|
|
4824
|
+
const gapTexts = this.querySelectorAll("qti-gap-text");
|
|
4825
|
+
gapTexts.forEach((gapText) => this.resizeObserver?.observe(gapText));
|
|
4826
|
+
}
|
|
4827
|
+
disconnectedCallback() {
|
|
4828
|
+
super.disconnectedCallback();
|
|
4829
|
+
if (this.observer) {
|
|
4830
|
+
this.observer.disconnect();
|
|
4831
|
+
this.observer = null;
|
|
4832
|
+
}
|
|
4833
|
+
if (this.resizeObserver) {
|
|
4834
|
+
this.resizeObserver.disconnect();
|
|
4835
|
+
this.resizeObserver = null;
|
|
4836
|
+
}
|
|
4837
|
+
}
|
|
4838
|
+
updateMinDimensionsForDrowZones() {
|
|
4839
|
+
const gapTexts = this.querySelectorAll("qti-gap-text");
|
|
4840
|
+
const gaps = this.querySelectorAll("qti-gap");
|
|
4841
|
+
let maxHeight = 0;
|
|
4842
|
+
let maxWidth = 0;
|
|
4843
|
+
gapTexts.forEach((gapText) => {
|
|
4844
|
+
const rect = gapText.getBoundingClientRect();
|
|
4845
|
+
maxHeight = Math.max(maxHeight, rect.height);
|
|
4846
|
+
maxWidth = Math.max(maxWidth, rect.width);
|
|
4847
|
+
});
|
|
4848
|
+
const dragSlot = this.shadowRoot?.querySelector('[part="drags"]');
|
|
4849
|
+
if (dragSlot) {
|
|
4850
|
+
dragSlot.style.minHeight = `${maxHeight}px`;
|
|
4851
|
+
dragSlot.style.minWidth = `${maxWidth}px`;
|
|
4852
|
+
}
|
|
4853
|
+
for (const gap of gaps) {
|
|
4854
|
+
gap.style.minHeight = `${maxHeight}px`;
|
|
4855
|
+
gap.style.minWidth = `${maxWidth}px`;
|
|
4856
|
+
}
|
|
4715
4857
|
}
|
|
4716
4858
|
set correctResponse(value) {
|
|
4717
4859
|
let matches = [];
|
|
@@ -4723,54 +4865,24 @@ var QtiGapMatchInteraction = class extends DragDropInteractionMixin(Interaction,
|
|
|
4723
4865
|
});
|
|
4724
4866
|
}
|
|
4725
4867
|
const gaps = this.querySelectorAll("qti-gap");
|
|
4726
|
-
gaps.forEach((gap
|
|
4727
|
-
var _a, _b, _c, _d;
|
|
4868
|
+
gaps.forEach((gap) => {
|
|
4728
4869
|
const identifier = gap.getAttribute("identifier");
|
|
4729
|
-
const textIdentifier =
|
|
4730
|
-
const text =
|
|
4870
|
+
const textIdentifier = matches.find((x) => x.gap === identifier)?.text;
|
|
4871
|
+
const text = this.querySelector(`qti-gap-text[identifier="${textIdentifier}"]`)?.textContent.trim();
|
|
4731
4872
|
if (textIdentifier && text) {
|
|
4732
|
-
if (!
|
|
4873
|
+
if (!gap.nextElementSibling?.classList.contains("correct-option")) {
|
|
4733
4874
|
const textSpan = document.createElement("span");
|
|
4734
4875
|
textSpan.classList.add("correct-option");
|
|
4735
4876
|
textSpan.textContent = text;
|
|
4736
4877
|
gap.insertAdjacentElement("afterend", textSpan);
|
|
4737
4878
|
}
|
|
4738
|
-
} else if (
|
|
4879
|
+
} else if (gap.nextElementSibling?.classList.contains("correct-option")) {
|
|
4739
4880
|
gap.nextElementSibling.remove();
|
|
4740
4881
|
}
|
|
4741
4882
|
});
|
|
4742
4883
|
}
|
|
4743
4884
|
};
|
|
4744
|
-
QtiGapMatchInteraction.styles =
|
|
4745
|
-
css16`
|
|
4746
|
-
:host {
|
|
4747
|
-
display: flex;
|
|
4748
|
-
align-items: flex-start;
|
|
4749
|
-
flex-direction: column;
|
|
4750
|
-
gap: 0.5rem;
|
|
4751
|
-
}
|
|
4752
|
-
|
|
4753
|
-
:host(.qti-choices-top) {
|
|
4754
|
-
flex-direction: column;
|
|
4755
|
-
}
|
|
4756
|
-
:host(.qti-choices-bottom) {
|
|
4757
|
-
flex-direction: column-reverse;
|
|
4758
|
-
}
|
|
4759
|
-
:host(.qti-choices-left) {
|
|
4760
|
-
flex-direction: row;
|
|
4761
|
-
}
|
|
4762
|
-
:host(.qti-choices-right) {
|
|
4763
|
-
flex-direction: row-reverse;
|
|
4764
|
-
}
|
|
4765
|
-
/* [part='drops'] , */
|
|
4766
|
-
[part='drags'] {
|
|
4767
|
-
display: flex;
|
|
4768
|
-
align-items: flex-start;
|
|
4769
|
-
flex: 1;
|
|
4770
|
-
gap: 0.5rem;
|
|
4771
|
-
}
|
|
4772
|
-
`
|
|
4773
|
-
];
|
|
4885
|
+
QtiGapMatchInteraction.styles = qti_gap_match_interaction_styles_default;
|
|
4774
4886
|
QtiGapMatchInteraction = __decorateClass([
|
|
4775
4887
|
customElement27("qti-gap-match-interaction")
|
|
4776
4888
|
], QtiGapMatchInteraction);
|
|
@@ -4869,13 +4981,12 @@ var QtiGraphicAssociateInteraction = class extends Interaction {
|
|
|
4869
4981
|
return this._lines;
|
|
4870
4982
|
}
|
|
4871
4983
|
render() {
|
|
4872
|
-
var _a, _b, _c, _d;
|
|
4873
4984
|
return html32`<slot name="prompt"></slot>
|
|
4874
4985
|
<line-container>
|
|
4875
4986
|
<svg
|
|
4876
|
-
width=${ifDefined3(
|
|
4877
|
-
height=${ifDefined3(
|
|
4878
|
-
viewbox="0 0 ${
|
|
4987
|
+
width=${ifDefined3(this.grImage[0]?.width)}
|
|
4988
|
+
height=${ifDefined3(this.grImage[0]?.height)}
|
|
4989
|
+
viewbox="0 0 ${this.grImage[0]?.width} ${this.grImage[0]?.height}"
|
|
4879
4990
|
>
|
|
4880
4991
|
${repeat(
|
|
4881
4992
|
this._lines,
|
|
@@ -4908,7 +5019,8 @@ var QtiGraphicAssociateInteraction = class extends Interaction {
|
|
|
4908
5019
|
/>`}
|
|
4909
5020
|
</svg>
|
|
4910
5021
|
<slot></slot>
|
|
4911
|
-
</line-container
|
|
5022
|
+
</line-container>
|
|
5023
|
+
<div role="alert" id="validationMessage"></div>`;
|
|
4912
5024
|
}
|
|
4913
5025
|
positionHotspotOnRegister(e) {
|
|
4914
5026
|
const img = this.querySelector("img");
|
|
@@ -5002,21 +5114,116 @@ QtiGraphicAssociateInteraction = __decorateClass([
|
|
|
5002
5114
|
], QtiGraphicAssociateInteraction);
|
|
5003
5115
|
|
|
5004
5116
|
// src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.ts
|
|
5005
|
-
import {
|
|
5117
|
+
import { html as html33 } from "lit";
|
|
5006
5118
|
import { customElement as customElement29 } from "lit/decorators.js";
|
|
5119
|
+
|
|
5120
|
+
// src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.styles.ts
|
|
5121
|
+
import { css as css18 } from "lit";
|
|
5122
|
+
var qti_graphic_gap_match_interaction_styles_default = css18`
|
|
5123
|
+
:host {
|
|
5124
|
+
display: flex;
|
|
5125
|
+
align-items: flex-start;
|
|
5126
|
+
flex-direction: column;
|
|
5127
|
+
flex-wrap: wrap;
|
|
5128
|
+
gap: 0.5rem;
|
|
5129
|
+
}
|
|
5130
|
+
|
|
5131
|
+
:host(.qti-choices-top) {
|
|
5132
|
+
flex-direction: column-reverse;
|
|
5133
|
+
}
|
|
5134
|
+
:host(.qti-choices-bottom) {
|
|
5135
|
+
flex-direction: column;
|
|
5136
|
+
}
|
|
5137
|
+
:host(.qti-choices-left) {
|
|
5138
|
+
flex-direction: row-reverse;
|
|
5139
|
+
& [name='drags'] {
|
|
5140
|
+
width: 25%;
|
|
5141
|
+
}
|
|
5142
|
+
& [part='image'] {
|
|
5143
|
+
width: 75%;
|
|
5144
|
+
}
|
|
5145
|
+
}
|
|
5146
|
+
:host(.qti-choices-right) {
|
|
5147
|
+
flex-direction: row;
|
|
5148
|
+
& [name='drags'] {
|
|
5149
|
+
width: 25%;
|
|
5150
|
+
}
|
|
5151
|
+
& [part='image'] {
|
|
5152
|
+
width: 75%;
|
|
5153
|
+
}
|
|
5154
|
+
}
|
|
5155
|
+
[part='image'] {
|
|
5156
|
+
display: block;
|
|
5157
|
+
position: relative;
|
|
5158
|
+
}
|
|
5159
|
+
/* [part='drops'] , */
|
|
5160
|
+
|
|
5161
|
+
[name='drags'] {
|
|
5162
|
+
display: flex;
|
|
5163
|
+
align-items: flex-start;
|
|
5164
|
+
flex-wrap: wrap;
|
|
5165
|
+
flex: 1;
|
|
5166
|
+
border: 2px solid transparent;
|
|
5167
|
+
padding: 0.3rem;
|
|
5168
|
+
border-radius: 0.3rem;
|
|
5169
|
+
gap: 0.5rem;
|
|
5170
|
+
}
|
|
5171
|
+
::slotted(img) {
|
|
5172
|
+
display: inline-block;
|
|
5173
|
+
user-select: none;
|
|
5174
|
+
pointer-events: none;
|
|
5175
|
+
}
|
|
5176
|
+
`;
|
|
5177
|
+
|
|
5178
|
+
// src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.ts
|
|
5007
5179
|
var QtiGraphicGapMatchInteraction = class extends DragDropInteractionMixin(
|
|
5008
5180
|
Interaction,
|
|
5009
|
-
"qti-gap-img",
|
|
5181
|
+
"qti-gap-img, qti-gap-text",
|
|
5010
5182
|
false,
|
|
5011
5183
|
"qti-associable-hotspot"
|
|
5012
5184
|
) {
|
|
5185
|
+
constructor() {
|
|
5186
|
+
super(...arguments);
|
|
5187
|
+
this.observer = null;
|
|
5188
|
+
this.resizeObserver = null;
|
|
5189
|
+
}
|
|
5013
5190
|
render() {
|
|
5014
5191
|
return html33` <slot name="prompt"></slot>
|
|
5015
|
-
<slot></slot>
|
|
5016
|
-
<slot name="
|
|
5192
|
+
<slot part="image"></slot>
|
|
5193
|
+
<slot part="drags" name="drags"></slot>
|
|
5194
|
+
<div role="alert" id="validationMessage"></div>`;
|
|
5195
|
+
}
|
|
5196
|
+
firstUpdated(_changedProperties) {
|
|
5197
|
+
super.firstUpdated(_changedProperties);
|
|
5198
|
+
this.updateMinDimensionsForDrowZones();
|
|
5199
|
+
this.observer = new MutationObserver(() => this.updateMinDimensionsForDrowZones());
|
|
5200
|
+
this.observer.observe(this, { childList: true, subtree: true });
|
|
5201
|
+
this.resizeObserver = new ResizeObserver(() => this.updateMinDimensionsForDrowZones());
|
|
5202
|
+
const draggableGaps = this.querySelectorAll("qti-gap-img, qti-gap-text");
|
|
5203
|
+
draggableGaps.forEach((gapText) => this.resizeObserver?.observe(gapText));
|
|
5204
|
+
}
|
|
5205
|
+
updateMinDimensionsForDrowZones() {
|
|
5206
|
+
const draggableGaps = this.querySelectorAll("qti-gap-img, qti-gap-text");
|
|
5207
|
+
const gaps = this.querySelectorAll("qti-associable-hotspot");
|
|
5208
|
+
let maxHeight = 0;
|
|
5209
|
+
let maxWidth = 0;
|
|
5210
|
+
draggableGaps.forEach((gapText) => {
|
|
5211
|
+
const rect = gapText.getBoundingClientRect();
|
|
5212
|
+
maxHeight = Math.max(maxHeight, rect.height);
|
|
5213
|
+
maxWidth = Math.max(maxWidth, rect.width);
|
|
5214
|
+
});
|
|
5215
|
+
const slots = this.shadowRoot.querySelectorAll("slot");
|
|
5216
|
+
const dragSlot = Array.from(slots).find((slot) => slot.name === "drags");
|
|
5217
|
+
if (dragSlot) {
|
|
5218
|
+
dragSlot.style.minHeight = `${maxHeight}px`;
|
|
5219
|
+
dragSlot.style.minWidth = `${maxWidth}px`;
|
|
5220
|
+
}
|
|
5221
|
+
for (const gap of gaps) {
|
|
5222
|
+
gap.style.minHeight = `${maxHeight}px`;
|
|
5223
|
+
gap.style.minWidth = `${maxWidth}px`;
|
|
5224
|
+
}
|
|
5017
5225
|
}
|
|
5018
5226
|
positionHotspotOnRegister(e) {
|
|
5019
|
-
const img = this.querySelector("img");
|
|
5020
5227
|
const hotspot = e.target;
|
|
5021
5228
|
const coords = hotspot.getAttribute("coords");
|
|
5022
5229
|
const shape = hotspot.getAttribute("shape");
|
|
@@ -5052,16 +5259,7 @@ var QtiGraphicGapMatchInteraction = class extends DragDropInteractionMixin(
|
|
|
5052
5259
|
this.removeEventListener("qti-register-hotspot", this.positionHotspotOnRegister);
|
|
5053
5260
|
}
|
|
5054
5261
|
};
|
|
5055
|
-
QtiGraphicGapMatchInteraction.styles =
|
|
5056
|
-
:host {
|
|
5057
|
-
display: inline-block;
|
|
5058
|
-
position: relative;
|
|
5059
|
-
}
|
|
5060
|
-
slot[name='qti-gap-img'] {
|
|
5061
|
-
display: flex;
|
|
5062
|
-
gap: 1rem;
|
|
5063
|
-
}
|
|
5064
|
-
`;
|
|
5262
|
+
QtiGraphicGapMatchInteraction.styles = qti_graphic_gap_match_interaction_styles_default;
|
|
5065
5263
|
QtiGraphicGapMatchInteraction = __decorateClass([
|
|
5066
5264
|
customElement29("qti-graphic-gap-match-interaction")
|
|
5067
5265
|
], QtiGraphicGapMatchInteraction);
|
|
@@ -5080,6 +5278,7 @@ var QtiGraphicOrderInteraction = class extends ChoicesMixin(Interaction, "qti-ho
|
|
|
5080
5278
|
<!-- slot for the prompt -->
|
|
5081
5279
|
<slot></slot>
|
|
5082
5280
|
<!-- slot for the image and hotspots -->
|
|
5281
|
+
<div role="alert" id="validationMessage"></div>
|
|
5083
5282
|
`;
|
|
5084
5283
|
}
|
|
5085
5284
|
setHotspotOrder(e) {
|
|
@@ -5203,9 +5402,9 @@ import { customElement as customElement33, property as property30, state as stat
|
|
|
5203
5402
|
import { unsafeHTML as unsafeHTML2 } from "lit/directives/unsafe-html.js";
|
|
5204
5403
|
|
|
5205
5404
|
// src/lib/qti-components/qti-interaction/qti-simple-associable-choice.ts
|
|
5206
|
-
import { css as css21, html as html36, LitElement as
|
|
5405
|
+
import { css as css21, html as html36, LitElement as LitElement20 } from "lit";
|
|
5207
5406
|
import { customElement as customElement32, property as property29 } from "lit/decorators.js";
|
|
5208
|
-
var QtiSimpleAssociableChoice = class extends ActiveElementMixin(
|
|
5407
|
+
var QtiSimpleAssociableChoice = class extends ActiveElementMixin(LitElement20, "qti-simple-associable-choice") {
|
|
5209
5408
|
constructor() {
|
|
5210
5409
|
super(...arguments);
|
|
5211
5410
|
this.matchMin = 0;
|
|
@@ -5381,20 +5580,21 @@ var QtiMatchInteraction = class extends DragDropInteractionMixin(
|
|
|
5381
5580
|
}
|
|
5382
5581
|
render() {
|
|
5383
5582
|
if (!this.classList.contains("qti-match-tabular")) {
|
|
5384
|
-
return html37`<slot name="prompt"></slot> <slot></slot
|
|
5583
|
+
return html37`<slot name="prompt"></slot> <slot></slot>
|
|
5584
|
+
<div role="alert" id="validationMessage"></div>`;
|
|
5385
5585
|
}
|
|
5386
5586
|
return html37`
|
|
5387
5587
|
<slot name="prompt"></slot>
|
|
5388
5588
|
<table>
|
|
5389
5589
|
<tr>
|
|
5390
5590
|
<td></td>
|
|
5391
|
-
${this.cols.map((col
|
|
5591
|
+
${this.cols.map((col) => html37`<th part="r-header">${unsafeHTML2(col.innerHTML)}</th>`)}
|
|
5392
5592
|
</tr>
|
|
5393
5593
|
|
|
5394
5594
|
${this.rows.map(
|
|
5395
|
-
(row
|
|
5595
|
+
(row) => html37`<tr>
|
|
5396
5596
|
<td part="c-header">${unsafeHTML2(row.innerHTML)}</td>
|
|
5397
|
-
${this.cols.map((col
|
|
5597
|
+
${this.cols.map((col) => {
|
|
5398
5598
|
const rowId = row.getAttribute("identifier");
|
|
5399
5599
|
const colId = col.getAttribute("identifier");
|
|
5400
5600
|
const value = `${rowId} ${colId}`;
|
|
@@ -5459,13 +5659,16 @@ var QtiMediaInteraction = class extends Interaction {
|
|
|
5459
5659
|
}
|
|
5460
5660
|
}
|
|
5461
5661
|
static get properties() {
|
|
5462
|
-
return
|
|
5463
|
-
|
|
5464
|
-
|
|
5465
|
-
|
|
5466
|
-
|
|
5662
|
+
return {
|
|
5663
|
+
...Interaction.properties,
|
|
5664
|
+
...{
|
|
5665
|
+
step: {
|
|
5666
|
+
type: Number,
|
|
5667
|
+
attribute: "step",
|
|
5668
|
+
default: 10
|
|
5669
|
+
}
|
|
5467
5670
|
}
|
|
5468
|
-
}
|
|
5671
|
+
};
|
|
5469
5672
|
}
|
|
5470
5673
|
render() {
|
|
5471
5674
|
return html38` <slot name="prompt"></slot>
|
|
@@ -5523,12 +5726,12 @@ var QtiOrderInteraction = class extends ShuffleMixin(
|
|
|
5523
5726
|
}
|
|
5524
5727
|
if (this.correctResponses.length === 0) {
|
|
5525
5728
|
const responses = Array.isArray(value) ? value : [value];
|
|
5526
|
-
responses.forEach((response
|
|
5729
|
+
responses.forEach((response) => {
|
|
5527
5730
|
let simpleChoice = this.querySelector(`qti-simple-choice[identifier="${response}"]`);
|
|
5528
5731
|
if (!simpleChoice) {
|
|
5529
5732
|
simpleChoice = this.shadowRoot.querySelector(`qti-simple-choice[identifier="${response}"]`);
|
|
5530
5733
|
}
|
|
5531
|
-
const text = simpleChoice
|
|
5734
|
+
const text = simpleChoice?.textContent.trim();
|
|
5532
5735
|
this.correctResponses = [...this.correctResponses, text];
|
|
5533
5736
|
});
|
|
5534
5737
|
}
|
|
@@ -5622,13 +5825,13 @@ QtiOrderInteraction = __decorateClass([
|
|
|
5622
5825
|
], QtiOrderInteraction);
|
|
5623
5826
|
|
|
5624
5827
|
// src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-interaction.ts
|
|
5625
|
-
import { LitElement as
|
|
5626
|
-
var
|
|
5828
|
+
import { LitElement as LitElement21, css as css25, html as html40 } from "lit";
|
|
5829
|
+
var QtiPositionObjectInteraction = class extends LitElement21 {
|
|
5627
5830
|
render() {
|
|
5628
5831
|
return html40`<slot></slot>`;
|
|
5629
5832
|
}
|
|
5630
5833
|
};
|
|
5631
|
-
|
|
5834
|
+
QtiPositionObjectInteraction.styles = [
|
|
5632
5835
|
css25`
|
|
5633
5836
|
:host {
|
|
5634
5837
|
display: block;
|
|
@@ -5642,12 +5845,12 @@ QtiSPositionObjectInteraction.styles = [
|
|
|
5642
5845
|
}
|
|
5643
5846
|
`
|
|
5644
5847
|
];
|
|
5645
|
-
customElements.define("qti-position-object-interaction",
|
|
5848
|
+
customElements.define("qti-position-object-interaction", QtiPositionObjectInteraction);
|
|
5646
5849
|
|
|
5647
5850
|
// src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-stage.ts
|
|
5648
|
-
import { LitElement as
|
|
5851
|
+
import { LitElement as LitElement22, css as css26, html as html41 } from "lit";
|
|
5649
5852
|
import { customElement as customElement36 } from "lit/decorators.js";
|
|
5650
|
-
var QtiPositionObjectStage = class extends
|
|
5853
|
+
var QtiPositionObjectStage = class extends LitElement22 {
|
|
5651
5854
|
render() {
|
|
5652
5855
|
return html41`<slot></slot>`;
|
|
5653
5856
|
}
|
|
@@ -5678,7 +5881,7 @@ var QtiPositionObjectStage = class extends LitElement30 {
|
|
|
5678
5881
|
});
|
|
5679
5882
|
document.addEventListener("mouseup", this.removeMoveListener);
|
|
5680
5883
|
}
|
|
5681
|
-
removeMoveListener(
|
|
5884
|
+
removeMoveListener() {
|
|
5682
5885
|
document.removeEventListener("mousemove", this.dragElementHandler, true);
|
|
5683
5886
|
}
|
|
5684
5887
|
disconnectedCallback() {
|
|
@@ -5816,9 +6019,9 @@ var QtiSliderInteraction = class extends Interaction {
|
|
|
5816
6019
|
this._value = 0;
|
|
5817
6020
|
this.stepLabel = false;
|
|
5818
6021
|
this.reverse = false;
|
|
5819
|
-
this._handleDisabledChange = (
|
|
6022
|
+
this._handleDisabledChange = () => {
|
|
5820
6023
|
};
|
|
5821
|
-
this._handleReadonlyChange = (
|
|
6024
|
+
this._handleReadonlyChange = () => {
|
|
5822
6025
|
};
|
|
5823
6026
|
this.csLive = getComputedStyle(this);
|
|
5824
6027
|
}
|
|
@@ -5965,9 +6168,6 @@ var QtiSliderInteraction = class extends Interaction {
|
|
|
5965
6168
|
}
|
|
5966
6169
|
};
|
|
5967
6170
|
QtiSliderInteraction.styles = [css28``];
|
|
5968
|
-
__decorateClass([
|
|
5969
|
-
query3("#knob")
|
|
5970
|
-
], QtiSliderInteraction.prototype, "_knob", 2);
|
|
5971
6171
|
__decorateClass([
|
|
5972
6172
|
query3("#rail")
|
|
5973
6173
|
], QtiSliderInteraction.prototype, "_rail", 2);
|
|
@@ -5998,39 +6198,29 @@ QtiSliderInteraction = __decorateClass([
|
|
|
5998
6198
|
|
|
5999
6199
|
// src/lib/qti-components/qti-custom-operator/qti-custom-operator.ts
|
|
6000
6200
|
import { consume as consume6 } from "@lit/context";
|
|
6001
|
-
import { LitElement as
|
|
6201
|
+
import { LitElement as LitElement23, html as html44 } from "lit";
|
|
6002
6202
|
import { customElement as customElement39, state as state17 } from "lit/decorators.js";
|
|
6003
|
-
var QtiCustomOperator = class extends
|
|
6203
|
+
var QtiCustomOperator = class extends LitElement23 {
|
|
6004
6204
|
render() {
|
|
6005
6205
|
return html44`<slot @slotchange=${this.handleSlotChange}></slot>`;
|
|
6006
6206
|
}
|
|
6007
|
-
handleSlotChange(
|
|
6008
|
-
|
|
6009
|
-
const commentNode = Array.from((_b = (_a = this.firstElementChild) == null ? void 0 : _a.childNodes) != null ? _b : []).find(
|
|
6207
|
+
handleSlotChange() {
|
|
6208
|
+
const commentNode = Array.from(this.firstElementChild?.childNodes ?? []).find(
|
|
6010
6209
|
(node) => node.nodeType === Node.COMMENT_NODE
|
|
6011
6210
|
);
|
|
6012
6211
|
try {
|
|
6013
|
-
this.operatorFunction = new Function("context", "fn", "item",
|
|
6212
|
+
this.operatorFunction = new Function("context", "fn", "item", commentNode.textContent ?? "");
|
|
6014
6213
|
} catch (e) {
|
|
6015
6214
|
console.error("custom-operator contains invalid javascript code", e);
|
|
6016
6215
|
}
|
|
6017
6216
|
}
|
|
6018
6217
|
calculate() {
|
|
6019
6218
|
const fn = {
|
|
6020
|
-
variable: (responseIdentifier) =>
|
|
6021
|
-
|
|
6022
|
-
return (_c = (_b = (_a = this._context) == null ? void 0 : _a.variables.find((v) => v.identifier === responseIdentifier)) == null ? void 0 : _b.value) != null ? _c : "";
|
|
6023
|
-
},
|
|
6024
|
-
correct: (responseIdentifier) => {
|
|
6025
|
-
var _a, _b, _c;
|
|
6026
|
-
return (_c = (_b = (_a = this._context) == null ? void 0 : _a.variables.find((v) => v.identifier === responseIdentifier)) == null ? void 0 : _b.correctResponse) != null ? _c : "";
|
|
6027
|
-
}
|
|
6219
|
+
variable: (responseIdentifier) => this._context?.variables.find((v) => v.identifier === responseIdentifier)?.value ?? "",
|
|
6220
|
+
correct: (responseIdentifier) => this._context?.variables.find((v) => v.identifier === responseIdentifier)?.correctResponse ?? ""
|
|
6028
6221
|
};
|
|
6029
6222
|
const item = {
|
|
6030
|
-
getVariable: (variableIdentifier) =>
|
|
6031
|
-
var _a;
|
|
6032
|
-
return (_a = this._context) == null ? void 0 : _a.variables.find((v) => v.identifier === variableIdentifier);
|
|
6033
|
-
},
|
|
6223
|
+
getVariable: (variableIdentifier) => this._context?.variables.find((v) => v.identifier === variableIdentifier),
|
|
6034
6224
|
updateOutcomeVariable: (outcomeIdentifier, value) => {
|
|
6035
6225
|
this.dispatchEvent(
|
|
6036
6226
|
new CustomEvent("qti-set-outcome-value", {
|
|
@@ -6068,9 +6258,9 @@ QtiCustomOperator = __decorateClass([
|
|
|
6068
6258
|
], QtiCustomOperator);
|
|
6069
6259
|
|
|
6070
6260
|
// src/lib/qti-components/qti-interaction/qti-associable-hotspot.ts
|
|
6071
|
-
import { LitElement as
|
|
6261
|
+
import { LitElement as LitElement24, css as css29, html as html45 } from "lit";
|
|
6072
6262
|
import { customElement as customElement40 } from "lit/decorators.js";
|
|
6073
|
-
var QtiAssociableHotspot = class extends
|
|
6263
|
+
var QtiAssociableHotspot = class extends LitElement24 {
|
|
6074
6264
|
connectedCallback() {
|
|
6075
6265
|
super.connectedCallback();
|
|
6076
6266
|
this.dispatchEvent(
|
|
@@ -6082,7 +6272,7 @@ var QtiAssociableHotspot = class extends LitElement32 {
|
|
|
6082
6272
|
);
|
|
6083
6273
|
}
|
|
6084
6274
|
render() {
|
|
6085
|
-
return html45` <slot name="
|
|
6275
|
+
return html45` <slot name="drags"></slot> `;
|
|
6086
6276
|
}
|
|
6087
6277
|
};
|
|
6088
6278
|
QtiAssociableHotspot.styles = css29`
|
|
@@ -6097,15 +6287,15 @@ QtiAssociableHotspot = __decorateClass([
|
|
|
6097
6287
|
], QtiAssociableHotspot);
|
|
6098
6288
|
|
|
6099
6289
|
// src/lib/qti-components/qti-interaction/qti-gap.ts
|
|
6100
|
-
import { css as css30, html as html46, LitElement as
|
|
6290
|
+
import { css as css30, html as html46, LitElement as LitElement25 } from "lit";
|
|
6101
6291
|
import { customElement as customElement41, property as property34 } from "lit/decorators.js";
|
|
6102
|
-
var QtiGap = class extends
|
|
6292
|
+
var QtiGap = class extends LitElement25 {
|
|
6103
6293
|
constructor() {
|
|
6104
6294
|
super(...arguments);
|
|
6105
6295
|
this.tabindex = 0;
|
|
6106
6296
|
}
|
|
6107
6297
|
render() {
|
|
6108
|
-
return html46` <slot name="
|
|
6298
|
+
return html46` <slot name="drags"></slot>`;
|
|
6109
6299
|
}
|
|
6110
6300
|
};
|
|
6111
6301
|
QtiGap.styles = css30`
|
|
@@ -6122,15 +6312,15 @@ QtiGap = __decorateClass([
|
|
|
6122
6312
|
], QtiGap);
|
|
6123
6313
|
|
|
6124
6314
|
// src/lib/qti-components/qti-interaction/qti-gap-img.ts
|
|
6125
|
-
import { css as css31, LitElement as
|
|
6315
|
+
import { css as css31, LitElement as LitElement26 } from "lit";
|
|
6126
6316
|
import { customElement as customElement42, property as property35 } from "lit/decorators.js";
|
|
6127
|
-
var QtiGapImg = class extends
|
|
6317
|
+
var QtiGapImg = class extends LitElement26 {
|
|
6128
6318
|
constructor() {
|
|
6129
6319
|
super(...arguments);
|
|
6130
6320
|
this.tabindex = 0;
|
|
6131
6321
|
}
|
|
6132
6322
|
connectedCallback() {
|
|
6133
|
-
this.setAttribute("slot", "
|
|
6323
|
+
this.setAttribute("slot", "drags");
|
|
6134
6324
|
}
|
|
6135
6325
|
};
|
|
6136
6326
|
QtiGapImg.styles = css31`
|
|
@@ -6147,16 +6337,16 @@ QtiGapImg = __decorateClass([
|
|
|
6147
6337
|
], QtiGapImg);
|
|
6148
6338
|
|
|
6149
6339
|
// src/lib/qti-components/qti-interaction/qti-gap-text.ts
|
|
6150
|
-
import { css as css32, html as html47, LitElement as
|
|
6340
|
+
import { css as css32, html as html47, LitElement as LitElement27 } from "lit";
|
|
6151
6341
|
import { customElement as customElement43, property as property36 } from "lit/decorators.js";
|
|
6152
|
-
var QtiGapText = class extends ActiveElementMixin(
|
|
6342
|
+
var QtiGapText = class extends ActiveElementMixin(LitElement27, "qti-gap-text") {
|
|
6153
6343
|
constructor() {
|
|
6154
6344
|
super(...arguments);
|
|
6155
6345
|
this.tabindex = 0;
|
|
6156
6346
|
}
|
|
6157
6347
|
connectedCallback() {
|
|
6158
6348
|
super.connectedCallback();
|
|
6159
|
-
this.setAttribute("slot", "
|
|
6349
|
+
this.setAttribute("slot", "drags");
|
|
6160
6350
|
}
|
|
6161
6351
|
render() {
|
|
6162
6352
|
return html47`<slot></slot>`;
|
|
@@ -6176,9 +6366,9 @@ QtiGapText = __decorateClass([
|
|
|
6176
6366
|
], QtiGapText);
|
|
6177
6367
|
|
|
6178
6368
|
// src/lib/qti-components/qti-interaction/qti-hotspot-choice.ts
|
|
6179
|
-
import { css as css33, LitElement as
|
|
6369
|
+
import { css as css33, LitElement as LitElement28 } from "lit";
|
|
6180
6370
|
import { customElement as customElement44, property as property37 } from "lit/decorators.js";
|
|
6181
|
-
var QtiHotspotChoice = class extends ActiveElementMixin(
|
|
6371
|
+
var QtiHotspotChoice = class extends ActiveElementMixin(LitElement28, "qti-hotspot-choice") {
|
|
6182
6372
|
};
|
|
6183
6373
|
QtiHotspotChoice.styles = css33`
|
|
6184
6374
|
:host {
|
|
@@ -6195,9 +6385,9 @@ QtiHotspotChoice = __decorateClass([
|
|
|
6195
6385
|
], QtiHotspotChoice);
|
|
6196
6386
|
|
|
6197
6387
|
// src/lib/qti-components/qti-interaction/qti-hottext.ts
|
|
6198
|
-
import { css as css34, html as html48, LitElement as
|
|
6388
|
+
import { css as css34, html as html48, LitElement as LitElement29 } from "lit";
|
|
6199
6389
|
import { customElement as customElement45 } from "lit/decorators.js";
|
|
6200
|
-
var QtiHottext = class extends ActiveElementMixin(
|
|
6390
|
+
var QtiHottext = class extends ActiveElementMixin(LitElement29, "qti-hottext") {
|
|
6201
6391
|
render() {
|
|
6202
6392
|
return html48`<div part="ch"><div part="cha"></div></div>
|
|
6203
6393
|
<slot></slot> `;
|
|
@@ -6214,9 +6404,9 @@ QtiHottext = __decorateClass([
|
|
|
6214
6404
|
], QtiHottext);
|
|
6215
6405
|
|
|
6216
6406
|
// src/lib/qti-components/qti-interaction/qti-inline-choice.ts
|
|
6217
|
-
import { css as css35, html as html49, LitElement as
|
|
6407
|
+
import { css as css35, html as html49, LitElement as LitElement30 } from "lit";
|
|
6218
6408
|
import { customElement as customElement46, property as property38 } from "lit/decorators.js";
|
|
6219
|
-
var QtiInlineChoice = class extends
|
|
6409
|
+
var QtiInlineChoice = class extends LitElement30 {
|
|
6220
6410
|
static get styles() {
|
|
6221
6411
|
return [
|
|
6222
6412
|
css35`
|
|
@@ -6263,9 +6453,9 @@ QtiInlineChoice = __decorateClass([
|
|
|
6263
6453
|
], QtiInlineChoice);
|
|
6264
6454
|
|
|
6265
6455
|
// src/lib/qti-components/qti-interaction/qti-simple-choice.ts
|
|
6266
|
-
import { css as css36, html as html50, LitElement as
|
|
6456
|
+
import { css as css36, html as html50, LitElement as LitElement31, nothing as nothing2 } from "lit";
|
|
6267
6457
|
import { customElement as customElement47, property as property39 } from "lit/decorators.js";
|
|
6268
|
-
var QtiSimpleChoice = class extends ActiveElementMixin(
|
|
6458
|
+
var QtiSimpleChoice = class extends ActiveElementMixin(LitElement31, "qti-simple-choice") {
|
|
6269
6459
|
get checked() {
|
|
6270
6460
|
return this["internals"].states.has("--checked");
|
|
6271
6461
|
}
|
|
@@ -6369,6 +6559,7 @@ export {
|
|
|
6369
6559
|
QtiOutcomeProcessing,
|
|
6370
6560
|
QtiOutcomeProcessingProcessor,
|
|
6371
6561
|
QtiPortableCustomInteraction,
|
|
6562
|
+
QtiPositionObjectInteraction,
|
|
6372
6563
|
QtiPositionObjectStage,
|
|
6373
6564
|
QtiPrintedVariable,
|
|
6374
6565
|
QtiProduct,
|
|
@@ -6381,7 +6572,6 @@ export {
|
|
|
6381
6572
|
QtiResponseProcessing,
|
|
6382
6573
|
QtiRubricBlock,
|
|
6383
6574
|
QtiRule,
|
|
6384
|
-
QtiSPositionObjectInteraction,
|
|
6385
6575
|
QtiSelectPointInteraction,
|
|
6386
6576
|
QtiSetOutcomeValue,
|
|
6387
6577
|
QtiSetOutcomeValueRule,
|
|
@@ -6390,12 +6580,14 @@ export {
|
|
|
6390
6580
|
QtiSliderInteraction,
|
|
6391
6581
|
QtiStringMatch,
|
|
6392
6582
|
QtiStylesheet,
|
|
6583
|
+
QtiSubtract,
|
|
6393
6584
|
QtiSum,
|
|
6394
6585
|
QtiSumExpression,
|
|
6395
6586
|
QtiTextEntryInteraction,
|
|
6396
6587
|
QtiVariable,
|
|
6397
6588
|
itemContext,
|
|
6398
6589
|
itemContextVariables,
|
|
6399
|
-
qtiAndMixin
|
|
6590
|
+
qtiAndMixin,
|
|
6591
|
+
qtiSubtractMixin
|
|
6400
6592
|
};
|
|
6401
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/lib/qti-components/qti-assessment-item/qti-assessment-item.ts", "../../src/lib/decorators/watch.ts", "../../src/lib/qti-components/qti-assessment-item/qti-assessment-item.context.ts", "../../src/lib/qti-components/qti-assessment-stimulus-ref/qti-assessment-stimulus-ref.ts", "../../src/lib/qti-transformers/qti-transformers.ts", "../../src/lib/qti-transformers/qti-transform-item.ts", "../../src/lib/qti-components/qti-interaction/internal/active-element/active-element.mixin.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.styles.ts", "../../src/lib/qti-components/qti-prompt/qti-prompt.ts", "../../src/lib/qti-components/qti-stylesheet/qti-stylesheet.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-variable-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-response-declaration/qti-response-declaration.ts", "../../src/lib/qti-components/qti-companion-materials-info/qti-companion-materials-info.ts", "../../src/lib/qti-components/qti-rubric-block/qti-content-body.ts", "../../src/lib/qti-components/qti-rubric-block/qti-rubric-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-block/qti-feedback-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback.ts", "../../src/lib/qti-components/internal/utils.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-inline/qti-feedback-inline.ts", "../../src/lib/qti-components/qti-feedback/qti-modal-feedback/qti-modal-feedback.ts", "../../src/lib/qti-components/qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/interaction/interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext-interaction/qti-hottext-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/choices/choices.mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/shuffle/shuffle-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/vocabulary/vocabulary-mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.styles.ts", "../../src/lib/qti-components/qti-outcome-processing/qti-outcome-processing.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-processing/qti-response-processing.ts", "../../src/lib/qti-components/internal/template-strings.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-lookup-outcome-value/qti-lookup-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-rule.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-response-condition/qti-response-condition.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-set-outcome-value/qti-set-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-else.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-else-if/qti-response-else-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-condition-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/qti-and.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/index.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-basevalue/qti-basevalue.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-contains/qti-contains.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-correct/qti-correct.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal-rounded/qti-equal-rounded.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal/qti-equal.ts", "../../src/lib/qti-components/qti-response-processing/utilities/scoring-helper.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gt/qti-gt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gte/qti-gte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-is-null/qti-is-null.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lt/qti-lt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lte/qti-lte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-map-response/qti-map-response.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-mapping/qti-mapping.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-match/qti-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-member/qti-member.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-multiple/qti-multiple.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-not/qti-not.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-or/qti-or.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-ordered/qti-ordered.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-printed-variable/qti-printed-variable.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-product/qti-product.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-string-match/qti-string-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-sum/qti-sum.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-variable/qti-variable.ts", "../../src/lib/qti-components/qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-api.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/droppables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/flippables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-interaction-mixin.ts", "../../src/lib/decorators/live-query.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-custom-interaction/qti-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/hotspots/hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-associable-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-media-interaction/qti-media-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-order-interaction/qti-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-stage.ts", "../../src/lib/qti-components/qti-interaction/qti-select-point-interaction/qti-select-point-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-slider-interaction/qti-slider-interaction.ts", "../../src/lib/qti-components/qti-custom-operator/qti-custom-operator.ts", "../../src/lib/qti-components/qti-interaction/qti-associable-hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-gap.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-img.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-text.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-choice.ts", "../../src/lib/qti-components/index.ts"],
  "sourcesContent": ["import { provide } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\nimport type { InteractionChangedDetails, OutcomeChangedDetails } from '../internal/event-types';\nimport type { ResponseInteraction } from '../internal/expression-result';\nimport type { VariableDeclaration, VariableValue } from '../internal/variables';\nimport { OutcomeVariable, ResponseVariable } from '../internal/variables';\nimport type { QtiFeedback } from '../qti-feedback/qti-feedback';\nimport type { Interaction } from '../qti-interaction/internal/interaction/interaction';\nimport type { QtiResponseProcessing } from '../qti-response-processing';\nimport { ItemContext, itemContext, itemContextVariables } from './qti-assessment-item.context';\nimport QtiRegisterVariable from '../internal/events/qti-register-variable';\n\n/**\n * @summary The qti-assessment-item element contains all the other QTI 3 item structures.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.dltnnj87l0yj\n * @status stable\n * @since 4.0\n *\n * @dependency qti-feedback\n * @dependency qti-responseprocessing\n *\n * @slot - The default slot where all the other QTI 3 item structures go.\n *\n * @event qti-interaction-changed - Emitted when an interaction is changed.\n * @event qti-outcome-changed - Emitted when an outcome has changed.\n * @event qti-response-processing - Emitted when response-processing is called.\n *\n */\n@customElement('qti-assessment-item')\nexport class QtiAssessmentItem extends LitElement {\n  @property({ type: String }) title: string;\n  @property({ type: String }) identifier: string = '';\n  @property({ type: String }) adaptive: 'true' | 'false' = 'false';\n  @property({ type: String }) timeDependent: 'true' | 'false' | null = null;\n\n  @property({ type: Boolean }) disabled: boolean;\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  _handleDisabledChange = (_: boolean, disabled: boolean) => {\n    this._interactionElements.forEach(ch => (ch.disabled = disabled));\n  };\n\n  @property({ type: Boolean }) readonly: boolean;\n  @watch('readonly', { waitUntilFirstUpdate: true })\n  _handleReadonlyChange = (_: boolean, readonly: boolean) =>\n    this._interactionElements.forEach(ch => (ch.readonly = readonly));\n\n  @provide({ context: itemContext })\n  private _context: ItemContext = {\n    identifier: this.getAttribute('identifier'),\n    variables: itemContextVariables\n  };\n\n  public get variables(): VariableValue<string | string[] | null>[] {\n    return this._context.variables.map(v => ({\n      identifier: v.identifier,\n      value: v.value,\n      type: v.type,\n      // add externalscored, a fixed prop to the test, so the testcontext can read and decide how to score this item\n      ...(v.type === 'outcome' && v.identifier === 'SCORE'\n        ? { externalScored: (v as OutcomeVariable).externalScored }\n        : {})\n    }));\n  }\n\n  public set variables(value: VariableValue<string | string[] | null>[]) {\n    if (!Array.isArray(value) || value.some(v => !('identifier' in v))) {\n      console.warn('variables property should be an array of VariableDeclaration');\n      return;\n    }\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(variable => {\n        const matchingValue = value.find(v => v.identifier === variable.identifier);\n        if (matchingValue) {\n          return { ...variable, ...matchingValue };\n        }\n        return variable;\n      })\n    };\n\n    this._context.variables.forEach(variable => {\n      if (variable.type === 'response') {\n        const interactionElement = this._interactionElements.find(\n          (el: Interaction) => el.responseIdentifier === variable.identifier\n        );\n        if (interactionElement) {\n          interactionElement.value = variable.value as string | string[];\n        }\n      }\n\n      if (variable.type === 'outcome') {\n        this._feedbackElements.forEach(fe => fe.checkShowFeedback(variable.identifier));\n      }\n    });\n  }\n\n  private _initialContext: Readonly<ItemContext> = { ...this._context, variables: this._context.variables };\n  private _feedbackElements: QtiFeedback[] = [];\n  private _interactionElements: Interaction[] = [];\n\n  async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n    await this.updateComplete;\n    this._emit<{ detail: QtiAssessmentItem }>('qti-assessment-item-connected', this);\n  }\n\n  /** @deprecated use variables property instead */\n  set responses(myResponses: ResponseInteraction[]) {\n    if (myResponses) {\n      for (const response of myResponses) {\n        const responseVariable = this.getResponse(response.responseIdentifier);\n        if (responseVariable) {\n          this.updateResponseVariable(response.responseIdentifier, response.response);\n        }\n\n        const interaction: Interaction | undefined = this._interactionElements.find(\n          i => i.getAttribute('response-identifier') === response.responseIdentifier\n        );\n        if (interaction) {\n          interaction.value = response.response;\n        }\n      }\n    }\n  }\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  constructor() {\n    super();\n    this.addEventListener('qti-register-variable', (e: QtiRegisterVariable) => {\n      this._context = { ...this._context, variables: [...this._context.variables, e.detail.variable] };\n      this._initialContext = this._context;\n      e.stopPropagation();\n    });\n    this.addEventListener('qti-register-feedback', (e: CustomEvent<QtiFeedback>) => {\n      e.stopPropagation();\n      const feedbackElement = e.detail;\n      this._feedbackElements.push(feedbackElement);\n      feedbackElement.checkShowFeedback(feedbackElement.outcomeIdentifier);\n    });\n    this.addEventListener('qti-register-interaction', (e: CustomEvent<null>) => {\n      e.stopPropagation();\n      this._interactionElements.push(e.target as Interaction);\n    });\n    this.addEventListener('end-attempt', (e: CustomEvent<{ responseIdentifier: string; countAttempt: boolean }>) => {\n      const { responseIdentifier, countAttempt } = e.detail;\n      this.updateResponseVariable(responseIdentifier, 'true');\n      this.processResponse(countAttempt);\n    });\n\n    this.addEventListener(\n      // wordt aangeroepen vanuit de processingtemplate\n      'qti-set-outcome-value',\n      (e: CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>) => {\n        const { outcomeIdentifier, value } = e.detail;\n        this.updateOutcomeVariable(outcomeIdentifier, value);\n        e.stopPropagation();\n      }\n    );\n\n    this.addEventListener('qti-interaction-response', this.handleUpdateResponseVariable);\n  }\n\n  public showCorrectResponse(show: boolean) {\n    const responseVariables = this._context.variables.filter(\n      (vari: ResponseVariable | OutcomeVariable) => 'correctResponse' in vari && vari.correctResponse\n    ) as ResponseVariable[];\n    const responses = responseVariables.map(cr => {\n      return {\n        responseIdentifier: cr.identifier,\n        response: cr.correctResponse\n      };\n    });\n    for (const response of responses) {\n      const interaction: Interaction | undefined = this._interactionElements.find(\n        i => i.getAttribute('response-identifier') === response.responseIdentifier\n      );\n      if (interaction) {\n        interaction.correctResponse = show ? response.response : '';\n      }\n    }\n  }\n\n  public processResponse(countNumAttempts: boolean = true): boolean {\n    const responseProcessor = this.querySelector<QtiResponseProcessing>('qti-response-processing');\n    if (!responseProcessor) {\n      // console.info('Client side response processing template not available');\n      return false;\n    }\n\n    if (!responseProcessor.process) {\n      // console.info('Client side response webcomponents not available');\n      return false;\n    }\n\n    responseProcessor.process();\n\n    if (this.adaptive === 'false') {\n      // if adaptive, completionStatus is set by the processing template\n      this.updateOutcomeVariable('completionStatus', this._getCompletionStatus());\n    }\n\n    if (countNumAttempts) {\n      this.updateOutcomeVariable(\n        'numAttempts',\n        (+this._context.variables.find(v => v.identifier === 'numAttempts')?.value + 1).toString()\n      );\n    }\n\n    this._emit('qti-response-processed');\n    return true;\n  }\n\n  public resetResponses() {\n    this._context = this._initialContext;\n  }\n\n  public getResponse(identifier: string): Readonly<ResponseVariable> {\n    return this.getVariable(identifier) as ResponseVariable;\n  }\n\n  public getOutcome(identifier: string): Readonly<OutcomeVariable> {\n    return this.getVariable(identifier) as OutcomeVariable;\n  }\n\n  public getVariable(identifier: string): Readonly<VariableDeclaration<string | string[] | null>> {\n    return this._context.variables.find(v => v.identifier === identifier) || null;\n  }\n\n  // saving privates here: ------------------------------------------------------------------------------\n\n  private handleUpdateResponseVariable(event: CustomEvent<ResponseInteraction>) {\n    const { responseIdentifier, response } = event.detail;\n    this.updateResponseVariable(responseIdentifier, response);\n  }\n\n  public updateResponseVariable(identifier: string, value: string | string[] | undefined) {\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(v => (v.identifier !== identifier ? v : { ...v, value: value }))\n    };\n\n    this._emit<InteractionChangedDetails>('qti-interaction-changed', {\n      item: this.identifier,\n      responseIdentifier: identifier,\n      response: Array.isArray(value) ? [...value] : value\n    });\n\n    if (this.adaptive === 'false') {\n      // if adapative, completionStatus is set by the processing template\n      this.updateOutcomeVariable('completionStatus', this._getCompletionStatus());\n    }\n  }\n\n  public updateOutcomeVariable(identifier: string, value: string | string[] | undefined) {\n    const outcomeVariable = this.getOutcome(identifier);\n\n    if (!outcomeVariable) {\n      console.warn(`Can not set qti-outcome-identifier: ${identifier}, it is not available`);\n      return;\n    }\n\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(v => {\n        if (v.identifier !== identifier) {\n          return v;\n        }\n        return {\n          ...v,\n          value: outcomeVariable.cardinality === 'single' ? value : [...v.value, value as string]\n        };\n      })\n    };\n    this._feedbackElements.forEach(fe => fe.checkShowFeedback(identifier));\n\n    this._emit<OutcomeChangedDetails>('qti-outcome-changed', {\n      item: this.identifier,\n      outcomeIdentifier: identifier,\n      value: this._context.variables.find(v => v.identifier === identifier)?.value\n    });\n  }\n\n  private _getCompletionStatus(): 'completed' | 'incomplete' | 'not_attempted' | 'unknown' {\n    if (this._interactionElements.every(interactionElement => interactionElement.validate())) return 'completed';\n    if (this._interactionElements.some(interactionElement => interactionElement.validate())) return 'incomplete';\n    return 'not_attempted';\n  }\n\n  private _emit<T>(name, detail = null) {\n    this.dispatchEvent(\n      new CustomEvent<T>(name, {\n        bubbles: true,\n        composed: true,\n        detail\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-item': QtiAssessmentItem;\n  }\n}\n", "import type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\n\ntype NonUndefined<A> = A extends undefined ? never : A;\n\nexport type UpdateHandlerFunctionKeys<T extends object> = {\n  [K in keyof T]-?: NonUndefined<T[K]> extends UpdateHandler ? K : never;\n}[keyof T];\n\ninterface WatchOptions {\n  /**\n   * If true, will only start watching after the initial update/render\n   */\n  waitUntilFirstUpdate?: boolean;\n}\n\n/**\n * Runs when observed properties change, e.g. @property or @state, but before the component updates. To wait for an\n * update to complete after a change occurs, use `await this.updateComplete` in the handler. To start watching after the\n * initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n *\n * Usage:\n *\n * @watch('propName')\n * handlePropChange(oldValue, newValue) {\n *   ...\n * }\n */\nexport function watch(propertyName: string | string[], options?: WatchOptions) {\n  const resolvedOptions: Required<WatchOptions> = {\n    waitUntilFirstUpdate: false,\n    ...options\n  };\n  return <ElemClass extends LitElement>(\n    proto: ElemClass,\n    decoratedFnName: UpdateHandlerFunctionKeys<ElemClass> | any\n  ) => {\n    // @ts-expect-error - update is a protected property\n    const { update } = proto;\n    const watchedProperties = Array.isArray(propertyName) ? propertyName : [propertyName];\n\n    // @ts-expect-error - update is a protected property\n    proto.update = function (this: ElemClass, changedProps: Map<keyof ElemClass, ElemClass[keyof ElemClass]>) {\n      watchedProperties.forEach(property => {\n        const key = property as keyof ElemClass;\n        if (changedProps.has(key)) {\n          const oldValue = changedProps.get(key);\n          const newValue = this[key];\n\n          if (oldValue !== newValue) {\n            if (!resolvedOptions.waitUntilFirstUpdate || this.hasUpdated) {\n              (this[decoratedFnName] as unknown as UpdateHandler)(oldValue, newValue);\n            }\n          }\n        }\n      });\n\n      update.call(this, changedProps);\n    };\n  };\n}\n", "import { createContext } from '@lit/context';\nimport { VariableDeclaration } from '../internal/variables';\n\nexport interface ItemContext {\n  href?: string;\n  identifier: string;\n  variables: ReadonlyArray<VariableDeclaration<string | string[]>>;\n}\n\nexport const itemContextVariables = [\n  {\n    identifier: 'completionStatus',\n    cardinality: 'single',\n    baseType: 'string',\n    value: 'unknown',\n    type: 'outcome'\n  },\n  {\n    identifier: 'numAttempts',\n    cardinality: 'single',\n    baseType: 'integer',\n    value: '0',\n    type: 'response'\n  }\n] as VariableDeclaration<string | string[]>[];\n\nexport const itemContext = createContext<ItemContext>(Symbol('item'));\n", "import { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { qtiTransformItem } from '../../qti-transformers';\n\n/**\n * Represents a custom element for referencing an assessment stimulus.\n */\n@customElement('qti-assessment-stimulus-ref')\nexport class QtiAssessmentStimulusRef extends LitElement {\n  /**\n   * The identifier of the stimulus.\n   */\n  @property({ type: String }) identifier = '';\n\n  /**\n   * The href of the stimulus.\n   */\n  @property({ type: String }) href = '';\n\n  /**\n   * Lifecycle method called when the element is connected to the DOM.\n   * Loads and appends the stimulus if the 'qti-assessment-stimulus-ref-connected' event is not prevented.\n   */\n  public async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n\n    const event = new Event('qti-assessment-stimulus-ref-connected', { cancelable: true, bubbles: true });\n    const isPrevented = this.dispatchEvent(event);\n\n    if (isPrevented) {\n      const item = this.closest('qti-assessment-item');\n\n      const stimulusRef = item.querySelector(`[data-stimulus-idref=${this.identifier}]`);\n      if (stimulusRef) {\n        await this.updateStimulusRef(stimulusRef);\n      } else {\n        console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`);\n      }\n    }\n  }\n\n  /**\n   * Loads and appends the stimulus to the specified element.\n   * @param stimulusRef - The element to which the stimulus will be appended.\n   */\n  public async updateStimulusRef(stimulusRef: Element) {\n    const path = this.href.substring(0, this.href.lastIndexOf('/'));\n    const stimulus = await qtiTransformItem()\n      .load(this.href)\n      .then(api => api.htmlDoc());\n    if (stimulus) {\n      const elements = stimulus.querySelectorAll('qti-stimulus-body, qti-stylesheet');\n      stimulusRef.innerHTML = '';\n      stimulusRef.append(...elements);\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-stimulus-ref': QtiAssessmentStimulusRef;\n  }\n}\n", "const xml = String.raw;\n\n/*   <!-- convert CDATA to comments -->\n  <xsl:template match=\"text()[contains(., 'CDATA')]\">\n  <xsl:comment>\n    <xsl:value-of select=\".\"/>\n  </xsl:comment>\n</xsl:template>\n*/\n\n/*\n  <!-- remove xml comments -->\n  <xsl:template match=\"comment()\" />\n  */\n\nconst xmlToHTML = xml`<xsl:stylesheet version=\"1.0\" xmlns:xsl=\"http://www.w3.org/1999/XSL/Transform\">\n<xsl:output method=\"html\" version=\"5.0\" encoding=\"UTF-8\" indent=\"yes\" />\n  <xsl:template match=\"@*|node()\">\n    <xsl:copy>\n      <xsl:apply-templates select=\"@*|node()\"/>\n    </xsl:copy>\n  </xsl:template>\n\n  <!-- remove existing namespaces -->\n  <xsl:template match=\"*\">\n    <!-- remove element prefix -->\n    <xsl:element name=\"{local-name()}\">\n      <!-- process attributes -->\n      <xsl:for-each select=\"@*\">\n        <!-- remove attribute prefix -->\n        <xsl:attribute name=\"{local-name()}\">\n          <xsl:value-of select=\".\"/>\n        </xsl:attribute>\n      </xsl:for-each>\n    <xsl:apply-templates/>\n  </xsl:element>\n</xsl:template>\n</xsl:stylesheet>`;\n\n// Function to extend elements with a specific tag name by adding an extension suffix\nexport function extendElementName(xmlFragment: XMLDocument, tagName: string, extension: string) {\n  xmlFragment.querySelectorAll(tagName).forEach(element => {\n    const newTagName = `${tagName}-${extension}`;\n    const newElement = createElementWithNewTagName(element, newTagName);\n    element.replaceWith(newElement);\n  });\n}\n\n// Function to extend any element with a specific class pattern (e.g., \"extend:suffix\")\nexport function extendElementsWithClass(xmlFragment: XMLDocument, classNamePattern: string) {\n  xmlFragment.querySelectorAll('*').forEach(element => {\n    const classList = element.classList;\n    if (classList) {\n      classList.forEach(className => {\n        if (className.startsWith(`${classNamePattern}:`)) {\n          const suffix = className.slice(`${classNamePattern}:`.length);\n          const newTagName = `${element.nodeName}-${suffix}`;\n          const newElement = createElementWithNewTagName(element, newTagName);\n          element.replaceWith(newElement);\n        }\n      });\n    }\n  });\n}\n\n// Helper function to create a new element with a new tag name and copy attributes and children\nfunction createElementWithNewTagName(element, newTagName) {\n  const newElement = document.createElement(newTagName);\n  // Copy attributes\n  for (const attr of element.attributes) {\n    newElement.setAttribute(attr.name, attr.value);\n  }\n  // Copy child nodes\n  while (element.firstChild) {\n    newElement.appendChild(element.firstChild);\n  }\n  return newElement;\n}\n\nexport function itemsFromTest(xmlFragment: DocumentFragment) {\n  const items: { identifier: string; href: string; category: string }[] = [];\n  xmlFragment.querySelectorAll('qti-assessment-item-ref').forEach(el => {\n    const identifier = el.getAttribute('identifier');\n    const href = el.getAttribute('href');\n    const category = el.getAttribute('category');\n    items.push({ identifier, href, category });\n  });\n  return items;\n}\n\nlet currentRequest: XMLHttpRequest | null = null;\n\nexport function loadXML(url, cancelPreviousRequest = false) {\n  if (cancelPreviousRequest && currentRequest !== null) {\n    currentRequest.abort(); // Abort the ongoing request if there is one\n  }\n\n  return new Promise<XMLDocument | null>((resolve, reject) => {\n    const xhr = new XMLHttpRequest();\n    currentRequest = xhr; // Store the current request\n\n    xhr.open('GET', url, true);\n    xhr.responseType = 'document';\n\n    xhr.onload = () => {\n      if (xhr.status >= 200 && xhr.status < 300) {\n        resolve(xhr.responseXML);\n      } else {\n        reject(xhr.statusText);\n      }\n    };\n\n    xhr.onerror = () => {\n      reject(xhr.statusText);\n    };\n\n    xhr.send();\n  });\n}\n\nexport function parseXML(xmlDocument: string) {\n  const parser = new DOMParser();\n  const xmlFragment = parser.parseFromString(xmlDocument, 'text/xml');\n  return xmlFragment;\n}\n\nexport function toHTML(xmlFragment: Document): DocumentFragment {\n  const processor = new XSLTProcessor();\n  const xsltDocument = new DOMParser().parseFromString(xmlToHTML, 'text/xml');\n  processor.importStylesheet(xsltDocument);\n  const itemHTMLFragment = processor.transformToFragment(xmlFragment, document);\n  return itemHTMLFragment;\n}\n\nexport function setLocation(xmlFragment: DocumentFragment, location: string) {\n  if (!location.endsWith('/')) {\n    location += '/';\n  }\n\n  xmlFragment.querySelectorAll('[src],[href],[primary-path]').forEach(elWithSrc => {\n    let attr: 'src' | 'href' | 'primary-path' | '' = '';\n\n    if (elWithSrc.getAttribute('src')) {\n      attr = 'src';\n    }\n    if (elWithSrc.getAttribute('href')) {\n      attr = 'href';\n    }\n    if (elWithSrc.getAttribute('primary-path')) {\n      attr = 'primary-path';\n    }\n    const attrValue = elWithSrc.getAttribute(attr)?.trim();\n\n    if (!attrValue.startsWith('data:') && !attrValue.startsWith('http')) {\n      const newSrcValue = location + encodeURI(attrValue);\n      elWithSrc.setAttribute(attr, newSrcValue);\n    }\n  });\n}\n\nexport function convertCDATAtoComment(xmlFragment: DocumentFragment) {\n  const cdataElements = xmlFragment.querySelectorAll('qti-custom-operator[class=\"js.org\"] > qti-base-value');\n  cdataElements.forEach(element => {\n    const commentText = document.createComment(element.textContent);\n    element.replaceChild(commentText, element.firstChild);\n  });\n}\n\nexport function stripStyleSheets(xmlFragment: DocumentFragment) {\n  // remove qti-stylesheet tag\n  xmlFragment.querySelectorAll('qti-stylesheet').forEach(stylesheet => stylesheet.remove());\n}\n", "/**\n * Browser based QTI-XML to HTML transformer.\n * Returns an object with methods to load, parse, transform and serialize QTI XML items.\n * @returns An object with methods to load, parse, transform and serialize QTI XML items.\n * @example\n * const qtiTransformer = qtiTransformItem();\n * await qtiTransformer.load('path/to/xml/file.xml');\n * qtiTransformer.path('/assessmentItem/itemBody');\n * const html = qtiTransformer.html();\n * const xml = qtiTransformer.xml();\n * const htmldoc = qtiTransformer.htmldoc();\n * const xmldoc = qtiTransformer.xmldoc();\n *\n * qtiTransformItem().parse(storyXML).html()\n */\n\nimport {\n  convertCDATAtoComment,\n  extendElementName,\n  extendElementsWithClass,\n  loadXML,\n  parseXML,\n  setLocation,\n  stripStyleSheets,\n  toHTML\n} from './qti-transformers';\n\nexport type transformItemApi = {\n  load: (uri: string, cancelPreviousRequest?: boolean) => Promise<transformItemApi>;\n  parse: (xmlString: string) => transformItemApi;\n  path: (location: string) => transformItemApi;\n  fn: (fn: (xmlFragment: XMLDocument) => void) => transformItemApi;\n  pciHooks: (uri: string) => transformItemApi;\n  extendElementName: (elementName: string, extend: string) => transformItemApi;\n  extendElementsWithClass: (param?: string) => transformItemApi;\n  customInteraction: (baseRef: string, baseItem: string) => transformItemApi;\n  convertCDATAtoComment: () => transformItemApi;\n  stripStyleSheets: () => transformItemApi;\n  html: () => string;\n  xml: () => string;\n  htmlDoc: () => DocumentFragment;\n  xmlDoc: () => XMLDocument;\n};\n\nexport const qtiTransformItem = () => {\n  let xmlFragment: XMLDocument;\n\n  const api: transformItemApi = {\n    async load(uri: string, cancelPreviousRequest = false): Promise<typeof api> {\n      return new Promise<typeof api>((resolve, reject) => {\n        loadXML(uri, cancelPreviousRequest).then(xml => {\n          xmlFragment = xml;\n          // set the base path for images and other resources,\n          // you probably want to set the base path to the document root else you can use the path method to set it\n          api.path(uri.substring(0, uri.lastIndexOf('/')));\n          return resolve(api);\n        });\n      });\n    },\n    parse(xmlString: string): typeof api {\n      xmlFragment = parseXML(xmlString);\n      return api;\n    },\n    path: (location: string): typeof api => {\n      setLocation(xmlFragment, location);\n      return api;\n    },\n    fn(fn: (xmlFragment: XMLDocument) => void): typeof api {\n      fn(xmlFragment);\n      return api;\n    },\n    pciHooks(uri: string): typeof api {\n      const attributes = ['hook', 'module'];\n      const documentPath = uri.substring(0, uri.lastIndexOf('/'));\n      for (const attribute of attributes) {\n        const srcAttributes = xmlFragment.querySelectorAll('[' + attribute + ']');\n        srcAttributes.forEach(node => {\n          const srcValue = node.getAttribute(attribute)!;\n          if (!srcValue.startsWith('data:') && !srcValue.startsWith('http')) {\n            // Just paste the relative path of the src location after the documentrootPath\n            // old pcis can have a .js, new pci's don't\n            node.setAttribute('base-url', uri);\n            node.setAttribute(\n              'module',\n              documentPath + '/' + encodeURI(srcValue + (srcValue.endsWith('.js') ? '' : '.js'))\n            );\n          }\n        });\n      }\n      return api;\n    },\n    extendElementName: (tagName: string, extension: string): typeof api => {\n      extendElementName(xmlFragment, tagName, extension);\n      return api;\n    },\n    extendElementsWithClass: (param: string = 'extend'): typeof api => {\n      extendElementsWithClass(xmlFragment, param);\n      return api;\n    },\n    customInteraction(baseRef: string, baseItem: string): typeof api {\n      const qtiCustomInteraction = xmlFragment.querySelector('qti-custom-interaction');\n      const qtiCustomInteractionObject = qtiCustomInteraction.querySelector('object');\n\n      qtiCustomInteraction.setAttribute('data-base-ref', baseRef);\n      qtiCustomInteraction.setAttribute('data-base-item', baseRef + baseItem);\n      qtiCustomInteraction.setAttribute('data', qtiCustomInteractionObject.getAttribute('data'));\n      qtiCustomInteraction.setAttribute('width', qtiCustomInteractionObject.getAttribute('width'));\n      qtiCustomInteraction.setAttribute('height', qtiCustomInteractionObject.getAttribute('height'));\n\n      qtiCustomInteraction.removeChild(qtiCustomInteractionObject);\n      return api;\n    },\n    convertCDATAtoComment(): typeof api {\n      convertCDATAtoComment(xmlFragment);\n      return api;\n    },\n    stripStyleSheets(): typeof api {\n      stripStyleSheets(xmlFragment);\n      return api;\n    },\n    html() {\n      return new XMLSerializer().serializeToString(toHTML(xmlFragment));\n    },\n    xml(): string {\n      return new XMLSerializer().serializeToString(xmlFragment);\n    },\n    htmlDoc() {\n      return toHTML(xmlFragment);\n    },\n    xmlDoc(): XMLDocument {\n      return xmlFragment; // new XMLSerializer().serializeToString(xmlFragment);\n    }\n  };\n  return api;\n};\n", "import { ComplexAttributeConverter, LitElement, html } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport interface ChoiceInterface {\n  identifier: string;\n  disabled: boolean;\n  readonly: boolean;\n}\n\n/**\n * Converter to handle boolean attributes for ARIA properties,\n * ensuring they are set as 'true' or 'false' strings.\n */\nconst ariaBooleanConverter: ComplexAttributeConverter<boolean, boolean> = {\n  toAttribute: (value: boolean) => (value ? 'true' : 'false'),\n  fromAttribute: (value: string | null) => value === 'true'\n};\n\n/**\n * A mixin that adds choice functionality to a LitElement-based class.\n * It dispatches events with a custom `type` and handles selection logic.\n *\n * @param Base - The base class to extend.\n * @param type - The type of the choice, used in event names.\n * @returns A new class extending the base class with choice functionality.\n */\nexport interface ActiveElementMixinInterface {\n  identifier: string;\n  tabIndex: number;\n  disabled: boolean;\n  readonly: boolean;\n  internals: ElementInternals;\n}\n\n\nexport function ActiveElementMixin<T extends Constructor<LitElement>>(Base: T, type: string) {\n  abstract class QtiChoice extends Base {\n    @property({ type: String })\n    public identifier = '';\n\n    @property({ type: Number, reflect: true, attribute: 'tabindex' })\n    public tabIndex = 0;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-disabled',\n      converter: ariaBooleanConverter\n    })\n    public disabled = false;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-readonly',\n      converter: ariaBooleanConverter\n    })\n    public readonly = false;\n\n    public internals: ElementInternals;\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    handleDisabledChange(_oldValue: boolean, disabled: boolean) {\n      this.tabIndex = disabled ? -1 : 0;\n      if (disabled) {\n        this.blur();\n      }\n    }\n\n    constructor(...args: any[]) {\n      super(...args);\n      this.internals = this.attachInternals();\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n\n      this.addEventListener('keyup', this._onKeyUp);\n      this.addEventListener('click', this._onClick);\n\n      this.dispatchEvent(\n        new CustomEvent(`register-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener('keyup', this._onKeyUp);\n      this.removeEventListener('click', this._onClick);\n      this.dispatchEvent(\n        new CustomEvent(`unregister-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    private _onKeyUp(event: KeyboardEvent) {\n      if (event.altKey) return;\n\n      if (event.code === 'Space') {\n        event.preventDefault();\n        this._activate();\n      }\n    }\n\n    private _onClick() {\n      if (this.disabled || this.readonly) return;\n      this.focus();\n      this._activate();\n    }\n\n    private _activate() {\n      if (this.disabled || this.readonly) return;\n\n      this.dispatchEvent(\n        new CustomEvent<{ identifier: string }>(`activate-${type}`, {\n          bubbles: true,\n          composed: true,\n          detail: { identifier: this.identifier }\n        })\n      );\n    }\n\n    override render() {\n      return html`<slot></slot>`;\n    }\n  }\n  return QtiChoice as Constructor<ActiveElementMixinInterface> & T;\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\nimport styles from './qti-item-body.styles';\nimport type { CSSResultGroup } from 'lit';\n\n/**\n * @summary The qti-item-body node contains the text, graphics, media objects and interactions that describe the item's content and information about how it is structured.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.sphpo6lu6zqi\n * @status stable\n * @since 4.0\n *\n * @slot - item body content.\n * @slot qti-rubric-block - the qti rubric block is placed above the item\n *\n */\n@customElement('qti-item-body')\nexport class QtiItemBody extends LitElement {\n  static styles: CSSResultGroup = styles;\n\n  override render() {\n    return html`<slot name=\"qti-rubric-block\"></slot><slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-item-body': QtiItemBody;\n  }\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: block;\n  }\n`;\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n@customElement('qti-prompt')\nexport class QtiPrompt extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  override connectedCallback(): void {\n    // if prompts are in interactions they should have a slot, so the prompt has to go there\n    // if prompt is in the body, then just display the prompt there.\n    // A better check would be the latter, but not can't get through the shadowroot to find the slot\n    const inInteraction = this.parentElement.tagName.endsWith('INTERACTION');\n    if (inInteraction) {\n      this.setAttribute('slot', 'prompt');\n    }\n    // const promptSlot = this.parentElement.shadowRoot.querySelector(\"[name='prompt']\");\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-prompt': QtiPrompt;\n  }\n}\n", "import { LitElement, PropertyValueMap } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-stylesheet')\nexport class QtiStylesheet extends LitElement {\n  private styleElement: HTMLStyleElement | null = null;\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    super.firstUpdated(_changedProperties);\n\n    const link = this.getAttribute('href');\n\n    if (link !== null) {\n      // Fetch the stylesheet content\n      fetch(link)\n        .then(response => response.text())\n        .then(cssContent => {\n          // Minify the CSS content by removing whitespace and comments\n          const minifiedCss = this.minifyCss(cssContent);\n\n          // Create a <style> element with @scope surrounding the minified CSS\n          this.styleElement = document.createElement('style');\n          this.styleElement.media = 'screen';\n          this.styleElement.textContent = `@scope {${minifiedCss}}`;\n\n          // Append the style element to the parent element of this component\n          if (this.parentElement) {\n            this.parentElement.appendChild(this.styleElement);\n          } else {\n            console.warn('No parent element to append the scoped stylesheet to.');\n          }\n        })\n        .catch(error => {\n          console.error('Failed to load stylesheet:', error);\n        });\n    }\n\n    if (this.textContent !== null && this.textContent.trim() !== '') {\n      // Minify the inline CSS content\n      const minifiedCss = this.minifyCss(this.textContent);\n\n      // Directly create a <style> element with the @scope surrounding the minified inline styles\n      this.styleElement = document.createElement('style');\n      this.styleElement.media = 'screen';\n      this.styleElement.textContent = `@scope {${minifiedCss}}`;\n\n      // Append the style element to the parent element of this component\n      if (this.parentElement) {\n        this.parentElement.appendChild(this.styleElement);\n      } else {\n        console.warn('No parent element to append the scoped stylesheet to.');\n      }\n    }\n  }\n\n  private minifyCss(cssContent: string): string {\n    // Remove comments, whitespace, and newline characters\n    return cssContent\n      .replace(/\\/\\*[\\s\\S]*?\\*\\//g, '') // Remove comments\n      .replace(/\\s+/g, ' ') // Collapse whitespace\n      .replace(/\\s*([{}:;])\\s*/g, '$1') // Remove spaces around {}, :, ;\n      .trim(); // Trim leading/trailing whitespace\n  }\n\n  override disconnectedCallback() {\n    if (this.styleElement) {\n      try {\n        this.styleElement.remove();\n      } catch (error) {\n        console.error('Could not remove stylesheet:', error);\n      }\n    }\n    super.disconnectedCallback();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-stylesheet': QtiStylesheet;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { BaseType, Cardinality } from '../../internal/expression-result';\nimport { OutcomeVariable } from '../../internal/variables';\nimport { ItemContext, itemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiVariableDeclaration } from '../qti-variable-declaration';\n\n@customElement('qti-outcome-declaration')\nexport class QtiOutcomeDeclaration extends QtiVariableDeclaration {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType;\n  @property({ type: String, attribute: 'external-scored' }) externalScored: 'human' | 'externalMachine' | null = null;\n  @property({ type: String }) identifier: string;\n  @property({ type: String }) cardinality: Cardinality;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\n\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    const value = this.itemContext?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  get interpolationTable(): Map<number, number> | null {\n    const table = this.querySelector('qti-interpolation-table');\n    if (table) {\n      const entries = new Map<number, number>();\n      for (const entry of table.querySelectorAll('qti-interpolation-table-entry')) {\n        if (!entry.getAttribute('source-value') && entry.getAttribute('target-value')) {\n          console.error('source-value or target-value is missing in qti-interpolation-table-entry');\n        }\n        const sourceValue = parseInt(entry.getAttribute('source-value'));\n        const targetValue = parseInt(entry.getAttribute('target-value'));\n        if (isNaN(sourceValue) || isNaN(targetValue)) {\n          console.error('source-value or target-value is not a number in qti-interpolation-table-entry');\n        }\n        entries.set(sourceValue, targetValue);\n      }\n      return entries;\n    }\n    return null;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n    const outcomeVariable: OutcomeVariable = {\n      identifier: this.identifier,\n      cardinality: this.cardinality,\n      baseType: this.baseType,\n      type: 'outcome',\n      value: null,\n      interpolationTable: this.interpolationTable,\n      externalScored: this.externalScored\n    };\n    outcomeVariable.value = this.defaultValues(outcomeVariable);\n    this.dispatchEvent(\n      new CustomEvent('qti-register-variable', {\n        bubbles: true,\n        composed: true,\n        detail: { variable: outcomeVariable }\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-outcome-declaration': QtiOutcomeDeclaration;\n  }\n}\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { VariableDeclaration } from '../internal/variables';\n\n@customElement('qti-variabledeclaration')\nexport class QtiVariableDeclaration extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  protected defaultValues(variable: VariableDeclaration<string | string[] | null>) {\n    const htmlValues = Array.from(this.querySelectorAll('qti-default-value > qti-value'));\n\n    if (htmlValues.length === 0) {\n      return null;\n    }\n\n    const defaultValues = htmlValues.map(n => n.innerHTML.trim());\n    if (defaultValues.length > 1 || variable.cardinality === 'multiple' || variable.cardinality === 'ordered') {\n      return defaultValues;\n    }\n    return defaultValues[0];\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-variabledeclaration': QtiVariableDeclaration;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { BaseType, Cardinality } from '../../internal/expression-result';\nimport { ResponseVariable } from '../../internal/variables';\nimport { ItemContext, itemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiMapping } from '../../qti-response-processing/qti-expression/qti-mapping/qti-mapping';\nimport { QtiVariableDeclaration } from '../qti-variable-declaration';\n\n@customElement('qti-response-declaration')\nexport class QtiResponseDeclaration extends QtiVariableDeclaration {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType;\n\n  @property({ type: String }) identifier: string;\n\n  @property({ type: String }) cardinality: Cardinality;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\n\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    const value = this.itemContext?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n\n    const responseVariable: ResponseVariable = {\n      baseType: this.baseType,\n      identifier: this.identifier,\n      correctResponse: this.correctResponse,\n      cardinality: this.cardinality || 'single',\n      mapping: this.mapping,\n      value: null,\n      type: 'response',\n      candidateResponse: null\n    };\n    responseVariable.value = this.defaultValues(responseVariable);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-register-variable', {\n        bubbles: true,\n        composed: true,\n        detail: { variable: responseVariable }\n      })\n    );\n  }\n\n  private get correctResponse(): string | string[] {\n    let result: string | string[];\n    const correctResponse = this.querySelector('qti-correct-response');\n    if (correctResponse) {\n      const values = correctResponse.querySelectorAll('qti-value');\n      if (this.cardinality === 'single' && values.length > 0) {\n        result = values[0].textContent;\n        values[0].remove();\n      } else if (this.cardinality !== 'single') {\n        result = [];\n        for (let i = 0; i < values.length; i++) {\n          result.push(values[i].textContent);\n          values[i].remove();\n        }\n      }\n    }\n    return result;\n  }\n\n  private get mapping() {\n    return this.querySelector('qti-mapping') as QtiMapping;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-declaration': QtiResponseDeclaration;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-companion-materials-info')\nexport class QtiCompanionMaterialsInfo extends LitElement {\n  // static override styles = css`\n  //   slot {\n  //     display: hidden;\n  //   }\n  // `;\n  // override render() {\n  //   return html` <slot></slot> `;\n  // }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-companion-materials-info': QtiCompanionMaterialsInfo;\n  }\n}\n", "import { LitElement, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-content-body')\nexport class QtiContentBody extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-content-body': QtiContentBody;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\n\n@customElement('qti-rubric-block')\nexport class QtiRubricBlock extends LitElement {\n  @property({ type: String }) override id; // =\"qtiAspectInhoudRubricBlock\"\n\n  @property({ type: String }) use: 'instructions' | 'scoring' | 'navigation'; //  = \"scoring\"\n\n  @property({ type: String }) view: 'author' | 'candidate' | 'proctor' | 'scorer' | 'testConstructor' | 'tutor';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames', { waitUntilFirstUpdate: true })\n  handleclassNamesChange(old, disabled: boolean) {\n    const classNames = this.classNames.split(' ');\n    classNames.forEach((className: string) => {\n      switch (className) {\n        case 'qti-rubric-discretionary-placement':\n          this.setAttribute('slot', 'qti-rubric-block');\n          break;\n        case 'qti-rubric-inline':\n          this.setAttribute('slot', '');\n          break;\n        default:\n          break;\n      }\n    });\n  }\n\n  static override styles = css`\n    :host {\n      display: block;\n    }\n  `;\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    // by default put this in a slot in the item-body\n    this.setAttribute('slot', 'qti-rubric-block');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rubric-block': QtiRubricBlock;\n  }\n}\n", "import { PropertyValueMap, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiFeedback } from '../qti-feedback';\n\n@customElement('qti-feedback-block')\nexport class QtiFeedbackBlock extends QtiFeedback {\n  static override styles = css`\n    :host {\n      display: block;\n    }\n    .on {\n      display: block;\n    }\n    .off {\n      display: none;\n    }\n  `;\n\n  override render() {\n    return html` <slot part=\"feedback\" class=\"feedback ${this.showStatus}\"></slot> `;\n  }\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    this.checkShowFeedback(this.outcomeIdentifier);\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-feedback-block': QtiFeedbackBlock;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport { IsNullOrUndefined } from '../internal/utils';\nimport { itemContext, ItemContext } from '../qti-assessment-item/qti-assessment-item.context';\n\nexport abstract class QtiFeedback extends LitElement {\n  @property({ type: String, attribute: 'show-hide' })\n  protected showHide: string;\n\n  @property({ type: String, attribute: 'outcome-identifier' })\n  public outcomeIdentifier: string;\n\n  @property({ type: String })\n  protected identifier: string;\n\n  @property({ type: String, attribute: false })\n  public showStatus: string;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  private _context?: ItemContext;\n\n  public override connectedCallback() {\n    super.connectedCallback();\n    this.dispatchEvent(\n      new CustomEvent<QtiFeedback>('qti-register-feedback', {\n        bubbles: true,\n        composed: true,\n        detail: this\n      })\n    );\n  }\n\n  public checkShowFeedback(outcomeIdentifier: string) {    \n    const outcomeVariable = this._context.variables.find(v => v.identifier === outcomeIdentifier) || null;;\n\n    if (this.outcomeIdentifier !== outcomeIdentifier || !outcomeVariable) return;\n    let isFound = false;\n    if (Array.isArray(outcomeVariable.value)) {\n      isFound = outcomeVariable.value.includes(this.identifier);\n    } else {\n      isFound =\n        (!IsNullOrUndefined(this.identifier) &&\n          !IsNullOrUndefined(outcomeVariable?.value) &&\n          this.identifier === outcomeVariable.value) ||\n        false;\n    }\n\n    this.showFeedback(isFound);\n  }\n\n  private showFeedback(value: boolean) {    \n    this.showStatus = (value && this.showHide === 'show') || (!value && this.showHide === 'hide') ? 'on' : 'off';    \n  }\n}\n", "export const decimalSeparator = () => {\n  return new Intl.NumberFormat().format(0.1).replace(/\\d/g, '');\n};\n\nexport const convertNumberToUniveralFormat = (number: number | string) => {\n  // check if type is string\n  if (typeof number === 'string') {\n    return number;\n  }\n  const dSep = decimalSeparator();\n  if (dSep === '.') {\n    return number.toLocaleString();\n  } else {\n    return number.toString().replace('.', '').replace(dSep, '.');\n  }\n};\n\nexport function IsNullOrUndefined(value: unknown) {\n  return value === null || value === undefined;\n}\n\nexport function removeDoubleSlashes(str: string) {\n  const singleForwardSlashes = str\n    .replace(/([^:]\\/)\\/+/g, '$1')\n    .replace(/\\/\\//g, '/')\n    .replace('http:/', 'http://')\n    .replace('https:/', 'https://');\n  return singleForwardSlashes;\n}\n", "import { css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiFeedback } from '../qti-feedback';\n\n@customElement('qti-feedback-inline')\nexport class QtiFeedbackInline extends QtiFeedback {\n  static override styles = css`\n    .on {\n      display: inline-block;\n    }\n    .off {\n      display: none;\n    }\n  `;\n\n  override render = () => html` <slot part=\"feedback\" class=\"${this.showStatus}\"></slot> `;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-feedback-inline': QtiFeedbackInline;\n  }\n}\n", "import { css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiFeedback } from '../qti-feedback';\n\n@customElement('qti-modal-feedback')\nexport class QtiModalFeedback extends QtiFeedback {\n  static override styles = css`\n    .on {\n      display: inline-block;\n    }\n    .off {\n      display: none;\n    }\n  `;\n\n  override render = () => html` <slot part=\"feedback\" class=\"${this.showStatus}\"></slot> `;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-modal-feedback': QtiModalFeedback;\n  }\n}\n", "import { css, html } from 'lit';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { watch } from '../../../decorators/watch';\n\n@customElement('qti-extended-text-interaction')\nexport class QtiExtendedTextInteraction extends Interaction {\n  @state()\n  private _rows = 5;\n\n  /** expected length is mapped to the property maxlength on the textarea */\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  /** text appearing in the extended-text-nteraction if it is empty */\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @property({ type: String, attribute: 'data-patternmask-message' }) dataPatternmaskMessage: string;\n\n  @state()\n  private _value = '';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames')\n  handleclassNamesChange(old, classes: string) {\n    const classNames = classes.split(' ');\n    let rowsSet = false;\n    classNames.forEach((className: string) => {\n      if (className.startsWith('qti-height-lines-')) {\n        const nrRows = className.replace('qti-height-lines-', '');\n        this._rows = parseInt(nrRows);\n        rowsSet = true;\n      }\n    });\n    // If no qti-height-lines class is set, calculate rows based on expectedLength\n    if (!rowsSet && this.expectedLength) {\n      const estimatedRows = Math.ceil(this.expectedLength / 50); //  '50' based on an estimate for characters per row\n      this._rows = estimatedRows;\n    }\n  }\n\n  get value(): string | string[] {\n    return this._value;\n  }\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this._value = val;\n      const formData = new FormData();\n      formData.append(this.responseIdentifier, val);\n      this._internals.setFormValue(formData);\n      this.validate();\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  public override validate() {\n    const textarea = this.shadowRoot.querySelector('textarea');\n    if (!textarea) return false;\n\n    if (this.patternMask && this.dataPatternmaskMessage) {\n      // Clear any custom error initially\n      this._internals.setValidity({});\n      textarea.setCustomValidity('');\n      const patternSource =\n        this.patternMask.startsWith('^') && this.patternMask.endsWith('$') ? this.patternMask : `^${this.patternMask}$`;\n\n      const pattern = new RegExp(patternSource);\n      const isValid = textarea.checkValidity() && pattern.test(textarea.value);\n\n      if (!isValid) {\n        // Set custom error if invalid\n        this._internals.setValidity({ customError: true }, this.dataPatternmaskMessage);\n        textarea.setCustomValidity(this.dataPatternmaskMessage);\n      }\n    } else {\n      const isValid = textarea.checkValidity();\n      this._internals.setValidity(isValid ? {} : { customError: false });\n    }\n\n    return this._value !== '' && textarea.checkValidity();\n  }\n\n  override reportValidity() {\n    const textarea = this.shadowRoot.querySelector('textarea');\n    if (!textarea) return false;\n\n    // Run the validate function to ensure the custom validity state is up to date\n    const isValid = this.validate();\n    if (!isValid) {\n      textarea.reportValidity();\n    }\n    return isValid;\n  }\n\n  static override get styles() {\n    return [\n      css`\n        /* PK: display host as block, else design will be collapsed */\n        :host {\n          display: block;\n        }\n        textarea {\n          box-sizing: border-box;\n          width: 100%;\n          height: 100%;\n          border: 0;\n        }\n      `\n    ];\n  }\n\n  override render() {\n    return html`<slot name=\"prompt\"></slot\n      ><textarea\n        part=\"textarea\"\n        name=\"${this.responseIdentifier}\"\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        maxlength=\"${5000}\"\n        @keydown=\"${event => event.stopImmediatePropagation()}\"\n        @keyup=\"${this.textChanged}\"\n        @change=\"${this.textChanged}\"\n        @blur=\"${(event: FocusEvent) => {\n          this.reportValidity();\n        }}\"\n        placeholder=\"${ifDefined(this.placeholderText ? this.placeholderText : undefined)}\"\n        rows=\"${this._rows}\"\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n        .value=${this._value}\n      ></textarea>`;\n  }\n\n  protected textChanged(event: Event) {\n    if (this.disabled || this.readonly) return;\n    const input = event.target as HTMLInputElement;\n    this.setEmptyAttribute(input.value);\n    if (this._value !== input.value) {\n      this.value = input.value;\n      const isValid = this.validate();\n      this.saveResponse(input.value);\n    }\n  }\n\n  private setEmptyAttribute(text: string) {\n    this.setAttribute('empty', text === '' ? 'true' : 'false');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-extended-text-interaction': QtiExtendedTextInteraction;\n  }\n}\n", "import { property, state } from 'lit/decorators.js';\nimport { LitElement } from 'lit';\nimport { IInteraction } from './interaction.interface';\n\nexport abstract class Interaction extends LitElement implements IInteraction {\n  static formAssociated = true; // Enable form association\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier = '';\n  /** disabled should be exposed to the attributes and accessible as property */\n  @property({ reflect: true, type: Boolean }) disabled = false;\n\n  /** readonly should be exposed to the attributes and accessible as property */\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\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  abstract get value(): string | string[];\n  abstract set value(val: string | string[]);\n\n  public get correctResponse(): string | string[] {\n    return this._correctResponse;\n  }\n  set correctResponse(value: string | string[]) {\n    this._correctResponse = value;\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      })\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", "import { CSSResultGroup, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { createRef } from 'lit/directives/ref.js';\nimport { watch } from '../../../decorators';\nimport { Interaction } from '../internal/interaction/interaction';\nimport styles from './qti-text-entry-interaction.styles';\n@customElement('qti-text-entry-interaction')\nexport class QtiTextEntryInteraction extends Interaction {\n  static styles: CSSResultGroup = styles;\n\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @property({ type: String, attribute: 'data-patternmask-message' }) dataPatternmaskMessage: string;\n\n  @state()\n  private _value = '';\n\n  inputRef = createRef<HTMLInputElement>();\n\n  get value(): string | string[] {\n    return this._value;\n  }\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this._value = val;\n      const formData = new FormData();\n      formData.append(this.responseIdentifier, val);\n      this._internals.setFormValue(formData);\n      this.validate();\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  public override validate() {\n    const input = this.shadowRoot.querySelector('input');\n    if (!input) return false;\n    if (this.patternMask && this.dataPatternmaskMessage) {\n      // Clear any custom error if the input is valid\n      this._internals.setValidity({});\n      input.setCustomValidity(''); // Clear the custom message\n      const isValid = input.checkValidity();\n      if (!isValid) {\n        // Set custom error if invalid\n        this._internals.setValidity({ customError: true }, this.dataPatternmaskMessage);\n        input.setCustomValidity(this.dataPatternmaskMessage); // Set custom message only if invalid\n      }\n    } else {\n      const isValid = input.checkValidity();\n      this._internals.setValidity(isValid ? {} : { customError: false });\n    }\n    return this._value !== '' && input.checkValidity();\n  }\n\n  override render() {\n    return html`\n      <input\n        part=\"input\"\n        name=\"${this.responseIdentifier}\"\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        @blur=\"${(event: FocusEvent) => {\n          this.reportValidity();\n        }}\"\n        @keydown=\"${event => event.stopImmediatePropagation()}\"\n        @keyup=\"${this.textChanged}\"\n        @change=\"${this.textChanged}\"\n        type=\"${this.patternMask == '[0-9]*' ? 'number' : 'text'}\"\n        placeholder=\"${ifDefined(this.placeholderText ? this.placeholderText : undefined)}\"\n        .value=\"${this._value}\"\n        pattern=\"${ifDefined(this.patternMask ? this.patternMask : undefined)}\"\n        maxlength=${1000}\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n      />\n      <div part=\"correct\">${this._correctResponse}</div>\n    `;\n  }\n  protected textChanged(event: Event) {\n    if (this.disabled || this.readonly) return;\n    const input = event.target as HTMLInputElement;\n    this.setEmptyAttribute(input.value);\n    if (this._value !== input.value) {\n      this.value = input.value;\n      const isValid = this.validate();\n      this.saveResponse(input.value);\n    }\n  }\n\n  override reportValidity() {\n    const input = this.shadowRoot.querySelector('input');\n    if (!input) return false;\n\n    // Run the validate function to ensure the custom validity state is up to date\n    const isValid = this.validate();\n    if (!isValid) {\n      input.reportValidity();\n    }\n    return isValid;\n  }\n\n  reset(): void {\n    this._value = '';\n  }\n\n  private setEmptyAttribute(text: string) {\n    this.setAttribute('empty', text === '' ? 'true' : 'false');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-text-entry-interaction': QtiTextEntryInteraction;\n  }\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: inline-block;\n  }\n  [part='correct'] {\n    position: absolute;\n    width: 100%;\n  }\n  :host(.qti-input-width-1) [part='input'] {\n    width: 1.1rem;\n    min-width: 1.1rem;\n  }\n\n  :host(.qti-input-width-2) [part='input'] {\n    width: 2.3rem;\n    min-width: 2.3rem;\n  }\n\n  :host(.qti-input-width-3) [part='input'] {\n    width: 3.3rem;\n    min-width: 3.3rem;\n  }\n\n  :host(.qti-input-width-4) [part='input'] {\n    width: 4.2rem;\n    min-width: 4.2rem;\n  }\n\n  :host(.qti-input-width-6) [part='input'] {\n    width: 6.6rem;\n    min-width: 6.6rem;\n  }\n\n  :host(.qti-input-width-10) [part='input'] {\n    width: 8rem;\n    min-width: 8rem;\n  }\n\n  :host(.qti-input-width-15) [part='input'] {\n    width: 12rem;\n    min-width: 12rem;\n  }\n\n  :host(.qti-input-width-20) [part='input'] {\n    width: 17rem;\n    min-width: 17rem;\n  }\n\n  :host(.qti-input-width-25) [part='input'] {\n    width: 20rem;\n    min-width: 20rem;\n  }\n\n  :host(.qti-input-width-30) [part='input'] {\n    width: 24rem;\n    min-width: 24rem;\n  }\n\n  :host(.qti-input-width-35) [part='input'] {\n    width: 28rem;\n    min-width: 28rem;\n  }\n\n  :host(.qti-input-width-40) [part='input'] {\n    width: 32rem;\n    min-width: 32rem;\n  }\n\n  :host(.qti-input-width-45) [part='input'] {\n    width: 36rem;\n    min-width: 36rem;\n  }\n\n  :host(.qti-input-width-50) [part='input'] {\n    width: 40rem;\n    min-width: 40rem;\n  }\n\n  :host(.qti-input-width-72) [part='input'] {\n    width: 57rem;\n    min-width: 57rem;\n  }\n`;\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-hottext-interaction')\nexport class QtiHottextInteraction extends ChoicesMixin(Interaction, 'qti-hottext') {\n  override connectedCallback() {\n    super.connectedCallback();\n    this.setAttribute('qti-hottext-interaction', '');\n  }\n\n  override render = () => html`<slot></slot>`;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hottext-interaction': QtiHottextInteraction;\n  }\n}\n", "import { property, query } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\nimport { ChoiceInterface } from '../active-element/active-element.mixin';\nimport { Interaction } from '../interaction/interaction';\nimport { IInteraction } from '../interaction/interaction.interface';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport type Choice = HTMLElement & ChoiceInterface & { internals: ElementInternals };\n\nexport interface ChoicesInterface extends IInteraction {\n  correctResponse: string | string[];\n}\n\nexport const ChoicesMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class ChoicesMixinElement extends superClass implements ChoicesInterface {\n    protected _choiceElements: Choice[] = [];\n\n    @query('#validationMessage')\n    private _validationMessageElement!: HTMLElement;\n\n    @property({ type: Number, attribute: 'min-choices' })\n    public minChoices = 0;\n\n    @property({ type: Number, attribute: 'max-choices' })\n    public maxChoices = 1;\n\n    @watch('maxChoices', { waitUntilFirstUpdate: true })\n    protected _handleMaxChoicesChange(_oldValue: number, _newValue: number) {\n      this._determineInputType();\n    }\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    protected _handleDisabledChange = (_: boolean, disabled: boolean) => {\n      this._choiceElements.forEach(ch => (ch.disabled = disabled));\n    };\n\n    @watch('readonly', { waitUntilFirstUpdate: true })\n    protected _handleReadonlyChange = (_: boolean, readonly: boolean) => {\n      this._choiceElements.forEach(choice => (choice.readonly = readonly));\n    };\n\n    private _value: string | string[] = '';\n\n    get value(): string | string[] {\n      return Array.isArray(this._value) ? this._value.join(',') : this._value;\n    }\n\n    set value(val: string | string[]) {\n      if (this.maxChoices > 1 && typeof val === 'string') {\n        this._value = val.split(',');\n      } else {\n        this._value = val;\n      }\n      // Assuming this.value is an array of strings\n      if (Array.isArray(this._value)) {\n        const formData = new FormData();\n        this._value.forEach(response => {\n          formData.append(this.responseIdentifier, response);\n        });\n        this._internals.setFormValue(formData);\n      } else {\n        // Handle the case where this.value is not an array\n        this._internals.setFormValue(this._value);\n      }\n      this._updateChoiceSelection();\n    }\n\n    public get correctResponse(): string | string[] {\n      return this._correctResponse;\n    }\n\n    public set correctResponse(value: string | string[]) {\n      this._correctResponse = value;\n      const responseArray = Array.isArray(value) ? value : [value];\n      this._choiceElements.forEach(choice => {\n        choice.internals.states.delete('correct-response');\n        choice.internals.states.delete('incorrect-response');\n        if (responseArray.length > 0) {\n          if (responseArray.includes(choice.identifier)) {\n            choice.internals.states.add('correct-response');\n          } else {\n            choice.internals.states.add('incorrect-response');\n          }\n        }\n      });\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.addEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.addEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.addEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.removeEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.removeEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n    }\n\n    public validate(): boolean {\n      const selectedChoices = this._choiceElements.filter(choice => this._getChoiceChecked(choice));\n      const selectedCount = selectedChoices.length;\n      let isValid = true;\n      let validityMessage = '';\n      if (this.maxChoices !== 0 && selectedCount > this.maxChoices) {\n        isValid = false;\n        validityMessage = this.dataset.maxSelectionsMessage || `You can select at most ${this.maxChoices} choices.`;\n      } else if (selectedCount < this.minChoices) {\n        isValid = false;\n        validityMessage = this.dataset.minSelectionsMessage || `You must select at least ${this.minChoices} choices.`;\n      }\n\n      if (selectedChoices.length > 0) {\n        this._internals.setValidity(\n          isValid ? {} : { customError: true },\n          validityMessage,\n          selectedChoices[selectedCount - 1] || this._choiceElements[0] || this\n        );\n      }\n      this.reportValidity();\n      return isValid;\n    }\n\n    override reportValidity() {\n      if (this._validationMessageElement) {\n        if (!this._internals.validity.valid) {\n          this._validationMessageElement.textContent = this._internals.validationMessage;\n          this._validationMessageElement.style.display = 'block';\n        } else {\n          this._validationMessageElement.textContent = '';\n          this._validationMessageElement.style.display = 'none';\n        }\n      }\n      return this._internals.validity.valid;\n    }\n\n    private _registerChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      choiceElement.disabled = this.disabled;\n\n      this._choiceElements.push(choiceElement);\n      this._setInputType(choiceElement);\n    }\n\n    private _unregisterChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      this._choiceElements = this._choiceElements.filter(choice => choice !== choiceElement);\n    }\n\n    private _determineInputType() {\n      this._choiceElements.forEach(choice => {\n        this._setInputType(choice);\n      });\n    }\n\n    private _setInputType(choiceElement: Choice) {\n      this._internals.ariaLabel = this.maxChoices === 1 ? 'radio-group' : 'checkbox-group';\n\n      choiceElement.internals.role = this.maxChoices === 1 ? 'radio' : 'checkbox';\n      choiceElement.internals.states.add(choiceElement.internals.role);\n    }\n\n    protected _choiceElementSelectedHandler(event: CustomEvent<{ identifier: string }>) {\n      this._toggleChoiceChecked(event.target as Choice);\n      if (this.maxChoices === 1) {\n        this._choiceElements.forEach(choice => {\n          if (choice.identifier !== event.detail.identifier) {\n            this._setChoiceChecked(choice, false);\n          }\n        });\n      }\n      this._handleChoiceSelection();\n    }\n\n    private _setChoiceChecked(choice: Choice, checked: boolean) {\n      if (choice.internals?.states) {\n        if (checked) {\n          choice.internals.states.add('--checked');\n          choice.internals.ariaChecked = 'true';\n        } else {\n          choice.internals.states.delete('--checked');\n          choice.internals.ariaChecked = 'false';\n        }\n      }\n    }\n\n    private _getChoiceChecked(choice: Choice): boolean {\n      return choice.internals.states.has('--checked');\n    }\n\n    private _toggleChoiceChecked(choice: Choice) {\n      const checked = this._getChoiceChecked(choice);\n      this._setChoiceChecked(choice, !checked);\n    }\n\n    private _handleChoiceSelection() {\n      const selectedChoices = this._choiceElements.filter(choice => this._getChoiceChecked(choice));\n      const selectedIdentifiers = selectedChoices.map(choice => choice.identifier);\n\n      this.value = this.maxChoices === 1 ? selectedIdentifiers[0] || '' : selectedIdentifiers;\n      this.validate();\n      this.saveResponse(this._value);\n    }\n\n    /**\n     * Updates the selection state of each choice element based on the current response.\n     */\n    private _updateChoiceSelection() {\n      const responseArray = Array.isArray(this._value) ? this._value : [this._value];\n      this._choiceElements.forEach(choice => {\n        const isSelected = responseArray.includes(choice.identifier);\n        this._setChoiceChecked(choice, isSelected);\n      });\n    }\n  }\n  return ChoicesMixinElement as Constructor<ChoicesInterface> & T;\n};\n", "import { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\ninterface OptionType {\n  textContent: string;\n  value: string;\n  selected: boolean;\n}\n\n@customElement('qti-inline-choice-interaction')\nexport class QtiInlineChoiceInteraction extends Interaction {\n  static override get styles() {\n    return [\n      css`\n        :host {\n          display: inline-block;\n        }\n        slot {\n          display: flex;\n          flex-direction: column;\n        }\n        [role='menu'] {\n          position: absolute;\n          z-index: 1000;\n        }\n        .anchor {\n          /* anchor-name: --infobox; */\n          width: fit-content;\n        }\n\n        .positionedElement {\n          position: absolute;\n          /* position-anchor: --infobox; */\n          /* top: anchor(bottom); */\n        }\n      `\n    ];\n  }\n\n  public static inputWidthClass = [\n    '',\n    'qti-input-width-2',\n    'qti-input-width-1',\n    'qti-input-width-3',\n    'qti-input-width-4',\n    'qti-input-width-6',\n    'qti-input-width-10',\n    'qti-input-width-15',\n    'qti-input-width-20',\n    'qti-input-width-72'\n  ];\n\n  @state() options: OptionType[] = [];\n\n  @state() correctOption: string = '';\n\n  @property({ attribute: 'data-prompt', type: String })\n  dataPrompt: string = 'select';\n\n  override render() {\n    return html`\n      <select part=\"select\" @change=\"${this.choiceSelected}\" ?disabled=\"${this.disabled}\" ?readonly=\"${this.readonly}\">\n        ${this.options.map(\n          option => html`\n            <option value=\"${option.value}\" ?selected=\"${option.selected}\">${unsafeHTML(option.textContent)}</option>\n          `\n        )}\n      </select>\n\n      ${unsafeHTML(this.correctOption)}\n    `;\n  }\n\n  connectedCallback() {\n    super.connectedCallback();\n    this.addEventListener('on-dropdown-selected', this.choiceSelected);\n    const choices = Array.from(this.querySelectorAll('qti-inline-choice'));\n    this.options = [\n      {\n        textContent: this.dataPrompt,\n        value: '',\n        selected: false\n      },\n      ...choices.map(choice => ({\n        textContent: choice.innerHTML,\n        value: choice.getAttribute('identifier'),\n        selected: false\n      }))\n    ];\n  }\n\n  disconnectedCallback() {\n    this.removeEventListener('on-dropdown-selected', this.choiceSelected);\n  }\n\n  public validate(): boolean {\n    const selectedOption = this.options.find(option => option.selected);\n    return selectedOption ? selectedOption.value !== '' : false;\n  }\n\n  public reset() {\n    this.options = this.options.map((option, i) => ({ ...option, selected: i === 0 }));\n  }\n\n  public set value(value: string) {\n    this.options = this.options.map(option => {\n      if (value === option.value) {\n        option.selected = true;\n      }\n      return option;\n    });\n  }\n  get value(): string {\n    return this.options.find(option => option.selected).value;\n  }\n\n  set correctResponse(value: string | string[]) {\n    if (value === '') {\n      this.correctOption = '';\n      return;\n    }\n    this.correctOption = `<span part=\"correct-option\">${\n      this.options.find(option => value === option.value).textContent\n    }</span>`;\n  }\n\n  public choiceSelected(event: Event) {\n    const selectedOptionValue = (event.target as HTMLSelectElement).value;\n    this.options = this.options.map(option => ({ ...option, selected: option.value === selectedOptionValue }));\n    this.saveResponse(selectedOptionValue);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-inline-choice-interaction': QtiInlineChoiceInteraction;\n  }\n}\n", "import type { CSSResultGroup } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ChoicesInterface, ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { ShuffleMixin } from '../internal/shuffle/shuffle-mixin';\nimport { VocabularyMixin } from '../internal/vocabulary/vocabulary-mixin';\nimport styles from './qti-choice-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n\nexport type Orientation = 'horizontal' | 'vertical' | undefined;\n\n@customElement('qti-choice-interaction')\nexport class QtiChoiceInteraction\n  extends VocabularyMixin(\n    ShuffleMixin(ChoicesMixin(Interaction, 'qti-simple-choice'), 'qti-simple-choice'),\n    'qti-simple-choice'\n  )\n  implements ChoicesInterface\n{\n  static styles: CSSResultGroup = styles;\n\n  constructor() {\n    super();\n    this._internals.role = 'group';\n  }\n\n  /** orientation of choices */\n  @property({ type: String })\n  public orientation: Orientation;\n\n  render() {\n    return html`\n      <slot name=\"prompt\"></slot><slot part=\"slot\"></slot>\n      <div role=\"alert\" id=\"validationMessage\"></div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-choice-interaction': QtiChoiceInteraction;\n  }\n}\n", "/**\n * Mixin that provides shuffling functionality for a LitElement.\n * @template T - The type of the LitElement subclass.\n * @param {T} superClass - The superclass to extend.\n * @param {string} selector - The CSS selector for the elements to shuffle.\n * @returns {Constructor<ShuffleInterface> & T} - The extended class with shuffling functionality.\n *\n * adds a shuffle property to the class with an attribute converter\n *\n * qti-inline-choice-interaction\n * qti-choice-interaction\n * qti-match-interaction\n */\nimport { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class ShuffleInterface {}\nexport const ShuffleMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class ShuffleElement extends superClass {\n    private _shuffle: boolean = false;\n\n    // Define the property with the custom converter\n    @property({\n      type: String,\n      reflect: true,\n      converter: stringToBooleanConverter\n    })\n    set shuffle(value: boolean) {\n      const oldValue = this._shuffle;\n      this._shuffle = value;\n      if (value) {\n        this._shuffleChoices();\n      } else {\n        this._resetShuffleChoices();\n      }\n      this.requestUpdate('shuffle', oldValue);\n    }\n\n    get shuffle(): boolean {\n      return this._shuffle;\n    }\n\n    connectedCallback() {\n      super.connectedCallback();\n      // Call _resetShuffleChoices initially to set the CSS order to initial.\n      // If shuffle is true, _shuffleChoices will be called automatically via the setter.\n      if (this.shuffle) {\n        this._shuffleChoices();\n      } else {\n        this._resetShuffleChoices();\n      }\n    }\n\n    private _shuffleChoices() {\n      const choices = Array.from(this.querySelectorAll<HTMLElement>(selector));\n      const fixedElements: Array<{ element: HTMLElement; index: number }> = [];\n      const nonFixedElements: Array<HTMLElement> = [];\n\n      // Separate fixed and non-fixed elements\n      choices.forEach((choice, index) => {\n        if (choice.hasAttribute('fixed')) {\n          fixedElements.push({ element: choice, index: index });\n        } else {\n          nonFixedElements.push(choice);\n        }\n      });\n\n      // If there are 1 or fewer non-fixed elements, throw an error (no shuffle possible)\n      if (nonFixedElements.length <= 1) {\n        console.warn('Shuffling is not possible with fewer than 2 non-fixed elements.');\n        return;\n      }\n\n      let isShuffled = false;\n      const maxAttempts = 10; // Max attempts to prevent infinite loops\n      let attempt = 0;\n\n      // Create a copy of the original order for comparison\n      const originalOrder = [...nonFixedElements];\n\n      // Shuffle until the result is different or maxAttempts is reached\n      while (!isShuffled && attempt < maxAttempts) {\n        attempt++;\n\n        // Shuffle non-fixed elements\n        for (let i = nonFixedElements.length - 1; i > 0; i--) {\n          const j = Math.floor(Math.random() * (i + 1));\n          [nonFixedElements[i], nonFixedElements[j]] = [nonFixedElements[j], nonFixedElements[i]];\n        }\n\n        // Check if the shuffled result is different from the original order\n        isShuffled = !nonFixedElements.every((choice, index) => choice === originalOrder[index]);\n\n        if (isShuffled) break;\n      }\n\n      if (!isShuffled) {\n        console.warn('Failed to shuffle the choices after multiple attempts.');\n      }\n\n      // Assign order to each element\n      let order = 1;\n      choices.forEach((choice: HTMLElement, index) => {\n        if (choice.hasAttribute('fixed')) {\n          choice.style.setProperty('order', String(order++));\n        } else {\n          const nonFixedChoice = nonFixedElements.shift();\n          nonFixedChoice!.style.setProperty('order', String(order++));\n        }\n      });\n    }\n\n    private _resetShuffleChoices() {\n      const choices = Array.from(this.querySelectorAll('qti-simple-choice'));\n      choices.forEach((choice, index) => {\n        choice.style.setProperty('order', 'initial'); // choice.style.order = 'initial';\n      });\n    }\n  }\n  return ShuffleElement as Constructor<ShuffleInterface> & T;\n};\n\nconst stringToBooleanConverter = {\n  fromAttribute(value: string | null): boolean {\n    return value === 'true';\n  },\n  toAttribute(value: boolean): string {\n    return value ? 'true' : 'false';\n  }\n};\n", "/**\n * Mixin that provides shuffling functionality for a LitElement.\n * @template T - The type of the LitElement subclass.\n * @param {T} superClass - The superclass to extend.\n * @param {string} selector - The CSS selector for the elements to shuffle.\n * @returns {Constructor<ShuffleInterface> & T} - The extended class with shuffling functionality.\n *\n * adds a shuffle property to the class with an attribute converter\n *\n * qti-inline-choice-interaction\n * qti-choice-interaction\n * qti-match-interaction\n */\nimport { PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { QtiSimpleChoice } from '../../qti-simple-choice';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ntype LabelType = 'qti-labels-decimal' | 'qti-labels-lower-alpha' | 'qti-labels-upper-alpha';\ntype LabelSuffixType = 'qti-labels-suffix-period' | 'qti-labels-suffix-parenthesis';\n\ndeclare class VocabularyInterface {}\n\nexport const VocabularyMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class VocabularyElement extends superClass {\n    private _classes: string[] = [];\n    private _allLabels = ['qti-labels-decimal', 'qti-labels-lower-alpha', 'qti-labels-upper-alpha'];\n    private _allLabelSuffixes = ['qti-labels-suffix-period', 'qti-labels-suffix-parenthesis'] as LabelSuffixType[];\n    // Define the property with the custom converter\n    @property({\n      type: String,\n      reflect: true\n    })\n    set class(value: string) {\n      if (!value) {\n        return;\n      }\n      // const oldValue = this._classes.join(' ');\n      this._classes = value.split(' ');\n\n      this._addLabels();\n      // this.requestUpdate('class', oldValue);\n    }\n    get class(): string {\n      return this._classes?.join(' ') || '';\n    }\n\n    protected override updated(_changedProperties: PropertyValues): void {\n      super.updated(_changedProperties);\n      if (_changedProperties.has('shuffle')) {\n        this._addLabels();\n      }\n    }\n\n    private _addLabels() {\n      const classContainsLabel = this._classes.some(\n        cls => this._allLabels.includes(cls) || this._allLabelSuffixes.includes(cls as LabelSuffixType)\n      );\n      const isNumber = value => {\n        return !isNaN(+value);\n      };\n      if (classContainsLabel) {\n        const choiceElements = Array.from(this.querySelectorAll('qti-simple-choice')).map(c => c as QtiSimpleChoice);\n        const choices = choiceElements\n          .map((choice: HTMLElement, index) => {\n            return { el: choice, order: isNumber(choice.style.order) ? +choice.style.order : index + 1 };\n          })\n          .sort((a, b) => a.order - b.order)\n          .map(choice => choice.el);\n        for (let i = 0; i < choices.length; i++) {\n          (choices[i] as QtiSimpleChoice).marker = this._getLabel(i + 1);\n        }\n      }\n    }\n    private _getLabel(index: number) {\n      let lastLabel = this._classes.filter(c => this._allLabels.includes(c)).pop() as LabelType;\n      const lastLabelSuffix = this._classes.filter(c => this._allLabelSuffixes.includes(c as LabelSuffixType)).pop();\n\n      if (!lastLabel && lastLabelSuffix) {\n        // a suffix without a label is strange so add qti-labels-upper-alpha\n        lastLabel = 'qti-labels-upper-alpha';\n      }\n      let label = '';\n      switch (lastLabel) {\n        case 'qti-labels-decimal':\n          label = `${index}`;\n          break;\n        case 'qti-labels-lower-alpha':\n          label = `${String.fromCharCode(97 + index - 1)}`;\n          break;\n        case 'qti-labels-upper-alpha':\n          label = `${String.fromCharCode(65 + index - 1)}`;\n          break;\n      }\n      if (lastLabelSuffix === 'qti-labels-suffix-period') {\n        label += '.';\n      } else if (lastLabelSuffix === 'qti-labels-suffix-parenthesis') {\n        label += `)`;\n      }\n      return label;\n    }\n  }\n  return VocabularyElement as Constructor<VocabularyInterface> & T;\n};\n", "import { css } from 'lit';\n\nexport default css`\n  [part='slot'] {\n    display: flex;\n    flex-direction: column;\n    gap: var(--qti-gap-size);\n    flex-wrap: wrap;\n  }\n\n  ::slotted(qti-simple-choice) {\n    flex: 0 0\n      calc((100% - (var(--qti-gap-size) * var(--choice-interactions-stacking))) / var(--choice-interactions-stacking)) !important;\n    box-sizing: border-box !important;\n  }\n\n  :host(.qti-choices-stacking-1) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 1;\n  }\n\n  :host(.qti-choices-stacking-2) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 2;\n  }\n  :host(.qti-choices-stacking-3) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 3;\n  }\n  :host(.qti-choices-stacking-4) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 4;\n  }\n  :host(.qti-choices-stacking-5) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 5;\n  }\n  :host([orientation='horizontal']) [part='slot'] {\n    flex-direction: row;\n  }\n`;\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiRule, QtiRuleBase } from '..';\n\n@customElement('qti-outcome-processing')\nexport class QtiOutcomeProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const logic = new QtiOutcomeProcessingProcessor();\n    const rules = [...this.children] as QtiRule[];\n    logic.process(rules);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-outcome-processing': QtiOutcomeProcessing;\n  }\n}\n\nexport class QtiOutcomeProcessingProcessor {\n  public process(rules: QtiRuleBase[]) {\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n}\n", "import { css, html, LitElement, PropertyValueMap } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { mapResponse, mapResponsePoint, matchCorrect } from '../../internal/template-strings';\nimport { type QtiRule } from '../qti-rule/qti-rule';\n\n@customElement('qti-response-processing')\nexport default class QtiResponseProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const rules = [...this.children] as QtiRule[];\n\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n\n  public firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    if (this.getAttribute('template')) {\n      const splittedTemplateName = this.getAttribute('template')!.split('/');\n      const templateName = splittedTemplateName[splittedTemplateName.length - 1].replace('.xml', '');\n      this.innerHTML = '';\n      switch (templateName) {\n        case 'map_response': {\n          this.appendChild(this.fragmentFromString(mapResponse).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'map_response_point': {\n          this.appendChild(this.fragmentFromString(mapResponsePoint).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'match_correct':\n          this.appendChild(this.fragmentFromString(matchCorrect).firstElementChild.firstElementChild);\n          break;\n      }\n    }\n  }\n\n  private fragmentFromString(strHTML: string) {\n    return document.createRange().createContextualFragment(strHTML);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-processing': QtiResponseProcessing;\n  }\n}\n", "export const matchCorrect = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-match>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n        <qti-correct identifier=\"RESPONSE\"></qti-correct>\n      </qti-match>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">1</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponse = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0.0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response identifier=\"RESPONSE\"> </qti-map-response>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponsePoint = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response-point identifier=\"RESPONSE\"></qti-map-response-point>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n", "import { OutcomeVariable } from '@citolab/qti-components/qti-components';\nimport { property } from 'lit/decorators.js';\nimport { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\n/**\n * The lookupOutcomeValue rule sets the value of an outcome variable to the value obtained\n * by looking up the value of the associated expression in the lookupTable associated\n * with the outcome's declaration.\n */\nexport class QtiLookupOutcomeValue extends QtiRule {\n  @property({ type: String }) identifier: string;\n\n  get childExpression(): QtiExpression<string> {\n    return this.firstElementChild as QtiExpression<string>;\n  }\n\n  public override process(): number {\n    const identifier = this.getAttribute('identifier');\n    const outcomeVariable = this.closest('qti-assessment-item').getVariable(identifier) as OutcomeVariable;\n    let value;\n    if (outcomeVariable.interpolationTable) {\n      value = outcomeVariable.interpolationTable.get(parseInt(this.childExpression.calculate()));\n    }\n    if (value === null || value === undefined) {\n      console.warn('lookupOutcomeValue: value is null or undefined');\n      return 0;\n    }\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier: this.identifier,\n          value: convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n    return value;\n  }\n}\ncustomElements.define('qti-lookup-outcome-value', QtiLookupOutcomeValue);\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-lookup-outcome-value': QtiLookupOutcomeValue;\n  }\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\n\n@customElement('qti-rule')\nexport class QtiRule extends LitElement implements QtiRuleBase {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    throw new Error('Not implemented');\n  }\n}\n\nexport interface QtiRuleBase {\n  process(): any;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rule': QtiRule;\n  }\n}\n", "import { html } from 'lit';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\nexport class QtiResponseCondition extends QtiRule {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public override process() {\n    const branches = [...this.children] as QtiExpression<any>[];\n\n    for (let i = 0; i < branches.length; i++) {\n      const branch = branches[i];\n\n      if (branch.calculate()) {\n        (branch as unknown as QtiRule).process();\n\n        return;\n      }\n    }\n  }\n}\n\ncustomElements.define('qti-response-condition', QtiResponseCondition);\n", "import { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression, QtiExpressionBase } from '../../qti-expression/qti-expression';\nimport { QtiRule, QtiRuleBase } from '../qti-rule';\n\nexport class QtiSetOutcomeValue extends QtiRule {\n  public override process() {\n    const outcomeIdentifier = this.getAttribute('identifier');\n\n    const expression = this.firstElementChild as QtiExpression<string>;\n\n    const rule = new QtiSetOutcomeValueRule(expression);\n    const value = rule.process();\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier,\n          value: Array.isArray(value)\n            ? value.map((v: string) => convertNumberToUniveralFormat(v))\n            : convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n  }\n}\n\nexport class QtiSetOutcomeValueRule<T> implements QtiRuleBase {\n  constructor(private expression: QtiExpressionBase<T>) {}\n\n  process(): any {\n    const value = this.expression ? this.expression.calculate() : null;\n\n    if (value === null || value === undefined) {\n      console.warn('setOutcomeValue: value is null or undefined');\n      return;\n    }\n    return value;\n  }\n}\n\ncustomElements.define('qti-set-outcome-value', QtiSetOutcomeValue);\n", "import { LitElement, html } from 'lit';\nimport { QtiRule } from '../qti-rule/qti-rule';\n\nexport class QtiResponseElse extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public calculate() {\n    const result = true;\n    return true;\n  }\n\n  public getSubRules(): QtiRule[] {\n    return [...this.children] as QtiRule[];\n  }\n\n  public process() {\n    const subRules = this.getSubRules();\n    for (let i = 0; i < subRules.length; i++) {\n      const subRule = subRules[i];\n      subRule.process();\n    }\n  }\n}\n\ncustomElements.define('qti-response-else', QtiResponseElse);\n", "import { html } from 'lit';\nimport { QtiResponseIf } from '../qti-response-if';\n\nexport class QtiResponseElseIf extends QtiResponseIf {\n  override render() {\n    return html`${super.render()}`;\n  }\n}\n\ncustomElements.define('qti-response-else-if', QtiResponseElseIf);\n", "import { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../../qti-rule/qti-rule';\nimport { QtiResponseElse } from '../qti-response-else';\n\nexport class QtiResponseIf extends QtiResponseElse {\n  public override calculate() {\n    const expression = this.firstElementChild as QtiExpression<boolean>;\n    const result = expression.calculate() as boolean;\n    return result;\n  }\n\n  public override getSubRules(): QtiRule[] {\n    const result = [];\n    for (let i = 1; i < this.children.length; i++) {\n      result.push(this.children[i]);\n    }\n    return result;\n  }\n}\n\ncustomElements.define('qti-response-if', QtiResponseIf);\n", "import { consume } from '@lit/context';\nimport { css, html, LitElement } from 'lit';\nimport { state } from 'lit/decorators.js';\nimport { ResponseVariable, VariableDeclaration } from '../../internal/variables';\nimport { itemContext, ItemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiMultiple } from './qti-multiple/qti-multiple';\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  getVariables = (): VariableDeclaration<number | string | (number | string)[] | null>[] =>\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        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            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            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: 'multiple',\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 = 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(),\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", "import { QtiExpression } from './qti-expression';\n\nexport abstract class QtiConditionExpression extends QtiExpression<boolean> {\n  public calculate(): Readonly<boolean> {\n    this.result = this.getResult();\n    return this.result;\n  }\n\n  public getResult(): Readonly<boolean> {\n    throw new Error('Not implemented');\n  }\n}\n", "import { QtiConditionExpression } from '../qti-condition-expression';\nimport { QtiExpression } from '../qti-expression';\n\ntype Constructor<T> = new (...args: any[]) => T;\nexport class QtiAnd extends qtiAndMixin(QtiConditionExpression as unknown as Constructor<QtiConditionExpression>) {\n  public calculate() {\n    return this.calculateChildren(Array.from(this.children as unknown as QtiExpression<any>[]));\n  }\n}\n\nexport type MockQtiExpression<T> = { calculate: () => T };\ntype MockConstructor = new (...args: any[]) => {};\nexport function qtiAndMixin<TBase extends MockConstructor>(Base: TBase) {\n  return class MockQtiAnd extends Base {\n    public calculateChildren(children: Array<MockQtiExpression<any>>) {\n      // children can be a mix of qti-expression and qti-condition-expression\n      const values = children.map(c => {\n        const condition = c as MockQtiExpression<any>;\n        if (!condition.calculate) {\n          console.error(\"Element doesn't implement QtiConditionExpression\");\n          return null;\n        }\n        const value = condition.calculate();\n        let val = false;\n        // convert string value to boolean and return null if not possible\n        if (typeof value === 'string') {\n          if (value === 'true') {\n            val = true;\n          } else if (value === 'false') {\n            val = false;\n          } else {\n            console.error('unexpected val in qti-or, expected boolean');\n            return null;\n          }\n        } else {\n          if (typeof value === 'boolean') {\n            val = value;\n          }\n        }\n        return val;\n      });\n      return values.every(e => {\n        return typeof e === 'boolean' && e;\n      });\n    }\n  };\n}\n", "import { QtiAnd } from './qti-and';\ncustomElements.define('qti-and', QtiAnd);\n\nexport * from './qti-and';\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-and': QtiAnd;\n  }\n}\n", "import { property } from 'lit/decorators.js';\nimport { BaseType } from '../../../internal/expression-result';\nimport { QtiExpression } from '../qti-expression';\nexport class QtiBaseValue extends QtiExpression<string> {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType = 'string';\n\n  public override getResult(): string {\n    const value = this.textContent.trim();\n    return value;\n  }\n}\n\ncustomElements.define('qti-base-value', QtiBaseValue);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiConditionExpression } from '../qti-condition-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiContains extends QtiConditionExpression {\n  public override getResult() {\n    // TODO: implement this for other types than directedPair\n    const values = this.getVariables() as ResponseVariable[];\n    if (this.children.length === 2) {\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'multiple'\n      ) {\n        const projection1 = value1.value as string[];\n        const projection2 = value2.value as string[];\n        const enumerable = projection1.filter(x => projection2.includes(x));\n\n        const result = enumerable.length > 0;\n        return result;\n      } else if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'single'\n      ) {\n        const projection1 = value1.value as string;\n        const projection2 = value2.value as string[];\n        return projection2.includes(projection1);\n      } else {\n        console.error(\n          'unsupported baseType or cardinality in qti contains, only baseType: directedPair and cardinality: multiple is supported'\n        );\n      }\n    } else {\n      console.error('unexpected number of children in qti contains');\n    }\n    return false;\n  }\n}\n\ncustomElements.define('qti-contains', QtiContains);\n", "import { ResponseVariable } from 'src/lib/qti-components/internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiCorrect extends QtiExpression<string | string[]> {\n  get interpretation() {\n    return this.getAttribute('interpretation') || '';\n  }\n\n  override getResult() {\n    const identifier = this.getAttribute('identifier') || '';\n    const responseVariable: ResponseVariable = this.context.variables.find(v => v.identifier === identifier) || null;\n    if (responseVariable.cardinality !== 'single') {\n      return responseVariable.correctResponse.length > 0 ? responseVariable.correctResponse[0] : '';\n    } else {\n      return responseVariable.correctResponse;\n    }\n  }\n}\n\ncustomElements.define('qti-correct', QtiCorrect);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiEqualRounded extends QtiExpression<boolean> {\n  @property({ type: String }) roundingMode: 'decimalPlaces' | 'significantFigures' = 'significantFigures';\n\n  get figures() {\n    const attr = this.getAttribute('figures');\n    if (!attr) {\n      console.error('figures attribute is missing');\n      return null;\n    }\n    const figures = parseInt(this.getAttribute('figures') || '0');\n    if (isNaN(figures)) {\n      console.error('figures attribute is not a number');\n      return null;\n    }\n    if (figures < 0) {\n      console.error('figures attribute is negative');\n      return null;\n    }\n    if (figures < 1 && this.roundingMode === 'significantFigures') {\n      console.error('figures cannot be smaller than 1 for RoundingMode significantFigures');\n      return null;\n    }\n    return figures;\n  }\n\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (this.roundingMode === null) {\n        return null;\n      }\n      if (\n        value1.cardinality !== 'single' ||\n        value2.cardinality !== 'single' ||\n        Array.isArray(value1.value) ||\n        Array.isArray(value2.value)\n      ) {\n        console.error('unexpected cardinality in qti equal');\n        return false;\n      }\n      switch (values[0].baseType) {\n        case 'integer':\n        case 'float': {\n          const float1 = parseFloat(value1.value as string);\n          const float2 = parseFloat(value2.value as string);\n\n          if (!isNaN(float1) && !isNaN(float2)) {\n            if (this.roundingMode === 'significantFigures') {\n              return float1.toPrecision(this.figures) === float2.toPrecision(this.figures);\n            } else {\n              return (\n                Math.round(float1 * Math.pow(10, this.figures)) / Math.pow(10, this.figures) ===\n                Math.round(float2 * Math.pow(10, this.figures)) / Math.pow(10, this.figures)\n              );\n            }\n          } else {\n            console.error(`value cannot be casted to numeric value in equalRounded operator: ${float1}, ${float2}`);\n          }\n          break;\n        }\n        default: {\n          console.error(`values other than float and int cannot be used in equalRounded operator.`);\n          break;\n        }\n      }\n      return false;\n    }\n    console.error('unexpected number of children in qti-equal-rounded');\n    return null;\n  }\n}\n\ncustomElements.define('qti-equal-rounded', QtiEqualRounded);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from '../../../internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiEqual extends QtiExpression<boolean> {\n  @property({ type: String }) toleranceMode: 'exact' | 'relative' | 'absolute' = 'exact';\n\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (this.toleranceMode !== 'exact') {\n        console.error('toleranceMode is not supported yet');\n        return false;\n      }\n      if (\n        value1.cardinality !== 'single' ||\n        value2.cardinality !== 'single' ||\n        Array.isArray(value1.value) ||\n        Array.isArray(value2.value)\n      ) {\n        console.error('unexpected cardinality in qti equal');\n        return false;\n      }\n      return ScoringHelper.compareSingleValues(value1.value as string, value2.value as string, value1.baseType);\n    }\n    console.error('unexpected number of children in qti-equal');\n    return null;\n  }\n}\n\ncustomElements.define('qti-equal', QtiEqual);\n", "import { BaseType } from '../..';\n\nexport class ScoringHelper {\n  public static compareSingleValues(value1: Readonly<string>, value2: Readonly<string>, baseType: BaseType): boolean {\n    switch (baseType) {\n      case 'identifier':\n      case 'string':\n        return value1 === value2;\n      case 'integer': {\n        const int1 = parseInt(value1, 10);\n        const int2 = parseInt(value2, 10);\n        if (!isNaN(int1) && !isNaN(int2)) {\n          return int1 === int2;\n        } else {\n          console.error(`Cannot convert ${value1} and/or ${value2} to int.`);\n        }\n        break;\n      }\n      case 'float': {\n        const float1 = parseFloat(value1);\n        const float2 = parseFloat(value2);\n        if (!isNaN(float1) && !isNaN(float2)) {\n          return float1 === float2;\n        } else {\n          console.error(`couldn't convert ${value1} and/or ${value2} to float.`);\n        }\n        break;\n      }\n      case 'pair':\n      case 'directedPair': {\n        const pair1 = value1.split(' ').sort();\n        const pair2 = value2.split(' ').sort();\n        if (pair1.length === 2 && pair2.length === 2) {\n          if (baseType === 'pair') {\n            pair1.sort();\n            pair2.sort();\n          }\n          return pair1.join(' ') === pair2.join(' ');\n        } else {\n          console.error(`compared two pair but one of the values does not have 2 values: 1: ${value1} 2: ${value2}`);\n        }\n        break;\n      }\n    }\n\n    return false;\n  }\n}\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiGt extends QtiExpression<boolean> {\n  public override getResult(): boolean {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (value1.baseType === value2.baseType && (value1.baseType === 'integer' || value1.baseType === 'float')) {\n        return +value1.value > +value2.value;\n      } else {\n        console.error('unexpected baseType or cardinality in qti gt');\n      }\n    }\n    console.error('unexpected number of children in qt');\n    return null;\n  }\n}\n\ncustomElements.define('qti-gt', QtiGt);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiConditionExpression } from '../qti-condition-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiGte extends QtiConditionExpression {\n  public override getResult(): boolean {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (value1.baseType === value2.baseType && (value1.baseType === 'integer' || value1.baseType === 'float')) {\n        return +value1.value >= +value2.value;\n      } else {\n        console.error('unexpected baseType or cardinality in qti gte');\n        return null;\n      }\n    }\n    console.log('unexpected number of children in qte');\n    return null;\n  }\n}\n\ncustomElements.define('qti-gte', QtiGte);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiIsNull extends QtiExpression<boolean> {\n  public override getResult(): boolean {\n    if (this.children.length === 1) {\n      const variables = this.getVariables() as ResponseVariable[];\n      if (!variables) {\n        return true;\n      }\n      const value = variables[0].value;\n      return value == null || value == undefined || value === '';\n    }\n    console.error('unexpected number of children in qti Null');\n    return null;\n  }\n}\n\ncustomElements.define('qti-is-null', QtiIsNull);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiLt extends QtiExpression<boolean> {\n  public override getResult(): boolean {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (value1.baseType === value2.baseType && (value1.baseType === 'integer' || value1.baseType === 'float')) {\n        return +value1.value < +value2.value;\n      } else {\n        console.error('unexpected baseType or cardinality in qti lt');\n      }\n    }\n    console.error('unexpected number of children in lt');\n    return null;\n  }\n}\n\ncustomElements.define('qti-lt', QtiLt);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiConditionExpression } from '../qti-condition-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiLte extends QtiConditionExpression {\n  public override getResult(): boolean {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (value1.baseType === value2.baseType && (value1.baseType === 'integer' || value1.baseType === 'float')) {\n        return +value1.value <= +value2.value;\n      } else {\n        console.error('unexpected baseType or cardinality in qti lte');\n        return null;\n      }\n    }\n    console.log('unexpected number of children in lte');\n    return null;\n  }\n}\n\ncustomElements.define('qti-lte', QtiLte);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from 'src/lib/qti-components/internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiMapResponse extends QtiExpression<number> {\n  @property({ type: String }) identifier: string;\n\n  public override getResult(): number {\n    const response: ResponseVariable = this.context.variables.find(r => r.identifier === this.identifier);\n    if (!response) {\n      console.warn(`Response ${this.identifier} can not be found`);\n      return null;\n    }\n    const mapping = response.mapping;\n    const candidateResponses = !Array.isArray(response.value) ? [response.value] : response.value;\n    let result = 0;\n    for (const candidateResponse of candidateResponses) {\n      const mappedValue = mapping.mapEntries.find(entry => {\n        return ScoringHelper.compareSingleValues(entry.mapKey, candidateResponse, response.baseType);\n      });\n      if (!(mappedValue == null || mappedValue.mappedValue == undefined)) {\n        result += mappedValue.mappedValue;\n      } else {\n        result += mapping.defaultValue;\n      }\n    }\n    if (mapping.lowerBound != null) {\n      result = Math.max(mapping.lowerBound, result);\n    }\n    if (mapping.upperBound != null) {\n      result = Math.min(mapping.upperBound, result);\n    }\n    return result;\n  }\n}\n\ncustomElements.define('qti-map-response', QtiMapResponse);\n", "import { property } from 'lit/decorators.js';\nimport { LitElement } from 'lit';\n\nexport class QtiMapping extends LitElement {\n  @property({ attribute: 'default-value', type: Number }) defaultValue: number = 0;\n  @property({ attribute: 'lower-bound', type: Number }) lowerBound: number;\n  @property({ attribute: 'upper-bound', type: Number }) upperBound: number;\n\n  public get mapEntries() {\n    return Array.from(this.querySelectorAll('qti-map-entry')).map(el => {\n      return {\n        mapKey: el.getAttribute('map-key'),\n        mappedValue: +el.getAttribute('mapped-value')\n      };\n    });\n  }\n}\n\ncustomElements.define('qti-mapping', QtiMapping);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiMatch extends QtiExpression<boolean> {\n  //PK : FIXME.\n  // This was a little experiment if we could call the match function as a static function,\n  // This can be used for all kind of things, but now especially for use in\n  // qti-response-condition-script\n  // in which we pass the expressions as pure functions, and hope for the best.\n  // SADLY, the getVariables throws roet in de eten.. weet nog niet precies hoe deze werkt.\n  // Maar ik ga erin duiken.\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const valueToMap = values[0];\n      const correctValueInfo = values[1];\n      return QtiMatch.match(valueToMap, correctValueInfo);\n    }\n\n    console.error('unexpected number of children in match');\n    return null;\n  }\n\n  public static match(valueToMap: ResponseVariable, correctValueInfo: ResponseVariable) {\n    switch (correctValueInfo.cardinality) {\n      case 'single': {\n        if (valueToMap.value === null) return false;\n        if (Array.isArray(valueToMap.value) || Array.isArray(correctValueInfo.value)) {\n          console.error('unexpected cardinality in qti match');\n          return false;\n        }\n        return ScoringHelper.compareSingleValues(\n          valueToMap.value?.toString(),\n          correctValueInfo.value.toString(),\n          correctValueInfo.baseType\n        );\n      }\n\n      case 'ordered': {\n        if (!Array.isArray(valueToMap.value) || !Array.isArray(correctValueInfo.value)) {\n          console.error('unexpected cardinality in qti match');\n          return false;\n        }\n        if (valueToMap.value.length !== correctValueInfo.value.length) {\n          return false;\n        }\n        for (let i = 0; i < valueToMap.value.length; i++) {\n          const result = ScoringHelper.compareSingleValues(\n            correctValueInfo.value[i],\n            valueToMap.value[i],\n            correctValueInfo.baseType\n          );\n          if (!result) {\n            return false;\n          }\n        }\n        return true;\n      }\n\n      case 'multiple': {\n        if (!Array.isArray(valueToMap.value) || !Array.isArray(correctValueInfo.value)) {\n          console.error('unexpected cardinality in qti match');\n          return false;\n        }\n        if (valueToMap.value.length !== correctValueInfo.value.length) {\n          return false;\n        }\n        let answerIndex = 0;\n        for (const correctAnswer of correctValueInfo.value) {\n          let matchingValue: string | null = null;\n          const arr = [...valueToMap.value];\n          for (const mv of arr) {\n            const result = ScoringHelper.compareSingleValues(correctAnswer, mv, correctValueInfo.baseType);\n            if (result) {\n              matchingValue = mv;\n              break;\n            }\n          }\n          if (matchingValue !== null) {\n            (arr as string[]).splice(arr.indexOf(matchingValue), 1);\n          } else {\n            return false;\n          }\n          answerIndex++;\n        }\n        return true;\n      }\n\n      default:\n        console.error('unexpected cardinality in qti match');\n        return false;\n    }\n  }\n}\n\ncustomElements.define('qti-match', QtiMatch);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiMember extends QtiExpression<boolean | null> {\n  public override getResult() {\n    const values = this.getVariables() as ResponseVariable[];\n\n    if (!(this.children.length === 2)) {\n      console.warn('The member operator takes two sub-expressions');\n    }\n\n    const [value1, value2] = values;\n\n    if (!(value1.baseType === value2.baseType)) {\n      console.warn('Which must both have the same base-type');\n    }\n    if (!(value2.cardinality === 'multiple' || value2.cardinality === 'ordered')) {\n      console.warn('and the second must be a multiple or ordered container');\n    }\n    if (value1.baseType === 'float' || value2.baseType === 'float') {\n      console.warn('The member operator should not be used on sub-expressions with a base-type of float');\n    }\n    if (value1.baseType === 'duration' || value2.baseType === 'duration') {\n      console.warn('It must not be used on sub-expressions with a base-type of duration');\n    }\n\n    // If either sub-expression is NULL then the result of the operator is NULL\n    if (value1.value === null || value2.value === null) {\n      return null;\n    }\n\n    // The result is a single boolean with a value of 'true' if the value given by the first sub-expression is in the container defined by the second sub-expression.\n    const projection1 = value1.value as string;\n    const projection2 = value2.value as string[];\n    return projection2.includes(projection1);\n  }\n}\n\ncustomElements.define('qti-member', QtiMember);\n", "import { ResponseVariable, VariableDeclaration } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\nexport class QtiMultiple extends QtiExpression<VariableDeclaration<string | string[]>[]> {\n  public override getResult(): ResponseVariable[] {\n    const variables = this.getVariables() as ResponseVariable[];\n    if (variables.length === 0) {\n      console.error('unexpected number of children in qti multiple');\n      return null;\n    }\n    for (const variable of variables) {\n      if (variable.cardinality !== 'multiple' && variable.cardinality !== 'single') {\n        console.error('unexpected cardinality in qti multiple');\n        return [];\n      }\n    }\n\n    // const values = variables.map(v => v.value);\n    // console.log(variables);\n    // const flattenedArray = values.reduce((acc: string[], value: string | string[]) => {\n    //   return acc.concat(Array.isArray(value) ? [...value] : value);\n    // }, []);\n    // return flattenedArray;\n\n    return variables;\n  }\n}\n\ncustomElements.define('qti-multiple', QtiMultiple);\n", "import { html } from 'lit';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiNot extends QtiExpression<boolean> {\n  override render() {\n    return html`${super.render()}`;\n  }\n\n  public override getResult() {\n    const expression = this.firstElementChild as QtiExpression<boolean>;\n    const result = expression.calculate() as boolean;\n    return !result;\n  }\n}\n\ncustomElements.define('qti-not', QtiNot);\n", "import { QtiConditionExpression } from '../qti-condition-expression';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiOr extends QtiConditionExpression {\n  public override getResult() {\n    // children can be a mix of qti-expression and qti-condition-expression\n    const values = Array.from(this.children).map(c => {\n      const condition = c as QtiExpression<any>;\n      if (!condition.calculate) {\n        console.error(\"Element doesn't implement QtiConditionExpression\");\n        return null;\n      }\n      const value = condition.calculate();\n      let val = false;\n      // convert string value to boolean and return null if not possible\n      if (typeof value === 'string') {\n        if (value === 'true') {\n          val = true;\n        } else if (value === 'false') {\n          val = false;\n        } else {\n          console.error('unexpected val in qti-or, expected boolean');\n          return null;\n        }\n      } else {\n        if (typeof value === 'boolean') {\n          val = value;\n        }\n      }\n      return val;\n    });\n    return values.some(e => {\n      return typeof e === 'boolean' && e;\n    });\n  }\n}\n\ncustomElements.define('qti-or', QtiOr);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\nexport class QtiOrdered extends QtiExpression<ResponseVariable[]> {\n  public override getResult(): ResponseVariable[] {\n    const variables = this.getVariables() as ResponseVariable[];\n    if (variables.length === 0) {\n      console.error('unexpected number of children in qti multiple');\n      return null;\n    }\n    for (const variable of variables) {\n      if (variable.cardinality !== 'ordered' && variable.cardinality !== 'single') {\n        console.error('unexpected cardinality in qti ordered');\n        return [];\n      }\n    }\n    return variables;\n  }\n}\n\ncustomElements.define('qti-ordered', QtiOrdered);\n", "import { consume } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { VariableDeclaration } from 'src/lib/qti-components/internal/variables';\nimport { ItemContext, itemContext } from '../../../qti-assessment-item/qti-assessment-item.context';\n\nexport class QtiPrintedVariable extends LitElement {\n  @property({ type: String })\n  identifier: string;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  protected context?: ItemContext;\n\n  override render() {\n    const value = this.context?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  public calculate(): VariableDeclaration<string | string[]> {\n    const result = this.context.variables.find(v => v.identifier === this.identifier) || null;\n    return result;\n  }\n}\n\ncustomElements.define('qti-printed-variable', QtiPrintedVariable);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiProduct extends QtiExpression<number> {\n  public override getResult() {\n    const values = this.getVariables() as ResponseVariable[];\n    const product = values.reduce((accumulator, currentValue) => {\n      if (currentValue.baseType == 'float' || currentValue.baseType == 'integer') {\n        try {\n          return accumulator * parseInt(currentValue.value.toString());\n        } catch (error) {\n          console.warn(`can not convert to number`);\n        }\n      } else {\n        console.warn(`has another baseType ${currentValue.baseType}`);\n      }\n      return accumulator;\n    }, 1);\n    return product;\n  }\n}\n\ncustomElements.define('qti-product', QtiProduct);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from '../../../internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiStringMatch extends QtiExpression<boolean> {\n  @property({ type: String, attribute: 'case-sensitive' }) caseSensitive = 'true';\n\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.cardinality !== 'single' ||\n        value2.cardinality !== 'single' ||\n        Array.isArray(value1.value) ||\n        Array.isArray(value2.value)\n      ) {\n        console.error('unexpected cardinality in qti string-match');\n        return false;\n      }\n      const v1 = this.caseSensitive === 'true' ? value1.value : (value1.value as string).toLowerCase();\n      const v2 = this.caseSensitive === 'true' ? value2.value : (value2.value as string).toLowerCase();\n      return ScoringHelper.compareSingleValues(v1 as string, v2 as string, value1.baseType);\n    }\n    console.error('unexpected number of children in qti-string-match');\n    return null;\n  }\n}\n\ncustomElements.define('qti-string-match', QtiStringMatch);\n", "import { QtiExpression, QtiExpressionBase } from '../qti-expression';\n\nexport class QtiSum extends QtiExpression<number> {\n  private _expression: QtiSumExpression;\n  constructor() {\n    super();\n    this._expression = new QtiSumExpression(Array.from(this.children as unknown as QtiExpressionBase<number>[]));\n  }\n\n  public override getResult() {\n    // children can be a mix of qti-expression and qti-condition-expression\n    const value = this._expression.calculate();\n    return value;\n  }\n}\n\nexport class QtiSumExpression implements QtiExpressionBase<number> {\n  constructor(private expressions: QtiExpressionBase<number>[]) {}\n\n  public calculate() {\n    const values = this.expressions.map(c => {\n      if (!c.calculate) {\n        console.error(\"Element doesn't implement QtiConditionExpression\");\n        return null;\n      }\n      const value = c.calculate();\n      if (Number.isNaN(value)) {\n        console.error('unexpected value in qti-sum, expected number');\n        return null;\n      }\n\n      return Number(value);\n    });\n    return values.reduce((a, b) => a + b, 0);\n  }\n}\n\ncustomElements.define('qti-sum', QtiSum);\n", "import { QtiExpression } from '../qti-expression';\n\nexport class QtiVariable extends QtiExpression<string | string[]> {\n  public override getResult() {\n    const identifier = this.getAttribute('identifier');\n    const result = this.context.variables.find(v => v.identifier === identifier).value\n    return result;\n  }\n}\n\ncustomElements.define('qti-variable', QtiVariable);\n", "import { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { IMSpci, ModuleResolutionConfig, QtiVariableJSON } from './interface';\n\ndeclare const requirejs: any;\ndeclare const define: any;\n\n@customElement('qti-portable-custom-interaction')\nexport class QtiPortableCustomInteraction extends Interaction {\n  private intervalId: any;\n  private rawResponse: string;\n\n  private pci: IMSpci<unknown>;\n\n  @property({ type: String, attribute: 'module' })\n  module: string;\n\n  @property({ type: String, attribute: 'custom-interaction-type-identifier' })\n  customInteractionTypeIdentifier: string;\n\n  @state()\n  private _errorMessage: string = null;\n\n  private convertQtiVariableJSON(input: QtiVariableJSON): string | string[] {\n    for (const topLevelKey in input) {\n      // eslint-disable-next-line no-prototype-builtins\n      if (input.hasOwnProperty(topLevelKey)) {\n        const nestedObject = input[topLevelKey as 'list' | 'base'];\n        if (nestedObject) {\n          for (const nestedKey in nestedObject) {\n            // eslint-disable-next-line no-prototype-builtins\n            if (nestedObject.hasOwnProperty(nestedKey)) {\n              const value = nestedObject[nestedKey as keyof typeof nestedObject];\n              if (Array.isArray(value)) {\n                return value.map(String); // Convert each element in the array to string\n              } else if (value !== undefined && value !== null) {\n                return String(value); // Convert the single value to string\n              }\n            }\n          }\n        }\n      }\n    }\n    return null;\n  }\n\n  private startChecking(): void {\n    // because the pci doesn't have a method to check for changes we'll use an interval\n    // to check if the response has changed. If changed we'll save the response\n    this.intervalId = setInterval(() => {\n      const response = this.pci.getResponse();\n      const newResponse = this.pci.getResponse();\n      const stringified = JSON.stringify(response);\n      if (stringified !== this.rawResponse) {\n        this.rawResponse = stringified;\n        const value = this.convertQtiVariableJSON(newResponse);\n        this.value = value;\n        this.saveResponse(value);\n      }\n    }, 200);\n  }\n\n  private stopChecking(): void {\n    if (this.intervalId !== undefined) {\n      clearInterval(this.intervalId);\n    }\n  }\n\n  validate(): boolean {\n    return true; // FOR NOW\n  }\n  set value(val: string | string[]) {\n    // Only set state is supported in a PCI\n  }\n  get value(): string | string[] {\n    return this.rawResponse;\n  }\n\n  getTAOConfig(node) {\n    const a = node.querySelectorAll('properties');\n    let config = {};\n\n    const getPropertyValue = el => {\n      const property = {};\n      const key = el.getAttribute('key');\n      if (key) {\n        const children = Array.from(el.children);\n        const allKey = children.map((c: HTMLElement) => c.getAttribute('key'));\n        const isArray = allKey.length > 0 && !allKey.find(k => !Number.isInteger(+k));\n        if (isArray) {\n          property[key] = children.map(c => getChildProperties(c));\n        } else {\n          property[key] = el.textContent;\n        }\n      }\n      return property;\n    };\n\n    const getChildProperties = (el): {} | void => {\n      if (el) {\n        let properties = {};\n        for (const child of el.children) {\n          properties = { ...properties, ...getPropertyValue(child) };\n        }\n        return properties;\n      }\n    };\n\n    for (const properties of a) {\n      const key = properties.getAttribute('key');\n      if (!key) {\n        config = { ...config, ...getChildProperties(properties) };\n      }\n      return config;\n    }\n    console.log('Can not find qti-custom-interaction config');\n    return null;\n  }\n\n  register(pci: IMSpci<unknown>) {\n    this.pci = pci;\n\n    const type = this.parentElement.tagName === 'QTI-CUSTOM-INTERACTION' ? 'TAO' : 'IMS';\n    const dom: HTMLElement =\n      type == 'IMS' ? this.querySelector('qti-interaction-markup') : this.querySelector('markup');\n    dom.classList.add('qti-customInteraction');\n\n    if (type == 'TAO' && this.querySelector('properties')) {\n      (this.querySelector('properties') as HTMLElement).style.display = 'none';\n    }\n\n    const config: any =\n      type == 'IMS'\n        ? {\n            properties: this.dataset,\n            onready: () => {\n              console.log('onready');\n            }\n          }\n        : this.getTAOConfig(this);\n    if (type == 'IMS') {\n      pci.getInstance(dom, config, undefined);\n    } else {\n      (pci as any).initialize(this.customInteractionTypeIdentifier, dom.firstElementChild, config);\n    }\n    if (type == 'TAO') {\n      const links = Array.from(this.querySelectorAll('link')).map(acc => acc.getAttribute('href'));\n      links.forEach(link => {\n        const styles = document.createElement('link');\n        styles.rel = 'stylesheet';\n        styles.type = 'text/css';\n        styles.media = 'screen';\n        styles.href = link;\n        dom.appendChild(styles);\n      });\n    }\n    this.startChecking();\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n\n    define('qtiCustomInteractionContext', () => {\n      return {\n        register: ctxA => {\n          this.register(ctxA);\n        },\n        notifyReady: () => {\n          /* only used in the TAO version */\n        }\n      };\n    });\n\n    const config = this.buildRequireConfig();\n    const requirePCI = requirejs.config(config);\n    requirePCI(['require'], require => {\n      // eslint-disable-next-line import/no-dynamic-require\n      require([this.module]);\n    });\n  }\n\n  override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    requirejs.undef(this.customInteractionTypeIdentifier);\n    // Clear the modules in the context\n    const context = requirejs.s.contexts;\n    delete context[this.customInteractionTypeIdentifier];\n    this.stopChecking();\n  }\n\n  buildRequireConfig() {\n    // Set RequireJS paths and shim configuration if available\n    const config: ModuleResolutionConfig = {\n      context: this.customInteractionTypeIdentifier,\n      catchError: true,\n      paths: window['requirePaths'] || {},\n      shim: window['requireShim'] || {}\n    };\n    // Check if RequireJS is available, if not, set an error message\n    if (!globalThis.require) {\n      this._errorMessage = `RequireJS not found. Please load it via CDN: https://cdnjs.com/libraries/require.js`;\n      return null;\n    }\n    const baseUrl = this.getAttribute('data-base-url');\n    const interactionModules = this.querySelector('qti-interaction-modules');\n\n    if (interactionModules) {\n      const modules = interactionModules.querySelectorAll('qti-interaction-module');\n      for (const module of modules) {\n        const moduleId = module.getAttribute('id');\n        const primaryPath = module.getAttribute('primary-path');\n        const fallbackPath = module.getAttribute('fallback-path');\n\n        if (moduleId && primaryPath) {\n          // Set the paths using RequireJS's fallback array\n          const paths = fallbackPath\n            ? this.combineRequireResolvePaths(\n                this.getResolvablePath(primaryPath, baseUrl),\n                this.getResolvablePath(fallbackPath, baseUrl)\n              )\n            : this.getResolvablePath(primaryPath, baseUrl);\n          const existingPath = config.paths[moduleId] || [];\n          config.paths[moduleId] = this.combineRequireResolvePaths(existingPath, paths);\n        }\n      }\n    }\n    return config;\n  }\n\n  private combineRequireResolvePaths(path1: string | string[], path2: string | string[]) {\n    const path1Array = Array.isArray(path1) ? path1 : [path1];\n    const path2Array = Array.isArray(path2) ? path2 : [path2];\n    return path1Array.concat(path2Array);\n  }\n\n  private removeDoubleSlashes(str: string) {\n    const singleForwardSlashes = str\n      .replace(/([^:]\\/)\\/+/g, '$1')\n      .replace(/\\/\\//g, '/')\n      .replace('http:/', 'http://')\n      .replace('https:/', 'https://');\n    return singleForwardSlashes;\n  }\n\n  loadConfig = async (url: string, baseUrl?: string): Promise<ModuleResolutionConfig> => {\n    url = this.removeDoubleSlashes(url);\n    try {\n      const requireConfig = await fetch(url);\n      if (requireConfig.ok) {\n        const config = await requireConfig.json();\n        const moduleCong = config as ModuleResolutionConfig;\n        for (const moduleId in moduleCong.paths) {\n          if (baseUrl) {\n            moduleCong.paths[moduleId] = this.getResolvablePath(moduleCong.paths[moduleId], baseUrl);\n          }\n        }\n        return moduleCong;\n      }\n    } catch (e) {\n      // do nothing\n    }\n    return null;\n  };\n\n  getResolvablePathString = (path: string, basePath?: string) => {\n    path = path.replace(/\\.js$/, '');\n    return path?.toLocaleLowerCase().startsWith('http') || !basePath\n      ? path\n      : this.removeDoubleSlashes(`${basePath}/${path}`);\n  };\n\n  getResolvablePath = (path: string | string[], basePath?: string) => {\n    return Array.isArray(path)\n      ? path.map(p => this.getResolvablePathString(p, basePath))\n      : this.getResolvablePathString(path, basePath);\n  };\n\n  override render() {\n    return html`<slot></slot>${this._errorMessage &&\n      html`<div style=\"color:red\">\n        <h1>Error</h1>\n        ${this._errorMessage}\n      </div>`}`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-portable-custom-interaction': QtiPortableCustomInteraction;\n  }\n}\n", "import { CSSResultGroup, LitElement, html } from 'lit';\n\nimport { customElement, state } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-associate-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n@customElement('qti-associate-interaction')\nexport class QtiAssociateInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-simple-associable-choice',\n  true,\n  '.dl'\n) {\n  @state() private _childrenMap: Element[] = [];\n\n  static styles: CSSResultGroup = styles;\n  // dragDropApi: TouchDragAndDrop;\n\n  private _registerChoiceHandler: (event: CustomEvent) => void;\n\n  constructor() {\n    super();\n    this._registerChoiceHandler = this._registerChoice.bind(this);\n    this.addEventListener('register-qti-simple-associable-choice', this._registerChoiceHandler);\n  }\n\n  private _registerChoice(event: CustomEvent) {\n    const choice = event.target as QtiSimpleAssociableChoice;\n    this._childrenMap.push(choice);\n  }\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot name=\"qti-simple-associable-choice\"></slot>\n      <div part=\"drop-container\">\n        ${this._childrenMap.length > 0 &&\n        Array.from(Array(Math.ceil(this._childrenMap.length / 2)).keys()).map(\n          (_, index) =>\n            html`<div part=\"associables-container\">\n              <div name=\"left${index}\" part=\"drop-list\" class=\"dl\" identifier=\"droplist${index}_left\"></div>\n              <div name=\"right${index}\" part=\"drop-list\" class=\"dl\" identifier=\"droplist${index}_right\"></div>\n            </div>`\n        )}\n      </div>`;\n  }\n\n  disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('register-qti-simple-associable-choice', this._registerChoiceHandler);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-associate-interaction': QtiAssociateInteraction;\n  }\n}\n", "export class TouchDragAndDrop {\n  private touchStartTime = 0; // Timestamp of the first touch\n  private touchStartPoint = null; // Point of the first touch\n  private lastClickTime = 0; // Timestamp of the previous click\n  private isDraggable = false; // Whether a draggable element is active\n  private dragSource: HTMLElement = null; // The source element being dragged\n  private dragClone: HTMLElement = null; // Clone of drag source for visual feedback\n  private touchEndTriggered = false; // Flag for touchEnd event\n  private isDragging = false; // Whether a drag operation is ongoing\n  private initialTransform = ''; // Original transform style\n  private hasDispatchedDragStart = false; // Flag to ensure dragstart event is dispatched once\n  private rootNode: Node = null; // Root node for boundary calculations\n\n  private focusedElement: HTMLElement = null; // To keep track of the currently focused draggable element\n  private focusableDropZones: HTMLElement[] = []; // All dropzones for keyboard navigation\n  private currentDropZoneIndex = -1; // Index for tabbing through drop zones\n\n  private dataTransfer = {\n    data: {},\n    setData(type, val) {\n      this.data[type] = val;\n    },\n    getData(type) {\n      return this.data[type];\n    },\n    effectAllowed: 'move'\n  };\n  private cloneOffset = { x: 0, y: 0 }; // Offset for positioning the drag clone\n\n  private lastTarget = null; // Last touch target\n  private currentDropTarget = null; // Current droppable element\n  private allowClick = true; // Flag to allow or prevent click\n  private static instance: TouchDragAndDrop;\n\n  copyStylesForDragClone = true;\n  dragOnClickEnabled = false;\n  useDragClone = false; // Set to true to drag with a clone; set to false to drag the original element\n\n  private readonly MIN_DRAG_DISTANCE = 5; // Minimum pixel movement to start dragging\n  private readonly DRAG_CLONE_OPACITY = 1; // Opacity of the drag clone element\n  initialTransition: string;\n  // droppables: Element[];\n\n  constructor() {\n    if (TouchDragAndDrop.instance) {\n      return TouchDragAndDrop.instance;\n    }\n    TouchDragAndDrop.instance = this;\n\n    // Add event listeners for touch and mouse interactions\n    document.addEventListener('touchmove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('mousemove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('touchend', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('mouseup', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('touchcancel', this.handleTouchCancel.bind(this), { passive: false });\n\n    document.addEventListener('keydown', this.handleKeyDown.bind(this));\n    document.addEventListener('keyup', this.handleKeyUp.bind(this));\n  }\n\n  addDraggableElements(draggables: Element[]) {\n    draggables.forEach(el => {\n      el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n      el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n      el.addEventListener('blur', () => (this.focusedElement = null));\n\n      el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n      el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n    });\n  }\n\n  // addDroppableElements(droppables: Element[]) {\n  //   // this.droppables = droppables;\n  //   droppables.forEach(el => {\n  //     el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n  //     el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n  //     el.addEventListener('blur', () => (this.focusedElement = null));\n\n  //     // el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n  //     // el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n  //   });\n  // }\n\n  private handleTouchStart(e) {\n    this.touchStartTime = Date.now();\n    const { x, y } = this.getEventCoordinates(e);\n    this.touchStartPoint = { x, y };\n    this.dragSource = e.currentTarget;\n    this.isDraggable = true;\n\n    // Get the root node\n    this.rootNode = this.dragSource.getRootNode();\n\n    if (this.dragOnClickEnabled) {\n      this.isDragging = true;\n      this.createDragClone(e, { clientX: x, clientY: y });\n    }\n\n    if (!this.useDragClone) {\n      // Save initial transform\n      const computedStyle = window.getComputedStyle(this.dragSource);\n      this.initialTransform = computedStyle.transform === 'none' ? '' : computedStyle.transform;\n\n      // Save the original transition style\n      this.initialTransition = computedStyle.transition || '';\n\n      // Disable transitions\n      this.dragSource.style.transition = 'none';\n\n      // Calculate clone offset\n      const rect = this.dragSource.getBoundingClientRect();\n      this.cloneOffset.x = x - rect.left;\n      this.cloneOffset.y = y - rect.top;\n\n      // Set higher z-index to bring it on top\n      this.dragSource.style.zIndex = '9999';\n      // this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n      this.dragSource.focus();\n    }\n\n    e.preventDefault();\n  }\n\n  private handleTouchMove(e) {\n    if (this.isDraggable && this.dragSource) {\n      const { x, y } = this.getEventCoordinates(e);\n      const currentTouch = { clientX: x, clientY: y };\n\n      if (this.calculateDragDistance(currentTouch) >= this.MIN_DRAG_DISTANCE) {\n        this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n        this.isDragging = true;\n      }\n\n      this.createDragClone(e, currentTouch);\n      e.preventDefault();\n    }\n  }\n\n  private createDragClone(e, currentTouch: { clientX: number; clientY: number }) {\n    if (!this.isDragging) return;\n\n    if (this.useDragClone) {\n      // Existing code for creating and handling the drag clone\n      if (!this.dragClone) {\n        this.dragSource.style.opacity = this.DRAG_CLONE_OPACITY.toString();\n        this.dragClone = this.dragSource.cloneNode(true) as HTMLElement;\n\n        if (this.copyStylesForDragClone) {\n          const computedStyles = window.getComputedStyle(this.dragSource);\n          for (const style of computedStyles) {\n            this.dragClone.style[style] = computedStyles.getPropertyValue(style);\n          }\n        }\n\n        // Move the drag clone to the root node\n        if (this.rootNode instanceof ShadowRoot) {\n          // Append to the host of the shadow root\n          this.rootNode.host.appendChild(this.dragClone);\n        } else if (this.rootNode instanceof Document) {\n          document.body.appendChild(this.dragClone);\n        }\n\n        this.calculateClonePosition(currentTouch);\n        this.setDragCloneStyles(currentTouch);\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      }\n\n      this.updateDragClonePosition(currentTouch);\n    } else {\n      // Handle dragging the original element using CSS transforms\n      if (this.touchStartPoint) {\n        const deltaX = currentTouch.clientX - this.touchStartPoint.x;\n        const deltaY = currentTouch.clientY - this.touchStartPoint.y;\n\n        // Apply boundaries\n        // const { boundedDeltaX, boundedDeltaY } = this.applyTransformBoundaries(deltaX, deltaY);\n        // this.dragSource.style.transform = `${this.initialTransform} translate(${boundedDeltaX}px, ${boundedDeltaY}px)`;\n\n        this.dragSource.style.transform = `${this.initialTransform} translate(${deltaX}px, ${deltaY}px)`;\n\n        if (!this.hasDispatchedDragStart) {\n          this.dispatchCustomEvent(this.dragSource, 'dragstart');\n          this.hasDispatchedDragStart = true;\n        }\n      }\n    }\n\n    const dropTarget = this.findDropTarget(e);\n\n    if (dropTarget !== this.lastTarget) {\n      this.dispatchCustomEvent(dropTarget, 'dragenter');\n      this.dispatchCustomEvent(this.lastTarget, 'dragleave');\n      this.lastTarget = dropTarget;\n    }\n\n    this.currentDropTarget = dropTarget;\n    if (this.currentDropTarget) this.dispatchCustomEvent(dropTarget, 'dragover');\n  }\n\n  private handleTouchEnd(e) {\n    this.touchEndTriggered = true;\n    this.isDraggable = false;\n    let dropFound = false;\n\n    // console.log('dropFound', dropFound);\n\n    if (this.currentDropTarget) {\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      dropFound = true;\n    } else if (this.isDragging) {\n      const dragEndEvent = new CustomEvent('dragend', { bubbles: true, cancelable: true });\n      dragEndEvent['dataTransfer'] = { dropEffect: 'none' };\n      this.dragSource?.dispatchEvent(dragEndEvent);\n    }\n\n    this.resetDragState(dropFound);\n  }\n\n  private handleTouchCancel(e) {\n    this.resetDragState();\n  }\n\n  private findDropTarget(event) {\n    const { x, y } = this.getEventCoordinates(event);\n    return this.getDropTargetAtPoint(document, x, y);\n  }\n\n  private getDropTargetAtPoint(root: DocumentOrShadowRoot, x: number, y: number, depth: number = 0): Element | null {\n    // Limit the recursion depth\n    const MAX_DEPTH = 2;\n    if (depth > MAX_DEPTH) {\n      return null;\n    }\n\n    const element = root.elementFromPoint(x, y) as HTMLElement;\n\n    if (!element) {\n      return null;\n    }\n\n    if (element.hasAttribute('dropzone')) {\n      return element;\n    }\n\n    // Traverse up the DOM tree to find an ancestor with 'dropzone' attribute\n    let currentElement = element.parentElement;\n    while (currentElement) {\n      if (currentElement.hasAttribute('dropzone')) {\n        return currentElement;\n      }\n      currentElement = currentElement.parentElement;\n    }\n\n    // If the element has a Shadow DOM and depth limit not reached, traverse it\n    if (element.shadowRoot && depth < MAX_DEPTH) {\n      const shadowElement = this.getDropTargetAtPoint(element.shadowRoot, x, y, depth + 1);\n      if (shadowElement) {\n        return shadowElement;\n      }\n    }\n\n    // No element with 'dropzone' found\n    return null;\n  }\n\n  private handleKeyDown(e: KeyboardEvent) {\n    if (this.focusedElement) {\n      if (e.key === ' ' && !this.isDragging) {\n        // Spacebar pressed to start dragging\n        e.preventDefault();\n        this.isDraggable = true;\n        this.dragSource = this.focusedElement;\n        this.isDragging = true;\n\n        // Store the drop zones for navigation\n        this.collectDropZones();\n\n        // Trigger dragstart event\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      } else if (e.key === 'Tab' && this.isDragging) {\n        // Tab key to navigate through drop zones\n        e.preventDefault();\n        this.moveToNextDropZone();\n      }\n    }\n  }\n\n  private handleKeyUp(e: KeyboardEvent) {\n    if (e.key === ' ' && this.isDragging && this.currentDropTarget) {\n      // Spacebar pressed again to drop the element\n      e.preventDefault();\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      this.resetDragState(true);\n    }\n  }\n\n  private collectDropZones() {\n    // Collect all elements with dropzone attribute\n    this.focusableDropZones = Array.from(document.querySelectorAll('[dropzone]')) as HTMLElement[]; // Array.from(this.droppables);\n    this.currentDropZoneIndex = -1; // Reset navigation index\n  }\n\n  private moveToNextDropZone() {\n    if (this.focusableDropZones.length === 0) return;\n\n    // Update index for the next drop zone\n    this.currentDropZoneIndex = (this.currentDropZoneIndex + 1) % this.focusableDropZones.length;\n\n    // Focus the next drop zone\n    const nextDropZone = this.focusableDropZones[this.currentDropZoneIndex];\n    nextDropZone.focus();\n\n    // Update current drop target\n    this.currentDropTarget = nextDropZone;\n\n    // Dispatch dragenter event\n    this.dispatchCustomEvent(nextDropZone, 'dragenter');\n  }\n\n  private getEventCoordinates(event, page = false) {\n    const touch = event.touches ? event.touches[0] : event;\n    return {\n      x: page ? touch.pageX : touch.clientX,\n      y: page ? touch.pageY : touch.clientY\n    };\n  }\n\n  private calculateClonePosition(touch) {\n    const rect = this.dragSource.getBoundingClientRect();\n    this.cloneOffset.x = touch.clientX - rect.left;\n    this.cloneOffset.y = touch.clientY - rect.top;\n  }\n\n  private setDragCloneStyles(touch) {\n    this.dragClone.style.position = 'fixed';\n    this.dragClone.style.top = `${touch.clientY - this.cloneOffset.y}px`;\n    this.dragClone.style.left = `${touch.clientX - this.cloneOffset.x}px`;\n    this.dragClone.style.pointerEvents = 'none';\n    this.dragClone.style.zIndex = '999999';\n  }\n\n  private updateDragClonePosition(touch) {\n    requestAnimationFrame(() => {\n      if (this.touchEndTriggered || !this.dragClone) return;\n\n      const newLeft = touch.clientX - this.cloneOffset.x;\n      const newTop = touch.clientY - this.cloneOffset.y;\n\n      // Apply boundaries\n      const { newLeft: boundedLeft, newTop: boundedTop } = this.applyBoundaries(newLeft, newTop, this.dragClone);\n\n      this.dragClone.style.left = `${boundedLeft}px`;\n      this.dragClone.style.top = `${boundedTop}px`;\n    });\n  }\n\n  private applyTransformBoundaries(deltaX: number, deltaY: number) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions and position of the element\n    const elementRect = this.dragSource.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Calculate potential new position\n    const newLeft = elementRect.left + deltaX;\n    const newTop = elementRect.top + deltaY;\n\n    // Limit the new position within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    // Calculate the bounded delta values\n    const boundedDeltaX = boundedLeft - elementRect.left;\n    const boundedDeltaY = boundedTop - elementRect.top;\n\n    return { boundedDeltaX, boundedDeltaY };\n  }\n\n  private applyBoundaries(newLeft: number, newTop: number, element: HTMLElement) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions of the element\n    const elementRect = element.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Limit the newLeft and newTop within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    return { newLeft: boundedLeft, newTop: boundedTop };\n  }\n\n  private calculateDragDistance(touch): number {\n    const xDist = Math.abs(touch.clientX - this.touchStartPoint.x);\n    const yDist = Math.abs(touch.clientY - this.touchStartPoint.y);\n    return xDist + yDist;\n  }\n\n  private dispatchCustomEvent(element, eventType, bubble = true) {\n    if (!element) return;\n    const event = new CustomEvent(eventType, { bubbles: bubble, cancelable: true });\n    event['dataTransfer'] = this.dataTransfer;\n    element.dispatchEvent(event);\n  }\n\n  private resetDragState(dropFound: boolean = false) {\n    if (this.isDragging) {\n      if (this.useDragClone) {\n        this.dragSource.style.opacity = '1.0';\n        this.dragClone?.parentElement.removeChild(this.dragClone);\n      } else {\n        // Restore original styles\n        if (!dropFound) this.dragSource.style.transform = 'translate(0, 0)';\n        this.dragSource.style.zIndex = '';\n        this.dragSource.style.pointerEvents = '';\n        // Restore the original transition style\n        this.dragSource.style.transition = this.initialTransition;\n\n        // Reset the original transition property\n        this.initialTransition = '';\n      }\n    }\n\n    this.isDragging = false;\n    this.dragSource = null;\n    this.dragClone = null;\n    this.isDraggable = false;\n    this.touchStartTime = 0;\n    this.touchStartPoint = null;\n    this.touchEndTriggered = false;\n    this.dataTransfer = {\n      data: {},\n      setData(type, val) {\n        this.data[type] = val;\n      },\n      getData(type) {\n        return this.data[type];\n      },\n      effectAllowed: 'move'\n    };\n    this.cloneOffset = { x: 0, y: 0 };\n    this.lastTarget = null;\n    this.currentDropTarget = null;\n    this.allowClick = true;\n    this.initialTransform = '';\n    this.hasDispatchedDragStart = false;\n\n    this.rootNode = null;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class DroppablesInterface {}\n\nexport const DroppablesMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  useShadowRoot: boolean,\n  droppablesSelector: string\n) => {\n  abstract class DroppablesElement extends superClass {\n    private observer: MutationObserver;\n\n    @property({ type: Boolean, reflect: true }) disabled = false;\n\n    override firstUpdated(changedProps): void {\n      if (this.isMatchTabular()) return;\n      super.firstUpdated(changedProps);\n\n      const droppables = this.getDroppableElements();\n      this.initializeEventHandlers();\n      droppables.forEach(droppable => {\n        this.prepareDroppable(droppable);\n        this.observeDroppableAttributes(droppable);\n      });\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private getDroppableElements(): Element[] {\n      return Array.from(\n        useShadowRoot ? this.shadowRoot.querySelectorAll(droppablesSelector) : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private initializeEventHandlers(): void {\n      this.dragoverHandler = this.dragoverHandler.bind(this);\n      this.dragleaveHandler = this.dragleaveHandler.bind(this);\n      this.dragenterHandler = this.dragenterHandler.bind(this);\n      this.dropHandler = this.dropHandler.bind(this);\n    }\n\n    private prepareDroppable(droppable: Element): void {\n      droppable.setAttribute('dropzone', 'move');\n      droppable.addEventListener('dragleave', this.dragleaveHandler);\n      this.attachEventListeners(droppable);\n    }\n\n    private observeDroppableAttributes(droppable: Element): void {\n      this.observer = new MutationObserver(mutations => {\n        mutations.forEach(({ attributeName }) => {\n          if (attributeName === 'disabled') {\n            this.toggleDroppableHandlers(droppable);\n          }\n        });\n      });\n      this.observer.observe(droppable, { attributes: true });\n    }\n\n    private toggleDroppableHandlers(droppable: Element): void {\n      const disabled = droppable.hasAttribute('disabled');\n      if (disabled) {\n        this.removeEventListeners(droppable);\n      } else {\n        this.attachEventListeners(droppable);\n      }\n    }\n\n    private attachEventListeners(droppable: Element): void {\n      droppable.addEventListener('dragover', this.dragoverHandler);\n      droppable.addEventListener('dragenter', this.dragenterHandler);\n      droppable.addEventListener('drop', this.dropHandler);\n    }\n\n    private removeEventListeners(droppable: Element): void {\n      droppable.removeEventListener('dragover', this.dragoverHandler);\n      droppable.removeEventListener('dragenter', this.dragenterHandler);\n      droppable.removeEventListener('drop', this.dropHandler);\n    }\n\n    override disconnectedCallback(): void {\n      if (this.isMatchTabular()) return;\n      super.disconnectedCallback();\n      this.observer?.disconnect();\n    }\n\n    private dragenterHandler(ev: DragEvent): void {\n      ev.preventDefault();\n    }\n\n    private dragoverHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.activateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'move';\n      return false;\n    }\n\n    private activateDroppable(droppable: HTMLElement): void {\n      droppable.setAttribute('active', '');\n    }\n\n    private async dropHandler(ev: DragEvent): Promise<boolean> {\n      ev.preventDefault();\n      const droppable = ev.currentTarget as HTMLElement;\n      const identifier = ev.dataTransfer.getData('text');\n      const draggable = this.findDraggable(identifier);\n      // console.log(this.isValidDrop(droppable, draggable));\n\n      if (!draggable) return false;\n      if (draggable && !this.isValidDrop(droppable, draggable)) {\n        draggable.style.transform = 'translate(0, 0)';\n        return false;\n      }\n\n      await this.moveDraggableToDroppable(draggable, droppable);\n      this.deactivateDroppable(droppable);\n      return false;\n    }\n\n    private findDraggable(identifier: string): HTMLElement | null {\n      if (!identifier) return null;\n      return (\n        this.querySelector(`[identifier=${identifier}]`) || this.shadowRoot.querySelector(`[identifier=${identifier}]`)\n      );\n    }\n\n    private isValidDrop(droppable: HTMLElement, draggable: HTMLElement): boolean {\n      return draggable.parentElement.getAttribute('identifier') !== droppable.getAttribute('identifier');\n    }\n\n    private async moveDraggableToDroppable(draggable: HTMLElement, droppable: HTMLElement): Promise<void> {\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n\n        // checkMaxAssociations and saveResponse are defined/overridden in a mixin\n        this['checkMaxAssociations']();\n        this['saveResponse'](null); //\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n        return;\n      }\n\n      const transition = document.startViewTransition(moveElement);\n      await transition.finished;\n\n      // this['checkMaxAssociations']();\n    }\n\n    private deactivateDroppable(droppable: HTMLElement): void {\n      droppable.removeAttribute('active');\n    }\n\n    private dragleaveHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.deactivateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'none';\n      return false;\n    }\n  }\n  return DroppablesElement as Constructor<DroppablesInterface> & T;\n};\n", "// THIS IS A MIXIN, THIS IS A MIXIN\n// USE LIKE THIS\n// ```class DropList extends Flippables(LitElement) {```\n// mixin which animates children with FLIP\n// a combination between this directive:\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\n// and a tutorial how to make a mixin\n// https://lit.dev/docs/composition/mixins/\n\nimport { LitElement } from 'lit';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport declare class FlippablesInterface {\n  connectedCallback(): void;\n  disconnectedCallback(): void;\n}\n\n// just a conversion of a angular FLIP directive, made as a Mixin\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\nexport const FlippablesMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  droppablesSel: string,\n  draggablesSel: string\n) => {\n  abstract class FlippablesElement extends superClass {\n    // private state = new Map<Element, any>();\n    // private observer: MutationObserver;\n    // flippablesSelector: string;\n    // override async firstUpdated(changedProps) {\n    //   await this.updateComplete; // pk: this is the key to calculate correct proportions\n    //   const draggables = Array.from(this.querySelectorAll(draggablesSel));\n    //   draggables.forEach((elem) => {\n    //     const { left, top, width, height } = elem.getBoundingClientRect();\n    //     this.state.set(elem, { left, top, width, height });\n    //   });\n    //   this.observer = new MutationObserver(this.animateMe);\n    //   const droppables = Array.from(this.querySelectorAll(droppablesSel));\n    //   droppables.forEach((draggable) => {\n    //     this.observer.observe(draggable, { childList: true });\n    //   });\n    //   this.observer.observe(this, { childList: true });\n    //   super.firstUpdated(changedProps);\n    // }\n    // private animateMe = () => {\n    //   this.state.forEach((value, elem) => {\n    //     const { left, top, width, height } = elem.getBoundingClientRect();\n    //     if (this.state.get(elem) == null) {\n    //       this.state.set(elem, { left, top, width, height });\n    //     }\n    //     const cache = this.state.get(elem);\n    //     const deltaX = cache.left - left;\n    //     const deltaY = cache.top - top;\n    //     const deltaW = cache.width / width;\n    //     const deltaH = cache.height / height;\n    //     this.state.set(elem, { left, top, width, height });\n    //     const { duration, easing } = { duration: 350, easing: 'cubic-bezier(0.26, 0.86, 0.44, 0.985)' };\n    //     elem.animate(\n    //       [\n    //         {\n    //           transformOrigin: 'top left',\n    //           transform: `\n    // translate(${deltaX}px, ${deltaY}px)\n    // scale(${deltaW}, ${deltaH})\n    // `,\n    //           // width: cache.width,\n    //           // height: cache.height+ 'px',\n    //           // opacity: cache.opacity,\n    //         },\n    //         {\n    //           transformOrigin: 'top left',\n    //           transform: 'none',\n    //         },\n    //       ],\n    //       {\n    //         duration,\n    //         easing,\n    //       }\n    //     );\n    //   });\n    // };\n    // override disconnectedCallback(): void {\n    //   super.disconnectedCallback();\n    //   this.observer.disconnect();\n    // }\n  }\n  return FlippablesElement as Constructor<FlippablesInterface> & T;\n};\n", "import { LitElement } from 'lit';\nimport { IInteraction } from '../interaction/interaction.interface';\nimport { DroppablesMixin } from './droppables-mixin';\nimport { FlippablesMixin } from './flippables-mixin';\n\nimport { property } from 'lit/decorators.js';\nimport { liveQuery } from '../../../../decorators/live-query';\nimport { TouchDragAndDrop } from './drag-drop-api';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ninterface InteractionConfiguration {\n  copyStylesDragClone: boolean;\n  dragCanBePlacedBack: boolean;\n  dragOnClick: boolean;\n}\n\nexport const DragDropInteractionMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  draggablesSelector: string,\n  useShadowRootForDroppables: boolean,\n  droppablesSelector: string\n) => {\n  abstract class DragDropInteractionElement extends FlippablesMixin(\n    DroppablesMixin(superClass, useShadowRootForDroppables, droppablesSelector),\n    droppablesSelector,\n    draggablesSelector\n  ) {\n    protected draggables = new Map<HTMLElement, { parent: HTMLElement; index: number }>();\n    protected droppables: HTMLElement[] = [];\n    dragDropApi: TouchDragAndDrop;\n\n    @property({ attribute: false, type: Object }) configuration: InteractionConfiguration = {\n      copyStylesDragClone: true,\n      dragCanBePlacedBack: true,\n      dragOnClick: false\n    };\n    @property({ type: Number, reflect: true, attribute: 'min-associations' }) minAssociations = 1;\n    @property({ type: Number, reflect: true, attribute: 'max-associations' }) maxAssociations = 1;\n\n    @liveQuery(draggablesSelector)\n    handleDraggablesChange(dragsAdded: HTMLElement[], dragsRemoved: Element[]) {\n      if (this.isMatchTabular()) return;\n      const newDraggables = this.filterExistingDraggables(dragsAdded);\n\n      if (newDraggables.length > 0) {\n        this.addNewDraggables(newDraggables);\n      }\n    }\n\n    override firstUpdated(changedProps): void {\n      super.firstUpdated(changedProps);\n      this.initializeDroppables();\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.initializeDragDropApi();\n    }\n\n    private initializeDragDropApi() {\n      this.dragDropApi = new TouchDragAndDrop();\n      this.dispatchEvent(\n        new CustomEvent<DragDropInteractionElement>('qti-register-interaction', {\n          bubbles: true,\n          composed: true,\n          detail: this\n        })\n      );\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private filterExistingDraggables(draggables: HTMLElement[]): HTMLElement[] {\n      return draggables.filter(d => !this.draggables.has(d));\n    }\n\n    private addNewDraggables(draggables: HTMLElement[]): void {\n      this.dragDropApi.addDraggableElements(draggables);\n      draggables.forEach(draggable => this.storeDraggable(draggable));\n    }\n\n    private storeDraggable(draggable: HTMLElement): void {\n      const index = Array.from(draggable.parentNode.children).indexOf(draggable);\n      this.draggables.set(draggable, {\n        parent: draggable.parentElement,\n        index\n      });\n      draggable.style.viewTransitionName = `drag-${index}-${this.getAttribute('identifier') || crypto.randomUUID()}`;\n      draggable.setAttribute('qti-draggable', 'true');\n      draggable.addEventListener('dragstart', this.handleDragStart);\n      draggable.addEventListener('dragend', this.handleDragEnd);\n    }\n\n    private initializeDroppables(): void {\n      this.droppables = Array.from(\n        useShadowRootForDroppables\n          ? this.shadowRoot.querySelectorAll(droppablesSelector)\n          : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private handleDragStart = (ev: DragEvent) => {\n      const target = ev.currentTarget as HTMLElement;\n      ev.dataTransfer.setData('text', target.getAttribute('identifier'));\n      target.setAttribute('dragging', '');\n      this.activateDroppables();\n    };\n\n    private handleDragEnd = async (ev: DragEvent) => {\n      ev.preventDefault();\n      this.deactivateDroppables();\n      const draggable = ev.currentTarget as HTMLElement;\n      draggable.removeAttribute('dragging');\n      const wasDropped = await this.wasDropped(ev);\n      if (!wasDropped) {\n        if (this.configuration.dragCanBePlacedBack) {\n          this.restoreInitialDraggablePosition(draggable);\n        }\n      }\n    };\n\n    private activateDroppables(): void {\n      this.droppables.forEach(d => d.setAttribute('enabled', ''));\n    }\n\n    private deactivateDroppables(): void {\n      this.droppables.forEach(d => d.removeAttribute('enabled'));\n    }\n\n    // MH: This method is just to make sure this can be tested.\n    // because I can't get the dropEffect to be 'move' in the test\n    private checkForMoveTestItem = (ev: DragEvent): Promise<boolean> => {\n      if (!ev.dataTransfer.items) {\n        return Promise.resolve(false);\n      }\n      return new Promise(resolve => {\n        let hasMoveTestItem = false;\n\n        // Iterate over all dataTransfer items\n        const items = Array.from(ev.dataTransfer.items);\n        const pending = items.length;\n\n        // If there are no items, resolve immediately\n        if (pending === 0) {\n          resolve(false);\n          return;\n        }\n\n        items.forEach(item => {\n          if (item.kind === 'string' && item.type === 'text') {\n            item.getAsString(data => {\n              if (data === 'move-test') {\n                hasMoveTestItem = true;\n              }\n\n              // Resolve the promise after processing all items\n              if (pending === 0) {\n                resolve(hasMoveTestItem);\n              }\n            });\n          } else {\n            // If the item is not 'string', still count down pending\n            if (pending === 0) {\n              resolve(hasMoveTestItem);\n            }\n          }\n        });\n      });\n    };\n\n    private async wasDropped(ev: DragEvent): Promise<boolean> {\n      const hasMoveTestItem = await this.checkForMoveTestItem(ev);\n      return ev.dataTransfer.dropEffect !== 'none' || hasMoveTestItem;\n    }\n\n    private wasMoved(ev: DragEvent): boolean {\n      return ev.dataTransfer.dropEffect === 'move';\n    }\n\n    private async restoreInitialDraggablePosition(draggable: HTMLElement): Promise<void> {\n      const { parent, index } = this.draggables.get(draggable);\n      const targetIndex = Math.min(index, parent.children.length);\n\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n        draggable.style.transform = 'translate(0, 0)';\n        this.checkMaxAssociations();\n      };\n\n      // Fallback if view transitions are not supported\n      if (!document.startViewTransition) {\n        moveDraggable(draggable, parent, index);\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        draggable.style.transform = '';\n        moveDraggable(draggable, parent, index);\n      });\n      // transition.finished.then(() => {\n      //   draggable.style.transition = '';\n      // });\n    }\n\n    protected checkMaxAssociations(): void {\n      this.droppables.forEach((d, index) => {\n        const maxMatch = +(d.getAttribute('match-max') || 1);\n        const currentAssociations = d.querySelectorAll('[qti-draggable=\"true\"]').length;\n        const disableDroppable = currentAssociations >= maxMatch;\n        if (disableDroppable) {\n          this.disableDroppable(d);\n        } else {\n          this.enableDroppable(d);\n        }\n      });\n    }\n\n    private disableDroppable(droppable: Element): void {\n      droppable.setAttribute('disabled', '');\n      droppable.removeAttribute('dropzone');\n    }\n\n    private enableDroppable(droppable: Element): void {\n      droppable.removeAttribute('disabled');\n      droppable.setAttribute('dropzone', 'move');\n    }\n\n    get value(): string[] {\n      return this.collectResponseData();\n    }\n\n    set value(value: string[]) {\n      if (this.isMatchTabular()) return;\n\n      this.resetDroppables();\n      value?.forEach(entry => this.placeResponse(entry));\n    }\n\n    private placeResponse(response: string): void {\n      const [dropId, ...dragIds] = response.split(' ').reverse();\n      const droppable = this.findDroppableById(dropId);\n      dragIds.forEach(dragId => this.placeDraggableInDroppable(dragId, droppable));\n    }\n\n    private findDroppableById(identifier: string): Element | undefined {\n      return this.droppables.find(drop => drop.getAttribute('identifier') === identifier);\n    }\n\n    private async placeDraggableInDroppable(dragId: string, droppable: Element): Promise<void> {\n      const draggable = this.querySelector<HTMLElement>(`[identifier=${dragId}]`);\n      if (!droppable || !draggable) {\n        console.error(`Cannot find draggable or droppable with the given identifier: ${dragId}`);\n        return;\n      }\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n        this.checkMaxAssociations();\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n      } else {\n        const transition = document.startViewTransition(moveElement);\n        await transition.finished;\n      }\n    }\n\n    validate(): boolean {\n      const validAssociations = this.getValidAssociations();\n      return this.minAssociations <= 0 || this.minAssociations <= validAssociations;\n    }\n\n    private getValidAssociations(): number {\n      return this.droppables.filter(d => d.childElementCount > 0).length;\n    }\n\n    public saveResponse(): void {\n      const response = this.collectResponseData();\n      this.dispatchEvent(\n        new CustomEvent('qti-interaction-response', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            responseIdentifier: this.responseIdentifier,\n            response\n          }\n        })\n      );\n    }\n\n    private collectResponseData(): string[] {\n      const response = this.droppables\n        .map(droppable => {\n          const draggablesInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n          const identifiers = Array.from(draggablesInDroppable).map(d => d.getAttribute('identifier'));\n          const droppableIdentifier = droppable.getAttribute('identifier');\n          return identifiers.map(id => `${id} ${droppableIdentifier}`);\n        })\n        .flat();\n      return response;\n    }\n\n    reset(save = true): void {\n      this.resetDroppables();\n      if (save) this.saveResponse();\n    }\n\n    private async resetDroppables(): Promise<void> {\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        draggable.style.transform = 'translate(0, 0)';\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n      };\n\n      if (!document.startViewTransition) {\n        // Fallback if view transitions are not supported\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n      });\n\n      await transition.finished;\n    }\n  }\n\n  return DragDropInteractionElement as Constructor<IInteraction> & T;\n};\n", "// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n//  @watch('propName')\n//  handlePropChange(oldValue, newValue) {\n//    ...\n//  }\n\nimport type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\n\ntype NonUndefined<A> = A extends undefined ? never : A;\n\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}\n\nexport function liveQuery(querySelector: string, options?: LiveQueryOptions) {\n  let observer: MutationObserver;\n  const resolvedOptions: Required<LiveQueryOptions> = {\n    ...options\n  };\n  return <ElemClass extends LitElement>(\n    proto: ElemClass,\n    decoratedFnName: UpdateHandlerFunctionKeys<ElemClass>\n  ): void => {\n    const { connectedCallback, disconnectedCallback } = proto;\n\n    proto.connectedCallback = function (this: ElemClass) {\n      connectedCallback.call(this);\n      const callback = (mutationList: MutationRecord[]) => {\n        const elementsToWatch = Array.from(this.querySelectorAll(querySelector));\n        for (const mutation of mutationList) {\n          const addedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          const removedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          if (mutation.type === 'childList' && addedNodes.find(n => elementsToWatch.includes(n))) {\n            (this[decoratedFnName] as unknown as UpdateHandler)(addedNodes, removedNodes);\n          }\n        }\n      };\n      observer = new MutationObserver(callback);\n      observer.observe(this, { childList: true, subtree: true });\n\n      const elementsAdded = this.querySelectorAll(querySelector) ?? [];\n      (this[decoratedFnName] as unknown as UpdateHandler)(Array.from(elementsAdded), []);\n    };\n\n    proto.disconnectedCallback = function (this: ElemClass) {\n      disconnectedCallback.call(this);\n      observer.disconnect();\n    };\n  };\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: block; /* necessary to calculate scaling position */\n  }\n  slot[name='qti-simple-associable-choice'] {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 0.5rem;\n  }\n\n  :host::part(associables-container) {\n    display: flex;\n    justify-content: space-between;\n    background: linear-gradient(\n      180deg,\n      rgb(0 0 0 / 0%) calc(50% - 1px),\n      var(--qti-border-color-gray) calc(50%),\n      rgb(0 0 0 / 0%) calc(50% + 1px)\n    );\n  }\n`;\n", "import { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { removeDoubleSlashes } from '../../internal/utils';\n\n@customElement('qti-custom-interaction')\nexport class QtiCustomInteraction extends Interaction {\n  // This custom-interaction support the CES API which is use in FACET\n  //\n  // It works like this:\n  // 1. The CI manifest is fetched\n  // 2. An iframe is created and the first style and first script from the manifest are loaded\n  // 3. The first script is bootstrap.js which also creates an iframe and loads the first media from the manifest\n  // 4. Communication is done via the CES API but because the iframe is not allowed to access the global CES object we need to use window.postMessage\n\n  // To achieve this we change the package by replacing the bootstrap.js with our own and inject a proxy CES API that communicates via postMessage\n  // Because we also want to run this in storybook, we cannot use window.top because to send messages there, because in case of storybook that is not the top window.\n  // So we send messages to all parent windows\n  private rawResponse: string;\n\n  constructor() {\n    super();\n    this.handlePostMessage = this.handlePostMessage.bind(this);\n  }\n\n  @property({ type: String, attribute: 'data' })\n  data: string;\n\n  @property({ type: String, attribute: 'data-base-item' })\n  baseItemUrl: string;\n\n  @property({ type: String, attribute: 'data-base-ref' })\n  baseRefUrl: string;\n\n  @property({ type: String, attribute: 'id' })\n  id: string;\n\n  @state()\n  private _errorMessage: string = null;\n  manifest: {\n    script: string[];\n    style: string[];\n    media: string[];\n  };\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n\n    const uriToManifest = this.data.startsWith('http')\n      ? this.data\n      : removeDoubleSlashes(this.baseItemUrl + '/' + this.data);\n    // fetch the json file located at the data attribute\n    fetch(uriToManifest)\n      .then(response => response.json())\n      .then(data => {\n        this.manifest = data;\n        this.setupCES();\n      })\n      .catch(err => {\n        this._errorMessage = err;\n      });\n  }\n\n  // MH: Changed the default bootstrap.js to use the new CES API\n  // Because the old one uses the global CES object that is not allowed to be accessed when the CI\n  // is embedded in an iframe and coming from another domain\n  // Therefor we need to use the new CES API to communicates via the broadcast API\n  setupCES() {\n    const iframe = this.shadowRoot.querySelector('#pciContainer') as HTMLIFrameElement,\n      iframeWin = iframe.contentWindow || iframe,\n      iframeDoc = iframe.contentDocument;\n\n    // const channel = new BroadcastChannel('ces_channel');\n    window.addEventListener('message', this.handlePostMessage);\n    iframeDoc.open();\n    iframeDoc.write(`\n      <html>\n        <head>\n          <link href='${removeDoubleSlashes(`${this.baseRefUrl}/${this.manifest.style[0]}`)}' rel=\"stylesheet\" />\n          <script src='${removeDoubleSlashes(`${this.baseRefUrl}/${this.manifest.script[0]}`)}'></script>\n        </head>\n        <body></body>\n      </html>\n      `);\n\n    iframeDoc.close();\n  }\n\n  private getIFrames() {\n    const iframesInShadowRoot = this.shadowRoot.querySelectorAll('iframe');\n    const iframe = this.querySelectorAll('iframe');\n\n    const outerIFrames = [...iframesInShadowRoot, ...iframe];\n    for (const iframe of outerIFrames) {\n      const iframeSrc = iframe.src;\n      const isSameOrigin = new URL(iframeSrc, window.location.href).origin === window.location.origin;\n      if (isSameOrigin) {\n        try {\n          const outerDoc = iframe.contentDocument || iframe.contentWindow.document;\n          if (outerDoc) {\n            this.getInnerIFrames(outerDoc, outerIFrames);\n          }\n        } catch (e) {\n          console.error('Error accessing nested iframe:', e);\n        }\n      }\n    }\n    // get only unique iframes\n    outerIFrames.forEach((iframe, index) => {\n      if (outerIFrames.indexOf(iframe) !== index) {\n        outerIFrames.splice(index, 1);\n      }\n    });\n    return outerIFrames;\n  }\n\n  private getInnerIFrames(iframeDocument: Document, iframes = []) {\n    // Get all iframes in the current document\n    const currentIframes = iframeDocument.querySelectorAll('iframe');\n\n    currentIframes.forEach(iframe => {\n      // Add the current iframe to the list\n      iframes.push(iframe);\n\n      // Recursively get iframes within the current iframe\n      // Check if the iframe src is from the same origin\n      const iframeSrc = iframe.src;\n      const isSameOrigin = new URL(iframeSrc, window.location.href).origin === window.location.origin;\n\n      if (isSameOrigin) {\n        try {\n          const nestedDoc = iframe.contentDocument || iframe.contentWindow.document;\n          this.getInnerIFrames(nestedDoc, iframes);\n        } catch (e) {\n          console.error('Error accessing nested iframe:', e);\n        }\n      } else {\n        console.warn('Skipped cross-origin iframe:', iframeSrc);\n      }\n    });\n\n    return iframes;\n  }\n\n  private postToWindowAndIframes(type: string, data: any) {\n    window.postMessage({ type, data }, '*');\n    const iframes = this.getIFrames();\n    for (const iframe of iframes) {\n      if (iframe.contentWindow) {\n        iframe.contentWindow.postMessage({ type, data }, '*');\n      }\n    }\n  }\n\n  handlePostMessage(event: MessageEvent) {\n    const { type, data } = event.data;\n    switch (type) {\n      case 'setResponse':\n        this.rawResponse = data;\n        this.saveResponse(data);\n        break;\n      case 'getResponse': {\n        this.postToWindowAndIframes('responseData', this.rawResponse);\n        break;\n      }\n      case 'getMedia': {\n        const mediaData = this.manifest.media.map(media => {\n          const url = media.startsWith('http') ? media : removeDoubleSlashes(this.baseRefUrl + '/' + media);\n          return url;\n        });\n        this.postToWindowAndIframes('mediaData', mediaData);\n        break;\n      }\n      case 'setStageHeight':\n        console.log('setStageHeight not implemented');\n        break;\n    }\n  }\n\n  validate(): boolean {\n    return this.rawResponse !== '';\n  }\n\n  get value(): string | string[] {\n    return this.rawResponse;\n  }\n\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this.rawResponse = val;\n      this.saveResponse(val);\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  override disconnectedCallback(): void {\n    window.removeEventListener('message', this.handlePostMessage);\n    super.disconnectedCallback();\n  }\n\n  override render() {\n    return html`<iframe\n        width=${this.getAttribute('width')}\n        height=${this.getAttribute('height')}\n        frameborder=\"0\"\n        title=\"pciContainer\"\n        id=\"pciContainer\"\n      >\n      </iframe>\n      ${this._errorMessage &&\n      html`<div style=\"color:red\">\n        <h1>Error</h1>\n        ${this._errorMessage}\n      </div>`}`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-custom-interaction': QtiCustomInteraction;\n  }\n}\n", "import { html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\n@customElement('qti-end-attempt-interaction')\nexport class QtiEndAttemptInteraction extends Interaction {\n  @property({ type: String, attribute: 'count-attempt' })\n  public countAttempt: string = 'true';\n\n  @property({ type: String })\n  public title: 'end attempt';\n\n  validate(): boolean {\n    // not implemented by design\n    return true;\n  }\n\n  get value(): string | string[] {\n    // throw new Error('Method not implemented.');\n    return '';\n  }\n\n  set value(val: string | string[]) {\n    // not implemented by design\n  }\n\n  override render() {\n    return html`<button ?disabled=${this.disabled} part=\"button\" @click=${this.endAttempt}>${this.title}</button>`;\n  }\n  public endAttempt(e: Event) {\n    this.dispatchEvent(\n      new CustomEvent('end-attempt', {\n        bubbles: true,\n        composed: true,\n        detail: { responseIdentifier: this.responseIdentifier, countAttempt: this.countAttempt === 'true' }\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-end-attempt-interaction': QtiEndAttemptInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-gap-match-interaction')\nexport class QtiGapMatchInteraction extends DragDropInteractionMixin(Interaction, 'qti-gap-text', false, 'qti-gap') {\n  static override styles = [\n    css`\n      :host {\n        display: flex;\n        align-items: flex-start;\n        flex-direction: column;\n        gap: 0.5rem;\n      }\n\n      :host(.qti-choices-top) {\n        flex-direction: column;\n      }\n      :host(.qti-choices-bottom) {\n        flex-direction: column-reverse;\n      }\n      :host(.qti-choices-left) {\n        flex-direction: row;\n      }\n      :host(.qti-choices-right) {\n        flex-direction: row-reverse;\n      }\n      /* [part='drops'] , */\n      [part='drags'] {\n        display: flex;\n        align-items: flex-start;\n        flex: 1;\n        gap: 0.5rem;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot name=\"prompt\"> </slot><slot part=\"drags\" name=\"qti-gap-text\"></slot> <slot part=\"drops\"></slot>`;\n  }\n\n  set correctResponse(value: string | string[]) {\n    let matches: { text: string; gap: string }[] = [];\n    const response = Array.isArray(value) ? value : [value];\n\n    if (response) {\n      matches = response.map(x => {\n        const split = x.split(' ');\n        return { text: split[0], gap: split[1] };\n      });\n    }\n\n    const gaps = this.querySelectorAll('qti-gap');\n    gaps.forEach((gap, index) => {\n      const identifier = gap.getAttribute('identifier');\n      const textIdentifier = matches.find(x => x.gap === identifier)?.text;\n      const text = this.querySelector(`qti-gap-text[identifier=\"${textIdentifier}\"]`)?.textContent.trim();\n      if (textIdentifier && text) {\n        if (!gap.nextElementSibling?.classList.contains('correct-option')) {\n          const textSpan = document.createElement('span');\n          textSpan.classList.add('correct-option');\n          textSpan.textContent = text;\n          gap.insertAdjacentElement('afterend', textSpan);\n        }\n      } else if (gap.nextElementSibling?.classList.contains('correct-option')) {\n        gap.nextElementSibling.remove();\n      }\n    });\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-match-interaction': QtiGapMatchInteraction;\n  }\n}\n", "import { css, html, svg } from 'lit';\nimport { customElement, query, queryAssignedElements, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\n@customElement('qti-graphic-associate-interaction')\nexport class QtiGraphicAssociateInteraction extends Interaction {\n  choiceOrdering: boolean;\n  hotspots;\n  startPoint = null;\n  endPoint = null;\n  @state() _lines = [];\n  @state() startCoord: { x: any; y: any };\n  @state() mouseCoord: { x: number; y: number };\n  @query('svg') svgContainer;\n  @queryAssignedElements({ selector: 'img' }) grImage;\n\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        // position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n      }\n      ::slotted(qti-associable-hotspot) {\n        transform: translate(-50%, -50%);\n      }\n      line-container {\n        display: block;\n        position: relative;\n      }\n      svg {\n        position: absolute;\n        top: 0px;\n        left: 0px;\n      }\n    `\n  ];\n  svg: SVGSVGElement;\n\n  constructor() {\n    super();\n    this.addEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n\n  reset(): void {\n    this._lines = [];\n  }\n  validate(): boolean {\n    return this._lines.length > 0;\n  }\n  set value(val: string | string[]) {\n    if (Array.isArray(val)) {\n      this._lines = val;\n    }\n  }\n  get value(): string | string[] {\n    return this._lines;\n  }\n\n  override render() {\n    return html`<slot name=\"prompt\"></slot>\n      <line-container>\n        <svg\n          width=${ifDefined(this.grImage[0]?.width)}\n          height=${ifDefined(this.grImage[0]?.height)}\n          viewbox=\"0 0 ${this.grImage[0]?.width} ${this.grImage[0]?.height}\"\n        >\n          ${repeat(\n            this._lines,\n            line => line,\n            (line, index) => svg`\n              <line\n                part=\"line\"\n                x1=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[0] + ']').style.left)}\n                y1=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[0] + ']').style.top)}\n                x2=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[1] + ']').style.left)}\n                y2=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[1] + ']').style.top)}\n                stroke=\"red\"\n                stroke-width=\"3\"\n                @click=${(e: Event) => {\n                  e.stopPropagation();\n                  this._lines = this._lines.filter((_, i) => i !== index);\n                  this.saveResponse(this._lines);\n                }}\n              />\n            `\n          )}\n          ${this.startPoint &&\n          svg`<line\n            part=\"point\"\n            x1=${this.startCoord.x}\n            y1=${this.startCoord.y}\n            x2=${this.mouseCoord.x}\n            y2=${this.mouseCoord.y}\n            stroke=\"red\"\n            stroke-width=\"3\"\n          />`}\n        </svg>\n        <slot></slot>\n      </line-container>`;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override firstUpdated(e): void {\n    super.firstUpdated(e);\n\n    this.hotspots = this.querySelectorAll('qti-associable-hotspot');\n\n    document.addEventListener('mousemove', event => {\n      this.mouseCoord = {\n        x: event.clientX - this.grImage[0].getBoundingClientRect().left,\n        y: event.clientY - this.grImage[0].getBoundingClientRect().top\n      };\n    });\n\n    this.hotspots.forEach(hotspot => {\n      hotspot.style.left = hotspot.getAttribute('coords').split(',')[0] + 'px';\n      hotspot.style.top = hotspot.getAttribute('coords').split(',')[1] + 'px';\n\n      hotspot.addEventListener('click', event => {\n        if (!this.startPoint) {\n          this.startPoint = event.target;\n\n          this.startCoord = {\n            x: this.startPoint.getAttribute('coords').split(',')[0],\n            y: this.startPoint.getAttribute('coords').split(',')[1]\n          };\n        } else if (!this.endPoint) {\n          this.endPoint = event.target;\n\n          this._lines = [\n            ...this._lines,\n            this.startPoint.getAttribute('identifier') + ' ' + this.endPoint.getAttribute('identifier')\n          ];\n          this.saveResponse(this._lines);\n          this.startPoint = null;\n          this.endPoint = null;\n        }\n      });\n    });\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-associate-interaction': QtiGraphicAssociateInteraction;\n  }\n}\n", "import { QtiHotspotChoice } from '../../qti-hotspot-choice';\n\nexport function positionHotspots(\n  shape: string,\n  coordsNumber: number[],\n  img: HTMLImageElement,\n  hotspot: QtiHotspotChoice\n) {\n  switch (shape) {\n    case 'circle':\n      {\n        const [centerX, centerY, radius] = coordsNumber;\n        const centerXPer = (centerX / img.width) * 100;\n        const centerYPer = (centerY / img.height) * 100;\n        const radiusPer = (radius / img.width) * 100;\n        hotspot.style.left = centerXPer - radiusPer + '%';\n        hotspot.style.top = centerYPer - radiusPer + '%';\n        hotspot.style.width = hotspot.style.height = 4 * radiusPer + 'px';\n        hotspot.style.borderRadius = `9999px`;\n      }\n      break;\n\n    case 'rect':\n      {\n        const [leftX, topY, rightX, bottomY] = coordsNumber;\n        const leftXPer = (leftX / img.width) * 100;\n        const topYPer = (topY / img.height) * 100;\n        const rightXPer = (rightX / img.width) * 100;\n        const bottomYPer = (bottomY / img.height) * 100;\n        hotspot.style.left = leftXPer + '%';\n        hotspot.style.top = topYPer + '%';\n        hotspot.style.width = rightXPer - leftXPer + '%';\n        hotspot.style.height = bottomYPer - topYPer + '%';\n      }\n      break;\n\n    case 'poly':\n      {\n        // from a,b,c,d,e,f => [{x:a, y:b},{x:c, y:d},{x:e, y:f}]\n        const polycoords = coordsNumber.reduce((acc, currentValue, currentIndex, polyC) => {\n          if (currentIndex % 2 === 1) {\n            const lastVal = acc.pop();\n            acc[acc.length] = { x: lastVal, y: polyC[currentIndex] };\n          } else {\n            acc.push(currentValue);\n          }\n          return acc;\n        }, []);\n\n        // calculate bounding box by finding the max ax min coordinates of x and y\n        const leftX = Math.min(...polycoords.map(point => point.x));\n        const rightX = Math.max(...polycoords.map(point => point.x));\n        const topY = Math.min(...polycoords.map(point => point.y));\n        const bottomY = Math.max(...polycoords.map(point => point.y));\n\n        // calculate the relative distance cause we want to use percentages\n        const leftXPer = (leftX / img.width) * 100;\n        const topYPer = (topY / img.height) * 100;\n        const rightXPer = (rightX / img.width) * 100;\n        const bottomYPer = (bottomY / img.height) * 100;\n\n        // set the hotspot on x,y and set the width and height in percentages\n        hotspot.style.left = (leftX / img.width) * 100 + '%';\n        hotspot.style.top = (topY / img.height) * 100 + '%';\n        hotspot.style.width = rightXPer - leftXPer + '%';\n        hotspot.style.height = bottomYPer - topYPer + '%';\n\n        // all the polygon points should be corrected caused they are from\n        // image 0,0 point, and should be from the hotspot point which already\n        // has been offsetted from the image in the previous few lines of code\n        // also the points have a relative distance to the image, but now have\n        // to have a relative distance from the width of the hotspot\n        const polygonData = polycoords.map(point => ({\n          x: ((point.x - leftX) / (rightX - leftX)) * 100,\n          y: ((point.y - topY) / (bottomY - topY)) * 100\n        }));\n\n        // create clip path coordinate style in percentages\n        const polyD = polygonData.map(p => Math.round(p.x) + '% ' + Math.round(p.y) + '%').join(',');\n\n        // 50% 0%, 100% 50%, 50% 100%, 0% 50%\n        hotspot.style.clipPath = `polygon(${polyD})`;\n      }\n      break;\n\n    default:\n      break;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-graphic-gap-match-interaction')\nexport class QtiGraphicGapMatchInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-gap-img',\n  false,\n  'qti-associable-hotspot'\n) {\n  static override styles = css`\n    :host {\n      display: inline-block;\n      position: relative;\n    }\n    slot[name='qti-gap-img'] {\n      display: flex;\n      gap: 1rem;\n    }\n  `;\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot></slot>\n      <slot name=\"qti-gap-img\"></slot>`;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<null>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    // positionHotspots(shape, coordsNumber, img, hotspot);\n    switch (shape) {\n      case 'circle':\n        {\n          const [centerX, centerY, radius] = coordsNumber;\n          hotspot.style.left = centerX - radius + 'px';\n          hotspot.style.top = centerY - radius + 'px';\n          hotspot.style.width = hotspot.style.height = 2 * radius + 'px';\n        }\n        break;\n\n      case 'rect':\n        {\n          const [leftX, topY, rightX, bottomY] = coordsNumber;\n          hotspot.style.left = leftX + 'px';\n          hotspot.style.top = topY + 'px';\n          hotspot.style.width = rightX - leftX + 'px';\n          hotspot.style.height = bottomY - topY + 'px';\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-gap-match-interaction': QtiGraphicGapMatchInteraction;\n  }\n}\n", "import { css, html } from 'lit';\nimport { Choice, ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\nimport { customElement } from 'lit/decorators.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { Interaction } from '../internal/interaction/interaction';\n\ntype HotspotChoice = Choice & { order: number };\n\n@customElement('qti-graphic-order-interaction')\nexport class QtiGraphicOrderInteraction extends ChoicesMixin(Interaction, 'qti-hotspot-choice') {\n  choiceOrdering: boolean;\n\n  protected _choiceElements: Choice[] = [];\n\n  // do not select ( highlight blue, the image)\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`\n      <slot name=\"prompt\"></slot>\n      <!-- slot for the prompt -->\n      <slot></slot>\n      <!-- slot for the image and hotspots -->\n    `;\n  }\n\n  private setHotspotOrder(e: CustomEvent<{ identifier: string; checked: boolean }>): void {\n    const { identifier } = e.detail;\n\n    const hotspot = this._choiceElements.find(el => el.getAttribute('identifier') === identifier) as HotspotChoice;\n\n    const maxSelection = this._choiceElements.length;\n    if (!this.choiceOrdering) {\n      this.choiceOrdering = true;\n      if (hotspot.order == null) {\n        if ((this._choiceElements as HotspotChoice[]).filter(i => i.order > 0).length >= maxSelection) {\n          this.choiceOrdering = false;\n          return; // don't do anything if user already selected 5 images.\n        }\n        hotspot.order = (this._choiceElements as HotspotChoice[]).filter(i => !!i.order).length + 1;\n        this.choiceOrdering = false;\n        return;\n      } else {\n        (this._choiceElements as HotspotChoice[]).forEach(hotspot => {\n          if (hotspot.order > hotspot.order) {\n            hotspot.order--;\n          }\n          return hotspot;\n        });\n        hotspot.order = null;\n      }\n      this.choiceOrdering = false;\n    }\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.addEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.removeEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-order-interaction': QtiGraphicOrderInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-hotspot-interaction')\nexport class QtiHotspotInteraction extends ChoicesMixin(Interaction, 'qti-hotspot-choice') {\n  // do not select ( highlight blue, the image)\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n        /* width:100%; */\n      }\n    `\n  ];\n  override render() {\n    return html`\n      <slot name=\"prompt\"></slot>\n      <!-- slot for the prompt -->\n      <slot></slot>\n      <!-- slot for the image and hotspots -->\n    `;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('unregister-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-interaction': QtiHotspotInteraction;\n  }\n}\n", "import { CSSResultGroup, html, LitElement } from 'lit';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { ResponseInteraction } from '../../internal/expression-result';\n// import { TouchDragAndDrop } from '../internal/drag-drop';\nimport '../qti-simple-associable-choice';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-match-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n\ninterface Column {\n  id: number;\n  name: string;\n}\n\ninterface Row {\n  id: number;\n  name: string;\n  isChecked: boolean;\n}\n\n@customElement('qti-match-interaction')\nexport class QtiMatchInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-simple-match-set:first-of-type qti-simple-associable-choice',\n  false,\n  'qti-simple-match-set:last-of-type qti-simple-associable-choice'\n) {\n  static styles: CSSResultGroup = styles;\n\n  rows: QtiSimpleAssociableChoice[];\n  cols: QtiSimpleAssociableChoice[];\n  lastCheckedRadio: HTMLInputElement | null = null;\n\n  @state() _response: string | string[] = [];\n  // dragDropApi: TouchDragAndDrop;\n  get value(): string[] {\n    if (!this.classList.contains('qti-match-tabular')) return super.value as string[];\n    else return this._response as string[];\n  }\n  set value(val: string[]) {\n    if (!this.classList.contains('qti-match-tabular')) super.value = val;\n    else this._response = val;\n  }\n  @state() correctOptions: string[] = [];\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n  async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n    // await this.updateComplete;\n    // this.dragDropApi = new TouchDragAndDrop();\n    // this.dragDropApi.addDraggableElements(\n    //   this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    // );\n    // this.dragDropApi.addDroppableElements(\n    //   this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    // );\n    this.rows = Array.from<QtiSimpleAssociableChoice>(\n      this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    );\n    this.cols = Array.from<QtiSimpleAssociableChoice>(\n      this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    );\n\n    this.value = [];\n  }\n\n  handleRadioClick = e => {\n    const radio = e.target as HTMLInputElement;\n    if (this.lastCheckedRadio === radio) {\n      radio.checked = false;\n      this.lastCheckedRadio = null;\n      this.handleRadioChange(e);\n    } else {\n      this.lastCheckedRadio = radio;\n    }\n  };\n\n  handleRadioChange = e => {\n    const checkbox = e.target as HTMLInputElement;\n    const value = checkbox.value;\n    const name = checkbox.name;\n    const type = checkbox.type;\n\n    if (checkbox.checked) {\n      if (!this.value) {\n        this.value = [value];\n      } else if (this.value.indexOf(value) === -1) {\n        if (type === 'radio') {\n          this.value = this.value.filter(v => v.indexOf(name) === -1);\n        }\n        this.value = [...this.value, value];\n      }\n      this.lastCheckedRadio = checkbox;\n    } else {\n      this.value = this.value.filter(v => v !== value);\n      this.lastCheckedRadio = null;\n    }\n\n    this.requestUpdate();\n    this.dispatchEvent(\n      new CustomEvent<ResponseInteraction>('qti-interaction-response', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          responseIdentifier: this.responseIdentifier,\n          response: Array.isArray(this.value) ? [...this.value] : this.value\n        }\n      })\n    );\n  };\n\n  set correctResponse(responseValue: string | string[]) {\n    if (responseValue === '') {\n      this.correctOptions = [];\n      return;\n    } else if (Array.isArray(responseValue)) {\n      this.correctOptions = responseValue;\n    }\n  }\n\n  override render() {\n    if (!this.classList.contains('qti-match-tabular')) {\n      return html`<slot name=\"prompt\"></slot> <slot></slot>`;\n    }\n    return html`\n      <slot name=\"prompt\"></slot>\n      <table>\n        <tr>\n          <td></td>\n          ${this.cols.map((col, i) => html`<th part=\"r-header\">${unsafeHTML(col.innerHTML)}</th>`)}\n        </tr>\n\n        ${this.rows.map(\n          (row, rIndex) =>\n            html`<tr>\n              <td part=\"c-header\">${unsafeHTML(row.innerHTML)}</td>\n              ${this.cols.map((col, cIndex) => {\n                const rowId = row.getAttribute('identifier');\n                const colId = col.getAttribute('identifier');\n                const value = `${rowId} ${colId}`;\n                const selectedInRowCount = this.value.filter(v => v.split(' ')[0] === rowId).length || 0;\n                const checked = this.value.includes(value);\n                const part = `rb ${checked ? 'rb-checked' : ''} ${this.correctOptions.includes(value) ? 'rb-correct' : ''}`;\n                // disable if match max is greater than 1 and max is reached\n                const disable =\n                  this.correctOptions.length > 0\n                    ? true\n                    : row.matchMax === 1\n                      ? false\n                      : selectedInRowCount >= row.matchMax && !checked;\n                return html`<td>\n                  <input\n                    type=${row.matchMax === 1 ? 'radio' : `checkbox`}\n                    part=${part}\n                    name=${rowId}\n                    value=${value}\n                    .disabled=${disable}\n                    @change=${e => this.handleRadioChange(e)}\n                    @click=${e => (row.matchMax === 1 ? this.handleRadioClick(e) : null)}\n                  />\n                </td>`;\n              })}\n            </tr>`\n        )}\n      </table>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-match-interaction': QtiMatchInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/* \nqti-match-interaction\nqti-associate-interaction\n*/\n@customElement('qti-simple-associable-choice')\n// tslint:disable: indent\nexport class QtiSimpleAssociableChoice extends ActiveElementMixin(LitElement, 'qti-simple-associable-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: block;\n    }\n    slot[name='qti-simple-associable-choice'] {\n      width: 100%;\n    }\n  `;\n\n  /** the minimal number of selections a candidate must make */\n  @property({\n    type: Number,\n    attribute: 'match-min'\n  })\n  public matchMin: number = 0;\n\n  /** the maximum number of selections a candidate must make, the other options will be disabled when max options is checked */\n  @property({\n    type: Number,\n    attribute: 'match-max'\n  })\n  public matchMax: number = 1;\n\n  @property({\n    type: Boolean,\n    attribute: 'fixed'\n  })\n  public fixed = false;\n\n  // pk: This needs some explanation\n  // in the associate interaction there is a special slot for these qti-simple-associable-choices\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-simple-associable-choice');\n    this.setAttribute('part', 'qti-simple-associable-choice');\n  }\n\n  // pk: This needs some explanation\n  // in qti-match-interaction, qti-simple-associable-choice is used to denote the\n  // draggable, but also the droppable. WEIRD.. but lets deal with it.\n  // So we have a slot for whenever another qti-simple-associable-choice is dropped in here.\n  // And we have slot for content like in this associate interaction\n  override render() {\n    return html`\n      <slot part=\"slot\"></slot>\n      <slot part=\"dropslot\" name=\"qti-simple-associable-choice\"></slot>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-associable-choice': QtiSimpleAssociableChoice;\n  }\n}\n", "import { css } from 'lit';\n// import componentStyles from '../../utilities/styles/component.styles';\n\n/* ${componentStyles} */\nexport default css`\n  slot {\n    /* slot where the */\n    display: flex;\n    flex-direction: column;\n    gap: 0.5rem;\n    align-items: flex-start; /* prevents the drag and drop container slots having the same height */\n  }\n  :host(.qti-choices-top) slot {\n    flex-direction: column;\n  }\n  :host(.qti-choices-bottom) slot {\n    flex-direction: column-reverse;\n  }\n  :host(.qti-choices-left) slot {\n    flex-direction: row;\n  }\n  :host(.qti-choices-right) slot {\n    flex-direction: row-reverse;\n  }\n  slot[name='prompt'] {\n    display: block;\n  }\n  ::slotted(qti-simple-match-set) {\n    /* Make sure the drag and drop container slots have the same width */\n    flex: 1;\n  }\n`;\n", "import { css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-media-interaction')\nexport class QtiMediaInteraction extends Interaction {\n  private _value = 0;\n  reset() {\n    // throw new Error('Method not implemented.');\n  }\n  validate(): boolean {\n    return true;\n    // maybe check if the media has been played?\n  }\n\n  get value(): string | string[] {\n    return this._value.toString();\n  }\n\n  set value(val: string | string[]) {\n    const isNumber = !isNaN(parseInt(val.toString()));\n    if (isNumber) {\n      this._value = parseInt(val.toString());\n    } else {\n      throw new Error('Value must be a number');\n    }\n  }\n\n  static override get properties() {\n    return {\n      ...Interaction.properties,\n      ...{\n        step: {\n          type: Number,\n          attribute: 'step',\n          default: 10\n        }\n      }\n    };\n  }\n\n  static override styles = [css``];\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot></slot>`;\n  }\n\n  constructor() {\n    super();\n  }\n\n  override connectedCallback() {\n    super.connectedCallback();\n    // get audio, video of object tag.\n    const mediaObject = this.querySelector('audio') || this.querySelector('video') || this.querySelector('object');\n    if (mediaObject) {\n      // listen to ended event\n      mediaObject.addEventListener('ended', () => {\n        // set value to 0\n        // check if this.value is a number\n        this._value++;\n        this.saveResponse(this.value);\n      });\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-media-interaction': QtiMediaInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { ShuffleMixin } from '../internal/shuffle/shuffle-mixin'; // Import the mixin\nimport { QtiSimpleChoice } from '../qti-simple-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-order-interaction')\nexport class QtiOrderInteraction extends ShuffleMixin(\n  DragDropInteractionMixin(Interaction, `qti-simple-choice`, true, 'drop-list'),\n  'qti-simple-choice'\n) {\n  childrenMap: Element[];\n\n  @state() nrChoices: number = 0;\n  @state() correctResponses: string[] = [];\n  @state() showCorrectResponses: boolean = false;\n\n  /** orientation of choices */\n  @property({ type: String })\n  public orientation: 'horizontal' | 'vertical';\n\n  static override styles = [\n    css`\n      [part='drags'] {\n        display: flex;\n        align-items: flex-start;\n        flex: 1;\n      }\n\n      [part='drops'] {\n        flex: 1;\n        display: grid;\n        grid-auto-flow: column;\n        grid-auto-columns: 1fr;\n      }\n\n      :host([orientation='horizontal']) [part='drags'] {\n        flex-direction: row;\n      }\n      :host([orientation='horizontal']) [part='drops'] {\n        grid-auto-flow: column;\n      }\n      :host([orientation='vertical']) [part='drags'] {\n        flex-direction: column;\n      }\n      :host([orientation='vertical']) [part='drops'] {\n        grid-auto-flow: row;\n      }\n\n      [part='drop-list'] {\n        display: block;\n        flex: 1;\n      }\n\n      [part='container'] {\n        display: flex;\n        gap: 0.5rem;\n      }\n      :host(.qti-choices-top) [part='container'] {\n        flex-direction: column;\n      }\n      :host(.qti-choices-bottom) [part='container'] {\n        flex-direction: column-reverse;\n      }\n      :host(.qti-choices-left) [part='container'] {\n        flex-direction: row;\n      }\n      :host(.qti-choices-right) [part='container'] {\n        flex-direction: row-reverse;\n      }\n    `\n  ];\n\n  override render() {\n    const choices = Array.from(this.querySelectorAll('qti-simple-choice'));\n    if (this.nrChoices < choices.length) {\n      this.nrChoices = choices.length;\n    }\n\n    return html` <slot name=\"prompt\"> </slot>\n      <div part=\"container\">\n        <slot part=\"drags\"> </slot>\n        <div part=\"drops\">\n          ${Array.from(Array(this.nrChoices)).map(\n            (_, i) =>\n              html`<drop-list part=\"drop-list\" identifier=\"droplist${i}\"></drop-list>${this.showCorrectResponses &&\n                this.correctResponses.length > i\n                  ? unsafeHTML(`<span part='correct-response'>${this.correctResponses[i]}</span>`)\n                  : ''}`\n          )}\n        </div>\n      </div>`;\n  }\n\n  set correctResponse(value: string | string[]) {\n    if (value === '') {\n      this.showCorrectResponses = false;\n      return;\n    }\n\n    if (this.correctResponses.length === 0) {\n      const responses = Array.isArray(value) ? value : [value];\n\n      responses.forEach((response, index) => {\n        let simpleChoice = this.querySelector(`qti-simple-choice[identifier=\"${response}\"]`);\n        if (!simpleChoice) {\n          simpleChoice = this.shadowRoot.querySelector(`qti-simple-choice[identifier=\"${response}\"]`);\n        }\n\n        const text = simpleChoice?.textContent.trim();\n        this.correctResponses = [...this.correctResponses, text];\n      });\n    }\n\n    this.showCorrectResponses = true;\n  }\n\n  // some interactions have a different way of getting the response\n  // this is called from the drag and drop mixin class\n  // you have to implement your own getResponse method in the superclass\n  // cause they are different for some interactions.\n  // MH: is this function called? Shouldn't we use getValue?\n  protected getResponse(): string[] {\n    const droppables = Array.from<QtiSimpleChoice>(this.shadowRoot.querySelectorAll('drop-list'));\n\n    const response = droppables.map(droppable => {\n      const dragsInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n      const identifiers = Array.from(dragsInDroppable).map(d => d.getAttribute('identifier'));\n      return [...identifiers].join(' ');\n    });\n    return response;\n  }\n\n  override async firstUpdated(changedProps) {\n    super.firstUpdated(changedProps);\n    this.childrenMap = Array.from(this.querySelectorAll('qti-simple-choice'));\n    this.childrenMap.forEach(el => el.setAttribute('part', 'qti-simple-choice'));\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-order-interaction': QtiOrderInteraction;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\n\nexport class QtiSPositionObjectInteraction extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  static override styles = [\n    css`\n      :host {\n        display: block;\n      }\n      ::slotted(img) {\n        position: absolute;\n        cursor: move;\n        user-select: none;\n        left: 50%;\n        transform: translateX(-50%);\n      }\n    `\n  ];\n}\n\ncustomElements.define('qti-position-object-interaction', QtiSPositionObjectInteraction);\n", "import { LitElement, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-position-object-stage')\nexport class QtiPositionObjectStage extends LitElement {\n  choiceOrdering: boolean;\n  startX: any;\n  startY: any;\n  dragElement: any;\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  static override styles = [\n    css`\n      :host {\n        display: inline-block;\n        position: relative;\n      }\n    `\n  ];\n\n  constructor() {\n    super();\n    this.removeMoveListener = this.removeMoveListener.bind(this);\n    this.dragElementHandler = this.dragElementHandler.bind(this);\n  }\n\n  // Define a function to handle the mousemove event on the draggable element\n  dragElementHandler(event) {\n    event.preventDefault();\n\n    // Calculate the distance the mouse has moved since the last event\n    const deltaX = event.clientX - this.startX;\n    const deltaY = event.clientY - this.startY;\n\n    // Update the position of the draggable element\n    this.dragElement.style.left = this.dragElement.offsetLeft + deltaX + 'px';\n    this.dragElement.style.top = this.dragElement.offsetTop + deltaY + 'px';\n\n    // Update the starting position of the mouse\n    this.startX = event.clientX;\n    this.startY = event.clientY;\n  }\n\n  override firstUpdated(a): void {\n    super.firstUpdated(a);\n\n    // Get the draggable and drop zone elements\n    this.dragElement = this.querySelector('qti-position-object-interaction>img');\n    // const canvasElement = document.getElementById('canvas');\n\n    // Initialize variables for the starting position of the draggable element\n    this.startX = 0;\n    this.startY = 0;\n\n    // Add a mousedown event listener to the draggable element\n    this.dragElement.addEventListener('mousedown', (event: MouseEvent) => {\n      // Save the starting position of the mouse\n      this.startX = event.clientX;\n      this.startY = event.clientY;\n\n      // Add a mousemove event listener to the document\n      document.addEventListener('mousemove', this.dragElementHandler, true);\n    });\n    document.addEventListener('mouseup', this.removeMoveListener);\n  }\n\n  removeMoveListener(event) {\n    document.removeEventListener('mousemove', this.dragElementHandler, true);\n  }\n\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    document.removeEventListener('mousemove', this.dragElementHandler);\n    document.removeEventListener('mouseup', this.removeMoveListener);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-position-object-stage': QtiPositionObjectStage;\n  }\n}\n", "import { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { styleMap } from 'lit/directives/style-map.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-select-point-interaction')\nexport class QtiSelectPointInteraction extends Interaction {\n  static override styles = [\n    css`\n      :host {\n        display: block;\n      }\n      point-container {\n        display: block;\n        position: relative;\n      }\n    `\n  ];\n\n  @property({\n    type: Number,\n    attribute: 'max-choices'\n  })\n  public maxChoices: number = Infinity;\n\n  @property({\n    type: Number,\n    attribute: 'min-choices'\n  })\n  public minChoices: number = 0;\n\n  @state()\n  private _points: string[] = [];\n\n  // Reference to the image element\n  private _imgElement: HTMLImageElement | null = null;\n\n  // Extracted click handler method\n  private _onImageClick = (event: MouseEvent) => {\n    if (this._points.length < this.maxChoices) {\n      const x = event.offsetX;\n      const y = event.offsetY;\n\n      this._points = [...this._points, `${x} ${y}`];\n      this.saveResponse(this._points);\n    }\n  };\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <point-container>\n        ${repeat(\n          this._points,\n          point => point,\n          (point, index) => html`\n            <button\n              part=\"point\"\n              style=${styleMap({\n                position: 'absolute',\n                transform: 'translate(-50%, -50%)',\n                left: `${point.split(' ')[0]}px`,\n                top: `${point.split(' ')[1]}px`\n              })}\n              aria-label=\"Remove point at ${point}\"\n              @click=${(e: Event) => {\n                e.stopPropagation();\n                this._points = this._points.filter((_, i) => i !== index);\n                this.saveResponse(this._points);\n              }}\n            ></button>\n          `\n        )}\n        <slot></slot>\n      </point-container>`;\n  }\n\n  reset(): void {\n    this._points = [];\n  }\n\n  validate(): boolean {\n    return this._points.length >= this.minChoices && this._points.length <= this.maxChoices;\n  }\n\n  set value(val: string | string[]) {\n    this._points = Array.isArray(val) ? val : [val];\n  }\n  get value(): string | string[] {\n    return this._points;\n  }\n\n  override firstUpdated(): void {\n    this._imgElement = this.querySelector('img');\n\n    if (this._imgElement) {\n      // Attach the click event listener to the image element\n      this._imgElement.addEventListener('click', this._onImageClick);\n    } else {\n      console.warn('No <img> element found in <qti-select-point-interaction>');\n    }\n  }\n\n  override disconnectedCallback(): void {\n    super.disconnectedCallback();\n\n    if (this._imgElement) {\n      // Remove the click event listener from the image element\n      this._imgElement.removeEventListener('click', this._onImageClick);\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-select-point-interaction': QtiSelectPointInteraction;\n  }\n}\n", "import { css, html, nothing } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\n\nimport { watch } from '../../../decorators/watch';\nimport { Interaction } from '../internal/interaction/interaction';\n\n/**\n * @summary The SliderInteraction.Type (qti-slider-interaction) presents the candidate with a control for selecting a numerical value between a lower and upper bound.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.s61xcrj4qcyj\n * @status stable\n * @since 6.0\n *\n * @event qti-register-interaction - emitted when the interaction wants to register itself\n * @event qti-interaction-response - emitted when the interaction changes\n *\n * @cssprop --show-value - shows the current value while sliding\n * @cssprop --show-ticks - shows the ticks according to steps\n * @cssprop --show-bounds - shows value for lower and upper boundary\n *\n * @csspart slider -- slider inluding, bounds and ticks and value, use it for paddings and margins\n * @csspart bounds -- div for bounds, containing two divs for with min, and max bounds value\n * @csspart ticks -- div for ticks, use lineair gradient and exposed css variables for styling\n * @csspart rail -- div for rail, style according to needs\n * @csspart knob -- div, should be relative or absolute\n * @csspart value -- div, containing value\n *\n * @slot - The default slot where <qti-simple-choice> must be placed.\n * @slot prompt - slot where the prompt is placed.\n */\n\n@customElement('qti-slider-interaction')\nexport class QtiSliderInteraction extends Interaction {\n  private _value = 0;\n  csLive: CSSStyleDeclaration;\n\n  @query('#knob')\n  private _knob: HTMLElement;\n\n  @query('#rail')\n  private _rail: HTMLElement;\n\n  @property({ type: Boolean, attribute: 'step-label' }) stepLabel = false;\n\n  @property({ type: Boolean }) reverse = false;\n\n  private _min: number;\n  @property({ type: Number, attribute: 'lower-bound' }) set min(value: number) {\n    this._min = value;\n    this._value = value;\n    this.style.setProperty('--min', `${this._min}`);\n  }\n  get min(): number {\n    return this._min;\n  }\n\n  private _max: number;\n  @property({ type: Number, attribute: 'upper-bound' }) set max(value: number) {\n    this._max = value;\n    this.style.setProperty('--max', `${this._max}`);\n  }\n  get max(): number {\n    return this._max;\n  }\n\n  private _step: number;\n  @property({ type: Number, attribute: 'step' }) set step(value: number) {\n    this._step = value;\n    this.style.setProperty('--step', `${this._step}`);\n  }\n  get step(): number {\n    return this._step;\n  }\n\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  _handleDisabledChange = (old, disabled) => {};\n\n  @watch('readonly', { waitUntilFirstUpdate: true })\n  _handleReadonlyChange = (old, readonly) => {};\n\n  reset() {\n    // throw new Error('Method not implemented.');\n  }\n  validate(): boolean {\n    return true;\n  }\n\n  get value(): string | string[] {\n    return this._value.toString();\n  }\n\n  set value(val: string | string[]) {\n    const isNumber = !isNaN(parseInt(val.toString()));\n    if (isNumber) {\n      this._value = parseInt(val.toString());\n    } else {\n      throw new Error('Value must be a number');\n    }\n  }\n\n  // static shadowRootOptions: ShadowRootInit = { ...LitElement.shadowRootOptions, delegatesFocus: true, mode: 'open' };\n\n  constructor() {\n    super();\n    /* the computed style is a live property, we use this to get css variables\n    see render template */\n    this.csLive = getComputedStyle(this);\n  }\n\n  set response(myResponse: string | string[]) {\n    if (Array.isArray(myResponse)) {\n      console.error('QtiSliderInteraction: response is an array, but should be a single value');\n      return;\n    }\n    const value = parseInt(myResponse);\n    if (Number.isNaN(value)) {\n      console.error('QtiSliderInteraction: response is not a number');\n      return;\n    }\n    this._value = value;\n  }\n\n  static override styles = [css``];\n\n  override render() {\n    // convert the value, which is the real slider value to a percentage for the dom.\n    if (this._value < this.min) {\n      this._value = this.min;\n    }\n    if (this._value > this.max) {\n      this._value = this.max;\n    }\n    const valuePercentage = ((this._value - this.min) / (this.max - this.min)) * 100;\n    this.style.setProperty('--value-percentage', `${valuePercentage}%`);\n    this.setAttribute('aria-valuenow', this.value.toString());\n\n    return html`<slot name=\"prompt\"></slot>\n      <div id=\"slider\" part=\"slider\">\n        ${this.csLive.getPropertyValue('--show-bounds') == 'true'\n          ? html`<div id=\"bounds\" part=\"bounds\">\n              <div>${this._min}</div>\n              <div>${this._max}</div>\n            </div>`\n          : nothing}\n        ${this.csLive.getPropertyValue('--show-ticks') == 'true' ? html`<div id=\"ticks\" part=\"ticks\"></div>` : nothing}\n        <div id=\"rail\" part=\"rail\" @mousedown=${this._onMouseDown} @touchstart=${this._onTouchMove}>\n          <div id=\"knob\" part=\"knob\">\n            ${this.csLive.getPropertyValue('--show-value') == 'true'\n              ? html`<div id=\"value\" part=\"value\">${this.value}</div>`\n              : nothing}\n          </div>\n        </div>\n      </div>`;\n  }\n\n  override connectedCallback() {\n    super.connectedCallback();\n    this.step = 1;\n    this.setAttribute('tabindex', '0');\n    this.setAttribute('role', 'slider');\n  }\n\n  private _onTouchMove(event) {\n    const handleTouchMove = event => {\n      const { x } = this.getPositionFromEvent(event);\n      const diffX = x - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n      this.calculateValue(diffX);\n      event.stopPropagation();\n    };\n\n    const handleTouchEnd = () => {\n      document.removeEventListener('touchmove', handleTouchMove);\n      document.removeEventListener('touchend', handleTouchEnd);\n\n      this.saveResponse(this.value.toString());\n    };\n\n    document.addEventListener('touchmove', handleTouchMove);\n    document.addEventListener('touchend', handleTouchEnd);\n\n    const { x } = this.getPositionFromEvent(event);\n    const diffX = x - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n    this.calculateValue(diffX);\n    event.stopPropagation();\n  }\n\n  private _onMouseDown(event) {\n    const handleMouseMove = (event: MouseEvent) => {\n      // if the qti-slider-interaction has an absolute left position and body is scrolled a bit, take account for that\n      const diffX = event.pageX - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n\n      this.calculateValue(diffX);\n      event.preventDefault();\n      event.stopPropagation();\n    };\n\n    const handleMouseUp = () => {\n      document.removeEventListener('mousemove', handleMouseMove);\n      document.removeEventListener('mouseup', handleMouseUp);\n\n      this.saveResponse(this.value.toString());\n    };\n\n    document.addEventListener('mousemove', handleMouseMove);\n    document.addEventListener('mouseup', handleMouseUp);\n\n    // if the qti-slider-interaction has an absolute left position and body is scrolled a bit, take account for that\n    const diffX = event.pageX - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n\n    this.calculateValue(diffX);\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  /** calculateValue gets x position and compares this with the total width in pixels */\n  private calculateValue(diffX: number) {\n    const valueNow = this.min + ((this.max - this.min) * diffX) / this._rail.getBoundingClientRect().width;\n    const roundedStepValue = this.min + Math.round((valueNow - this.min) / this._step) * this._step;\n    this._value = roundedStepValue;\n  }\n\n  private getPositionFromEvent(e: any): {\n    x: number;\n    y: number;\n  } {\n    let _touchMove;\n    if (e.type == 'touchstart' || e.type == 'touchmove' || e.type == 'touchend' || e.type == 'touchcancel') {\n      const evt = typeof e.originalEvent === 'undefined' ? e : e.originalEvent;\n      const touch = evt.touches[0] || evt.changedTouches[0];\n      _touchMove = {\n        x: touch.pageX,\n        y: touch.pageY\n      };\n    } else if (\n      e.type == 'mousedown' ||\n      e.type == 'mouseup' ||\n      e.type == 'mousemove' ||\n      e.type == 'mouseover' ||\n      e.type == 'mouseout' ||\n      e.type == 'mouseenter' ||\n      e.type == 'mouseleave'\n    ) {\n      _touchMove = {\n        x: e.clientX,\n        y: e.clientY\n      };\n    }\n    return _touchMove;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-slider-interaction': QtiSliderInteraction;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { customElement, state } from 'lit/decorators.js';\nimport { Calculate } from '../internal/expression-result';\nimport { ResponseVariable } from '../internal/variables';\nimport { ItemContext, itemContext } from '../qti-assessment-item/qti-assessment-item.context';\n\n/**\n * https://www.imsglobal.org/spec/qti/v3p0/impl#h.fi29q8dubjgw\n * <qti-custom-operator class=\"js.org\">\n        <qti-base-value base-type=\"string\"><![CDATA[\n          console.log(context.variables);\n          return 'B'\n          document.querySelector('qti-end-attempt-interaction').disabled = true;\n          ]]></qti-base-value>\n      </qti-custom-operator>\n    </qti-set-outcome-value>\n */\n@customElement('qti-custom-operator')\nexport class QtiCustomOperator extends LitElement implements Calculate {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n  private operatorFunction: Function;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  private _context?: ItemContext;\n\n  render() {\n    return html`<slot @slotchange=${this.handleSlotChange}></slot>`;\n  }\n\n  handleSlotChange(event: Event) {\n    // expecting <[!CDATA[ ... ]]> is converted into <!-- ... --> with qti-transform: cDataToComment\n    const commentNode = Array.from(this.firstElementChild?.childNodes ?? []).find(\n      node => node.nodeType === Node.COMMENT_NODE\n    );\n    try {\n      this.operatorFunction = new Function('context', 'fn', 'item', commentNode.textContent ?? '');\n    } catch (e) {\n      console.error('custom-operator contains invalid javascript code', e);\n    }\n  }\n\n  public calculate() {\n    const fn = {\n      variable: (responseIdentifier: string) =>\n        this._context?.variables.find(v => v.identifier === responseIdentifier)?.value ?? '',\n      correct: (responseIdentifier: string) =>\n        (this._context?.variables.find(v => v.identifier === responseIdentifier) as ResponseVariable)\n          ?.correctResponse ?? ''\n    };\n    const item = {\n      getVariable: (variableIdentifier: string) =>\n        this._context?.variables.find(v => v.identifier === variableIdentifier),\n      updateOutcomeVariable: (outcomeIdentifier: string, value: string | string[]) => {\n        this.dispatchEvent(\n          new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n            bubbles: true,\n            composed: true,\n            detail: {\n              outcomeIdentifier,\n              value\n            }\n          })\n        );\n      },\n      updateResponseVariable: (responseIdentifier: string, response: string | string[]) => {\n        this.dispatchEvent(\n          new CustomEvent<{ responseIdentifier: string; response: string | string[] }>('qti-interaction-response', {\n            bubbles: true,\n            composed: true,\n            detail: {\n              responseIdentifier,\n              response\n            }\n          })\n        );\n      }\n    };\n\n    return this.operatorFunction(this._context, fn, item);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-custom-operator': QtiCustomOperator;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-associable-hotspot')\nexport class QtiAssociableHotspot extends LitElement {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n      position: absolute;\n    }\n  `;\n\n  override connectedCallback() {\n    super.connectedCallback();\n    this.dispatchEvent(\n      new CustomEvent('qti-register-hotspot', {\n        bubbles: true,\n        composed: true,\n        cancelable: false\n      })\n    );\n  }\n\n  override render() {\n    return html` <slot name=\"qti-gap-img\"></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-associable-hotspot': QtiAssociableHotspot;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('qti-gap')\nexport class QtiGap extends LitElement {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n  `;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  override render() {\n    return html` <slot name=\"qti-gap-text\"></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap': QtiGap;\n  }\n}\n", "import { css, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('qti-gap-img')\nexport class QtiGapImg extends LitElement {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n  `;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  connectedCallback() {\n    this.setAttribute('slot', 'qti-gap-img');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-img': QtiGapImg;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-gap-text')\nexport class QtiGapText extends ActiveElementMixin(LitElement, 'qti-gap-text') {\n  static styles = css`\n    :host {\n      display: inline-flex;\n      user-select: none;\n    }\n  `;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-gap-text');\n  }\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-text': QtiGapText;\n  }\n}\n", "import { css, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n// type shape = { shape: 'rect' | 'circle' | 'poly'; coords: number[] };\n\n@customElement('qti-hotspot-choice')\nexport class QtiHotspotChoice extends ActiveElementMixin(LitElement, 'qti-hotspot-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n      position: absolute;\n    }\n  `;\n  @property({ attribute: 'aria-ordervalue', type: Number, reflect: true }) order: number;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-choice': QtiHotspotChoice;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-hottext')\nexport class QtiHottext extends ActiveElementMixin(LitElement, 'qti-hottext') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n  `;\n\n  override render() {\n    return html`<div part=\"ch\"><div part=\"cha\"></div></div>\n      <slot></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hottext': QtiHottext;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('qti-inline-choice')\nexport class QtiInlineChoice extends LitElement {\n  static override get styles() {\n    return [\n      css`\n        :host {\n          display: block;\n          cursor: pointer;\n        }\n      `\n    ];\n  }\n\n  @property({ type: String })\n  identifier: string;\n\n  override connectedCallback() {\n    super.connectedCallback();\n\n    this.addEventListener('click', this._onSelectInlineChoice);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-inline-choice-register', {\n        bubbles: true,\n        composed: true,\n        cancelable: false\n      })\n    );\n  }\n\n  override disconnectedCallback() {\n    this.removeEventListener('click', this._onSelectInlineChoice);\n  }\n\n  override render() {\n    return html` <slot></slot> `;\n  }\n\n  private _onSelectInlineChoice() {\n    // if (this.disabled || this.readonly) return;\n\n    this.dispatchEvent(\n      new CustomEvent('qti-inline-choice-select', {\n        bubbles: true,\n        cancelable: false,\n        composed: true,\n        detail: { identifier: this.identifier }\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-inline-choice': QtiInlineChoice;\n  }\n}\n", "import { css, html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/**\n * qti-order-interaction\n * qti-choice-interaction\n */\n@customElement('qti-simple-choice')\nexport class QtiSimpleChoice extends ActiveElementMixin(LitElement, 'qti-simple-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      align-items: center;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: flex;\n      align-items: center;\n    }\n    [part='ch'] {\n      display: flex;\n      flex-shrink: 0;\n      align-items: center;\n      justify-content: center;\n    }\n  `;\n\n  // property label\n  @property({ type: String, attribute: false })\n  public marker: string;\n\n\n  get checked() {\n    return this['internals'].states.has('--checked');\n  }\n\n  override render() {\n    return html`<div part=\"ch\">\n        <div part=\"cha\"></div>\n      </div>\n      ${this.marker ? html`<div id=\"label\">${this.marker}</div>` : nothing}\n      <slot part=\"slot\"></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-choice': QtiSimpleChoice;\n  }\n}\n", "/* only exported to override or extend for specific purposes */\nexport * from './internal/event-types';\nexport * from './internal/events';\nexport * from './internal/expression-result';\nexport * from './internal/variables';\n/* only exported to override or extend for specific purposes */\nexport * from './qti-assessment-item/qti-assessment-item';\nexport * from './qti-assessment-stimulus-ref/qti-assessment-stimulus-ref';\nexport * from './qti-interaction/internal/active-element/active-element.mixin';\nexport * from './qti-item-body/qti-item-body';\nexport * from './qti-prompt/qti-prompt';\nexport * from './qti-stylesheet/qti-stylesheet';\n/* start response and outcome */\nexport * from './qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration';\nexport * from './qti-variable-declaration/qti-response-declaration/qti-response-declaration';\n/* end response and outcome */\nexport * from './qti-companion-materials-info/qti-companion-materials-info';\nexport * from './qti-rubric-block/qti-content-body';\nexport * from './qti-rubric-block/qti-rubric-block';\n/* start feedback */\nexport * from './qti-feedback/qti-feedback-block/qti-feedback-block';\nexport * from './qti-feedback/qti-feedback-inline/qti-feedback-inline';\nexport * from './qti-feedback/qti-modal-feedback/qti-modal-feedback';\n/* end feedback */\n/* start textentryinteraction */\nexport * from './qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction';\nexport * from './qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction';\n/* end textentryinteraction */\n/* start hottext */\nexport * from './qti-interaction/qti-hottext-interaction/qti-hottext-interaction';\n/* end hottext */\n/* start inlinechoice */\nexport * from './qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction';\n/* end inlinechoice */\n/* start choiceinteraction */\nexport * from './qti-interaction/qti-choice-interaction/qti-choice-interaction';\n/* end choiceinteraction */\nexport * from './qti-outcome-processing/qti-outcome-processing';\nexport * from './qti-response-processing';\n/* start custom interactions */\nexport * from './qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction';\n/* end custom interactions */\n/* start only preview items */\nexport * from './qti-interaction/qti-associate-interaction/qti-associate-interaction';\nexport * from './qti-interaction/qti-custom-interaction/qti-custom-interaction';\nexport * from './qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction';\nexport * from './qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction';\nexport * from './qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction';\nexport * from './qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction';\nexport * from './qti-interaction/qti-match-interaction/qti-match-interaction';\nexport * from './qti-interaction/qti-media-interaction/qti-media-interaction';\nexport * from './qti-interaction/qti-order-interaction/qti-order-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-stage';\nexport * from './qti-interaction/qti-select-point-interaction/qti-select-point-interaction';\nexport * from './qti-interaction/qti-slider-interaction/qti-slider-interaction';\n/* end only preview items */\nexport * from './qti-assessment-item/qti-assessment-item.context';\nexport * from './qti-custom-operator/qti-custom-operator';\nexport * from './qti-interaction/internal/interaction/interaction';\nexport * from './qti-interaction/qti-associable-hotspot';\nexport * from './qti-interaction/qti-gap';\nexport * from './qti-interaction/qti-gap-img';\nexport * from './qti-interaction/qti-gap-text';\nexport * from './qti-interaction/qti-hotspot-choice';\nexport * from './qti-interaction/qti-hottext';\nexport * from './qti-interaction/qti-inline-choice';\nexport * from './qti-interaction/qti-simple-associable-choice';\nexport * from './qti-interaction/qti-simple-choice';\n\nconsole.log(\n  '%cC\u00BFTO%cLab%c: qti-components loaded',\n  'font-weight:bold; color:green',\n  'font-family: \"PT Sans\", font-weight:bold; color:green; font-size: smaller;vertical-align: sub',\n  'font-weight:unset'\n);\n\n// css for font pt-sans and subscript and green\n"],
  "mappings": "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",
  "names": ["property", "LitElement", "customElement", "property", "xml", "LitElement", "property", "customElement", "html", "property", "html", "property", "customElement", "html", "LitElement", "LitElement", "html", "customElement", "html", "LitElement", "customElement", "LitElement", "html", "customElement", "LitElement", "customElement", "LitElement", "customElement", "css", "html", "customElement", "property", "html", "LitElement", "customElement", "LitElement", "html", "customElement", "html", "css", "property", "customElement", "consume", "css", "html", "customElement", "property", "state", "html", "css", "property", "consume", "state", "customElement", "LitElement", "customElement", "LitElement", "customElement", "LitElement", "html", "customElement", "LitElement", "html", "customElement", "LitElement", "css", "html", "customElement", "property", "LitElement", "html", "css", "property", "customElement", "css", "html", "customElement", "consume", "LitElement", "property", "state", "LitElement", "property", "consume", "state", "html", "css", "customElement", "css", "html", "customElement", "html", "css", "customElement", "css", "html", "customElement", "html", "css", "customElement", "css", "html", "property", "state", "LitElement", "LitElement", "property", "state", "customElement", "property", "state", "css", "html", "state", "property", "customElement", "html", "customElement", "property", "state", "ifDefined", "css", "html", "ifDefined", "property", "state", "customElement", "html", "customElement", "property", "property", "html", "customElement", "css", "html", "customElement", "property", "state", "css", "html", "state", "property", "customElement", "html", "customElement", "property", "property", "property", "property", "property", "css", "html", "property", "customElement", "css", "html", "LitElement", "customElement", "LitElement", "html", "css", "customElement", "css", "html", "LitElement", "customElement", "LitElement", "html", "css", "customElement", "property", "customElement", "html", "LitElement", "LitElement", "html", "customElement", "property", "html", "html", "LitElement", "html", "html", "html", "consume", "css", "html", "LitElement", "state", "LitElement", "html", "css", "state", "consume", "property", "property", "property", "property", "property", "property", "property", "property", "property", "LitElement", "LitElement", "property", "html", "html", "consume", "LitElement", "html", "property", "state", "LitElement", "html", "property", "consume", "state", "property", "property", "html", "customElement", "property", "state", "property", "require", "html", "state", "customElement", "html", "customElement", "state", "property", "property", "property", "draggable", "parent", "index", "targetIndex", "property", "css", "html", "state", "customElement", "html", "customElement", "property", "state", "iframe", "html", "property", "state", "customElement", "html", "customElement", "property", "html", "property", "customElement", "css", "html", "customElement", "html", "css", "customElement", "css", "html", "customElement", "query", "state", "ifDefined", "html", "ifDefined", "css", "state", "query", "customElement", "css", "html", "customElement", "html", "css", "customElement", "css", "html", "customElement", "html", "hotspot", "css", "customElement", "css", "html", "customElement", "html", "css", "customElement", "html", "customElement", "property", "state", "unsafeHTML", "css", "html", "LitElement", "customElement", "property", "LitElement", "html", "css", "property", "customElement", "css", "html", "unsafeHTML", "state", "property", "customElement", "css", "html", "customElement", "html", "css", "customElement", "css", "html", "customElement", "property", "state", "unsafeHTML", "html", "unsafeHTML", "css", "state", "property", "customElement", "LitElement", "css", "html", "LitElement", "css", "html", "customElement", "LitElement", "html", "css", "customElement", "css", "html", "customElement", "property", "state", "repeat", "html", "repeat", "css", "property", "state", "customElement", "css", "html", "customElement", "property", "query", "html", "event", "x", "diffX", "css", "query", "property", "customElement", "consume", "LitElement", "html", "customElement", "state", "LitElement", "html", "consume", "state", "customElement", "LitElement", "css", "html", "customElement", "LitElement", "html", "css", "customElement", "css", "html", "LitElement", "customElement", "property", "LitElement", "html", "css", "property", "customElement", "css", "LitElement", "customElement", "property", "LitElement", "css", "property", "customElement", "css", "html", "LitElement", "customElement", "property", "LitElement", "html", "css", "property", "customElement", "css", "LitElement", "customElement", "property", "LitElement", "css", "property", "customElement", "css", "html", "LitElement", "customElement", "LitElement", "html", "css", "customElement", "css", "html", "LitElement", "customElement", "property", "LitElement", "css", "html", "property", "customElement", "css", "html", "LitElement", "nothing", "customElement", "property", "LitElement", "html", "nothing", "css", "property", "customElement"]
}

|
|
6593
|
+
//# sourceMappingURL=index.js.map
|