@citolab/qti-components 6.9.1-beta.9 → 7.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,573 +0,0 @@
1
- import{a as Nt}from"../chunk-62FWJYVB.js";import{a as b,b as q,c as i}from"../chunk-E7TLXHQH.js";import{provide as dr}from"@lit/context";import{LitElement as ur,html as mr}from"lit";import{customElement as hr,property as z}from"lit/decorators.js";function v(c,s){let e=b({waitUntilFirstUpdate:!1},s);return(t,r)=>{let{update:o}=t,n=Array.isArray(c)?c:[c];t.update=function(a){n.forEach(l=>{let p=l;if(a.has(p)){let d=a.get(p),h=this[p];d!==h&&(!e.waitUntilFirstUpdate||this.hasUpdated)&&this[r](d,h)}}),o.call(this,a)}}}import{createContext as pr}from"@lit/context";var Ht=[{identifier:"completionStatus",cardinality:"single",baseType:"string",value:"unknown",type:"outcome"},{identifier:"numAttempts",cardinality:"single",baseType:"integer",value:"0",type:"response"}],A=pr("item");var C=class extends ur{constructor(){super();this.identifier="";this.adaptive="false";this.timeDependent=null;this._handleDisabledChange=(e,t)=>{this._interactionElements.forEach(r=>r.disabled=t)};this._handleReadonlyChange=(e,t)=>this._interactionElements.forEach(r=>r.readonly=t);this._context={identifier:this.getAttribute("identifier"),variables:Ht};this._initialContext=q(b({},this._context),{variables:this._context.variables});this._feedbackElements=[];this._interactionElements=[];this.addEventListener("qti-register-variable",e=>{this._context=q(b({},this._context),{variables:[...this._context.variables,e.detail.variable]}),this._initialContext=this._context,e.stopPropagation()}),this.addEventListener("qti-register-feedback",e=>{e.stopPropagation();let t=e.detail;this._feedbackElements.push(t),t.checkShowFeedback(t.outcomeIdentifier)}),this.addEventListener("qti-register-interaction",e=>{e.stopPropagation(),this._interactionElements.push(e.target)}),this.addEventListener("end-attempt",e=>{let{responseIdentifier:t,countAttempt:r}=e.detail;this.updateResponseVariable(t,"true"),this.processResponse(r)}),this.addEventListener("qti-set-outcome-value",e=>{let{outcomeIdentifier:t,value:r}=e.detail;this.updateOutcomeVariable(t,r),e.stopPropagation()}),this.addEventListener("qti-interaction-response",this.handleUpdateResponseVariable)}get variables(){return this._context.variables.map(e=>b({identifier:e.identifier,value:e.value,type:e.type},e.type==="outcome"&&e.identifier==="SCORE"?{externalScored:e.externalScored}:{}))}set variables(e){if(!Array.isArray(e)||e.some(t=>!("identifier"in t))){console.warn("variables property should be an array of VariableDeclaration");return}this._context=q(b({},this._context),{variables:this._context.variables.map(t=>{let r=e.find(o=>o.identifier===t.identifier);return r?b(b({},t),r):t})}),this._context.variables.forEach(t=>{if(t.type==="response"){let r=this._interactionElements.find(o=>o.responseIdentifier===t.identifier);r&&(r.response=t.value)}t.type==="outcome"&&this._feedbackElements.forEach(r=>r.checkShowFeedback(t.identifier))})}async connectedCallback(){super.connectedCallback(),await this.updateComplete,this._emit("qti-assessment-item-connected",this)}set responses(e){if(e)for(let t of e){this.getResponse(t.responseIdentifier)&&this.updateResponseVariable(t.responseIdentifier,t.response);let o=this._interactionElements.find(n=>n.getAttribute("response-identifier")===t.responseIdentifier);o&&(o.response=t.response)}}render(){return mr`<slot></slot>`}showCorrectResponse(e){let r=this._context.variables.filter(o=>"correctResponse"in o&&o.correctResponse).map(o=>({responseIdentifier:o.identifier,response:o.correctResponse}));for(let o of r){let n=this._interactionElements.find(a=>a.getAttribute("response-identifier")===o.responseIdentifier);n&&(n.correctResponse=e?o.response:"")}}processResponse(e=!0){var r;let t=this.querySelector("qti-response-processing");return!t||!t.process?!1:(t.process(),this.adaptive==="false"&&this.updateOutcomeVariable("completionStatus",this._getCompletionStatus()),e&&this.updateOutcomeVariable("numAttempts",(+((r=this._context.variables.find(o=>o.identifier==="numAttempts"))==null?void 0:r.value)+1).toString()),this._emit("qti-response-processed"),!0)}resetResponses(){this._context=this._initialContext}getResponse(e){return this.getVariable(e)}getOutcome(e){return this.getVariable(e)}getVariable(e){return this._context.variables.find(t=>t.identifier===e)||null}handleUpdateResponseVariable(e){let{responseIdentifier:t,response:r}=e.detail;this.updateResponseVariable(t,r)}updateResponseVariable(e,t){this._context=q(b({},this._context),{variables:this._context.variables.map(r=>r.identifier!==e?r:q(b({},r),{value:t}))}),this._emit("qti-interaction-changed",{item:this.identifier,responseIdentifier:e,response:Array.isArray(t)?[...t]:t}),this.adaptive==="false"&&this.updateOutcomeVariable("completionStatus",this._getCompletionStatus())}updateOutcomeVariable(e,t){var o;let r=this.getOutcome(e);if(!r){console.warn(`Can not set qti-outcome-identifier: ${e}, it is not available`);return}this._context=q(b({},this._context),{variables:this._context.variables.map(n=>n.identifier!==e?n:q(b({},n),{value:r.cardinality==="single"?t:[...n.value,t]}))}),this._feedbackElements.forEach(n=>n.checkShowFeedback(e)),this._emit("qti-outcome-changed",{item:this.identifier,outcomeIdentifier:e,value:(o=this._context.variables.find(n=>n.identifier===e))==null?void 0:o.value})}_getCompletionStatus(){return this._interactionElements.every(e=>e.validate())?"completed":this._interactionElements.some(e=>e.validate())?"incomplete":"not_attempted"}_emit(e,t=null){this.dispatchEvent(new CustomEvent(e,{bubbles:!0,composed:!0,detail:t}))}};i([z({type:String})],C.prototype,"title",2),i([z({type:String})],C.prototype,"identifier",2),i([z({type:String})],C.prototype,"adaptive",2),i([z({type:String})],C.prototype,"timeDependent",2),i([z({type:Boolean})],C.prototype,"disabled",2),i([v("disabled",{waitUntilFirstUpdate:!0})],C.prototype,"_handleDisabledChange",2),i([z({type:Boolean})],C.prototype,"readonly",2),i([v("readonly",{waitUntilFirstUpdate:!0})],C.prototype,"_handleReadonlyChange",2),i([dr({context:A})],C.prototype,"_context",2),C=i([hr("qti-assessment-item")],C);import{LitElement as fr}from"lit";import{customElement as gr,property as Vt}from"lit/decorators.js";var W=class extends fr{constructor(){super(...arguments);this.identifier="";this.href=""}async connectedCallback(){super.connectedCallback();let e=new Event("qti-assessment-stimulus-ref-connected",{cancelable:!0,bubbles:!0});if(this.dispatchEvent(e)){let o=this.closest("qti-assessment-item").querySelector(`[data-stimulus-idref=${this.identifier}]`);o?await this.loadAndAppendStimulus(o):console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`)}}async loadAndAppendStimulus(e){var o;let t=this.href.substring(0,this.href.lastIndexOf("/")),r=await Nt().load(this.href).then(n=>n.path(t).htmldoc());if(r){let n=r.querySelectorAll("qti-stimulus-body, qti-stylesheet");e.append(...n),((o=r.querySelector("qti-assessment-stimulus"))==null?void 0:o.title).includes("(lijst)")&&e.classList.add("qti-stimulus-list")}}};i([Vt({type:String})],W.prototype,"identifier",2),i([Vt({type:String})],W.prototype,"href",2),W=i([gr("qti-assessment-stimulus-ref")],W);import{LitElement as br,html as vr}from"lit";import{property as ce}from"lit/decorators.js";var yr={SPACE:32},E=class extends br{constructor(){super(...arguments);this.tabindex=0;this.disabled=!1;this.readonly=!1;this.checked=!1}handleDisabledChange(e,t){t?(this.tabindex=void 0,this.blur()):this.tabIndex=0}connectedCallback(){super.connectedCallback(),this.addEventListener("keyup",this._onKeyUp),this.addEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent("qti-register-choice",{bubbles:!0,cancelable:!1,composed:!0}))}disconnectedCallback(){this.removeEventListener("keyup",this._onKeyUp),this.removeEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent("qti-loose-choice",{bubbles:!0,cancelable:!1,composed:!0}))}reset(){this.checked=!1,this.disabled=!1}_onKeyUp(e){if(!e.altKey)switch(e.keyCode){case yr.SPACE:e.preventDefault(),this._toggleChecked();break;default:}}_onClick(){this._toggleChecked()}_toggleChecked(){this.disabled||this.readonly||(this.checked=!this.checked,this.dispatchEvent(new CustomEvent("qti-choice-element-selected",{bubbles:!0,cancelable:!1,composed:!0,detail:{identifier:this.identifier,checked:this.checked}})))}render(){return vr` <slot></slot> `}};i([ce({type:String})],E.prototype,"identifier",2),i([ce({type:Number,reflect:!0})],E.prototype,"tabindex",2),i([ce({reflect:!0,type:Boolean,attribute:"aria-disabled",converter:{toAttribute:e=>e}})],E.prototype,"disabled",2),i([ce({reflect:!0,type:Boolean,attribute:"aria-readonly",converter:{toAttribute:e=>e}})],E.prototype,"readonly",2),i([ce({reflect:!0,type:Boolean,attribute:"aria-checked",converter:{toAttribute:e=>e}})],E.prototype,"checked",2),i([v("disabled",{waitUntilFirstUpdate:!0})],E.prototype,"handleDisabledChange",1);import{customElement as Er}from"lit/decorators.js";import{html as qr,LitElement as Cr}from"lit";import{css as xr}from"lit";var $t=xr`
2
- :host {
3
- display: block;
4
- }
5
- `;var J=class extends Cr{render(){return qr`<slot name="qti-rubric-block"></slot><slot></slot>`}};J.styles=$t,J=i([Er("qti-item-body")],J);import{html as _r,LitElement as kr}from"lit";import{customElement as Tr}from"lit/decorators.js";var Le=class extends kr{render(){return _r`<slot></slot>`}connectedCallback(){this.parentElement.tagName.endsWith("INTERACTION")&&this.setAttribute("slot","prompt")}};Le=i([Tr("qti-prompt")],Le);import{LitElement as wr}from"lit";import{customElement as Rr}from"lit/decorators.js";var Me=class extends wr{firstUpdated(s){super.firstUpdated(s);let e=this,t=this.getAttribute("href");if(t!==null){let r=document.createElement("link");r.rel="stylesheet",r.type="text/css",r.media="screen",r.href=t,e.appendChild(r),this.styleLink=r}if(this.textContent!==null){let r=document.createElement("style");r.media="screen",r.textContent=this.textContent,e.appendChild(r),this.styleLink=r}}disconnectedCallback(){if(this.styleLink)try{this.styleLink.remove()}catch(s){console.log("could not remove stylesheet")}}};Me=i([Rr("qti-stylesheet")],Me);import{consume as Mr}from"@lit/context";import{css as Nr,html as Hr}from"lit";import{customElement as Vr,property as Ne,state as $r}from"lit/decorators.js";import{html as Ar,LitElement as Sr}from"lit";import{customElement as Lr}from"lit/decorators.js";var P=class extends Sr{render(){return Ar`<slot></slot>`}defaultValues(s){let e=Array.from(this.querySelectorAll("qti-default-value > qti-value"));if(e.length===0)return null;let t=e.map(r=>r.innerHTML);return t.length>1||s.cardinality==="multiple"||s.cardinality==="ordered"?t:t[0]}};P=i([Lr("qti-variabledeclaration")],P);var S=class extends P{constructor(){super(...arguments);this.externalScored=null}render(){var t,r;let e=(r=(t=this.itemContext)==null?void 0:t.variables.find(o=>o.identifier===this.identifier))==null?void 0:r.value;return Hr`${JSON.stringify(e,null,2)}`}get interpolationTable(){let e=this.querySelector("qti-interpolation-table");if(e){let t=new Map;for(let r of e.querySelectorAll("qti-interpolation-table-entry")){!r.getAttribute("source-value")&&r.getAttribute("target-value")&&console.error("source-value or target-value is missing in qti-interpolation-table-entry");let o=parseInt(r.getAttribute("source-value")),n=parseInt(r.getAttribute("target-value"));(isNaN(o)||isNaN(n))&&console.error("source-value or target-value is not a number in qti-interpolation-table-entry"),t.set(o,n)}return t}return null}connectedCallback(){super.connectedCallback();let e={identifier:this.identifier,cardinality:this.cardinality,baseType:this.baseType,type:"outcome",value:null,interpolationTable:this.interpolationTable,externalScored:this.externalScored};e.value=this.defaultValues(e),this.dispatchEvent(new CustomEvent("qti-register-variable",{bubbles:!0,composed:!0,detail:{variable:e}}))}};S.styles=[Nr`
6
- :host {
7
- display: none;
8
- }
9
- `],i([Ne({type:String,attribute:"base-type"})],S.prototype,"baseType",2),i([Ne({type:String,attribute:"external-scored"})],S.prototype,"externalScored",2),i([Ne({type:String})],S.prototype,"identifier",2),i([Ne({type:String})],S.prototype,"cardinality",2),i([Mr({context:A,subscribe:!0}),$r()],S.prototype,"itemContext",2),S=i([Vr("qti-outcome-declaration")],S);import{consume as Dr}from"@lit/context";import{css as Or,html as Pr}from"lit";import{customElement as Ir,property as Ge,state as Ur}from"lit/decorators.js";var D=class extends P{render(){var e,t;let s=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return Pr`${JSON.stringify(s,null,2)}`}connectedCallback(){super.connectedCallback();let s={baseType:this.baseType,identifier:this.identifier,correctResponse:this.correctResponse,cardinality:this.cardinality||"single",mapping:this.mapping,value:null,type:"response",candidateResponse:null};s.value=this.defaultValues(s),this.dispatchEvent(new CustomEvent("qti-register-variable",{bubbles:!0,composed:!0,detail:{variable:s}}))}get correctResponse(){let s,e=this.querySelector("qti-correct-response");if(e){let t=e.querySelectorAll("qti-value");if(this.cardinality==="single"&&t.length>0)s=t[0].textContent,t[0].remove();else if(this.cardinality!=="single"){s=[];for(let r=0;r<t.length;r++)s.push(t[r].textContent),t[r].remove()}}return s}get mapping(){return this.querySelector("qti-mapping")}};D.styles=[Or`
10
- :host {
11
- display: none;
12
- }
13
- `],i([Ge({type:String,attribute:"base-type"})],D.prototype,"baseType",2),i([Ge({type:String})],D.prototype,"identifier",2),i([Ge({type:String})],D.prototype,"cardinality",2),i([Dr({context:A,subscribe:!0}),Ur()],D.prototype,"itemContext",2),D=i([Ir("qti-response-declaration")],D);import{LitElement as Fr}from"lit";import{customElement as Br}from"lit/decorators.js";var He=class extends Fr{};He=i([Br("qti-companion-materials-info")],He);import{LitElement as Xr,html as Yr}from"lit";import{customElement as jr}from"lit/decorators.js";var Ve=class extends Xr{render(){return Yr`<slot></slot>`}};Ve=i([jr("qti-content-body")],Ve);import{LitElement as Kr,css as zr,html as Wr}from"lit";import{customElement as Jr,property as $e}from"lit/decorators.js";var L=class extends Kr{handleclassNamesChange(s,e){this.classNames.split(" ").forEach(r=>{switch(r){case"qti-rubric-discretionary-placement":this.setAttribute("slot","qti-rubric-block");break;case"qti-rubric-inline":this.setAttribute("slot","");break;default:break}})}render(){return Wr`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-rubric-block")}};L.styles=zr`
14
- :host {
15
- display: block;
16
- }
17
- `,i([$e({type:String})],L.prototype,"id",2),i([$e({type:String})],L.prototype,"use",2),i([$e({type:String})],L.prototype,"view",2),i([$e({type:String,attribute:"class"})],L.prototype,"classNames",2),i([v("classNames",{waitUntilFirstUpdate:!0})],L.prototype,"handleclassNamesChange",1),L=i([Jr("qti-rubric-block")],L);import{css as Qr,html as es}from"lit";import{customElement as ts}from"lit/decorators.js";import{LitElement as Gr}from"lit";import{property as De}from"lit/decorators.js";var Zr=()=>new Intl.NumberFormat().format(.1).replace(/\d/g,""),pe=c=>{if(typeof c=="string")return c;let s=Zr();return s==="."?c.toLocaleString():c.toString().replace(".","").replace(s,".")};function Qe(c){return c==null}function de(c){return c.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}var k=class extends Gr{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-feedback",{bubbles:!0,composed:!0,detail:this}))}checkShowFeedback(s){let e=this.closest("qti-assessment-item").getOutcome(s);if(this.outcomeIdentifier!==s||!e)return;let t=!1;Array.isArray(e.value)?t=e.value.includes(this.identifier):t=!Qe(this.identifier)&&!Qe(e==null?void 0:e.value)&&this.identifier===e.value||!1,this.showFeedback(t)}showFeedback(s){this.showStatus=s&&this.showHide==="show"||!s&&this.showHide==="hide"?"on":"off"}};i([De({type:String,attribute:"show-hide"})],k.prototype,"showHide",2),i([De({type:String,attribute:"outcome-identifier"})],k.prototype,"outcomeIdentifier",2),i([De({type:String})],k.prototype,"identifier",2),i([De({type:String,attribute:!1})],k.prototype,"showStatus",2);var ue=class extends k{render(){return es` <slot part="feedback" class="feedback ${this.showStatus}"></slot> `}firstUpdated(s){this.checkShowFeedback(this.outcomeIdentifier)}};ue.styles=Qr`
18
- :host {
19
- display: block;
20
- }
21
- .on {
22
- display: block;
23
- }
24
- .off {
25
- display: none;
26
- }
27
- `,ue=i([ts("qti-feedback-block")],ue);import{css as rs,html as ss}from"lit";import{customElement as is}from"lit/decorators.js";var me=class extends k{constructor(){super(...arguments);this.render=()=>ss` <slot part="feedback" class="${this.showStatus}"></slot> `}};me.styles=rs`
28
- .on {
29
- display: inline-block;
30
- }
31
- .off {
32
- display: none;
33
- }
34
- `,me=i([is("qti-feedback-inline")],me);import{css as os,html as ns}from"lit";import{customElement as as}from"lit/decorators.js";var he=class extends k{constructor(){super(...arguments);this.render=()=>ns` <slot part="feedback" class="${this.showStatus}"></slot> `}};he.styles=os`
35
- .on {
36
- display: inline-block;
37
- }
38
- .off {
39
- display: none;
40
- }
41
- `,he=i([as("qti-modal-feedback")],he);import{css as cs,html as ps}from"lit";import{ifDefined as tt}from"lit/directives/if-defined.js";import{property as et}from"lit/decorators.js";import{LitElement as ls}from"lit";var g=class extends ls{constructor(){super(...arguments);this.responseIdentifier="";this.disabled=!1;this.readonly=!1}set correctResponse(e){console.warn("correctResponse is not implemented")}connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,cancelable:!1,composed:!0}))}saveResponse(e){this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,cancelable:!1,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:Array.isArray(e)?[...e]:e}}))}};i([et({attribute:"response-identifier"})],g.prototype,"responseIdentifier",2),i([et({reflect:!0,type:Boolean})],g.prototype,"disabled",2),i([et({reflect:!0,type:Boolean})],g.prototype,"readonly",2);import{ref as ds,createRef as us}from"lit/directives/ref.js";import{customElement as ms,property as Oe,state as hs}from"lit/decorators.js";var M=class extends g{constructor(){super(...arguments);this.textareaRef=us();this._value=""}handleclassNamesChange(e,t){this.classNames.split(" ").forEach(o=>{if(o.startsWith("qti-height-lines")){let n=o.replace("qti-height-lines-","");this.textareaRef&&(this.textareaRef.value.rows=parseInt(n))}})}set response(e){this._value=e!==void 0?e:""}validate(){return this._value!==""}static get styles(){return[cs`
42
- /* PK: display host as block, else design will be collapsed */
43
- :host {
44
- display: block;
45
- }
46
- textarea {
47
- box-sizing: border-box;
48
- width: 100%;
49
- height: 100%;
50
- border: 0;
51
- }
52
- `]}render(){return ps`<slot name="prompt"></slot
53
- ><textarea
54
- part="textarea"
55
- ${ds(this.textareaRef)}
56
- spellcheck="false"
57
- autocomplete="off"
58
- @keydown="${e=>e.stopImmediatePropagation()}"
59
- @keyup="${this.textChanged}"
60
- @change="${this.textChanged}"
61
- @blur="${e=>{let t=e.target;t.checkValidity()?t.setCustomValidity(""):(t.setCustomValidity(this.dataset.patternmaskMessage||"Invalid input"),t.reportValidity())}}"
62
- placeholder="${tt(this.placeholderText?this.placeholderText:void 0)}"
63
- maxlength="${tt(this.expectedLength?this.expectedLength:void 0)}"
64
- pattern="${tt(this.patternMask?this.patternMask:void 0)}"
65
- ?disabled="${this.disabled}"
66
- ?readonly="${this.readonly}"
67
- .value=${this._value}
68
- ></textarea>`}textChanged(e){if(this.disabled||this.readonly)return;let t=e.target;this.setEmptyAttribute(t.value),this._value!==t.value&&(this._value=t.value,this.saveResponse(t.value))}reset(){this._value=""}setEmptyAttribute(e){this.setAttribute("empty",e===""?"true":"false")}};i([Oe({type:Number,attribute:"expected-length"})],M.prototype,"expectedLength",2),i([Oe({type:String,attribute:"pattern-mask"})],M.prototype,"patternMask",2),i([Oe({type:String,attribute:"placeholder-text"})],M.prototype,"placeholderText",2),i([hs()],M.prototype,"_value",2),i([Oe({type:String,attribute:"class"})],M.prototype,"classNames",2),i([v("classNames",{waitUntilFirstUpdate:!0})],M.prototype,"handleclassNamesChange",1),M=i([ms("qti-extended-text-interaction")],M);import{css as fs,html as gs}from"lit";import{customElement as bs,property as Pe,state as rt}from"lit/decorators.js";import{ifDefined as Ot}from"lit/directives/if-defined.js";import{createRef as vs}from"lit/directives/ref.js";function Dt(c,s){let e,t=b({},s);return(r,o)=>{let{connectedCallback:n,disconnectedCallback:a}=r;r.connectedCallback=function(){var d;n.call(this);let l=h=>{let m=Array.from(this.querySelectorAll(c));for(let f of h){let _=Array.from(f.addedNodes).map(j=>j),y=Array.from(f.addedNodes).map(j=>j);f.type==="childList"&&_.find(j=>m.includes(j))&&this[o](_,y)}};e=new MutationObserver(l),e.observe(this,{childList:!0,subtree:!0});let p=(d=this.querySelectorAll(c))!=null?d:[];this[o](Array.from(p),[])},r.disconnectedCallback=function(){a.call(this),e.disconnect()}}}var T=class extends g{constructor(){super(...arguments);this._value="";this._correctValue="";this._size=5;this.inputRef=vs()}handleclassNamesChange(e,t){t.split(" ").forEach(o=>{if(o.startsWith("qti-input-width")){let n=o.replace("qti-input-width-","");this._size=parseInt(n)}})}set response(e){this._value=e!==void 0?e:""}validate(){return this._value!==""}static get styles(){return[fs`
69
- [part='correct'] {
70
- position: absolute;
71
- width: 100%;
72
- }
73
- `]}set correctResponse(e){this._correctValue=e}render(){return gs`
74
- <input
75
- part="input"
76
- spellcheck="false"
77
- autocomplete="off"
78
- @blur="${e=>{let t=e.target;t.checkValidity()?t.setCustomValidity(""):(t.setCustomValidity(this.dataset.patternmaskMessage||"Invalid input"),t.reportValidity())}}"
79
- @keydown="${e=>e.stopImmediatePropagation()}"
80
- @keyup="${this.textChanged}"
81
- @change="${this.textChanged}"
82
- type="${this.patternMask=="[0-9]*"?"number":"text"}"
83
- placeholder="${Ot(this.placeholderText?this.placeholderText:void 0)}"
84
- .value="${this._value}"
85
- size="${this._size}"
86
- pattern="${Ot(this.patternMask?this.patternMask:void 0)}"
87
- ?disabled="${this.disabled}"
88
- ?readonly="${this.readonly}"
89
- />
90
- <div part="correct">${this._correctValue}</div>
91
- `}textChanged(e){if(this.disabled||this.readonly)return;let t=e.target;this.setEmptyAttribute(t.value),this._value!==t.value&&(this._value=t.value,this.saveResponse(t.value))}reset(){this._value=""}setEmptyAttribute(e){this.setAttribute("empty",e===""?"true":"false")}};i([Pe({type:Number,attribute:"expected-length"})],T.prototype,"expectedLength",2),i([Pe({type:String,attribute:"pattern-mask"})],T.prototype,"patternMask",2),i([Pe({type:String,attribute:"placeholder-text"})],T.prototype,"placeholderText",2),i([rt()],T.prototype,"_value",2),i([rt()],T.prototype,"_correctValue",2),i([rt()],T.prototype,"_size",2),i([Pe({type:String,attribute:"class"})],T.prototype,"classNames",2),i([v("classNames")],T.prototype,"handleclassNamesChange",1),T=i([bs("qti-text-entry-interaction")],T);import{html as ys,LitElement as xs}from"lit";import{customElement as Es}from"lit/decorators.js";import{property as st}from"lit/decorators.js";var I=(c,s)=>{class e extends c{constructor(...o){super(...o);this._choiceElements=[];this.responseIdentifier="";this.minChoices=0;this.maxChoices=1;this._handleDisabledChange=(o,n)=>this._choiceElements.forEach(a=>a.disabled=n);this._handleReadonlyChange=(o,n)=>this._choiceElements.forEach(a=>a.readonly=n);this._handleMaxChoicesChange=()=>this._determineInputType();this.addEventListener("qti-register-choice",this._registerChoiceElement),this.addEventListener("qti-loose-choice",this._looseChoiceElement)}validate(){return this._choiceElements.reduce((n,a)=>n+(a.checked?1:0),0)>=this.minChoices}set response(o){let n=Array.isArray(o)?o:[o];this._choiceElements.forEach(a=>{a.checked=!!n.find(l=>l===a.identifier)})}set correctResponse(o){let n=Array.isArray(o)?o:[o];if(o==""){this._choiceElements.forEach(a=>{a.removeAttribute("data-correct-response")});return}this._choiceElements.forEach(a=>{a.setAttribute("data-correct-response",n.find(l=>l===a.identifier)?"true":"false")})}connectedCallback(){super.connectedCallback(),this.addEventListener("qti-register-choice",this._registerChoiceElement),this.addEventListener("qti-choice-element-selected",this._choiceElementSelectedHandler),this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,cancelable:!1,composed:!0}))}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-choice-element-selected",this._choiceElementSelectedHandler),this.removeEventListener("qti-register-choice",this._registerChoiceElement)}_registerChoiceElement(o){o.stopPropagation();let n=o.target;this._choiceElements.push(n),this._setInputType(n)}_looseChoiceElement(o){o.stopPropagation();let n=o.target;this._choiceElements.push(n),this._choiceElements=this._choiceElements.filter(a=>a!==n)}_determineInputType(){this._choiceElements.forEach(o=>{this._setInputType(o)})}_setInputType(o){this.maxChoices===1?o.setAttribute("role","radio"):o.setAttribute("role","checkbox")}_choiceElementSelectedHandler(o){this.maxChoices===1&&this._choiceElements.filter(n=>n.identifier!==o.detail.identifier).forEach(n=>{n.checked=!1}),this._choiceElementSelected()}_choiceElementSelected(){let o=this._choiceElements.filter(a=>a.checked).map(a=>a.identifier);this.maxChoices>1&&(this.maxChoices===o.length?this._choiceElements.forEach(a=>a.disabled=!a.checked):this._choiceElements.forEach(a=>a.disabled=!1));let n;this.maxChoices===1?n=o.length>0?o[0]:void 0:n=o,this.saveResponse(n)}saveResponse(o){this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:o}}))}}return i([st({attribute:"response-identifier"})],e.prototype,"responseIdentifier",2),i([st({type:Number,attribute:"min-choices"})],e.prototype,"minChoices",2),i([st({type:Number,attribute:"max-choices"})],e.prototype,"maxChoices",2),i([v("disabled",{waitUntilFirstUpdate:!0})],e.prototype,"_handleDisabledChange",2),i([v("readonly",{waitUntilFirstUpdate:!0})],e.prototype,"_handleReadonlyChange",2),i([v("maxChoices",{waitUntilFirstUpdate:!0})],e.prototype,"_handleMaxChoicesChange",2),e};var Ie=class extends I(xs,"qti-hottext"){constructor(){super(...arguments);this.render=()=>ys`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("qti-hottext-interaction","")}};Ie=i([Es("qti-hottext-interaction")],Ie);import{css as qs,html as Pt}from"lit";import{customElement as Cs,property as _s,state as It}from"lit/decorators.js";import{unsafeHTML as Ut}from"lit/directives/unsafe-html.js";var U=class extends g{constructor(){super(...arguments);this.options=[];this.correctOption="";this.dataPrompt="select"}static get styles(){return[qs`
92
- :host {
93
- display: inline-block;
94
- }
95
- slot {
96
- display: flex;
97
- flex-direction: column;
98
- }
99
- [role='menu'] {
100
- position: absolute;
101
- z-index: 1000;
102
- }
103
- .anchor {
104
- /* anchor-name: --infobox; */
105
- width: fit-content;
106
- }
107
-
108
- .positionedElement {
109
- position: absolute;
110
- /* position-anchor: --infobox; */
111
- /* top: anchor(bottom); */
112
- }
113
- `]}render(){return Pt`
114
- <select part="select" @change="${this.choiceSelected}" ?disabled="${this.disabled}" ?readonly="${this.readonly}">
115
- ${this.options.map(e=>Pt`
116
- <option value="${e.value}" ?selected="${e.selected}">${Ut(e.textContent)}</option>
117
- `)}
118
- </select>
119
-
120
- ${Ut(this.correctOption)}
121
- `}connectedCallback(){super.connectedCallback(),this.addEventListener("on-dropdown-selected",this.choiceSelected);let e=Array.from(this.querySelectorAll("qti-inline-choice"));this.options=[{textContent:this.dataPrompt,value:"",selected:!1},...e.map(t=>({textContent:t.innerHTML,value:t.getAttribute("identifier"),selected:!1}))]}disconnectedCallback(){this.removeEventListener("on-dropdown-selected",this.choiceSelected)}validate(){let e=this.options.find(t=>t.selected);return e?e.value!=="":!1}reset(){this.options=this.options.map((e,t)=>q(b({},e),{selected:t===0}))}set response(e){this.options=this.options.map(t=>(e===t.value&&(t.selected=!0),t))}set correctResponse(e){if(e===""){this.correctOption="";return}this.correctOption=`<span part="correct-option">${this.options.find(t=>e===t.value).textContent}</span>`}choiceSelected(e){let t=e.target.value;this.options=this.options.map(r=>q(b({},r),{selected:r.value===t})),this.saveResponse(t)}};U.inputWidthClass=["","qti-input-width-2","qti-input-width-1","qti-input-width-3","qti-input-width-4","qti-input-width-6","qti-input-width-10","qti-input-width-15","qti-input-width-20","qti-input-width-72"],i([It()],U.prototype,"options",2),i([It()],U.prototype,"correctOption",2),i([_s({attribute:"data-prompt",type:String})],U.prototype,"dataPrompt",2),U=i([Cs("qti-inline-choice-interaction")],U);import{html as As,LitElement as Ss}from"lit";import{customElement as Ls,property as Ms}from"lit/decorators.js";import{property as ks}from"lit/decorators.js";var Ue=(c,s)=>{class e extends c{constructor(){super(...arguments);this._shuffle=!1}set shuffle(o){let n=this._shuffle;this._shuffle=o,o?this._shuffleChoices():this._resetShuffleChoices(),this.requestUpdate("shuffle",n)}get shuffle(){return this._shuffle}connectedCallback(){super.connectedCallback(),this.shuffle?this._shuffleChoices():this._resetShuffleChoices()}_shuffleChoices(){let o=Array.from(this.querySelectorAll(s)),n=[],a=[];o.forEach((m,f)=>{m.hasAttribute("fixed")?n.push({element:m,index:f}):a.push(m)}),a.length<=1&&console.warn("Shuffling is not possible with fewer than 2 non-fixed elements.");let l=!1,p=10,d=0;for(;!l&&d<p;){d++;for(let m=a.length-1;m>0;m--){let f=Math.floor(Math.random()*(m+1));[a[m],a[f]]=[a[f],a[m]]}if(l=a.some((m,f)=>o.indexOf(m)!==f),l)break}l||console.warn("Failed to shuffle the choices after multiple attempts.");let h=1;o.forEach((m,f)=>{m.hasAttribute("fixed")?m.style.setProperty("order",String(h++)):a.shift().style.setProperty("order",String(h++))})}_resetShuffleChoices(){Array.from(this.querySelectorAll("qti-simple-choice")).forEach((n,a)=>{n.style.setProperty("order","initial")})}}return i([ks({type:String,reflect:!0,converter:Ts})],e.prototype,"shuffle",1),e},Ts={fromAttribute(c){return c==="true"},toAttribute(c){return c?"true":"false"}};import{property as ws}from"lit/decorators.js";var Ft=(c,s)=>{class e extends c{constructor(){super(...arguments);this._classes=[];this._allLabels=["qti-labels-decimal","qti-labels-lower-alpha","qti-labels-upper-alpha"];this._allLabelSuffixes=["qti-labels-suffix-period","qti-labels-suffix-parenthesis"]}set class(o){o&&(this._classes=o.split(" "),this._addLabels())}get class(){var o;return((o=this._classes)==null?void 0:o.join(" "))||""}updated(o){super.updated(o),o.has("shuffle")&&this._addLabels()}_addLabels(){let o=this._classes.some(a=>this._allLabels.includes(a)||this._allLabelSuffixes.includes(a)),n=a=>!isNaN(+a);if(o){let l=Array.from(this.querySelectorAll("qti-simple-choice")).map(p=>p).map((p,d)=>({el:p,order:n(p.style.order)?+p.style.order:d+1})).sort((p,d)=>p.order-d.order).map(p=>p.el);for(let p=0;p<l.length;p++)l[p].marker=this._getLabel(p+1)}}_getLabel(o){let n=this._classes.filter(p=>this._allLabels.includes(p)).pop(),a=this._classes.filter(p=>this._allLabelSuffixes.includes(p)).pop();!n&&a&&(n="qti-labels-upper-alpha");let l="";switch(n){case"qti-labels-decimal":l=`${o}`;break;case"qti-labels-lower-alpha":l=`${String.fromCharCode(97+o-1)}`;break;case"qti-labels-upper-alpha":l=`${String.fromCharCode(65+o-1)}`;break}return a==="qti-labels-suffix-period"?l+=".":a==="qti-labels-suffix-parenthesis"&&(l+=")"),l}}return i([ws({type:String,reflect:!0})],e.prototype,"class",1),e};import{css as Rs}from"lit";var Bt=Rs`
122
- :host {
123
- display: flex;
124
- flex-direction: column;
125
- gap: var(--qti-gap-size);
126
- // align-items: flex-start;
127
- }
128
- `;var Z=class extends Ft(Ue(I(Ss,"qti-simple-choice"),"qti-simple-choice"),"qti-simple-choice"){render(){return As` <slot name="prompt"></slot><slot part="slot"></slot>`}};Z.styles=Bt,i([Ms({type:String})],Z.prototype,"orientation",2),Z=i([Ls("qti-choice-interaction")],Z);import{css as Ns,html as Hs,LitElement as Vs}from"lit";import{customElement as $s}from"lit/decorators.js";var fe=class extends Vs{render(){return Hs`<slot></slot>`}process(){let s=new it,e=[...this.children];s.process(e)}};fe.styles=[Ns`
129
- :host {
130
- display: none;
131
- }
132
- `],fe=i([$s("qti-outcome-processing")],fe);var it=class{process(s){for(let e of s)e.process()}};import{css as Ds,html as Os,LitElement as Ps}from"lit";import{customElement as Is}from"lit/decorators.js";var Xt=`<qti-response-processing>
133
- <qti-response-condition>
134
- <qti-response-if>
135
- <qti-match>
136
- <qti-variable identifier="RESPONSE"></qti-variable>
137
- <qti-correct identifier="RESPONSE"></qti-correct>
138
- </qti-match>
139
- <qti-set-outcome-value identifier="SCORE">
140
- <qti-base-value base-type="float">1</qti-base-value>
141
- </qti-set-outcome-value>
142
- </qti-response-if>
143
- <qti-response-else>
144
- <qti-set-outcome-value identifier="SCORE">
145
- <qti-base-value base-type="float">0</qti-base-value>
146
- </qti-set-outcome-value>
147
- </qti-response-else>
148
- </qti-response-condition>
149
- </qti-response-processing>`,Yt=`<qti-response-processing>
150
- <qti-response-condition>
151
- <qti-response-if>
152
- <qti-is-null>
153
- <qti-variable identifier="RESPONSE"></qti-variable>
154
- </qti-is-null>
155
- <qti-set-outcome-value identifier="SCORE">
156
- <qti-base-value base-type="float">0.0</qti-base-value>
157
- </qti-set-outcome-value>
158
- </qti-response-if>
159
- <qti-response-else>
160
- <qti-set-outcome-value identifier="SCORE">
161
- <qti-map-response identifier="RESPONSE"> </qti-map-response>
162
- </qti-set-outcome-value>
163
- </qti-response-else>
164
- </qti-response-condition>
165
- </qti-response-processing>`,jt=`<qti-response-processing>
166
- <qti-response-condition>
167
- <qti-response-if>
168
- <qti-is-null>
169
- <qti-variable identifier="RESPONSE"></qti-variable>
170
- </qti-is-null>
171
- <qti-set-outcome-value identifier="SCORE">
172
- <qti-base-value base-type="float">0</qti-base-value>
173
- </qti-set-outcome-value>
174
- </qti-response-if>
175
- <qti-response-else>
176
- <qti-set-outcome-value identifier="SCORE">
177
- <qti-map-response-point identifier="RESPONSE"></qti-map-response-point>
178
- </qti-set-outcome-value>
179
- </qti-response-else>
180
- </qti-response-condition>
181
- </qti-response-processing>`;var K=class extends Ps{render(){return Os`<slot></slot>`}process(){let s=[...this.children];for(let e of s)e.process()}firstUpdated(s){if(this.getAttribute("template")){let e=this.getAttribute("template").split("/"),t=e[e.length-1].replace(".xml","");switch(this.innerHTML="",t){case"map_response":{this.appendChild(this.fragmentFromString(Yt).firstElementChild.firstElementChild);break}case"map_response_point":{this.appendChild(this.fragmentFromString(jt).firstElementChild.firstElementChild);break}case"match_correct":this.appendChild(this.fragmentFromString(Xt).firstElementChild.firstElementChild);break}}}fragmentFromString(s){return document.createRange().createContextualFragment(s)}};K.styles=[Ds`
182
- :host {
183
- display: none;
184
- }
185
- `],K=i([Is("qti-response-processing")],K);import{property as Xs}from"lit/decorators.js";import{customElement as Us}from"lit/decorators.js";import{html as Fs,LitElement as Bs}from"lit";var N=class extends Bs{render(){return Fs`<slot></slot>`}process(){throw new Error("Not implemented")}};N=i([Us("qti-rule")],N);var Fe=class extends N{get childExpression(){return this.firstElementChild}process(){let s=this.getAttribute("identifier"),e=this.closest("qti-assessment-item").getVariable(s),t;return e.interpolationTable&&(t=e.interpolationTable.get(parseInt(this.childExpression.calculate()))),t==null?(console.warn("lookupOutcomeValue: value is null or undefined"),0):(this.dispatchEvent(new CustomEvent("qti-set-outcome-value",{bubbles:!0,composed:!0,detail:{outcomeIdentifier:this.identifier,value:pe(t)}})),t)}};i([Xs({type:String})],Fe.prototype,"identifier",2);customElements.define("qti-lookup-outcome-value",Fe);import{html as Ys}from"lit";var ot=class extends N{render(){return Ys`<slot></slot>`}process(){let s=[...this.children];for(let e=0;e<s.length;e++){let t=s[e];if(t.calculate()){t.process();return}}}};customElements.define("qti-response-condition",ot);var nt=class extends N{process(){let s=this.getAttribute("identifier"),e=this.firstElementChild,r=new at(e).process();this.dispatchEvent(new CustomEvent("qti-set-outcome-value",{bubbles:!0,composed:!0,detail:{outcomeIdentifier:s,value:Array.isArray(r)?r.map(o=>pe(o)):pe(r)}}))}},at=class{constructor(s){this.expression=s}process(){let s=this.expression?this.expression.calculate():null;if(s==null){console.warn("setOutcomeValue: value is null or undefined");return}return s}};customElements.define("qti-set-outcome-value",nt);import{LitElement as js,html as Ks}from"lit";var ge=class extends js{render(){return Ks`<slot></slot>`}calculate(){return!0}getSubRules(){return[...this.children]}process(){let s=this.getSubRules();for(let e=0;e<s.length;e++)s[e].process()}};customElements.define("qti-response-else",ge);import{html as zs}from"lit";var be=class extends ge{calculate(){return this.firstElementChild.calculate()}getSubRules(){let s=[];for(let e=1;e<this.children.length;e++)s.push(this.children[e]);return s}};customElements.define("qti-response-if",be);var lt=class extends be{render(){return zs`${super.render()}`}};customElements.define("qti-response-else-if",lt);import{LitElement as Ws,css as Js,html as Zs}from"lit";import{state as Gs}from"lit/decorators.js";var u=class extends Ws{constructor(){super(...arguments);this.getVariables=()=>Array.from(this.children).map(e=>{switch(e.tagName.toLowerCase()){case"qti-base-value":return{baseType:e.getAttribute("base-type"),value:e.textContent,cardinality:"single"};case"qti-variable":{let t=e.getAttribute("identifier")||"";return this.assessmentItem.getVariable(t)}case"qti-multiple":{let r=e.getResult();return r.length>0?{identifier:"",baseType:r[0].baseType,value:r.map(o=>o.value),cardinality:"multiple",type:"response"}:null}case"qti-correct":{let t=e.getAttribute("identifier")||"",r=this.assessmentItem.getResponse(t);return{baseType:r.baseType,value:r.correctResponse,cardinality:r.cardinality}}default:{try{return{baseType:"integer",value:e.getResult().toString(),cardinality:"single"}}catch(t){console.warn("default not sufficient")}return null}}}).filter(e=>e!==null)}render(){return Zs`<pre>${JSON.stringify(this.result,null,2)}</pre>
186
- <slot></slot>`}calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}get assessmentItem(){return this.closest("qti-assessment-item")}};u.styles=Js`
187
- slot {
188
- display: none;
189
- }
190
- `,i([Gs()],u.prototype,"result",2);var w=class extends u{calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}};var Be=class extends Qs(w){calculate(){return this.calculateChildren(Array.from(this.children))}};function Qs(c){return class extends c{calculateChildren(e){return e.map(r=>{let o=r;if(!o.calculate)return console.error("Element doesn't implement QtiConditionExpression"),null;let n=o.calculate();if(typeof n=="string")if(n==="true")n=!0;else if(n==="false")n=!1;else return console.error("unexpected value in qti-and, expected boolean"),null;return n}).every(r=>typeof r=="boolean"&&r)}}}customElements.define("qti-and",Be);import{property as ei}from"lit/decorators.js";var Xe=class extends u{constructor(){super(...arguments);this.baseType="string"}getResult(){return this.textContent}};i([ei({type:String,attribute:"base-type"})],Xe.prototype,"baseType",2);customElements.define("qti-base-value",Xe);var ct=class extends w{getResult(){let s=this.getVariables();if(this.children.length===2){let e=s[0],t=s[1];if(e.baseType==="directedPair"&&t.baseType==="directedPair"&&e.cardinality==="multiple"){let r=e.value,o=t.value;return r.filter(l=>o.includes(l)).length>0}else if(e.baseType==="directedPair"&&t.baseType==="directedPair"&&e.cardinality==="single"){let r=e.value;return t.value.includes(r)}else console.error("unsupported baseType or cardinality in qti contains, only baseType: directedPair and cardinality: multiple is supported")}else console.error("unexpected number of children in qti contains");return!1}};customElements.define("qti-contains",ct);var pt=class extends u{get interpretation(){return this.getAttribute("interpretation")||""}getResult(){let s=this.getAttribute("identifier")||"",e=this.closest("qti-assessment-item").getResponse(s);return e.correctResponse,e.cardinality!=="single"?e.correctResponse.length>0?e.correctResponse[0]:"":e.correctResponse}};customElements.define("qti-correct",pt);import{property as ti}from"lit/decorators.js";var Ye=class extends u{constructor(){super(...arguments);this.roundingMode="significantFigures"}get figures(){if(!this.getAttribute("figures"))return console.error("figures attribute is missing"),null;let t=parseInt(this.getAttribute("figures")||"0");return isNaN(t)?(console.error("figures attribute is not a number"),null):t<0?(console.error("figures attribute is negative"),null):t<1&&this.roundingMode==="significantFigures"?(console.error("figures cannot be smaller than 1 for RoundingMode significantFigures"),null):t}getResult(){if(this.children.length===2){let e=this.getVariables(),t=e[0],r=e[1];if(this.roundingMode===null)return null;if(t.cardinality!=="single"||r.cardinality!=="single"||Array.isArray(t.value)||Array.isArray(r.value))return console.error("unexpected cardinality in qti equal"),!1;switch(e[0].baseType){case"integer":case"float":{let o=parseFloat(t.value),n=parseFloat(r.value);if(!isNaN(o)&&!isNaN(n))return this.roundingMode==="significantFigures"?o.toPrecision(this.figures)===n.toPrecision(this.figures):Math.round(o*Math.pow(10,this.figures))/Math.pow(10,this.figures)===Math.round(n*Math.pow(10,this.figures))/Math.pow(10,this.figures);console.error(`value cannot be casted to numeric value in equalRounded operator: ${o}, ${n}`);break}default:{console.error("values other than float and int cannot be used in equalRounded operator.");break}}return!1}return console.error("unexpected number of children in qti-equal-rounded"),null}};i([ti({type:String})],Ye.prototype,"roundingMode",2);customElements.define("qti-equal-rounded",Ye);import{property as ri}from"lit/decorators.js";var R=class{static compareSingleValues(s,e,t){switch(t){case"identifier":case"string":return s===e;case"integer":{let r=parseInt(s,10),o=parseInt(e,10);if(!isNaN(r)&&!isNaN(o))return r===o;console.error(`Cannot convert ${s} and/or ${e} to int.`);break}case"float":{let r=parseFloat(s),o=parseFloat(e);if(!isNaN(r)&&!isNaN(o))return r===o;console.error(`couldn't convert ${s} and/or ${e} to float.`);break}case"pair":case"directedPair":{let r=s.split(" ").sort(),o=e.split(" ").sort();if(r.length===2&&o.length===2)return t==="pair"&&(r.sort(),o.sort()),r.join(" ")===o.join(" ");console.error(`compared two pair but one of the values does not have 2 values: 1: ${s} 2: ${e}`);break}}return!1}};var je=class extends u{constructor(){super(...arguments);this.toleranceMode="exact"}getResult(){if(this.children.length===2){let e=this.getVariables(),t=e[0],r=e[1];return this.toleranceMode!=="exact"?(console.error("toleranceMode is not supported yet"),!1):t.cardinality!=="single"||r.cardinality!=="single"||Array.isArray(t.value)||Array.isArray(r.value)?(console.error("unexpected cardinality in qti equal"),!1):R.compareSingleValues(t.value,r.value,t.baseType)}return console.error("unexpected number of children in qti-equal"),null}};i([ri({type:String})],je.prototype,"toleranceMode",2);customElements.define("qti-equal",je);var dt=class extends u{getResult(){if(this.children.length===2){let s=this.getVariables(),e=s[0],t=s[1];if(e.baseType===t.baseType&&(e.baseType==="integer"||e.baseType==="float"))return+e.value>+t.value;console.error("unexpected baseType or cardinality in qti gt")}return console.error("unexpected number of children in qt"),null}};customElements.define("qti-gt",dt);var ut=class extends w{getResult(){if(this.children.length===2){let s=this.getVariables(),e=s[0],t=s[1];return e.baseType===t.baseType&&(e.baseType==="integer"||e.baseType==="float")?+e.value>=+t.value:(console.error("unexpected baseType or cardinality in qti gte"),null)}return console.log("unexpected number of children in qte"),null}};customElements.define("qti-gte",ut);var mt=class extends u{getResult(){if(this.children.length===1){let s=this.getVariables();if(!s)return!0;let e=s[0].value;return e==null||e==null||e===""}return console.error("unexpected number of children in qti Null"),null}};customElements.define("qti-is-null",mt);var ht=class extends u{getResult(){if(this.children.length===2){let s=this.getVariables(),e=s[0],t=s[1];if(e.baseType===t.baseType&&(e.baseType==="integer"||e.baseType==="float"))return+e.value<+t.value;console.error("unexpected baseType or cardinality in qti lt")}return console.error("unexpected number of children in lt"),null}};customElements.define("qti-lt",ht);var ft=class extends w{getResult(){if(this.children.length===2){let s=this.getVariables(),e=s[0],t=s[1];return e.baseType===t.baseType&&(e.baseType==="integer"||e.baseType==="float")?+e.value<=+t.value:(console.error("unexpected baseType or cardinality in qti lte"),null)}return console.log("unexpected number of children in lte"),null}};customElements.define("qti-lte",ft);import{property as si}from"lit/decorators.js";var Ke=class extends u{getResult(){let s=this.assessmentItem.getResponse(this.identifier);if(!s)return console.warn(`Response ${this.identifier} can not be found`),null;let e=s.mapping,t=Array.isArray(s.value)?s.value:[s.value],r=0;for(let o of t){let n=e.mapEntries.find(a=>R.compareSingleValues(a.mapKey,o,s.baseType));n==null||n.mappedValue==null?r+=e.defaultValue:r+=n.mappedValue}return e.lowerBound!=null&&(r=Math.max(e.lowerBound,r)),e.upperBound!=null&&(r=Math.min(e.upperBound,r)),r}};i([si({type:String})],Ke.prototype,"identifier",2);customElements.define("qti-map-response",Ke);import{property as gt}from"lit/decorators.js";import{LitElement as ii}from"lit";var G=class extends ii{constructor(){super(...arguments);this.defaultValue=0}get mapEntries(){return Array.from(this.querySelectorAll("qti-map-entry")).map(e=>({mapKey:e.getAttribute("map-key"),mappedValue:+e.getAttribute("mapped-value")}))}};i([gt({attribute:"default-value",type:Number})],G.prototype,"defaultValue",2),i([gt({attribute:"lower-bound",type:Number})],G.prototype,"lowerBound",2),i([gt({attribute:"upper-bound",type:Number})],G.prototype,"upperBound",2);customElements.define("qti-mapping",G);var bt=class c extends u{getResult(){if(this.children.length===2){let s=this.getVariables(),e=s[0],t=s[1];return c.match(e,t)}return console.error("unexpected number of children in match"),null}static match(s,e){var t;switch(e.cardinality){case"single":return s.value===null?!1:Array.isArray(s.value)||Array.isArray(e.value)?(console.error("unexpected cardinality in qti match"),!1):R.compareSingleValues((t=s.value)==null?void 0:t.toString(),e.value.toString(),e.baseType);case"ordered":{if(!Array.isArray(s.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(s.value.length!==e.value.length)return!1;for(let r=0;r<s.value.length;r++)if(!R.compareSingleValues(e.value[r],s.value[r],e.baseType))return!1;return!0}case"multiple":{if(!Array.isArray(s.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(s.value.length!==e.value.length)return!1;let r=0;for(let o of e.value){let n=null,a=[...s.value];for(let l of a)if(R.compareSingleValues(o,l,e.baseType)){n=l;break}if(n!==null)a.splice(a.indexOf(n),1);else return!1;r++}return!0}default:return console.error("unexpected cardinality in qti match"),!1}}};customElements.define("qti-match",bt);var vt=class extends u{getResult(){let s=this.getVariables();this.children.length!==2&&console.warn("The member operator takes two sub-expressions");let[e,t]=s;if(e.baseType!==t.baseType&&console.warn("Which must both have the same base-type"),t.cardinality==="multiple"||t.cardinality==="ordered"||console.warn("and the second must be a multiple or ordered container"),(e.baseType==="float"||t.baseType==="float")&&console.warn("The member operator should not be used on sub-expressions with a base-type of float"),(e.baseType==="duration"||t.baseType==="duration")&&console.warn("It must not be used on sub-expressions with a base-type of duration"),e.value===null||t.value===null)return null;let r=e.value;return t.value.includes(r)}};customElements.define("qti-member",vt);var yt=class extends u{getResult(){let s=this.getVariables();if(s.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of s)if(e.cardinality!=="multiple"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti multiple"),[];return s}};customElements.define("qti-multiple",yt);import{html as oi}from"lit";var xt=class extends u{render(){return oi`${super.render()}`}getResult(){return!this.firstElementChild.calculate()}};customElements.define("qti-not",xt);var Et=class extends w{getResult(){return Array.from(this.children).map(e=>{let t=e;if(!t.calculate)return console.error("Element doesn't implement QtiConditionExpression"),null;let r=t.calculate();if(typeof r=="string")if(r==="true")r=!0;else if(r==="false")r=!1;else return console.error("unexpected value in qti-or, expected boolean"),null;return r}).some(e=>typeof e=="boolean"&&e)}};customElements.define("qti-or",Et);var qt=class extends u{getResult(){let s=this.getVariables();if(s.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of s)if(e.cardinality!=="ordered"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti ordered"),[];return s}};customElements.define("qti-ordered",qt);import{consume as ni}from"@lit/context";import{LitElement as ai,html as li}from"lit";import{property as ci,state as pi}from"lit/decorators.js";var ve=class extends ai{render(){var e,t;let s=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return li`${JSON.stringify(s,null,2)}`}calculate(){let s=this.closest("qti-assessment-item"),e=this.identifier;return s.getVariable(e).value}};i([ci({type:String})],ve.prototype,"identifier",2),i([ni({context:A,subscribe:!0}),pi()],ve.prototype,"itemContext",2);customElements.define("qti-printed-variable",ve);var Ct=class extends u{getResult(){return this.getVariables().reduce((t,r)=>{if(r.baseType=="float"||r.baseType=="integer")try{return t*parseInt(r.value.toString())}catch(o){console.warn("can not convert to number")}else console.warn(`has another baseType ${r.baseType}`);return t},1)}};customElements.define("qti-product",Ct);import{property as di}from"lit/decorators.js";var ze=class extends u{constructor(){super(...arguments);this.caseSensitive="true"}getResult(){if(this.children.length===2){let e=this.getVariables(),t=e[0],r=e[1];if(t.cardinality!=="single"||r.cardinality!=="single"||Array.isArray(t.value)||Array.isArray(r.value))return console.error("unexpected cardinality in qti string-match"),!1;let o=this.caseSensitive==="true"?t.value:t.value.toLowerCase(),n=this.caseSensitive==="true"?r.value:r.value.toLowerCase();return R.compareSingleValues(o,n,t.baseType)}return console.error("unexpected number of children in qti-string-match"),null}};i([di({type:String,attribute:"case-sensitive"})],ze.prototype,"caseSensitive",2);customElements.define("qti-string-match",ze);var _t=class extends u{constructor(){super(),this._expression=new kt(Array.from(this.children))}getResult(){return this._expression.calculate()}},kt=class{constructor(s){this.expressions=s}calculate(){return this.expressions.map(e=>{if(!e.calculate)return console.error("Element doesn't implement QtiConditionExpression"),null;let t=e.calculate();return Number.isNaN(t)?(console.error("unexpected value in qti-sum, expected number"),null):Number(t)}).reduce((e,t)=>e+t,0)}};customElements.define("qti-sum",_t);var Tt=class extends u{getResult(){let s=this.getAttribute("identifier");return this.closest("qti-assessment-item").getVariable(s).value}};customElements.define("qti-variable",Tt);import{html as Kt}from"lit";import{customElement as ui,property as wt,state as mi}from"lit/decorators.js";var F=class extends g{constructor(){super(...arguments);this._errorMessage=null;this.loadConfig=async(e,t)=>{e=this.removeDoubleSlashes(e);try{let r=await fetch(e);if(r.ok){let n=await r.json();for(let a in n.paths)t&&(n.paths[a]=this.getResolvablePath(n.paths[a],t));return n}}catch(r){}return null};this.getResolvablePathString=(e,t)=>(e=e.replace(/\.js$/,""),e!=null&&e.toLocaleLowerCase().startsWith("http")||!t?e:this.removeDoubleSlashes(`${t}/${e}`));this.getResolvablePath=(e,t)=>Array.isArray(e)?e.map(r=>this.getResolvablePathString(r,t)):this.getResolvablePathString(e,t)}convertQtiVariableJSON(e){for(let t in e)if(e.hasOwnProperty(t)){let r=e[t];if(r){for(let o in r)if(r.hasOwnProperty(o)){let n=r[o];if(Array.isArray(n))return n.map(String);if(n!=null)return String(n)}}}return null}startChecking(){this.intervalId=setInterval(()=>{let e=this.pci.getResponse(),t=this.pci.getResponse(),r=JSON.stringify(e);if(r!==this.rawResponse){this.rawResponse=r;let o=this.convertQtiVariableJSON(t);this.response=o,this.saveResponse(o)}},200)}stopChecking(){this.intervalId!==void 0&&clearInterval(this.intervalId)}validate(){return!0}set response(e){}getTAOConfig(e){let t=e.querySelectorAll("properties"),r={},o=a=>{let l={},p=a.getAttribute("key");if(p){let d=Array.from(a.children),h=d.map(f=>f.getAttribute("key"));h.length>0&&!h.find(f=>!Number.isInteger(+f))?l[p]=d.map(f=>n(f)):l[p]=a.textContent}return l},n=a=>{if(a){let l={};for(let p of a.children)l=b(b({},l),o(p));return l}};for(let a of t)return a.getAttribute("key")||(r=b(b({},r),n(a))),r;return console.log("Can not find qti-custom-interaction config"),null}register(e){this.pci=e;let t=this.parentElement.tagName==="QTI-CUSTOM-INTERACTION"?"TAO":"IMS",r=t=="IMS"?this.querySelector("qti-interaction-markup"):this.querySelector("markup");r.classList.add("qti-customInteraction"),t=="TAO"&&this.querySelector("properties")&&(this.querySelector("properties").style.display="none");let o=t=="IMS"?{properties:this.dataset,onready:()=>{console.log("onready")}}:this.getTAOConfig(this);t=="IMS"?e.getInstance(r,o,void 0):e.initialize(this.customInteractionTypeIdentifier,r.firstElementChild,o),t=="TAO"&&Array.from(this.querySelectorAll("link")).map(a=>a.getAttribute("href")).forEach(a=>{let l=document.createElement("link");l.rel="stylesheet",l.type="text/css",l.media="screen",l.href=a,r.appendChild(l)}),this.startChecking()}connectedCallback(){super.connectedCallback(),define("qtiCustomInteractionContext",()=>({register:r=>{this.register(r)},notifyReady:()=>{}}));let e=this.buildRequireConfig();requirejs.config(e)(["require"],r=>{r([this.module])})}disconnectedCallback(){super.disconnectedCallback(),requirejs.undef(this.customInteractionTypeIdentifier);let e=requirejs.s.contexts;delete e[this.customInteractionTypeIdentifier],this.stopChecking()}buildRequireConfig(){let e={context:this.customInteractionTypeIdentifier,catchError:!0,paths:window.requirePaths||{},shim:window.requireShim||{}};if(!globalThis.require)return this._errorMessage="RequireJS not found. Please load it via CDN: https://cdnjs.com/libraries/require.js",null;let t=this.getAttribute("data-base-url"),r=this.querySelector("qti-interaction-modules");if(r){let o=r.querySelectorAll("qti-interaction-module");for(let n of o){let a=n.getAttribute("id"),l=n.getAttribute("primary-path"),p=n.getAttribute("fallback-path");if(a&&l){let d=p?this.combineRequireResolvePaths(this.getResolvablePath(l,t),this.getResolvablePath(p,t)):this.getResolvablePath(l,t),h=e.paths[a]||[];e.paths[a]=this.combineRequireResolvePaths(h,d)}}}return e}combineRequireResolvePaths(e,t){let r=Array.isArray(e)?e:[e],o=Array.isArray(t)?t:[t];return r.concat(o)}removeDoubleSlashes(e){return e.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}render(){return Kt`<slot></slot>${this._errorMessage&&Kt`<div style="color:red">
191
- <h1>Error</h1>
192
- ${this._errorMessage}
193
- </div>`}`}};i([wt({type:String,attribute:"response-identifier"})],F.prototype,"responseIdentifier",2),i([wt({type:String,attribute:"module"})],F.prototype,"module",2),i([wt({type:String,attribute:"custom-interaction-type-identifier"})],F.prototype,"customInteractionTypeIdentifier",2),i([mi()],F.prototype,"_errorMessage",2),F=i([ui("qti-portable-custom-interaction")],F);import{LitElement as fi,css as gi,html as Jt}from"lit";import{customElement as bi,state as vi}from"lit/decorators.js";var We=class c{constructor(){this._touchBegin=0;this._touchDown=null;this._lastClick=0;this._canDrag=!1;this._dragSrc=null;this._dragCopy=null;this._touchEndCalled=!1;this._dragRunning=!1;this._dataTransfer={data:{},setData:function(s,e){this.data[s]=e},getData:function(s){return this.data[s]},effectAllowed:"move"};this._copyOffset={x:0,y:0};this._lastTarget=null;this._currentDropContainer=null;this._handleClick=!0;this._DBLCLICKDELAY=500;this._CONTEXTMENUDELAY=1e3;this._DRAGDELTA=5;this._COPYOPACITY=1;this._ORGOPACITY=.7;this.copyStylesDragClone=!0;this.dragOnClick=!1;this._createDragCopy=(s,e)=>{if(this._dragCopy===null&&this._dragRunning){this._dragSrc.style.opacity=this._COPYOPACITY,this._dragCopy=this._dragSrc.cloneNode(!0);let t=window.getComputedStyle(this._dragSrc);if(this._dragCopy.style="",this._dragCopy.setAttribute("dragclone",""),this.copyStylesDragClone)for(let r of t)this._dragCopy.style[r]=t.getPropertyValue(r);this._calculateDragCopyPosition(e),this._dragCopy.style.top=e.clientY-this._copyOffset.y+"px",this._dragCopy.style.left=e.clientX-this._copyOffset.x+"px",this._dragCopy.style.position="fixed",this._dragCopy.style.pointerEvents="none",this._dragCopy.style.zIndex="999999",this._dragCopy=document.body.appendChild(this._dragCopy),this._dispatchEvent(this._dragSrc,"dragstart")}if(this._dragRunning){let t=this;requestAnimationFrame(function(){t._touchEndCalled||t._dragCopy===null||(t._dragCopy.style.top=e.clientY-t._copyOffset.y+"px",t._dragCopy.style.left=e.clientX-t._copyOffset.x+"px")});let r=this._findDroppable(s);r!=this._lastTarget&&(this._dispatchEvent(r,"dragenter"),this._dispatchEvent(this._lastTarget,"dragleave"),this._lastTarget=r),this._currentDropContainer=r,this._currentDropContainer&&this._dispatchEvent(r,"dragover")}};return c._instance?c._instance:(c._instance=this,document.addEventListener("touchmove",this._touchMove.bind(this),{passive:!1,capture:!1}),document.addEventListener("mousemove",this._touchMove.bind(this),{passive:!1,capture:!1}),document.addEventListener("touchend",this._touchEnd.bind(this),{passive:!1,capture:!1}),document.addEventListener("mouseup",this._touchEnd.bind(this),{passive:!1,capture:!1}),document.addEventListener("touchcancel",this._touchCancel.bind(this),{passive:!1,capture:!1}),this)}addDraggables(s){s.forEach(e=>{e.addEventListener("touchstart",this._touchStart.bind(this),{passive:!1,capture:!1}),e.addEventListener("mousedown",this._touchStart.bind(this),{passive:!1,capture:!1})})}_touchStart(s){this._touchBegin=Date.now();let{x:e,y:t}=this._getPoint(s);if(this._touchDown={x:e,y:t},this._dragSrc=s.currentTarget,this._canDrag=!0,this.dragOnClick){let r={clientX:e,clientY:t};this._dragRunning=!0,this._createDragCopy(s,r)}s.preventDefault()}_touchMove(s){if(this._canDrag&&this._dragSrc){let{x:e,y:t}=this._getPoint(s),r={clientX:e,clientY:t};this._getDelta(r)>=this._DRAGDELTA&&(this._dragRunning=!0),this._createDragCopy(s,r),s.preventDefault()}}_touchEnd(s){var e;if(this._touchEndCalled=!0,this._canDrag=!1,this._currentDropContainer)this._dispatchEvent(this._currentDropContainer,"drop"),this._dispatchEvent(this._dragSrc,"dragend");else if(this._dragRunning){let t=new CustomEvent("dragend",{bubbles:!0,cancelable:!0});t.dataTransfer={dropEffect:"none"},(e=this._dragSrc)==null||e.dispatchEvent(t)}this._reset()}_touchCancel(s){this._reset()}_findDroppable(s){let e=this._getPoint(s),t=new Set;return this.getElementWithDropzone(document,e.x,e.y,t)}getElementWithDropzone(s,e,t,r){let o=s.elementFromPoint(e,t);if(o){if(r.has(o))return null;if(r.add(o),o.hasAttribute("dropzone"))return o;if(o.shadowRoot){let n=this.getElementWithDropzone(o.shadowRoot,e,t,r);if(n)return n}return o}return null}_getPoint(s,e){return s&&s.touches&&(s=s.touches[0]),{x:e?s.pageX:s.clientX,y:e?s.pageY:s.clientY}}_calculateDragCopyPosition(s){let e=this._dragSrc.getBoundingClientRect();this._copyOffset.x=s.clientX-e.left,this._copyOffset.y=s.clientY-e.top}_getDelta(s){let e=Math.abs(s.clientX-this._touchDown.x),t=Math.abs(s.clientY-this._touchDown.y);return e+t}_dispatchEvent(s,e,t=!0){if(!s)return!1;let r=new CustomEvent(e,{bubbles:t,cancelable:!0});return r.dataTransfer=this._dataTransfer,s.dispatchEvent(r),r.defaultPrevented}_reset(){this._dragRunning&&(this._dragSrc.style.opacity="1.0",this._dragCopy.parentElement.removeChild(this._dragCopy)),this._dragRunning=!1,this._dragSrc=null,this._dragCopy=null,this._canDrag=!1,this._touchBegin=0,this._touchDown=null,this._lastClick=0,this._touchEndCalled=!1,this._dataTransfer={data:{},setData:function(s,e){this.data[s]=e},getData:function(s){return this.data[s]},effectAllowed:"move"},this._copyOffset={x:0,y:0},this._lastTarget=null,this._currentDropContainer=null,this._handleClick=!0}};import{property as hi}from"lit/decorators.js";var zt=(c,s,e)=>{class t extends c{constructor(){super(...arguments);this.disabled=!1}firstUpdated(n){if(this.classList.contains("qti-match-tabular"))return;super.firstUpdated(n);let a=Array.from(s?this.shadowRoot.querySelectorAll(e):this.querySelectorAll(e));this.dragoverHandler=this.dragoverHandler.bind(this),this.dragleaveHandler=this.dragleaveHandler.bind(this),this.dragenterHandler=this.dragenterHandler.bind(this),this.dropHandler=this.dropHandler.bind(this),a.forEach(l=>{l.setAttribute("dropzone","move"),l.addEventListener("dragleave",this.dragleaveHandler),this.attachHandler(l)});for(let l of a)this.observer=new MutationObserver(p=>{p.forEach(d=>{if(d.type==="attributes")switch(d.attributeName){case"disabled":{l.hasAttribute("disabled")?this.removeHandler(l):this.attachHandler(l);break}}})}),this.observer.observe(l,{attributes:!0})}attachHandler(n){n.addEventListener("dragover",this.dragoverHandler),n.addEventListener("dragenter",this.dragenterHandler),n.addEventListener("drop",this.dropHandler)}removeHandler(n){n.removeEventListener("dragover",this.dragoverHandler),n.removeEventListener("dragenter",this.dragenterHandler),n.removeEventListener("drop",this.dropHandler)}disconnectedCallback(){var n;this.classList.contains("qti-match-tabular")||(super.disconnectedCallback(),(n=this.observer)==null||n.disconnect())}dragenterHandler(n){n.preventDefault()}dragoverHandler(n){return n.preventDefault(),n.currentTarget.setAttribute("active",""),n.dataTransfer.dropEffect="move",!1}dropHandler(n){n.preventDefault();let a=n.currentTarget,l=this.querySelector(`[identifier=${n.dataTransfer.getData("text")}`),p=l||this.shadowRoot.querySelector(`[identifier=${n.dataTransfer.getData("text")}`);return a?p.parentElement.getAttribute("identifier")!==a.getAttribute("identifier")&&a.appendChild(p):console.error(`cannot find droppable, target: ${n.target?JSON.stringify(n.target):"null"}`),a.removeAttribute("active"),!1}dragleaveHandler(n){return n.preventDefault(),n.currentTarget.removeAttribute("active"),n.dataTransfer.dropEffect="none",!1}}return i([hi({type:Boolean,reflect:!0})],t.prototype,"disabled",2),t};var Wt=(c,s,e)=>{class t extends c{}return t};import{property as Q}from"lit/decorators.js";var H=(c,s,e,t)=>{class r extends Wt(zt(c,e,t),t,s){constructor(){super(...arguments);this.draggables=new Map;this.responseIdentifier="";this.configuration={copyStylesDragClone:!0,dragCanBePlacedBack:!0,dragOnClick:!1};this.disabled=!1;this.readonly=!1;this.minAssociations=1;this.maxAssociations=1;this.handleDragStart=a=>{a.dataTransfer.setData("text",a.currentTarget.getAttribute("identifier")),a.currentTarget.setAttribute("dragging",""),this.droppables.forEach(l=>l.setAttribute("enabled",""))};this.handleDragEnd=a=>{a.preventDefault(),this.droppables.forEach(p=>p.removeAttribute("enabled"));let l=a.currentTarget;l.removeAttribute("over"),l.removeAttribute("dragging"),(a.dataTransfer.dropEffect==="none"||a.dataTransfer.dropEffect===void 0)&&this.configuration.dragCanBePlacedBack&&this.placeDraggableBack(l),a.dataTransfer.dropEffect==="move"&&(this.saveResponse(),this.checkMaxMatchAssociations())}}reInitDragAndDrop(a,l){if(this.classList.contains("qti-match-tabular"))return;a.filter(d=>!this.draggables||!this.draggables.get(d)).length>0&&(this.dragDropApi.addDraggables(a),a.forEach(d=>{this.draggables.set(d,{parent:d.parentElement,index:Array.from(d.parentNode.children).indexOf(d)}),d.setAttribute("qti-draggable","true"),d.addEventListener("dragstart",this.handleDragStart),d.addEventListener("dragend",this.handleDragEnd)}))}handleDragOptionsChanged(a,l){this.dragDropApi.copyStylesDragClone=l.copyStylesDragClone,this.dragDropApi.dragOnClick=l.dragOnClick}handleDisabledChange(a,l){this.draggables.forEach((p,d)=>{l?d.setAttribute("disabled",""):d.removeAttribute("disabled"),l?d.removeAttribute("qti-draggable"):d.setAttribute("qti-draggable","true")})}handleReadonlyChange(a,l){this.draggables.forEach((p,d)=>{l?d.setAttribute("readonly",""):d.removeAttribute("readonly"),l?d.removeAttribute("qti-draggable"):d.setAttribute("qti-draggable","true")})}firstUpdated(a){super.firstUpdated(a),this.droppables=Array.from(e?this.shadowRoot.querySelectorAll(t):this.querySelectorAll(t))}connectedCallback(){super.connectedCallback(),this.dragDropApi=new We,this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,composed:!0,detail:this}))}placeDraggableBack(a){let l=this.draggables.get(a),p=l.index<=l.parent.children.length?l.index:l.parent.children.length-1,d=l.parent,h=l.parent.children[p];d.insertBefore(a,h),this.saveResponse(),this.checkMaxMatchAssociations()}reset(a=!0){this.draggables.forEach((l,p)=>{let d=l.parent.children,h=l.index<d.length?l.index:d.length;l.parent.insertBefore(p,d[h])}),a&&this.saveResponse()}checkMaxMatchAssociations(){this.droppables.forEach(a=>{let p=+(a.getAttribute("match-max")||1)<=(a.querySelectorAll('[qti-draggable="true"]').length||0);p?a.setAttribute("disabled",""):a.removeAttribute("disabled"),p?a.removeAttribute("dropzone"):a.setAttribute("dropzone","move")})}set response(a){this.classList.contains("qti-match-tabular")||(this.reset(!1),a!==null&&Array.isArray(a)&&a.forEach(l=>{let[p,...d]=l.split(" ").reverse();if(p){let h=this.droppables.find(m=>m.getAttribute("identifier")===p);d.forEach(m=>{let f=this.querySelector(`[identifier=${m}]`);h?f?(h.appendChild(f),this.checkMaxMatchAssociations()):console.error(`cannot find draggable with identifier: ${m}`):console.error(`cannot find droppable with identifier: ${p}`)})}}))}validate(){let l=(e?Array.from(this.shadowRoot.querySelectorAll(t)):Array.from(this.querySelectorAll(t))).filter(p=>p.childElementCount>0).length;return this.minAssociations<=0||this.minAssociations<=l}saveResponse(){let a;typeof this.getResponse=="function"?a=this.getResponse():a=this.droppables.map(l=>{let p=l.querySelectorAll('[qti-draggable="true"]'),d=Array.from(p).map(m=>m.getAttribute("identifier")),h=l.getAttribute("identifier");return[...d,h].join(" ")}),this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:a}}))}}return i([Dt(s)],r.prototype,"reInitDragAndDrop",1),i([Q({type:String,attribute:"response-identifier"})],r.prototype,"responseIdentifier",2),i([Q({attribute:!1,type:Object})],r.prototype,"configuration",2),i([v("configuration")],r.prototype,"handleDragOptionsChanged",1),i([Q({type:Boolean,reflect:!0})],r.prototype,"disabled",2),i([v("disabled",{waitUntilFirstUpdate:!0})],r.prototype,"handleDisabledChange",1),i([Q({type:Boolean,reflect:!0})],r.prototype,"readonly",2),i([v("readonly",{waitUntilFirstUpdate:!0})],r.prototype,"handleReadonlyChange",1),i([Q({type:Number,reflect:!0,attribute:"min-associations"})],r.prototype,"minAssociations",2),i([Q({type:Number,reflect:!0,attribute:"max-associations"})],r.prototype,"maxAssociations",2),r};var ee=class extends H(fi,"qti-simple-associable-choice",!0,".dl"){render(){return Jt` <slot name="prompt"></slot>
194
- <slot name="qti-simple-associable-choice"></slot>
195
- <div part="drop-container">
196
- ${this._childrenMap.length>0&&Array.from(Array(Math.ceil(this._childrenMap.length/2)).keys()).map((s,e)=>Jt`<div part="associables-container">
197
- <div name="left${e}" part="drop-list" class="dl" identifier="droplist${e}_left"></div>
198
- <div name="right${e}" part="drop-list" class="dl" identifier="droplist${e}_right"></div>
199
- </div>`)}
200
- </div>`}connectedCallback(){super.connectedCallback(),this._childrenMap=Array.from(this.querySelectorAll("qti-simple-associable-choice"))}};ee.styles=gi`
201
- :host {
202
- display: block; /* necessary to calculate scaling position */
203
- }
204
- slot[name='qti-simple-associable-choice'] {
205
- display: flex;
206
- flex-wrap: wrap;
207
- gap: 0.5rem;
208
- }
209
- `,i([vi()],ee.prototype,"_childrenMap",2),ee=i([bi("qti-associate-interaction")],ee);import{html as Zt}from"lit";import{customElement as yi,property as ye,state as xi}from"lit/decorators.js";var V=class extends g{constructor(){super();this._errorMessage=null;this.handlePostMessage=this.handlePostMessage.bind(this)}connectedCallback(){super.connectedCallback();let e=this.data.startsWith("http")?this.data:de(this.baseItemUrl+"/"+this.data);fetch(e).then(t=>t.json()).then(t=>{this.manifest=t,this.setupCES()}).catch(t=>{this._errorMessage=t})}setupCES(){let e=this.shadowRoot.querySelector("#pciContainer"),t=e.contentWindow||e,r=e.contentDocument;window.addEventListener("message",this.handlePostMessage),r.open(),r.write(`
210
- <html>
211
- <head>
212
- <link href='${de(`${this.baseRefUrl}/${this.manifest.style[0]}`)}' rel="stylesheet" />
213
- <script src='${de(`${this.baseRefUrl}/${this.manifest.script[0]}`)}'></script>
214
- </head>
215
- <body></body>
216
- </html>
217
- `),r.close()}getIFrames(){let e=this.shadowRoot.querySelectorAll("iframe"),t=this.querySelectorAll("iframe"),r=[...e,...t];for(let o of r){let n=o.src;if(new URL(n,window.location.href).origin===window.location.origin)try{let l=o.contentDocument||o.contentWindow.document;l&&this.getInnerIFrames(l,r)}catch(l){console.error("Error accessing nested iframe:",l)}}return r.forEach((o,n)=>{r.indexOf(o)!==n&&r.splice(n,1)}),r}getInnerIFrames(e,t=[]){return e.querySelectorAll("iframe").forEach(o=>{t.push(o);let n=o.src;if(new URL(n,window.location.href).origin===window.location.origin)try{let l=o.contentDocument||o.contentWindow.document;this.getInnerIFrames(l,t)}catch(l){console.error("Error accessing nested iframe:",l)}else console.warn("Skipped cross-origin iframe:",n)}),t}postToWindowAndIframes(e,t){window.postMessage({type:e,data:t},"*");let r=this.getIFrames();for(let o of r)o.contentWindow&&o.contentWindow.postMessage({type:e,data:t},"*")}handlePostMessage(e){let{type:t,data:r}=e.data;switch(t){case"setResponse":this.rawResponse=r,this.saveResponse(r);break;case"getResponse":{this.postToWindowAndIframes("responseData",this.rawResponse);break}case"getMedia":{let o=this.manifest.media.map(n=>n.startsWith("http")?n:de(this.baseRefUrl+"/"+n));this.postToWindowAndIframes("mediaData",o);break}case"setStageHeight":console.log("setStageHeight not implemented");break}}validate(){return this.rawResponse!==""}set response(e){this.rawResponse=e}disconnectedCallback(){window.removeEventListener("message",this.handlePostMessage),super.disconnectedCallback()}render(){return Zt`<iframe
218
- width=${this.getAttribute("width")}
219
- height=${this.getAttribute("height")}
220
- frameborder="0"
221
- title="pciContainer"
222
- id="pciContainer"
223
- >
224
- </iframe>
225
- ${this._errorMessage&&Zt`<div style="color:red">
226
- <h1>Error</h1>
227
- ${this._errorMessage}
228
- </div>`}`}};i([ye({type:String,attribute:"response-identifier"})],V.prototype,"responseIdentifier",2),i([ye({type:String,attribute:"data"})],V.prototype,"data",2),i([ye({type:String,attribute:"data-base-item"})],V.prototype,"baseItemUrl",2),i([ye({type:String,attribute:"data-base-ref"})],V.prototype,"baseRefUrl",2),i([ye({type:String,attribute:"id"})],V.prototype,"id",2),i([xi()],V.prototype,"_errorMessage",2),V=i([yi("qti-custom-interaction")],V);import{html as Ei}from"lit";import{customElement as qi,property as Gt}from"lit/decorators.js";var te=class extends g{constructor(){super(...arguments);this.countAttempt="true"}validate(){return!0}set response(e){}render(){return Ei`<button ?disabled=${this.disabled} part="button" @click=${this.endAttempt}>${this.title}</button>`}endAttempt(e){this.dispatchEvent(new CustomEvent("end-attempt",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,countAttempt:this.countAttempt==="true"}}))}};i([Gt({type:String,attribute:"count-attempt"})],te.prototype,"countAttempt",2),i([Gt({type:String})],te.prototype,"title",2),te=i([qi("qti-end-attempt-interaction")],te);import{css as Ci,html as _i,LitElement as ki}from"lit";import{customElement as Ti}from"lit/decorators.js";var xe=class extends H(ki,"qti-gap-text",!1,"qti-gap"){render(){return _i` <slot part="drags" name="qti-gap-text"></slot>
229
- <slot part="drops"></slot>`}set correctResponse(s){let e=[],t=Array.isArray(s)?s:[s];t&&(e=t.map(o=>{let n=o.split(" ");return{text:n[0],gap:n[1]}})),this.querySelectorAll("qti-gap").forEach((o,n)=>{var d,h,m,f;let a=o.getAttribute("identifier"),l=(d=e.find(_=>_.gap===a))==null?void 0:d.text,p=(h=this.querySelector(`qti-gap-text[identifier="${l}"]`))==null?void 0:h.textContent.trim();if(l&&p){if(!((m=o.nextElementSibling)!=null&&m.classList.contains("correct-option"))){let _=document.createElement("span");_.classList.add("correct-option"),_.textContent=p,o.insertAdjacentElement("afterend",_)}}else(f=o.nextElementSibling)!=null&&f.classList.contains("correct-option")&&o.nextElementSibling.remove()})}};xe.styles=[Ci`
230
- :host {
231
- display: flex;
232
- align-items: flex-start;
233
- flex-direction: column;
234
- gap: 0.5rem;
235
- }
236
-
237
- :host(.qti-choices-top) {
238
- flex-direction: column;
239
- }
240
- :host(.qti-choices-bottom) {
241
- flex-direction: column-reverse;
242
- }
243
- :host(.qti-choices-left) {
244
- flex-direction: row;
245
- }
246
- :host(.qti-choices-right) {
247
- flex-direction: row-reverse;
248
- }
249
- /* [part='drops'] , */
250
- [part='drags'] {
251
- display: flex;
252
- align-items: flex-start;
253
- flex: 1;
254
- gap: 0.5rem;
255
- }
256
- `],xe=i([Ti("qti-gap-match-interaction")],xe);import{css as wi,html as Ri,svg as Qt}from"lit";import{customElement as Ai,query as Si,queryAssignedElements as Li,state as Rt}from"lit/decorators.js";import{ifDefined as er}from"lit/directives/if-defined.js";import{repeat as Mi}from"lit/directives/repeat.js";function re(c,s,e,t){switch(c){case"circle":{let[r,o,n]=s,a=r/e.width*100,l=o/e.height*100,p=n/e.width*100;t.style.left=a-p+"%",t.style.top=l-p+"%",t.style.width=t.style.height=4*p+"px",t.style.borderRadius="9999px"}break;case"rect":{let[r,o,n,a]=s,l=r/e.width*100,p=o/e.height*100,d=n/e.width*100,h=a/e.height*100;t.style.left=l+"%",t.style.top=p+"%",t.style.width=d-l+"%",t.style.height=h-p+"%"}break;case"poly":{let r=s.reduce((y,j,Mt,lr)=>{if(Mt%2===1){let cr=y.pop();y[y.length]={x:cr,y:lr[Mt]}}else y.push(j);return y},[]),o=Math.min(...r.map(y=>y.x)),n=Math.max(...r.map(y=>y.x)),a=Math.min(...r.map(y=>y.y)),l=Math.max(...r.map(y=>y.y)),p=o/e.width*100,d=a/e.height*100,h=n/e.width*100,m=l/e.height*100;t.style.left=o/e.width*100+"%",t.style.top=a/e.height*100+"%",t.style.width=h-p+"%",t.style.height=m-d+"%";let _=r.map(y=>({x:(y.x-o)/(n-o)*100,y:(y.y-a)/(l-a)*100})).map(y=>Math.round(y.x)+"% "+Math.round(y.y)+"%").join(",");t.style.clipPath=`polygon(${_})`}break;default:break}}var $=class extends g{constructor(){super();this.startPoint=null;this.endPoint=null;this._lines=[];this.addEventListener("qti-register-hotspot",this.positionHotspotOnRegister)}reset(){this._lines=[]}validate(){return this._lines.length>0}set response(e){Array.isArray(e)&&(this._lines=e)}render(){var e,t,r,o;return Ri`<slot name="prompt"></slot>
257
- <line-container>
258
- <svg
259
- width=${er((e=this.grImage[0])==null?void 0:e.width)}
260
- height=${er((t=this.grImage[0])==null?void 0:t.height)}
261
- viewbox="0 0 ${(r=this.grImage[0])==null?void 0:r.width} ${(o=this.grImage[0])==null?void 0:o.height}"
262
- >
263
- ${Mi(this._lines,n=>n,(n,a)=>Qt`
264
- <line
265
- part="line"
266
- x1=${parseInt(this.querySelector("[identifier="+n.split(" ")[0]+"]").style.left)}
267
- y1=${parseInt(this.querySelector("[identifier="+n.split(" ")[0]+"]").style.top)}
268
- x2=${parseInt(this.querySelector("[identifier="+n.split(" ")[1]+"]").style.left)}
269
- y2=${parseInt(this.querySelector("[identifier="+n.split(" ")[1]+"]").style.top)}
270
- stroke="red"
271
- stroke-width="3"
272
- @click=${l=>{l.stopPropagation(),this._lines=this._lines.filter((p,d)=>d!==a),this.saveResponse(this._lines)}}
273
- />
274
- `)}
275
- ${this.startPoint&&Qt`<line
276
- part="point"
277
- x1=${this.startCoord.x}
278
- y1=${this.startCoord.y}
279
- x2=${this.mouseCoord.x}
280
- y2=${this.mouseCoord.y}
281
- stroke="red"
282
- stroke-width="3"
283
- />`}
284
- </svg>
285
- <slot></slot>
286
- </line-container>`}positionHotspotOnRegister(e){let t=this.querySelector("img"),r=e.target,o=r.getAttribute("coords"),n=r.getAttribute("shape"),a=o.split(",").map(l=>parseInt(l));re(n,a,t,r)}firstUpdated(e){super.firstUpdated(e),this.hotspots=this.querySelectorAll("qti-associable-hotspot"),document.addEventListener("mousemove",t=>{this.mouseCoord={x:t.clientX-this.grImage[0].getBoundingClientRect().left,y:t.clientY-this.grImage[0].getBoundingClientRect().top}}),this.hotspots.forEach(t=>{t.style.left=t.getAttribute("coords").split(",")[0]+"px",t.style.top=t.getAttribute("coords").split(",")[1]+"px",t.addEventListener("click",r=>{this.startPoint?this.endPoint||(this.endPoint=r.target,this._lines=[...this._lines,this.startPoint.getAttribute("identifier")+" "+this.endPoint.getAttribute("identifier")],this.saveResponse(this._lines),this.startPoint=null,this.endPoint=null):(this.startPoint=r.target,this.startCoord={x:this.startPoint.getAttribute("coords").split(",")[0],y:this.startPoint.getAttribute("coords").split(",")[1]})})})}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-register-hotspot",this.positionHotspotOnRegister)}};$.styles=[wi`
287
- slot:not([name='prompt']) {
288
- // position: relative; /* qti-hotspot-choice relative to the slot */
289
- display: block;
290
- width: fit-content; /* hotspots not stretching further if image is at max size */
291
- }
292
- ::slotted(img) {
293
- /* image not selectable anymore */
294
- pointer-events: none;
295
- user-select: none;
296
- }
297
- ::slotted(qti-associable-hotspot) {
298
- transform: translate(-50%, -50%);
299
- }
300
- line-container {
301
- display: block;
302
- position: relative;
303
- }
304
- svg {
305
- position: absolute;
306
- top: 0px;
307
- left: 0px;
308
- }
309
- `],i([Rt()],$.prototype,"_lines",2),i([Rt()],$.prototype,"startCoord",2),i([Rt()],$.prototype,"mouseCoord",2),i([Si("svg")],$.prototype,"svgContainer",2),i([Li({selector:"img"})],$.prototype,"grImage",2),$=i([Ai("qti-graphic-associate-interaction")],$);import{css as Ni,html as Hi,LitElement as Vi}from"lit";import{customElement as $i}from"lit/decorators.js";var Ee=class extends H(Vi,"qti-gap-img",!1,"qti-associable-hotspot"){render(){return Hi` <slot></slot>
310
- <slot name="qti-gap-img"></slot>`}positionHotspotOnRegister(s){let e=this.querySelector("img"),t=s.target,r=t.getAttribute("coords"),o=t.getAttribute("shape"),n=r.split(",").map(a=>parseInt(a));switch(o){case"circle":{let[a,l,p]=n;t.style.left=a-p+"px",t.style.top=l-p+"px",t.style.width=t.style.height=2*p+"px"}break;case"rect":{let[a,l,p,d]=n;t.style.left=a+"px",t.style.top=l+"px",t.style.width=p-a+"px",t.style.height=d-l+"px"}break;default:break}}connectedCallback(){super.connectedCallback(),this.addEventListener("qti-register-hotspot",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-register-hotspot",this.positionHotspotOnRegister)}};Ee.styles=Ni`
311
- :host {
312
- display: inline-block;
313
- position: relative;
314
- }
315
- slot[name='qti-gap-img'] {
316
- display: flex;
317
- gap: 1rem;
318
- }
319
- `,Ee=i([$i("qti-graphic-gap-match-interaction")],Ee);import{css as Di,html as Oi,LitElement as Pi}from"lit";import{customElement as Ii}from"lit/decorators.js";var qe=class extends I(Pi,"qti-hotspot-choice"){render(){return Oi`
320
- <slot name="prompt"></slot>
321
- <!-- slot for the prompt -->
322
- <slot></slot>
323
- <!-- slot for the image and hotspots -->
324
- `}setHotspotOrder(s){let{identifier:e}=s.detail,t=this._choiceElements.find(o=>o.getAttribute("identifier")===e),r=this._choiceElements.length;if(!this.choiceOrdering){if(this.choiceOrdering=!0,t.order==null){if(this._choiceElements.filter(o=>o.order>0).length>=r){this.choiceOrdering=!1;return}t.order=this._choiceElements.filter(o=>!!o.order).length+1,this.choiceOrdering=!1;return}else this._choiceElements.forEach(o=>(o.order>o.order&&o.order--,o)),t.order=null;this.choiceOrdering=!1}}positionHotspotOnRegister(s){let e=this.querySelector("img"),t=s.target,r=t.getAttribute("coords"),o=t.getAttribute("shape"),n=r.split(",").map(a=>parseInt(a));re(o,n,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("qti-choice-element-selected",this.setHotspotOrder),this.addEventListener("qti-register-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-choice-element-selected",this.setHotspotOrder),this.removeEventListener("qti-register-choice",this.positionHotspotOnRegister)}};qe.styles=[Di`
325
- slot:not([name='prompt']) {
326
- position: relative; /* qti-hotspot-choice relative to the slot */
327
- display: block;
328
- width: fit-content; /* hotspots not stretching further if image is at max size */
329
- }
330
- ::slotted(img) {
331
- /* image not selectable anymore */
332
- pointer-events: none;
333
- user-select: none;
334
- }
335
- `],qe=i([Ii("qti-graphic-order-interaction")],qe);import{css as Ui,html as Fi,LitElement as Bi}from"lit";import{customElement as Xi}from"lit/decorators.js";var Ce=class extends I(Bi,"qti-hotspot-choice"){render(){return Fi`
336
- <slot name="prompt"></slot>
337
- <!-- slot for the prompt -->
338
- <slot></slot>
339
- <!-- slot for the image and hotspots -->
340
- `}positionHotspotOnRegister(s){let e=this.querySelector("img"),t=s.target,r=t.getAttribute("coords"),o=t.getAttribute("shape"),n=r.split(",").map(a=>parseInt(a));re(o,n,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("qti-register-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-register-choice",this.positionHotspotOnRegister)}};Ce.styles=[Ui`
341
- slot:not([name='prompt']) {
342
- position: relative; /* qti-hotspot-choice relative to the slot */
343
- display: block;
344
- width: fit-content; /* hotspots not stretching further if image is at max size */
345
- }
346
- ::slotted(img) {
347
- /* image not selectable anymore */
348
- pointer-events: none;
349
- user-select: none;
350
- /* width:100%; */
351
- }
352
- `],Ce=i([Xi("qti-hotspot-interaction")],Ce);import{css as Wi,html as _e,LitElement as Ji}from"lit";import{customElement as Zi,property as Gi,state as tr}from"lit/decorators.js";import{unsafeHTML as rr}from"lit/directives/unsafe-html.js";import{css as Yi,html as ji,LitElement as Ki}from"lit";import{customElement as zi,property as At}from"lit/decorators.js";var B=class extends Ki{constructor(){super(...arguments);this.matchMin=0;this.matchMax=1;this.fixed=!1}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-simple-associable-choice"),this.setAttribute("part","qti-simple-associable-choice")}render(){return ji`
353
- <slot part="slot"></slot>
354
- <slot part="dropslot" name="qti-simple-associable-choice"></slot>
355
- `}};B.styles=Yi`
356
- :host {
357
- display: flex;
358
- user-select: none;
359
- }
360
- slot {
361
- width: 100%;
362
- display: block;
363
- }
364
- slot[name='qti-simple-associable-choice'] {
365
- width: 100%;
366
- }
367
- `,i([At({type:Number,attribute:"match-min"})],B.prototype,"matchMin",2),i([At({type:Number,attribute:"match-max"})],B.prototype,"matchMax",2),i([At({type:Boolean,attribute:"fixed"})],B.prototype,"fixed",2),B=i([zi("qti-simple-associable-choice")],B);var X=class extends H(Ji,"qti-simple-match-set:first-of-type qti-simple-associable-choice",!1,"qti-simple-match-set:last-of-type qti-simple-associable-choice"){constructor(){super(...arguments);this.lastCheckedRadio=null;this.response=[];this.correctOptions=[];this.responseIdentifier="";this.handleRadioClick=e=>{let t=e.target;this.lastCheckedRadio===t?(t.checked=!1,this.lastCheckedRadio=null,this.handleRadioChange(e)):this.lastCheckedRadio=t};this.handleRadioChange=e=>{let t=e.target,r=t.value,o=t.name,n=t.type;t.checked?(this.response?this.response.indexOf(r)===-1&&(n==="radio"&&(this.response=this.response.filter(a=>a.indexOf(o)===-1)),this.response=[...this.response,r]):this.response=[r],this.lastCheckedRadio=t):(this.response=this.response.filter(a=>a!==r),this.lastCheckedRadio=null),this.requestUpdate(),this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:Array.isArray(this.response)?[...this.response]:this.response}}))}}connectedCallback(){super.connectedCallback(),this.rows=Array.from(this.querySelectorAll("qti-simple-match-set:first-of-type qti-simple-associable-choice")),this.cols=Array.from(this.querySelectorAll("qti-simple-match-set:last-of-type qti-simple-associable-choice")),this.response=[]}set correctResponse(e){if(e===""){this.correctOptions=[];return}else Array.isArray(e)&&(this.correctOptions=e)}render(){return this.classList.contains("qti-match-tabular")?_e`
368
- <slot name="prompt"></slot>
369
- <table>
370
- <tr>
371
- <td></td>
372
- ${this.cols.map((e,t)=>_e`<th part="r-header">${rr(e.innerHTML)}</th>`)}
373
- </tr>
374
-
375
- ${this.rows.map((e,t)=>_e`<tr>
376
- <td part="c-header">${rr(e.innerHTML)}</td>
377
- ${this.cols.map((r,o)=>{let n=e.getAttribute("identifier"),a=r.getAttribute("identifier"),l=`${n} ${a}`,p=this.response.filter(f=>f.split(" ")[0]===n).length||0,d=this.response.includes(l),h=`rb ${d?"rb-checked":""} ${this.correctOptions.includes(l)?"rb-correct":""}`,m=this.correctOptions.length>0?!0:e.matchMax===1?!1:p>=e.matchMax&&!d;return _e`<td>
378
- <input
379
- type=${e.matchMax===1?"radio":"checkbox"}
380
- part=${h}
381
- name=${n}
382
- value=${l}
383
- .disabled=${m}
384
- @change=${f=>this.handleRadioChange(f)}
385
- @click=${f=>e.matchMax===1?this.handleRadioClick(f):null}
386
- />
387
- </td>`})}
388
- </tr>`)}
389
- </table>
390
- `:_e`<slot name="prompt"></slot> <slot class=".match"></slot>`}};X.styles=[Wi`
391
- .match {
392
- display: flex;
393
- flex-direction: column;
394
- gap: 0.5rem;
395
- }
396
-
397
- :host(.qti-choices-top) .match {
398
- flex-direction: column;
399
- }
400
- :host(.qti-choices-bottom) .match {
401
- flex-direction: column-reverse;
402
- }
403
- :host(.qti-choices-left) .match {
404
- flex-direction: row;
405
- }
406
- :host(.qti-choices-right) .match {
407
- flex-direction: row-reverse;
408
- }
409
- slot[name='prompt'] {
410
- display: block;
411
- }
412
- `],i([tr()],X.prototype,"response",2),i([tr()],X.prototype,"correctOptions",2),i([Gi({type:String,attribute:"response-identifier"})],X.prototype,"responseIdentifier",2),X=i([Zi("qti-match-interaction")],X);import{css as Qi,html as eo}from"lit";import{customElement as to}from"lit/decorators.js";var ke=class extends g{constructor(){super();this.value=0}reset(){}validate(){return!0}set response(e){}static get properties(){return q(b({},g.properties),{step:{type:Number,attribute:"step",default:10}})}render(){return eo` <slot name="prompt"></slot>
413
- <slot></slot>`}connectedCallback(){super.connectedCallback();let e=this.querySelector("audio")||this.querySelector("video")||this.querySelector("object");e&&e.addEventListener("ended",()=>{this.value++,this.saveResponse(this.value.toString())})}};ke.styles=[Qi``],ke=i([to("qti-media-interaction")],ke);import{css as ro,html as sr,LitElement as so}from"lit";import{customElement as io,property as oo,state as St}from"lit/decorators.js";import{unsafeHTML as no}from"lit/directives/unsafe-html.js";var O=class extends Ue(H(so,"qti-simple-choice",!0,"drop-list"),"qti-simple-choice"){constructor(){super(...arguments);this.nrChoices=0;this.correctResponses=[];this.showCorrectResponses=!1}render(){let e=Array.from(this.querySelectorAll("qti-simple-choice"));return this.nrChoices<e.length&&(this.nrChoices=e.length),sr` <slot name="prompt"> </slot>
414
- <div part="container">
415
- <slot part="drags"> </slot>
416
- <div part="drops">
417
- ${Array.from(Array(this.nrChoices)).map((t,r)=>sr`<drop-list part="drop-list" identifier="droplist${r}"></drop-list>${this.showCorrectResponses&&this.correctResponses.length>r?no(`<span part='correct-response'>${this.correctResponses[r]}</span>`):""}`)}
418
- </div>
419
- </div>`}set correctResponse(e){if(e===""){this.showCorrectResponses=!1;return}this.correctResponses.length===0&&(Array.isArray(e)?e:[e]).forEach((r,o)=>{let n=this.querySelector(`qti-simple-choice[identifier="${r}"]`);n||(n=this.shadowRoot.querySelector(`qti-simple-choice[identifier="${r}"]`));let a=n==null?void 0:n.textContent.trim();this.correctResponses=[...this.correctResponses,a]}),this.showCorrectResponses=!0}getResponse(){return Array.from(this.shadowRoot.querySelectorAll("drop-list")).map(r=>{let o=r.querySelectorAll('[qti-draggable="true"]');return[...Array.from(o).map(a=>a.getAttribute("identifier"))].join(" ")})}async firstUpdated(e){super.firstUpdated(e),this.childrenMap=Array.from(this.querySelectorAll("qti-simple-choice")),this.childrenMap.forEach(t=>t.setAttribute("part","qti-simple-choice"))}};O.styles=[ro`
420
- [part='drags'] {
421
- display: flex;
422
- align-items: flex-start;
423
- flex: 1;
424
- }
425
-
426
- [part='drops'] {
427
- flex: 1;
428
- display: grid;
429
- grid-auto-flow: column;
430
- grid-auto-columns: 1fr;
431
- }
432
-
433
- :host([orientation='horizontal']) [part='drags'] {
434
- flex-direction: row;
435
- }
436
- :host([orientation='horizontal']) [part='drops'] {
437
- grid-auto-flow: column;
438
- }
439
- :host([orientation='vertical']) [part='drags'] {
440
- flex-direction: column;
441
- }
442
- :host([orientation='vertical']) [part='drops'] {
443
- grid-auto-flow: row;
444
- }
445
-
446
- [part='drop-list'] {
447
- display: block;
448
- flex: 1;
449
- }
450
-
451
- [part='container'] {
452
- display: flex;
453
- gap: 0.5rem;
454
- }
455
- :host(.qti-choices-top) [part='container'] {
456
- flex-direction: column;
457
- }
458
- :host(.qti-choices-bottom) [part='container'] {
459
- flex-direction: column-reverse;
460
- }
461
- :host(.qti-choices-left) [part='container'] {
462
- flex-direction: row;
463
- }
464
- :host(.qti-choices-right) [part='container'] {
465
- flex-direction: row-reverse;
466
- }
467
- `],i([St()],O.prototype,"nrChoices",2),i([St()],O.prototype,"correctResponses",2),i([St()],O.prototype,"showCorrectResponses",2),i([oo({type:String})],O.prototype,"orientation",2),O=i([io("qti-order-interaction")],O);import{LitElement as ao,css as lo,html as co}from"lit";var Je=class extends ao{render(){return co`<slot></slot>`}};Je.styles=[lo`
468
- :host {
469
- display: block;
470
- }
471
- ::slotted(img) {
472
- position: absolute;
473
- cursor: move;
474
- user-select: none;
475
- left: 50%;
476
- transform: translateX(-50%);
477
- }
478
- `];customElements.define("qti-position-object-interaction",Je);import{LitElement as po,css as uo,html as mo}from"lit";import{customElement as ho}from"lit/decorators.js";var Te=class extends po{render(){return mo`<slot></slot>`}constructor(){super(),this.removeMoveListener=this.removeMoveListener.bind(this),this.dragElementHandler=this.dragElementHandler.bind(this)}dragElementHandler(s){s.preventDefault();let e=s.clientX-this.startX,t=s.clientY-this.startY;this.dragElement.style.left=this.dragElement.offsetLeft+e+"px",this.dragElement.style.top=this.dragElement.offsetTop+t+"px",this.startX=s.clientX,this.startY=s.clientY}firstUpdated(s){super.firstUpdated(s),this.dragElement=this.querySelector("qti-position-object-interaction>img"),this.startX=0,this.startY=0,this.dragElement.addEventListener("mousedown",e=>{this.startX=e.clientX,this.startY=e.clientY,document.addEventListener("mousemove",this.dragElementHandler,!0)}),document.addEventListener("mouseup",this.removeMoveListener)}removeMoveListener(s){document.removeEventListener("mousemove",this.dragElementHandler,!0)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("mousemove",this.dragElementHandler),document.removeEventListener("mouseup",this.removeMoveListener)}};Te.styles=[uo`
479
- :host {
480
- display: inline-block;
481
- position: relative;
482
- }
483
- `],Te=i([ho("qti-position-object-stage")],Te);import{css as fo,html as ir}from"lit";import{customElement as go,property as or,state as bo}from"lit/decorators.js";import{repeat as vo}from"lit/directives/repeat.js";import{styleMap as yo}from"lit/directives/style-map.js";var Y=class extends g{constructor(){super(...arguments);this.maxChoices=1/0;this.minChoices=0;this._points=[];this._imgElement=null;this._onImageClick=e=>{if(this._points.length<this.maxChoices){let t=e.offsetX,r=e.offsetY;this._points=[...this._points,`${t} ${r}`],this.saveResponse(this._points)}}}render(){return ir` <slot name="prompt"></slot>
484
- <point-container>
485
- ${vo(this._points,e=>e,(e,t)=>ir`
486
- <button
487
- part="point"
488
- style=${yo({position:"absolute",transform:"translate(-50%, -50%)",left:`${e.split(" ")[0]}px`,top:`${e.split(" ")[1]}px`})}
489
- aria-label="Remove point at ${e}"
490
- @click=${r=>{r.stopPropagation(),this._points=this._points.filter((o,n)=>n!==t),this.saveResponse(this._points)}}
491
- ></button>
492
- `)}
493
- <slot></slot>
494
- </point-container>`}reset(){this._points=[]}validate(){return this._points.length>=this.minChoices&&this._points.length<=this.maxChoices}set response(e){this._points=Array.isArray(e)?e:[e]}firstUpdated(){this._imgElement=this.querySelector("img"),this._imgElement?this._imgElement.addEventListener("click",this._onImageClick):console.warn("No <img> element found in <qti-select-point-interaction>")}disconnectedCallback(){super.disconnectedCallback(),this._imgElement&&this._imgElement.removeEventListener("click",this._onImageClick)}};Y.styles=[fo`
495
- :host {
496
- display: block;
497
- }
498
- point-container {
499
- display: block;
500
- position: relative;
501
- }
502
- `],i([or({type:Number,attribute:"max-choices"})],Y.prototype,"maxChoices",2),i([or({type:Number,attribute:"min-choices"})],Y.prototype,"minChoices",2),i([bo()],Y.prototype,"_points",2),Y=i([go("qti-select-point-interaction")],Y);import{css as xo,html as Ze,nothing as Lt}from"lit";import{customElement as Eo,property as se,query as nr}from"lit/decorators.js";var x=class extends g{constructor(){super();this.stepLabel=!1;this.reverse=!1;this._handleDisabledChange=(e,t)=>{};this._handleReadonlyChange=(e,t)=>{};this.csLive=getComputedStyle(this)}set min(e){this._min=e,this.value=e,this.style.setProperty("--min",`${this._min}`)}get min(){return this._min}set max(e){this._max=e,this.style.setProperty("--max",`${this._max}`)}get max(){return this._max}set step(e){this._step=e,this.style.setProperty("--step",`${this._step}`)}get step(){return this._step}reset(){}validate(){return!0}set response(e){if(Array.isArray(e)){console.error("QtiSliderInteraction: response is an array, but should be a single value");return}let t=parseInt(e);if(Number.isNaN(t)){console.error("QtiSliderInteraction: response is not a number");return}this.value=t}render(){this.value<this.min&&(this.value=this.min),this.value>this.max&&(this.value=this.max);let e=(this.value-this.min)/(this.max-this.min)*100;return this.style.setProperty("--value-percentage",`${e}%`),this.setAttribute("aria-valuenow",this.value.toString()),Ze`<slot name="prompt"></slot>
503
- <div id="slider" part="slider">
504
- ${this.csLive.getPropertyValue("--show-bounds")=="true"?Ze`<div id="bounds" part="bounds">
505
- <div>${this._min}</div>
506
- <div>${this._max}</div>
507
- </div>`:Lt}
508
- ${this.csLive.getPropertyValue("--show-ticks")=="true"?Ze`<div id="ticks" part="ticks"></div>`:Lt}
509
- <div id="rail" part="rail" @mousedown=${this._onMouseDown} @touchstart=${this._onTouchMove}>
510
- <div id="knob" part="knob">
511
- ${this.csLive.getPropertyValue("--show-value")=="true"?Ze`<div id="value" part="value">${this.value}</div>`:Lt}
512
- </div>
513
- </div>
514
- </div>`}connectedCallback(){super.connectedCallback(),this.step=1,this.setAttribute("tabindex","0"),this.setAttribute("role","slider")}_onTouchMove(e){let t=a=>{let{x:l}=this.getPositionFromEvent(a),p=l-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(p),a.stopPropagation()},r=()=>{document.removeEventListener("touchmove",t),document.removeEventListener("touchend",r),this.saveResponse(this.value.toString())};document.addEventListener("touchmove",t),document.addEventListener("touchend",r);let{x:o}=this.getPositionFromEvent(e),n=o-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(n),e.stopPropagation()}_onMouseDown(e){let t=n=>{let a=n.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(a),n.preventDefault(),n.stopPropagation()},r=()=>{document.removeEventListener("mousemove",t),document.removeEventListener("mouseup",r),this.saveResponse(this.value.toString())};document.addEventListener("mousemove",t),document.addEventListener("mouseup",r);let o=e.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(o),e.preventDefault(),e.stopPropagation()}calculateValue(e){let t=this.min+(this.max-this.min)*e/this._rail.getBoundingClientRect().width,r=this.min+Math.round((t-this.min)/this._step)*this._step;this.value=r}getPositionFromEvent(e){let t;if(e.type=="touchstart"||e.type=="touchmove"||e.type=="touchend"||e.type=="touchcancel"){let r=typeof e.originalEvent=="undefined"?e:e.originalEvent,o=r.touches[0]||r.changedTouches[0];t={x:o.pageX,y:o.pageY}}else(e.type=="mousedown"||e.type=="mouseup"||e.type=="mousemove"||e.type=="mouseover"||e.type=="mouseout"||e.type=="mouseenter"||e.type=="mouseleave")&&(t={x:e.clientX,y:e.clientY});return t}};x.styles=[xo``],i([nr("#knob")],x.prototype,"_knob",2),i([nr("#rail")],x.prototype,"_rail",2),i([se({type:Number})],x.prototype,"value",2),i([se({type:Boolean,attribute:"step-label"})],x.prototype,"stepLabel",2),i([se({type:Boolean})],x.prototype,"reverse",2),i([se({type:Number,attribute:"lower-bound"})],x.prototype,"min",1),i([se({type:Number,attribute:"upper-bound"})],x.prototype,"max",1),i([se({type:Number,attribute:"step"})],x.prototype,"step",1),i([v("disabled",{waitUntilFirstUpdate:!0})],x.prototype,"_handleDisabledChange",2),i([v("readonly",{waitUntilFirstUpdate:!0})],x.prototype,"_handleReadonlyChange",2),x=i([Eo("qti-slider-interaction")],x);import{consume as qo}from"@lit/context";import{LitElement as Co,html as _o}from"lit";import{customElement as ko,state as To}from"lit/decorators.js";var we=class extends Co{render(){return _o`<slot @slotchange=${this.handleSlotChange}></slot>`}handleSlotChange(s){var t,r,o;let e=Array.from((r=(t=this.firstElementChild)==null?void 0:t.childNodes)!=null?r:[]).find(n=>n.nodeType===Node.COMMENT_NODE);try{this.operatorFunction=new Function("context","fn","item",(o=e.textContent)!=null?o:"")}catch(n){console.error("custom-operator contains invalid javascript code",n)}}calculate(){let s={variable:t=>{var r,o,n;return(n=(o=(r=this._context)==null?void 0:r.variables.find(a=>a.identifier===t))==null?void 0:o.value)!=null?n:""},correct:t=>{var r,o,n;return(n=(o=(r=this._context)==null?void 0:r.variables.find(a=>a.identifier===t))==null?void 0:o.correctResponse)!=null?n:""}},e={getVariable:t=>{var r;return(r=this._context)==null?void 0:r.variables.find(o=>o.identifier===t)},updateOutcomeVariable:(t,r)=>{this.dispatchEvent(new CustomEvent("qti-set-outcome-value",{bubbles:!0,composed:!0,detail:{outcomeIdentifier:t,value:r}}))},updateResponseVariable:(t,r)=>{this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:t,response:r}}))}};return this.operatorFunction(this._context,s,e)}};i([qo({context:A,subscribe:!0}),To()],we.prototype,"_context",2),we=i([ko("qti-custom-operator")],we);import{LitElement as wo,css as Ro,html as Ao}from"lit";import{customElement as So}from"lit/decorators.js";var Re=class extends wo{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-hotspot",{bubbles:!0,cancelable:!1,composed:!0}))}render(){return Ao` <slot name="qti-gap-img"></slot> `}};Re.styles=Ro`
515
- :host {
516
- display: flex;
517
- user-select: none;
518
- position: absolute;
519
- }
520
- `,Re=i([So("qti-associable-hotspot")],Re);import{css as Lo,html as Mo,LitElement as No}from"lit";import{customElement as Ho,property as Vo}from"lit/decorators.js";var ie=class extends No{constructor(){super(...arguments);this.tabindex=0}render(){return Mo` <slot name="qti-gap-text"></slot>`}};ie.styles=Lo`
521
- :host {
522
- display: flex;
523
- user-select: none;
524
- }
525
- `,i([Vo({type:Number,reflect:!0})],ie.prototype,"tabindex",2),ie=i([Ho("qti-gap")],ie);import{css as $o,LitElement as Do}from"lit";import{customElement as Oo,property as Po}from"lit/decorators.js";var oe=class extends Do{constructor(){super(...arguments);this.tabindex=0}connectedCallback(){this.setAttribute("slot","qti-gap-img")}};oe.styles=$o`
526
- :host {
527
- display: flex;
528
- user-select: none;
529
- }
530
- `,i([Po({type:Number,reflect:!0})],oe.prototype,"tabindex",2),oe=i([Oo("qti-gap-img")],oe);import{css as Io,html as Uo,LitElement as Fo}from"lit";import{customElement as Bo,property as Xo}from"lit/decorators.js";var ne=class extends Fo{constructor(){super(...arguments);this.tabindex=0}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-gap-text")}render(){return Uo`<slot></slot>`}};ne.styles=Io`
531
- :host {
532
- display: inline-flex;
533
- user-select: none;
534
- }
535
- `,i([Xo({type:Number,reflect:!0})],ne.prototype,"tabindex",2),ne=i([Bo("qti-gap-text")],ne);import{css as Yo}from"lit";import{customElement as jo,property as Ko}from"lit/decorators.js";var ae=class extends E{};ae.styles=Yo`
536
- :host {
537
- display: flex;
538
- user-select: none;
539
- position: absolute;
540
- }
541
- `,i([Ko({attribute:"aria-ordervalue",type:Number,reflect:!0})],ae.prototype,"order",2),ae=i([jo("qti-hotspot-choice")],ae);import{css as zo,html as Wo}from"lit";import{customElement as Jo}from"lit/decorators.js";var Ae=class extends E{render(){return Wo`<div part="ch"><div part="cha"></div></div>
542
- <slot></slot> `}};Ae.styles=zo`
543
- :host {
544
- display: flex;
545
- user-select: none;
546
- }
547
- `,Ae=i([Jo("qti-hottext")],Ae);import{css as Zo,html as Go,LitElement as Qo}from"lit";import{customElement as en,property as tn}from"lit/decorators.js";var Se=class extends Qo{static get styles(){return[Zo`
548
- :host {
549
- display: block;
550
- cursor: pointer;
551
- }
552
- `]}connectedCallback(){super.connectedCallback(),this.addEventListener("click",this._onSelectInlineChoice),this.dispatchEvent(new CustomEvent("qti-inline-choice-register",{bubbles:!0,cancelable:!1,composed:!0}))}disconnectedCallback(){this.removeEventListener("click",this._onSelectInlineChoice)}render(){return Go` <slot></slot> `}_onSelectInlineChoice(){this.dispatchEvent(new CustomEvent("qti-inline-choice-select",{bubbles:!0,cancelable:!1,composed:!0,detail:{identifier:this.identifier}}))}};i([tn({type:String})],Se.prototype,"identifier",2),Se=i([en("qti-inline-choice")],Se);import{css as rn,html as ar,nothing as sn}from"lit";import{customElement as on,property as nn}from"lit/decorators.js";var le=class extends E{render(){return ar`<div part="ch">
553
- <div part="cha"></div>
554
- </div>
555
- ${this.marker?ar`<div id="label">${this.marker}</div>`:sn}
556
- <slot part="slot"></slot> `}};le.styles=rn`
557
- :host {
558
- display: flex;
559
- user-select: none;
560
- }
561
- slot {
562
- width: 100%;
563
- display: flex;
564
- align-items: center;
565
- }
566
- [part='ch'] {
567
- display: flex;
568
- flex-shrink: 0;
569
- align-items: center;
570
- justify-content: center;
571
- }
572
- `,i([nn({type:String,attribute:!1})],le.prototype,"marker",2),le=i([on("qti-simple-choice")],le);console.log("%cC\xBFTO%cLab%c: qti-components loaded","font-weight:bold; color:green",'font-family: "PT Sans", font-weight:bold; color:green; font-size: smaller;vertical-align: sub',"font-weight:unset");export{g as Interaction,ve as QtPrintedVariable,Be as QtiAnd,C as QtiAssessmentItem,W as QtiAssessmentStimulusRef,Re as QtiAssociableHotspot,ee as QtiAssociateInteraction,Xe as QtiBaseValue,E as QtiChoice,Z as QtiChoiceInteraction,He as QtiCompanionMaterialsInfo,w as QtiConditionExpression,ct as QtiContains,Ve as QtiContentBody,pt as QtiCorrect,V as QtiCustomInteraction,we as QtiCustomOperator,te as QtiEndAttemptInteraction,je as QtiEqual,Ye as QtiEqualRounded,u as QtiExpression,M as QtiExtendedTextInteraction,ue as QtiFeedbackBlock,me as QtiFeedbackInline,ie as QtiGap,oe as QtiGapImg,xe as QtiGapMatchInteraction,ne as QtiGapText,$ as QtiGraphicAssociateInteraction,Ee as QtiGraphicGapMatchInteraction,qe as QtiGraphicOrderInteraction,dt as QtiGt,ut as QtiGte,ae as QtiHotspotChoice,Ce as QtiHotspotInteraction,Ae as QtiHottext,Ie as QtiHottextInteraction,Se as QtiInlineChoice,U as QtiInlineChoiceInteraction,mt as QtiIsNull,Fe as QtiLookupOutcomeValue,ht as QtiLt,ft as QtiLte,Ke as QtiMapResponse,G as QtiMapping,bt as QtiMatch,X as QtiMatchInteraction,ke as QtiMediaInteraction,vt as QtiMember,he as QtiModalFeedback,yt as QtiMultiple,xt as QtiNot,Et as QtiOr,O as QtiOrderInteraction,qt as QtiOrdered,S as QtiOutcomeDeclaration,fe as QtiOutcomeProcessing,it as QtiOutcomeProcessingProcessor,F as QtiPortableCustomInteraction,Te as QtiPositionObjectStage,Ct as QtiProduct,Le as QtiPrompt,ot as QtiResponseCondition,D as QtiResponseDeclaration,ge as QtiResponseElse,lt as QtiResponseElseIf,be as QtiResponseIf,K as QtiResponseProcessing,L as QtiRubricBlock,N as QtiRule,Je as QtiSPositionObjectInteraction,Y as QtiSelectPointInteraction,nt as QtiSetOutcomeValue,at as QtiSetOutcomeValueRule,B as QtiSimpleAssociableChoice,le as QtiSimpleChoice,x as QtiSliderInteraction,ze as QtiStringMatch,Me as QtiStylesheet,_t as QtiSum,kt as QtiSumExpression,T as QtiTextEntryInteraction,Tt as QtiVariable,A as itemContext,Ht as itemContextVariables,Qs as qtiAndMixin};
573
- //# 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-components/qti-interaction/internal/choice/qti-choice.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/decorators/live-query.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext-interaction/qti-hottext-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/choices/choices.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/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-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';\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  // @property({ attribute: false })\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\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.response = variable.value;\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.response = 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 => {\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      interaction && (interaction.correctResponse = show ? response.response : '');\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    countNumAttempts &&\n      this.updateOutcomeVariable(\n        'numAttempts',\n        (+this._context.variables.find(v => v.identifier === 'numAttempts')?.value + 1).toString()\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\ntype 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>(proto: ElemClass, decoratedFnName: UpdateHandlerFunctionKeys<ElemClass>) => {\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>('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.loadAndAppendStimulus(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 loadAndAppendStimulus(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.path(path).htmldoc());\n    if (stimulus) {      \n      const elements = stimulus.querySelectorAll('qti-stimulus-body, qti-stylesheet');\n      stimulusRef.append(...elements);      \n      const title = (stimulus.querySelector('qti-assessment-stimulus') as HTMLElement)?.title;\n      if (title.includes('(lijst)')) {\n        stimulusRef.classList.add('qti-stimulus-list');\n      }\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-stimulus-ref': QtiAssessmentStimulusRef;\n  }\n}\n", "import { LitElement, html } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\nconst KEYCODE = {\n  SPACE: 32\n};\n\n/**\n * @summary qti-choice is used by qti-simple-choice, qti-inline-choice, qti-hottext, qti-hotspot-choice.\n *\n * @since 1.0\n * @status stable\n *\n * @event qti-register-choice - register itselves on a qti-choice-interaction element.\n * @event qti-loose-choice - de-register itselves on a qti-choice-interaction element.\n * @event qti-choice-element-selected - Emitted when the choice is selected.\n *\n * @slot - The choices slot element\n */\nexport abstract class QtiChoice extends LitElement {\n  @property({ type: String }) identifier: string;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  @property({\n    reflect: true,\n    type: Boolean,\n    attribute: 'aria-disabled',\n    converter: {\n      toAttribute: value => value\n    }\n  })\n  disabled = false;\n\n  @property({\n    reflect: true,\n    type: Boolean,\n    attribute: 'aria-readonly',\n    converter: {\n      toAttribute: value => value\n    }\n  })\n  readonly = false;\n\n  @property({\n    reflect: true,\n    type: Boolean,\n    attribute: 'aria-checked',\n    converter: {\n      toAttribute: value => value\n    }\n  })\n  checked = false;\n\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  handleDisabledChange(_: boolean, disabled: boolean) {\n    if (disabled) {\n      this.tabindex = undefined;\n      this.blur();\n    } else {\n      this.tabIndex = 0;\n    }\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('qti-register-choice', {\n        bubbles: true,\n        cancelable: false,\n        composed: true\n      })\n    );\n  }\n\n  override disconnectedCallback() {\n    this.removeEventListener('keyup', this._onKeyUp);\n    this.removeEventListener('click', this._onClick);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-loose-choice', {\n        bubbles: true,\n        cancelable: false,\n        composed: true\n      })\n    );\n  }\n\n  public reset() {\n    this.checked = false;\n    this.disabled = false;\n  }\n\n  private _onKeyUp(event: KeyboardEvent) {\n    if (event.altKey) return;\n\n    switch (event.keyCode) {\n      case KEYCODE.SPACE:\n        event.preventDefault();\n        this._toggleChecked();\n        break;\n\n      default:\n    }\n  }\n\n  private _onClick() {\n    this._toggleChecked();\n  }\n\n  private _toggleChecked() {\n    if (this.disabled || this.readonly) return;\n    this.checked = !this.checked;\n\n    this.dispatchEvent(\n      new CustomEvent('qti-choice-element-selected', {\n        bubbles: true,\n        cancelable: false,\n        composed: true,\n        detail: { identifier: this.identifier, checked: this.checked }\n      })\n    );\n  }\n\n  override render() {\n    return html` <slot></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-choice': QtiChoice;\n  }\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 default 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    inInteraction && this.setAttribute('slot', 'prompt');\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 styleLink: HTMLStyleElement | HTMLLinkElement;\n\n  // protected createRenderRoot(): HTMLElement | DocumentFragment {\n  //   return this;\n  // }\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    super.firstUpdated(_changedProperties);\n\n    const item = this;\n    const link = this.getAttribute('href');\n\n    if (link !== null) {\n      const styles = document.createElement('link');\n      styles.rel = 'stylesheet';\n      styles.type = 'text/css';\n      styles.media = 'screen';\n      styles.href = link;\n      item.appendChild(styles);\n      this.styleLink = styles;\n    }\n\n    if (this.textContent !== null) {\n      const styles = document.createElement('style');\n      styles.media = 'screen';\n      styles.textContent = this.textContent;\n      item.appendChild(styles);\n      this.styleLink = styles;\n    }\n  }\n\n  override disconnectedCallback() {\n    if (this.styleLink) {\n      try {\n        this.styleLink.remove();\n      } catch (error) {\n        console.log('could not remove stylesheet');\n      }\n    }\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);\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 { LitElement, PropertyValueMap } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { QtiAssessmentItem } from '../qti-assessment-item/qti-assessment-item';\nimport { IsNullOrUndefined } from '../internal/utils';\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  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.closest('qti-assessment-item') as QtiAssessmentItem).getOutcome(outcomeIdentifier);\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 { ref, createRef } from 'lit/directives/ref.js';\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  // public static rowHeightClass = [];\n\n  textareaRef = createRef<HTMLTextAreaElement>();\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  @state()\n  private _value = '';\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      if (className.startsWith('qti-height-lines')) {\n        const nrRows = className.replace('qti-height-lines-', '');\n        if (this.textareaRef) {\n          this.textareaRef.value.rows = parseInt(nrRows);\n        }\n      }\n    });\n  }\n\n  public set response(value: string) {\n    this._value = value !== undefined ? value : '';\n  }\n\n  public validate() {\n    return this._value !== '';\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        ${ref(this.textareaRef)}\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        @keydown=\"${event => event.stopImmediatePropagation()}\"\n        @keyup=\"${this.textChanged}\"\n        @change=\"${this.textChanged}\"\n        @blur=\"${(event: FocusEvent) => {\n          const input = event.target as HTMLInputElement;\n          if (!input.checkValidity()) {\n            input.setCustomValidity(this.dataset.patternmaskMessage || 'Invalid input');\n            input.reportValidity(); // Show the validation message\n          } else {\n            input.setCustomValidity(''); // Clear the custom validity message\n          }\n        }}\"\n        placeholder=\"${ifDefined(this.placeholderText ? this.placeholderText : undefined)}\"\n        maxlength=\"${ifDefined(this.expectedLength ? this.expectedLength : undefined)}\"\n        pattern=\"${ifDefined(this.patternMask ? this.patternMask : undefined)}\"\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      this.saveResponse(input.value);\n    }\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-extended-text-interaction': QtiExtendedTextInteraction;\n  }\n}\n", "import { property } from 'lit/decorators.js';\nimport { LitElement } from 'lit';\n\nexport abstract class Interaction extends LitElement {\n  @property({ attribute: 'response-identifier' }) responseIdentifier: string = '';\n\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  abstract validate(): boolean;\n  abstract set response(val: Readonly<string | string[]>);\n  set correctResponse(val: Readonly<string | string[]>) {\n    console.warn('correctResponse is not implemented');\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n\n    this.dispatchEvent(\n      new CustomEvent('qti-register-interaction', {\n        bubbles: true,\n        cancelable: false,\n        composed: true\n      })\n    );\n  }\n\n  public saveResponse(value: string | string[]) {\n    this.dispatchEvent(\n      new CustomEvent('qti-interaction-response', {\n        bubbles: true,\n        cancelable: false,\n        composed: true,\n        detail: {\n          responseIdentifier: this.responseIdentifier,\n          response: Array.isArray(value) ? [...value] : value\n        }\n      })\n    );\n  }\n}\n", "import { css, 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';\n\n@customElement('qti-text-entry-interaction')\nexport class QtiTextEntryInteraction extends Interaction {\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  @state()\n  private _value = '';\n\n  @state()\n  private _correctValue = '';\n\n  @state()\n  private _size = 5;\n\n  inputRef = createRef<HTMLInputElement>();\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames')\n  handleclassNamesChange(old, classes: string) {\n    const classNames = classes.split(' ');\n    classNames.forEach((className: string) => {\n      if (className.startsWith('qti-input-width')) {\n        const nrRows = className.replace('qti-input-width-', '');\n        this._size = parseInt(nrRows);\n      }\n    });\n  }\n\n  public set response(value: string | undefined) {\n    this._value = value !== undefined ? value : '';\n  }\n\n  public validate() {\n    return this._value !== '';\n  }\n\n  static override get styles() {\n    return [\n      css`\n        [part='correct'] {\n          position: absolute;\n          width: 100%;\n        }\n      `\n    ];\n  }\n\n  set correctResponse(value: string) {\n    this._correctValue = value;\n  }\n\n  override render() {\n    return html`\n      <input\n        part=\"input\"\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        @blur=\"${(event: FocusEvent) => {\n          const input = event.target as HTMLInputElement;\n          if (!input.checkValidity()) {\n            input.setCustomValidity(this.dataset.patternmaskMessage || 'Invalid input');\n            input.reportValidity(); // Show the validation message\n          } else {\n            input.setCustomValidity(''); // Clear the custom validity message\n          }\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        size=\"${this._size}\"\n        pattern=\"${ifDefined(this.patternMask ? this.patternMask : undefined)}\"\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n      />\n      <div part=\"correct\">${this._correctValue}</div>\n    `;\n  }\n  //\n  // maxlength=\"${ifDefined(this.expectedLength ? this.expectedLength : undefined)}\"\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      this.saveResponse(input.value);\n    }\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", "// @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 { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices';\n\n@customElement('qti-hottext-interaction')\nexport class QtiHottextInteraction extends ChoicesMixin(LitElement, '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 { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\nimport { QtiChoice } from '../choice/qti-choice';\n\ntype Constructor<T = {}> = new (...args: any[]) => T;\n\nexport interface ChoicesInterface {\n  validate(): boolean;\n  _choiceElements: HTMLElement[];\n  correctResponse: string | string[];\n}\n\nexport const ChoicesMixin = <T extends Constructor<LitElement>>(superClass: T, selector: string) => {\n  class ChoicesMixinElement extends superClass implements ChoicesInterface {\n    public _choiceElements: QtiChoice[] = [];\n\n    @property({ attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n    @property({\n      type: Number,\n      attribute: 'min-choices'\n    })\n    public minChoices: 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: 'max-choices'\n    })\n    public maxChoices: number = 1;\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    _handleDisabledChange = (_: boolean, disabled: boolean) =>\n      this._choiceElements.forEach(ch => (ch.disabled = disabled));\n\n    @watch('readonly', { waitUntilFirstUpdate: true })\n    _handleReadonlyChange = (_: boolean, readonly: boolean) =>\n      this._choiceElements.forEach(ch => (ch.readonly = readonly));\n\n    @watch('maxChoices', { waitUntilFirstUpdate: true })\n    _handleMaxChoicesChange = () => this._determineInputType();\n\n    constructor(...args: any[]) {\n      super(...args);\n\n      this.addEventListener('qti-register-choice', this._registerChoiceElement);\n      this.addEventListener('qti-loose-choice', this._looseChoiceElement);\n    }\n\n    validate(): boolean {\n      const nrSelected = this._choiceElements.reduce((acc, val) => {\n        return acc + (val.checked ? 1 : 0);\n      }, 0);\n      return nrSelected >= this.minChoices;\n    }\n\n    set response(responseValue: string | string[]) {\n      const responseValueArray = Array.isArray(responseValue) ? responseValue : [responseValue];\n      this._choiceElements.forEach(ce => {\n        ce.checked = responseValueArray.find(rv => rv === ce.identifier) ? true : false;\n      });\n    }\n\n    set correctResponse(responseValue: string | string[]) {\n      const responseValueArray = Array.isArray(responseValue) ? responseValue : [responseValue];\n      if (responseValue == '') {\n        this._choiceElements.forEach(ce => {\n          ce.removeAttribute('data-correct-response');\n        });\n        return;\n      }\n      this._choiceElements.forEach(ce => {\n        ce.setAttribute(\n          'data-correct-response',\n          responseValueArray.find(rv => rv === ce.identifier) ? 'true' : 'false'\n        );\n      });\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.addEventListener('qti-register-choice', this._registerChoiceElement);\n      this.addEventListener('qti-choice-element-selected', this._choiceElementSelectedHandler);\n      this.dispatchEvent(\n        new CustomEvent('qti-register-interaction', {\n          bubbles: true,\n          cancelable: false,\n          composed: true\n        })\n      );\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener('qti-choice-element-selected', this._choiceElementSelectedHandler);\n      this.removeEventListener('qti-register-choice', this._registerChoiceElement);\n    }\n\n    private _registerChoiceElement(e: CustomEvent) {\n      e.stopPropagation();\n      const choiceElement = e.target as QtiChoice;\n      this._choiceElements.push(choiceElement);\n      this._setInputType(choiceElement);\n    }\n\n    private _looseChoiceElement(e: CustomEvent) {\n      e.stopPropagation();\n      const choiceElement = e.target as QtiChoice;\n      this._choiceElements.push(choiceElement);\n      this._choiceElements = this._choiceElements.filter(ch => ch !== choiceElement);\n    }\n\n    private _determineInputType() {\n      this._choiceElements.forEach(choiceElement => {\n        this._setInputType(choiceElement);\n      });\n    }\n\n    private _setInputType(choiceElement: QtiChoice) {\n      if (this.maxChoices === 1) {\n        // if zero then you can choose how much you want\n        choiceElement.setAttribute('role', 'radio');\n      } else {\n        choiceElement.setAttribute('role', 'checkbox');\n      }\n    }\n\n    protected _choiceElementSelectedHandler(event: CustomEvent<{ identifier: string; checked: boolean }>) {\n      if (this.maxChoices === 1) {\n        this._choiceElements\n          .filter(ce => ce.identifier !== event.detail.identifier)\n          .forEach(ce => {\n            ce.checked = false;\n          });\n      }\n      this._choiceElementSelected();\n    }\n\n    protected _choiceElementSelected() {\n      const selectedIdentifiers = this._choiceElements.filter(ce => ce.checked).map(ce => ce.identifier);\n\n      if (this.maxChoices > 1) {\n        if (this.maxChoices === selectedIdentifiers.length) {\n          this._choiceElements.forEach(ce => (ce.disabled = !ce.checked));\n        } else {\n          this._choiceElements.forEach(ce => (ce.disabled = false));\n        }\n      }\n\n      let result: string | string[];\n      if (this.maxChoices === 1) {\n        result = selectedIdentifiers.length > 0 ? selectedIdentifiers[0] : undefined;\n      } else {\n        result = selectedIdentifiers;\n      }\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n      this.saveResponse(result);\n    }\n\n    protected saveResponse(response) {\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  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  /*\n    <details class=\"anchor\">\n      <summary>${this.dataPrompt}</summary>\n\n      <div role=\"menu\" part=\"menu\" class=\"positionedElement\">\n        <slot></slot>\n      </div>\n    </details>\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 response(value: string) {\n    this.options = this.options.map(option => {\n      value === option.value && (option.selected = true);\n      return option;\n    });\n  }\n\n  set correctResponse(value: Readonly<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';\nimport { ShuffleMixin } from '../internal/shuffle/shuffle-mixin';\nimport { VocabularyMixin } from '../internal/vocabulary/vocabulary-mixin';\nimport styles from './qti-choice-interaction.styles';\n\n@customElement('qti-choice-interaction')\nexport class QtiChoiceInteraction\n  extends VocabularyMixin(\n    ShuffleMixin(ChoicesMixin(LitElement, 'qti-simple-choice'), 'qti-simple-choice'),\n    'qti-simple-choice'\n  )\n  implements ChoicesInterface\n{\n  static styles: CSSResultGroup = styles;\n\n  /** orientation of choices */\n  @property({ type: String })\n  public orientation: 'horizontal' | 'vertical';\n\n  render() {\n    return html` <slot name=\"prompt\"></slot><slot part=\"slot\"></slot>`;\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';\n\ntype Constructor<T = {}> = new (...args: any[]) => T;\n\ndeclare class ShuffleInterface {}\nexport const ShuffleMixin = <T extends Constructor<LitElement>>(superClass: T, selector: string) => {\n  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\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      }\n\n      let isShuffled = false;\n      const maxAttempts = 10; // Max attempts to prevent infinite loops\n      let attempt = 0;\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.some((choice, index) => {\n          const originalIndex = choices.indexOf(choice);\n          return originalIndex !== index;\n        });\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++)); // choice.style.order = String(order++);\n        } else {\n          const nonFixedChoice = nonFixedElements.shift();\n          nonFixedChoice!.style.setProperty('order', String(order++)); // nonFixedChoice!.style.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 { html, LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { QtiChoice } from '../choice/qti-choice';\nimport { QtiSimpleChoice } from '../../qti-simple-choice';\n\ntype Constructor<T = {}> = 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<LitElement>>(superClass: T, selector: string) => {\n  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'];\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)\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();\n      const lastLabelSuffix = this._classes.filter(c => this._allLabelSuffixes.includes(c)).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// import componentStyles from '../../utilities/styles/component.styles';\n\n/* ${componentStyles} */\nexport default css`\n  :host {\n    display: flex;\n    flex-direction: column;\n    gap: var(--qti-gap-size);\n    // align-items: flex-start;\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 { LitElement, css, html } from 'lit';\nimport { state } from 'lit/decorators.js';\nimport { ResponseVariable, VariableDeclaration } from '../../internal/variables';\nimport { QtiAssessmentItem } from '../../qti-assessment-item/qti-assessment-item';\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  get assessmentItem(): QtiAssessmentItem {\n    return this.closest('qti-assessment-item') as QtiAssessmentItem;\n  }\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,\n              cardinality: 'single'\n            } as ResponseVariable;\n          }\n          case 'qti-variable': {\n            const identifier = e.getAttribute('identifier') || '';\n            const variable = this.assessmentItem.getVariable(identifier);\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 = this.assessmentItem.getResponse(identifier);\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        let value = condition.calculate() as Boolean;\n        // convert string value to boolean and return null if not possible\n        if (typeof value === 'string') {\n          if (value === 'true') {\n            value = true;\n          } else if (value === 'false') {\n            value = false;\n          } else {\n            console.error('unexpected value in qti-and, expected boolean');\n            return null;\n          }\n        }\n        return value;\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;\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 { QtiAssessmentItem } from '../../../qti-assessment-item/qti-assessment-item';\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 = (this.closest('qti-assessment-item') as QtiAssessmentItem).getResponse(identifier);\n    responseVariable.correctResponse;\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 { 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 = this.assessmentItem.getResponse(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      let value = condition.calculate() as Boolean;\n      // convert string value to boolean and return null if not possible\n      if (typeof value === 'string') {\n        if (value === 'true') {\n          value = true;\n        } else if (value === 'false') {\n          value = false;\n        } else {\n          console.error('unexpected value in qti-or, expected boolean');\n          return null;\n        }\n      }\n      return value;\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 { QtiAssessmentItem } from '../../../qti-assessment-item/qti-assessment-item';\nimport { ItemContext, itemContext } from '../../../qti-assessment-item/qti-assessment-item.context';\n\nexport class QtPrintedVariable extends LitElement {\n  @property({ type: String })\n  identifier: string;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\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  // constructor() {\n  //   super();\n  //   const assessmentItem = this.closest('qti-assessment-item') as QtiAssessmentItem;\n  //   assessmentItem.addEventListener('qti-response-processed', () => {\n  //     this.value = this.calculate() as string;\n  //   });\n  // }\n\n  // public connectedCallback(): void {\n  //   super.connectedCallback();\n  //   this.value = this.calculate() as string;\n  // }\n\n  public calculate(): Readonly<string | string[]> {\n    const assessmentItem = this.closest('qti-assessment-item') as QtiAssessmentItem;\n    const identifier = this.identifier;\n    const result = assessmentItem.getVariable(identifier).value;\n    return result;\n  }\n}\n\ncustomElements.define('qti-printed-variable', QtPrintedVariable);\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 { QtiAssessmentItem } from '../../../qti-assessment-item/qti-assessment-item';\nimport { 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.closest('qti-assessment-item') as QtiAssessmentItem).getVariable(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: 'response-identifier' })\n  responseIdentifier: string;\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.response = 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 response(val: Readonly<string | string[]>) {\n    // Only set state is supported in a PCI\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\n    type == 'IMS'\n      ? pci.getInstance(dom, config, undefined)\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      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 { LitElement, css, html } from 'lit';\n\nimport { customElement, state } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop';\n\n@customElement('qti-associate-interaction')\nexport class QtiAssociateInteraction extends DragDropInteractionMixin(\n  LitElement,\n  'qti-simple-associable-choice',\n  true,\n  '.dl'\n) {\n  @state() private _childrenMap: Element[];\n\n  static override styles = 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\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  override connectedCallback() {\n    super.connectedCallback();\n    this._childrenMap = Array.from(this.querySelectorAll('qti-simple-associable-choice'));\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-associate-interaction': QtiAssociateInteraction;\n  }\n}\n", "export class TouchDragAndDrop {\n  private _touchBegin = 0; // timestamp of first touch\n  private _touchDown = null; // point of first touch\n  private _lastClick = 0; // timestamp of previous click (touchstart + touchend)\n  private _canDrag = false; // whether there is an element which can be dragged\n  private _dragSrc = null; // the element which should be dragged\n  private _dragCopy = null; // copy of drag source for drag feedback\n  private _touchEndCalled = false; // whether touchEnd occured\n  private _dragRunning = false; // whether a drag process is running at the moment\n\n  private _dataTransfer = {\n    data: {},\n    setData: function (type, val) {\n      this.data[type] = val;\n    },\n    getData: function (type) {\n      return this.data[type];\n    },\n    effectAllowed: 'move'\n  };\n  private _copyOffset = { x: 0, y: 0 }; // Offset for positioning the drag copy\n\n  private _lastTarget = null; // The last registered touch target\n  private _currentDropContainer = null; // The current drop container; false if element is not droppable\n  private _handleClick = true; // Specifies\n\n  private _DBLCLICKDELAY = 500; // maximum delay in which a second click must occur\n  private _CONTEXTMENUDELAY = 1000; // hold delay after which context menu is shown\n  private _DRAGDELTA = 5; // Minimum of pixels which the finger must be moved to start drag\n  private _COPYOPACITY = 1; // Opacity of the drag copy element\n  private _ORGOPACITY = 0.7; // Opacity of the drag copy element\n  private static _instance: TouchDragAndDrop;\n\n  copyStylesDragClone: boolean = true;\n  dragOnClick: boolean = false;\n\n  constructor() {\n    // Check singleton\n    if (TouchDragAndDrop._instance) {\n      //  throw new Error(\"TouchDragAndDrop can't be instantiated more than once.\");\n      return TouchDragAndDrop._instance;\n    }\n    TouchDragAndDrop._instance = this;\n\n    // this._initializeFields();\n\n    // Add event listeners\n\n    document.addEventListener('touchmove', this._touchMove.bind(this), { passive: false, capture: false });\n    document.addEventListener('mousemove', this._touchMove.bind(this), { passive: false, capture: false });\n\n    document.addEventListener('touchend', this._touchEnd.bind(this), { passive: false, capture: false });\n    document.addEventListener('mouseup', this._touchEnd.bind(this), { passive: false, capture: false });\n\n    document.addEventListener('touchcancel', this._touchCancel.bind(this), { passive: false, capture: false });\n\n    return this;\n  }\n\n  addDraggables(draggables: Element[]) {\n    draggables.forEach(el => {\n      el.addEventListener('touchstart', this._touchStart.bind(this), { passive: false, capture: false });\n      el.addEventListener('mousedown', this._touchStart.bind(this), { passive: false, capture: false });\n    });\n  }\n\n  /**\n   * Callback for touchstart event listener.\n   * @param {TouchEvent} e\n   */\n  private _touchStart(e) {\n    // Save current timestamp\n    this._touchBegin = Date.now();\n\n    const { x, y } = this._getPoint(e);\n\n    this._touchDown = { x, y };\n\n    this._dragSrc = e.currentTarget;\n    this._canDrag = true;\n\n    if (this.dragOnClick) {\n      const _touches = { clientX: x, clientY: y };\n      this._dragRunning = true;\n      this._createDragCopy(e, _touches);\n    }\n\n    e.preventDefault();\n  }\n\n  /**\n   * Callback for touchmove event listener.\n   * @param {TouchEvent} e\n   */\n  private _touchMove(e) {\n    if (this._canDrag && this._dragSrc) {\n      // Create copy of element for visual drag feedback\n\n      const { x, y } = this._getPoint(e);\n      const _touches = { clientX: x, clientY: y };\n\n      if (this._getDelta(_touches) >= this._DRAGDELTA) {\n        this._dragRunning = true;\n      }\n\n      this._createDragCopy(e, _touches);\n      e.preventDefault();\n    }\n  }\n\n  private _createDragCopy = (e: any, _touches: { clientX: number; clientY: number }) => {\n    if (this._dragCopy === null && this._dragRunning) {\n      this._dragSrc.style.opacity = this._COPYOPACITY;\n      this._dragCopy = this._dragSrc.cloneNode(true);\n      const elementStyles = window.getComputedStyle(this._dragSrc);\n\n      this._dragCopy.style = '';\n      this._dragCopy.setAttribute('dragclone', '');\n\n      if (this.copyStylesDragClone) {\n        for (const style of elementStyles) {\n          this._dragCopy.style[style] = elementStyles.getPropertyValue(style);\n        }\n      }\n\n      this._calculateDragCopyPosition(_touches);\n\n      this._dragCopy.style.top = _touches.clientY - this._copyOffset.y + 'px';\n      this._dragCopy.style.left = _touches.clientX - this._copyOffset.x + 'px';\n      this._dragCopy.style.position = 'fixed';\n      this._dragCopy.style.pointerEvents = 'none';\n      this._dragCopy.style.zIndex = '999999';\n\n      this._dragCopy = document.body.appendChild(this._dragCopy);\n      this._dispatchEvent(this._dragSrc, 'dragstart');\n    }\n\n    // Drag is running, move drag copy and fire events\n    if (this._dragRunning) {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const _this = this;\n      requestAnimationFrame(function () {\n        if (_this._touchEndCalled || _this._dragCopy === null) return;\n        _this._dragCopy.style.top = _touches.clientY - _this._copyOffset.y + 'px';\n        _this._dragCopy.style.left = _touches.clientX - _this._copyOffset.x + 'px';\n      });\n\n      const target = this._findDroppable(e);\n\n      // Fire dragleave and dragenter events when target has changed during move\n      if (target != this._lastTarget) {\n        this._dispatchEvent(target, 'dragenter');\n        this._dispatchEvent(this._lastTarget, 'dragleave');\n        this._lastTarget = target;\n      }\n\n      // Make current drop container classwide available and fire dragover if it's really a drop container.\n\n      this._currentDropContainer = target;\n      if (this._currentDropContainer) this._dispatchEvent(target, 'dragover');\n    }\n  };\n\n  /**\n   * Callback for touchend event listener.\n   * @param {TouchEvent} e\n   */\n  private _touchEnd(e) {\n    this._touchEndCalled = true;\n    this._canDrag = false;\n\n    // console.log(1, e.target, this._currentDropContainer);\n\n    // User seems to click\n    // if (!this._dragRunning && this._handleClick) {\n    //   this._dispatchEvent(e.target, 'click');\n    //   e.preventDefault();\n    //   return;\n    // }\n    if (this._currentDropContainer) {\n      this._dispatchEvent(this._currentDropContainer, 'drop');\n      this._dispatchEvent(this._dragSrc, 'dragend');\n    } else {\n      // fire dragEvent even if their is no droppable. And assign dropEffect none.\n      // for our purpose, this will bring back the drag to its start position, seel drag-drop-interaction-mixin.ts\n      if (this._dragRunning) {\n        const event = new CustomEvent('dragend', { bubbles: true, cancelable: true });\n        event['dataTransfer'] = { dropEffect: 'none' };\n        this._dragSrc?.dispatchEvent(event);\n      }\n    }\n\n    this._reset();\n  }\n\n  /**\n   * Callback for touchcancel event listener, in case browser supports this.\n   * @param {TouchEvent} e\n   */\n  private _touchCancel(e) {\n    this._reset();\n  }\n\n  /**\n   * Determines the next droppable element at current point.\n   * @param {Object} pt\n   */\n  private _findDroppable(event) {\n    const pointFromTouchEvent = this._getPoint(event);\n    const visited = new Set<Element>();\n    const element = this.getElementWithDropzone(document, pointFromTouchEvent.x, pointFromTouchEvent.y, visited);\n    return element;\n  }\n\n  private getElementWithDropzone(\n    root: DocumentOrShadowRoot,\n    x: number,\n    y: number,\n    visited: Set<Element>\n  ): Element | null {\n    const el = root.elementFromPoint(x, y) as HTMLElement | null;\n    if (el) {\n      // Check if we've already visited this element\n      if (visited.has(el)) {\n        // Prevent infinite recursion by not revisiting the same element\n        return null;\n      }\n      visited.add(el);\n\n      if (el.hasAttribute('dropzone')) {\n        // Found an element with 'dropzone'; return it immediately\n        return el;\n      }\n      if (el.shadowRoot) {\n        // Recursively search within the Shadow DOM\n        const nestedEl = this.getElementWithDropzone(el.shadowRoot, x, y, visited);\n        if (nestedEl) {\n          // If a nested element with 'dropzone' is found, return it\n          return nestedEl;\n        }\n      }\n      // No 'dropzone' attribute found in deeper levels; return the current element\n      return el;\n    }\n    // No element found at the given coordinates\n    return null;\n  }\n\n  private _getPoint(event, page?) {\n    if (event && event.touches) {\n      event = event.touches[0];\n    }\n    return {\n      x: page ? event.pageX : event.clientX,\n      y: page ? event.pageY : event.clientY\n    };\n  }\n\n  /**\n   * Calculates the offset for displaying the drag copy to have a seamless dragging.\n   * @param {Touch} touch The current touch.\n   */\n  private _calculateDragCopyPosition(touch) {\n    const clientRect = this._dragSrc.getBoundingClientRect();\n    this._copyOffset.x = touch.clientX - clientRect.left;\n    this._copyOffset.y = touch.clientY - clientRect.top;\n  }\n\n  /**\n   * Calculates the pixel delta between first touch and the current touch position.\n   * @param {Object} touch\n   */\n  private _getDelta(touch) {\n    const x = Math.abs(touch.clientX - this._touchDown.x);\n    const y = Math.abs(touch.clientY - this._touchDown.y);\n\n    return x + y;\n  }\n\n  /**\n   *\n   * @param {Element} e The event's target element.\n   * @param {string} eventType The type of the event.\n   * @param {bool} bubble Sets whether the event should bubble.\n   */\n  private _dispatchEvent(e, eventType, bubble = true) {\n    if (!e) return false;\n\n    const event = new CustomEvent(eventType, { bubbles: bubble, cancelable: true });\n    event['dataTransfer'] = this._dataTransfer;\n    e.dispatchEvent(event);\n    return event.defaultPrevented;\n  }\n\n  /**\n   * Resets all variables and prepares for new Drag and Drop.\n   */\n  private _reset() {\n    if (this._dragRunning) {\n      this._dragSrc.style.opacity = '1.0';\n      this._dragCopy.parentElement.removeChild(this._dragCopy);\n    }\n\n    this._dragRunning = false;\n    this._dragSrc = null;\n    this._dragCopy = null;\n    this._canDrag = false;\n\n    this._touchBegin = 0;\n    this._touchDown = null;\n    this._lastClick = 0;\n    this._touchEndCalled = false;\n    this._dataTransfer = {\n      data: {},\n      setData: function (type, val) {\n        this.data[type] = val;\n      },\n      getData: function (type) {\n        return this.data[type];\n      },\n      effectAllowed: 'move'\n    };\n    this._copyOffset = { x: 0, y: 0 };\n\n    this._lastTarget = null;\n    this._currentDropContainer = null;\n    this._handleClick = true;\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", "import { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\ntype Constructor<T> = new (...args: any[]) => T;\n\ndeclare class DroppablesInterface {}\n\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\nexport const DroppablesMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n  droppablesInShadowRoot: boolean,\n  droppablesSelector: string\n) => {\n  class DroppablesElement extends superClass {\n    private observer: MutationObserver;\n\n    @property({ type: Boolean, reflect: true }) disabled = false;\n\n    override firstUpdated(changedProps): void {\n      // for qti-match-interaction the drag interaction can be replace with a qti-match-tabular class\n      // which shows the data in a a tabular way, so no drag drop should be involved then\n      if (this.classList.contains('qti-match-tabular')) return;\n\n      super.firstUpdated(changedProps);\n\n      const droppables = Array.from(\n        droppablesInShadowRoot\n          ? this.shadowRoot.querySelectorAll(droppablesSelector)\n          : this.querySelectorAll(droppablesSelector)\n      );\n\n      this.dragoverHandler = this.dragoverHandler.bind(this);\n      this.dragleaveHandler = this.dragleaveHandler.bind(this);\n      this.dragenterHandler = this.dragenterHandler.bind(this);\n\n      this.dropHandler = this.dropHandler.bind(this);\n\n      droppables.forEach(d => {\n        d.setAttribute('dropzone', 'move');\n        d.addEventListener('dragleave', this.dragleaveHandler);\n\n        this.attachHandler(d);\n      });\n      for (const droppable of droppables) {\n        this.observer = new MutationObserver(mutations => {\n          mutations.forEach(mutation => {\n            if (mutation.type === 'attributes') {\n              const propName = mutation.attributeName;\n              switch (propName) {\n                case 'disabled': {\n                  const disabled = droppable.hasAttribute('disabled');\n                  if (!disabled) {\n                    this.attachHandler(droppable);\n                  } else {\n                    this.removeHandler(droppable);\n                  }\n                  break;\n                }\n              }\n            }\n          });\n        });\n        this.observer.observe(droppable, {\n          attributes: true //configure it to listen to attribute changes\n        });\n      }\n    }\n\n    private attachHandler(droppable: Element) {\n      droppable.addEventListener('dragover', this.dragoverHandler);\n      droppable.addEventListener('dragenter', this.dragenterHandler);\n      droppable.addEventListener('drop', this.dropHandler);\n    }\n\n    private removeHandler(droppable: Element) {\n      droppable.removeEventListener('dragover', this.dragoverHandler);\n      droppable.removeEventListener('dragenter', this.dragenterHandler);\n      droppable.removeEventListener('drop', this.dropHandler);\n    }\n\n    override disconnectedCallback() {\n      // for qti-match-interaction the drag interaction can be replace with a qti-match-tabular class\n      // which shows the data in a a tabular way, so no drag drop should be involved then\n      if (this.classList.contains('qti-match-tabular')) return;\n\n      super.disconnectedCallback();\n      this.observer?.disconnect();\n    }\n\n    dragenterHandler(ev: DragEvent) {\n      ev.preventDefault();\n    }\n\n    dragoverHandler(ev: DragEvent) {\n      ev.preventDefault();\n      const droppable = ev.currentTarget as HTMLElement;\n      // droppablesInShadowRoot\n      // ? droppable.setAttribute('part', droppable.getAttribute('part') + ' active') :\n      droppable.setAttribute('active', '');\n\n      ev.dataTransfer.dropEffect = 'move';\n\n      return false;\n    }\n\n    dropHandler(ev: DragEvent) {\n      ev.preventDefault();\n      const droppable = ev.currentTarget as HTMLElement;\n      // pk: draggables in light dom can be dragged to shadowdom, this is one of the rules of webcomponents.\n      // They may not create new elements in light dom. Some sometimess drop zones should be generated\n      // by the webcomponent. Then a draggable ( which is always already created by a webcomponent )\n      // can be in light dom, en can be dragged to shadow dom.\n      // thinking of another way where we just change slots. Maybe thats better..\n      const draggableInLightDom = this.querySelector(`[identifier=${ev.dataTransfer.getData('text')}`);\n      const draggable = draggableInLightDom\n        ? draggableInLightDom\n        : this.shadowRoot.querySelector(`[identifier=${ev.dataTransfer.getData('text')}`);\n\n      if (!droppable) {\n        console.error(`cannot find droppable, target: ${ev.target ? JSON.stringify(ev.target) : 'null'}`);\n      } else if (draggable.parentElement.getAttribute('identifier') !== droppable.getAttribute('identifier')) {\n        droppable.appendChild(draggable);\n      }\n      // droppablesInShadowRoot\n      // ? droppable.setAttribute('part', droppable.getAttribute('part').replace('active', '').trim()) :\n      droppable.removeAttribute('active');\n\n      return false;\n    }\n\n    dragleaveHandler(ev: DragEvent) {\n      ev.preventDefault();\n\n      const droppable = ev.currentTarget as HTMLElement;\n      droppable.removeAttribute('active');\n      ev.dataTransfer.dropEffect = 'none';\n\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';\n\ntype Constructor<T> = 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<LitElement>>(\n  superClass: T,\n  droppablesSel: string,\n  draggablesSel: string\n) => {\n  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 { watch } from '../../../../decorators/watch';\nimport { TouchDragAndDrop } from './drag-drop-api';\n// keyboard navigatable drag drop: https://codepen.io/SitePoint/pen/vEzXbj\n// https://stackoverflow.com/questions/55242196/typescript-allows-to-use-proper-multiple-inheritance-with-mixins-but-fails-to-c\n// https://github.com/microsoft/TypeScript/issues/17744#issuecomment-558990381\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\n\ntype Constructor<T> = new (...args: any[]) => T;\n\ninterface InteractionConfiguration {\n  copyStylesDragClone: boolean;\n  dragCanBePlacedBack: boolean;\n  dragOnClick: boolean;\n}\n\nexport const DragDropInteractionMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n  draggablesSelector: string,\n  droppablesInShadowRoot: boolean,\n  droppablesSelector: string\n) => {\n  class DragDropInteractionElement extends FlippablesMixin(\n    DroppablesMixin(superClass, droppablesInShadowRoot, droppablesSelector),\n    droppablesSelector,\n    draggablesSelector\n  ) {\n    protected draggables = new Map<Element, { parent: Element; index: number }>();\n    protected droppables: Element[];\n    dragDropApi: TouchDragAndDrop;\n\n    @liveQuery(draggablesSelector)\n    reInitDragAndDrop(dragsAdded: Element[], dragsRemoved: Element[]) {\n      if (this.classList.contains('qti-match-tabular')) return;\n\n      // check if added elements are not already in list\n      const draggables = dragsAdded.filter(d => !this.draggables || !this.draggables.get(d));\n\n      if (draggables.length > 0) {\n        this.dragDropApi.addDraggables(dragsAdded);\n\n        dragsAdded.forEach(elem => {\n          // store initial positions of elements, and of course, just the elements for looping and such\n          this.draggables.set(elem, {\n            parent: elem.parentElement,\n            index: Array.from(elem.parentNode.children).indexOf(elem)\n          });\n          elem.setAttribute('qti-draggable', 'true');\n          elem.addEventListener('dragstart', this.handleDragStart);\n          elem.addEventListener('dragend', this.handleDragEnd);\n        });\n      }\n    }\n\n    @property({ type: String, attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n    @property({ attribute: false, type: Object }) configuration: InteractionConfiguration = {\n      copyStylesDragClone: true,\n      dragCanBePlacedBack: true,\n      dragOnClick: false\n    };\n    @watch('configuration')\n    handleDragOptionsChanged(old, dragOptions) {\n      this.dragDropApi.copyStylesDragClone = dragOptions.copyStylesDragClone;\n      this.dragDropApi.dragOnClick = dragOptions.dragOnClick;\n    }\n\n    @property({ type: Boolean, reflect: true }) disabled = false;\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    handleDisabledChange(old, disabled: boolean) {\n      this.draggables.forEach((s, ch) => {\n        disabled ? ch.setAttribute('disabled', '') : ch.removeAttribute('disabled');\n        disabled ? ch.removeAttribute('qti-draggable') : ch.setAttribute('qti-draggable', 'true');\n      });\n    }\n\n    @property({ type: Boolean, reflect: true }) readonly = false;\n    @watch('readonly', { waitUntilFirstUpdate: true })\n    handleReadonlyChange(old, readonly: boolean) {\n      this.draggables.forEach((s, ch) => {\n        readonly ? ch.setAttribute('readonly', '') : ch.removeAttribute('readonly');\n        readonly ? ch.removeAttribute('qti-draggable') : ch.setAttribute('qti-draggable', 'true');\n      });\n    }\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    override firstUpdated(changedProps): void {\n      super.firstUpdated(changedProps);\n      this.droppables = Array.from(\n        droppablesInShadowRoot\n          ? this.shadowRoot.querySelectorAll(droppablesSelector)\n          : this.querySelectorAll(droppablesSelector)\n      );\n      // PK: Maybe later, for now we assume droppables are not dynamicly added or removed\n      // .filter((elem) => !this.droppables || !this.droppables.includes(elem));\n      // this.droppables = this.droppables ? this.droppables.concat(newDroppables) : newDroppables;\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n\n      this.dragDropApi = new TouchDragAndDrop();\n\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 handleDragStart = (ev: any) => {\n      ev.dataTransfer.setData('text', ev.currentTarget.getAttribute(`identifier`));\n      ev.currentTarget.setAttribute('dragging', '');\n\n      // highlight all droppables with an active class\n      this.droppables.forEach(d => d.setAttribute('enabled', ''));\n    };\n\n    private handleDragEnd = (ev: DragEvent) => {\n      ev.preventDefault();\n      this.droppables.forEach(d => d.removeAttribute('enabled'));\n      const draggable = ev.currentTarget as HTMLElement;\n      draggable.removeAttribute('over');\n      draggable.removeAttribute('dragging');\n\n      // pk: if not dropped on a drop location put it back where it belongs\n      if (ev.dataTransfer.dropEffect === 'none' || ev.dataTransfer.dropEffect === undefined) {\n        if (this.configuration.dragCanBePlacedBack) {\n          this.placeDraggableBack(draggable);\n        }\n      }\n      if (ev.dataTransfer.dropEffect === 'move') {\n        this.saveResponse();\n        this.checkMaxMatchAssociations();\n      }\n    };\n\n    private placeDraggableBack(draggable: HTMLElement) {\n      const position = this.draggables.get(draggable);\n      const index =\n        position.index <= position.parent.children.length ? position.index : position.parent.children.length - 1;\n      const interaction = position.parent;\n      const gapText = position.parent.children[index];\n\n      interaction.insertBefore(draggable, gapText);\n      this.saveResponse();\n      this.checkMaxMatchAssociations();\n    }\n\n    reset(save = true): void {\n      this.draggables.forEach((position, draggable) => {\n        const children = position.parent.children;\n        const index = position.index < children.length ? position.index : children.length;\n        position.parent.insertBefore(draggable, children[index]);\n      });\n      save && this.saveResponse();\n    }\n\n    protected checkMaxMatchAssociations() {\n      this.droppables.forEach(d => {\n        const maxMatch = +(d.getAttribute('match-max') || 1);\n        // const maxMin = +(d.getAttribute('match-min') || 0);\n        // const disable = maxMatch <= (d.children.length || 0);\n        const disable = maxMatch <= (d.querySelectorAll('[qti-draggable=\"true\"]').length || 0);\n\n        disable ? d.setAttribute('disabled', '') : d.removeAttribute('disabled');\n        disable ? d.removeAttribute('dropzone') : d.setAttribute('dropzone', 'move');\n      });\n    }\n\n    set response(response: string[]) {\n      // for qti-match-interaction the drag interaction can be replace with a qti-match-tabular class\n      // which shows the data in a a tabular way, so no drag drop should be involved then\n      if (this.classList.contains('qti-match-tabular')) return;\n\n      this.reset(false);\n      if (response !== null && Array.isArray(response))\n        response.forEach(response => {\n          const [dropId, ...dragIds] = response.split(' ').reverse();\n          if (dropId) {\n            const droppable = this.droppables.find(drop => drop.getAttribute('identifier') === dropId);\n            dragIds.forEach(dragId => {\n              const draggable = this.querySelector(`[identifier=${dragId}]`);\n              if (!droppable) {\n                console.error(`cannot find droppable with identifier: ${dropId}`);\n              } else if (!draggable) {\n                console.error(`cannot find draggable with identifier: ${dragId}`);\n              } else {\n                droppable.appendChild(draggable);\n                this.checkMaxMatchAssociations();\n              }\n            });\n          }\n        });\n    }\n\n    validate() {\n      const droppables = droppablesInShadowRoot\n        ? Array.from(this.shadowRoot.querySelectorAll(droppablesSelector))\n        : Array.from(this.querySelectorAll(droppablesSelector));\n      const associations = droppables.filter(d => d.childElementCount > 0).length;\n      return this.minAssociations <= 0 || this.minAssociations <= associations;\n    }\n\n    protected saveResponse() {\n      let response: string | string[];\n      if (typeof (this as any).getResponse === 'function') {\n        // only for the qti-order-interaction, abstracted this away in a method\n        response = (this as any).getResponse(); // Call the method from the implementing class\n      } else {\n        response = this.droppables.map(droppable => {\n          const dragsInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n          const identifiers = Array.from(dragsInDroppable).map(d => d.getAttribute('identifier'));\n          const droppableIdentifier = droppable.getAttribute('identifier');\n          return [...identifiers, droppableIdentifier].join(' ');\n        });\n      }\n\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  return DragDropInteractionElement as Constructor<IInteraction> & T;\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: 'response-identifier' })\n  responseIdentifier: string;\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  set response(val: Readonly<string | string[]>) {\n    this.rawResponse = val as string;\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    // throw new Error('Method not implemented.');\n    return true;\n  }\n  set response(val: undefined) {\n    // throw new Error('Method not implemented.');\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';\n\n@customElement('qti-gap-match-interaction')\nexport class QtiGapMatchInteraction extends DragDropInteractionMixin(LitElement, '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 part=\"drags\" name=\"qti-gap-text\"></slot>\n      <slot part=\"drops\"></slot>`;\n  }\n\n  set correctResponse(value: Readonly<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", "/* eslint-disable lit/no-invalid-html */\nimport { 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 response(val: string | string[]) {\n    if (Array.isArray(val)) {\n      this._lines = val;\n    }\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';\n\n@customElement('qti-graphic-gap-match-interaction')\nexport class QtiGraphicGapMatchInteraction extends DragDropInteractionMixin(\n  LitElement,\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></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, LitElement } from 'lit';\nimport { ChoicesMixin } from '../internal/choices/choices';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\nimport { customElement } from 'lit/decorators.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\n\n@customElement('qti-graphic-order-interaction')\nexport class QtiGraphicOrderInteraction extends ChoicesMixin(LitElement, 'qti-hotspot-choice') {\n  choiceOrdering: boolean;\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 QtiHotspotChoice;\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 QtiHotspotChoice[]).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 QtiHotspotChoice[]).filter(i => !!i.order).length + 1;\n        this.choiceOrdering = false;\n        return;\n      } else {\n        (this._choiceElements as QtiHotspotChoice[]).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('qti-choice-element-selected', this.setHotspotOrder);\n    this.addEventListener('qti-register-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-choice-element-selected', this.setHotspotOrder);\n    this.removeEventListener('qti-register-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';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\n@customElement('qti-hotspot-interaction')\nexport class QtiHotspotInteraction extends ChoicesMixin(LitElement, '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('qti-register-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-interaction': QtiHotspotInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\n\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { ResponseInteraction } from '../../internal/expression-result';\nimport '../qti-simple-associable-choice';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\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  LitElement,\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 override styles = [\n    css`\n      .match {\n        display: flex;\n        flex-direction: column;\n        gap: 0.5rem;\n      }\n\n      :host(.qti-choices-top) .match {\n        flex-direction: column;\n      }\n      :host(.qti-choices-bottom) .match {\n        flex-direction: column-reverse;\n      }\n      :host(.qti-choices-left) .match {\n        flex-direction: row;\n      }\n      :host(.qti-choices-right) .match {\n        flex-direction: row-reverse;\n      }\n      slot[name='prompt'] {\n        display: block;\n      }\n    `\n  ];\n\n  rows: QtiSimpleAssociableChoice[];\n  cols: QtiSimpleAssociableChoice[];\n  lastCheckedRadio: HTMLInputElement | null = null;\n\n  @state() response = [];\n  @state() correctOptions: string[] = [];\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n  connectedCallback(): void {\n    super.connectedCallback();\n    this.rows = Array.from<QtiSimpleAssociableChoice>(\n      // eslint-disable-next-line wc/no-child-traversal-in-connectedcallback\n      this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    );\n    this.cols = Array.from<QtiSimpleAssociableChoice>(\n      // eslint-disable-next-line wc/no-child-traversal-in-connectedcallback\n      this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    );\n\n    this.response = [];\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.response) {\n        this.response = [value];\n      } else if (this.response.indexOf(value) === -1) {\n        if (type === 'radio') {\n          this.response = this.response.filter(v => v.indexOf(name) === -1);\n        }\n        this.response = [...this.response, value];\n      }\n      this.lastCheckedRadio = checkbox;\n    } else {\n      this.response = this.response.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.response) ? [...this.response] : this.response\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 class=\".match\"></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.response.filter(v => v.split(' ')[0] === rowId).length || 0;\n                const checked = this.response.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';\n\n// THIS IS NOT USED IN TABULAR MATCH INTERACTION\n@customElement('qti-simple-associable-choice')\n// tslint:disable: indent\nexport class QtiSimpleAssociableChoice extends LitElement {\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, 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  value = 0;\n  reset() {\n    // throw new Error('Method not implemented.');\n  }\n  validate(): boolean {\n    // throw new Error('Method not implemented.');\n    return true;\n  }\n  set response(val: undefined) {\n    // throw new Error('Method not implemented.');\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        this.value++;\n        this.saveResponse(this.value.toString());\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';\n\n@customElement('qti-order-interaction')\nexport class QtiOrderInteraction extends ShuffleMixin(\n  DragDropInteractionMixin(LitElement, `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: Readonly<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  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 response(val: string | string[]) {\n    this._points = Array.isArray(val) ? val : [val];\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  csLive: CSSStyleDeclaration;\n\n  @query('#knob')\n  private _knob: HTMLElement;\n\n  @query('#rail')\n  private _rail: HTMLElement;\n\n  @property({ type: Number }) value: number;\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  // 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    this.value < this.min && (this.value = this.min);\n    this.value > this.max && (this.value = this.max);\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  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\n    this.dispatchEvent(\n      new CustomEvent('qti-register-hotspot', {\n        bubbles: true,\n        cancelable: false,\n        composed: true\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';\n\n@customElement('qti-gap-text')\nexport class QtiGapText extends LitElement {\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 } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { QtiChoice } from './internal/choice/qti-choice';\n\n// type shape = { shape: 'rect' | 'circle' | 'poly'; coords: number[] };\n\n@customElement('qti-hotspot-choice')\nexport class QtiHotspotChoice extends QtiChoice {\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 } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiChoice } from './internal/choice/qti-choice';\n\n@customElement('qti-hottext')\nexport class QtiHottext extends QtiChoice {\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        cancelable: false,\n        composed: true\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, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { QtiChoice } from './internal/choice/qti-choice';\n\n/**\n * @summary Short summary of the component's intended use.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.j9nu1oa1tu3b\n * @status stable\n * @since 4.0\n *\n * @event qti-choice-element-selected - Emitted when a choice is selected.\n * @event qti-register-choice - Emitted when an choice is added\n * @event qti-loose-choice - Emitted when a choice is removed\n *\n * @slot - The default slot.\n */\n@customElement('qti-simple-choice')\nexport class QtiSimpleChoice extends QtiChoice {\n  static styles = css`\n    :host {\n      display: flex;\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  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/choice/qti-choice';\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": ["provide", "LitElement", "html", "customElement", "property", "watch", "propertyName", "options", "resolvedOptions", "__spreadValues", "proto", "decoratedFnName", "update", "watchedProperties", "changedProps", "property", "key", "oldValue", "newValue", "createContext", "itemContextVariables", "itemContext", "QtiAssessmentItem", "LitElement", "_", "disabled", "ch", "readonly", "itemContextVariables", "__spreadProps", "__spreadValues", "feedbackElement", "responseIdentifier", "countAttempt", "outcomeIdentifier", "value", "v", "variable", "matchingValue", "interactionElement", "el", "fe", "myResponses", "response", "interaction", "i", "html", "show", "responses", "vari", "cr", "countNumAttempts", "_a", "responseProcessor", "identifier", "event", "outcomeVariable", "name", "detail", "__decorateClass", "property", "watch", "provide", "itemContext", "customElement", "LitElement", "customElement", "property", "QtiAssessmentStimulusRef", "LitElement", "event", "stimulusRef", "_a", "path", "stimulus", "qtiTransformItem", "api", "elements", "__decorateClass", "property", "customElement", "LitElement", "html", "property", "KEYCODE", "QtiChoice", "LitElement", "_", "disabled", "event", "html", "__decorateClass", "property", "value", "watch", "customElement", "html", "LitElement", "css", "qti_item_body_styles_default", "QtiItemBody", "LitElement", "html", "qti_item_body_styles_default", "__decorateClass", "customElement", "html", "LitElement", "customElement", "QtiPrompt", "LitElement", "html", "__decorateClass", "customElement", "LitElement", "customElement", "QtiStylesheet", "LitElement", "_changedProperties", "item", "link", "styles", "error", "__decorateClass", "customElement", "consume", "css", "html", "customElement", "property", "state", "html", "LitElement", "customElement", "QtiVariableDeclaration", "LitElement", "html", "variable", "htmlValues", "defaultValues", "n", "__decorateClass", "customElement", "QtiOutcomeDeclaration", "QtiVariableDeclaration", "_a", "_b", "value", "v", "html", "table", "entries", "entry", "sourceValue", "targetValue", "outcomeVariable", "css", "__decorateClass", "property", "consume", "itemContext", "state", "customElement", "consume", "css", "html", "customElement", "property", "state", "QtiResponseDeclaration", "QtiVariableDeclaration", "_a", "_b", "value", "v", "html", "responseVariable", "result", "correctResponse", "values", "i", "css", "__decorateClass", "property", "consume", "itemContext", "state", "customElement", "LitElement", "customElement", "QtiCompanionMaterialsInfo", "LitElement", "__decorateClass", "customElement", "LitElement", "html", "customElement", "QtiContentBody", "LitElement", "html", "__decorateClass", "customElement", "LitElement", "css", "html", "customElement", "property", "QtiRubricBlock", "LitElement", "old", "disabled", "className", "html", "css", "__decorateClass", "property", "watch", "customElement", "css", "html", "customElement", "LitElement", "property", "decimalSeparator", "convertNumberToUniveralFormat", "number", "dSep", "IsNullOrUndefined", "value", "removeDoubleSlashes", "str", "QtiFeedback", "LitElement", "outcomeIdentifier", "outcomeVariable", "isFound", "IsNullOrUndefined", "value", "__decorateClass", "property", "QtiFeedbackBlock", "QtiFeedback", "html", "_changedProperties", "css", "__decorateClass", "customElement", "css", "html", "customElement", "QtiFeedbackInline", "QtiFeedback", "html", "css", "__decorateClass", "customElement", "css", "html", "customElement", "QtiModalFeedback", "QtiFeedback", "html", "css", "__decorateClass", "customElement", "css", "html", "ifDefined", "property", "LitElement", "Interaction", "LitElement", "val", "value", "__decorateClass", "property", "ref", "createRef", "customElement", "property", "state", "QtiExtendedTextInteraction", "Interaction", "createRef", "old", "disabled", "className", "nrRows", "value", "css", "html", "ref", "event", "input", "ifDefined", "text", "__decorateClass", "property", "state", "watch", "customElement", "css", "html", "customElement", "property", "state", "ifDefined", "createRef", "liveQuery", "querySelector", "options", "observer", "resolvedOptions", "__spreadValues", "proto", "decoratedFnName", "connectedCallback", "disconnectedCallback", "_a", "callback", "mutationList", "elementsToWatch", "mutation", "addedNodes", "e", "removedNodes", "n", "elementsAdded", "QtiTextEntryInteraction", "Interaction", "createRef", "old", "classes", "className", "nrRows", "value", "css", "html", "event", "input", "ifDefined", "text", "__decorateClass", "property", "state", "watch", "customElement", "html", "LitElement", "customElement", "property", "ChoicesMixin", "superClass", "selector", "ChoicesMixinElement", "args", "_", "disabled", "ch", "readonly", "acc", "val", "responseValue", "responseValueArray", "ce", "rv", "e", "choiceElement", "event", "selectedIdentifiers", "result", "response", "__decorateClass", "property", "watch", "QtiHottextInteraction", "ChoicesMixin", "LitElement", "html", "__decorateClass", "customElement", "css", "html", "customElement", "property", "state", "unsafeHTML", "QtiInlineChoiceInteraction", "Interaction", "css", "html", "option", "unsafeHTML", "choices", "choice", "selectedOption", "i", "__spreadProps", "__spreadValues", "value", "event", "selectedOptionValue", "__decorateClass", "state", "property", "customElement", "html", "LitElement", "customElement", "property", "property", "ShuffleMixin", "superClass", "selector", "ShuffleElement", "value", "oldValue", "choices", "fixedElements", "nonFixedElements", "choice", "index", "isShuffled", "maxAttempts", "attempt", "i", "j", "order", "__decorateClass", "property", "stringToBooleanConverter", "property", "VocabularyMixin", "superClass", "selector", "VocabularyElement", "value", "_a", "_changedProperties", "classContainsLabel", "cls", "isNumber", "choices", "c", "choice", "index", "a", "b", "i", "lastLabel", "lastLabelSuffix", "label", "__decorateClass", "property", "css", "qti_choice_interaction_styles_default", "QtiChoiceInteraction", "VocabularyMixin", "ShuffleMixin", "ChoicesMixin", "LitElement", "html", "qti_choice_interaction_styles_default", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "customElement", "QtiOutcomeProcessing", "LitElement", "html", "logic", "QtiOutcomeProcessingProcessor", "rules", "css", "__decorateClass", "customElement", "rule", "css", "html", "LitElement", "customElement", "matchCorrect", "mapResponse", "mapResponsePoint", "QtiResponseProcessing", "LitElement", "html", "rules", "rule", "_changedProperties", "splittedTemplateName", "templateName", "mapResponse", "mapResponsePoint", "matchCorrect", "strHTML", "css", "__decorateClass", "customElement", "property", "customElement", "html", "LitElement", "QtiRule", "LitElement", "html", "__decorateClass", "customElement", "QtiLookupOutcomeValue", "QtiRule", "identifier", "outcomeVariable", "value", "convertNumberToUniveralFormat", "__decorateClass", "property", "html", "QtiResponseCondition", "QtiRule", "html", "branches", "i", "branch", "QtiSetOutcomeValue", "QtiRule", "outcomeIdentifier", "expression", "value", "QtiSetOutcomeValueRule", "v", "convertNumberToUniveralFormat", "LitElement", "html", "QtiResponseElse", "subRules", "i", "html", "QtiResponseIf", "QtiResponseElse", "result", "i", "QtiResponseElseIf", "QtiResponseIf", "html", "LitElement", "css", "html", "state", "QtiExpression", "LitElement", "identifier", "values", "v", "responseVariable", "error", "html", "css", "__decorateClass", "state", "QtiConditionExpression", "QtiExpression", "QtiAnd", "qtiAndMixin", "QtiConditionExpression", "Base", "children", "c", "condition", "value", "e", "QtiAnd", "property", "QtiBaseValue", "QtiExpression", "__decorateClass", "property", "QtiContains", "QtiConditionExpression", "values", "value1", "value2", "projection1", "projection2", "x", "QtiCorrect", "QtiExpression", "identifier", "responseVariable", "property", "QtiEqualRounded", "QtiExpression", "figures", "values", "value1", "value2", "float1", "float2", "__decorateClass", "property", "property", "ScoringHelper", "value1", "value2", "baseType", "int1", "int2", "float1", "float2", "pair1", "pair2", "QtiEqual", "QtiExpression", "values", "value1", "value2", "ScoringHelper", "__decorateClass", "property", "QtiGt", "QtiExpression", "values", "value1", "value2", "QtiGte", "QtiConditionExpression", "values", "value1", "value2", "QtiIsNull", "QtiExpression", "variables", "value", "QtiLt", "QtiExpression", "values", "value1", "value2", "QtiLte", "QtiConditionExpression", "values", "value1", "value2", "property", "QtiMapResponse", "QtiExpression", "response", "mapping", "candidateResponses", "result", "candidateResponse", "mappedValue", "entry", "ScoringHelper", "__decorateClass", "property", "property", "LitElement", "QtiMapping", "LitElement", "el", "__decorateClass", "property", "QtiMatch", "_QtiMatch", "QtiExpression", "values", "valueToMap", "correctValueInfo", "_a", "ScoringHelper", "i", "answerIndex", "correctAnswer", "matchingValue", "arr", "mv", "QtiMember", "QtiExpression", "values", "value1", "value2", "projection1", "QtiMultiple", "QtiExpression", "variables", "variable", "html", "QtiNot", "QtiExpression", "html", "QtiOr", "QtiConditionExpression", "c", "condition", "value", "QtiOrdered", "QtiExpression", "variables", "variable", "consume", "LitElement", "html", "property", "state", "QtPrintedVariable", "LitElement", "_a", "_b", "value", "v", "html", "assessmentItem", "identifier", "__decorateClass", "property", "consume", "itemContext", "state", "QtiProduct", "QtiExpression", "accumulator", "currentValue", "error", "property", "QtiStringMatch", "QtiExpression", "values", "value1", "value2", "v1", "v2", "ScoringHelper", "__decorateClass", "property", "QtiSum", "QtiExpression", "QtiSumExpression", "expressions", "c", "value", "a", "b", "QtiVariable", "QtiExpression", "identifier", "html", "customElement", "property", "state", "QtiPortableCustomInteraction", "Interaction", "url", "baseUrl", "requireConfig", "moduleCong", "moduleId", "e", "path", "basePath", "p", "input", "topLevelKey", "nestedObject", "nestedKey", "value", "response", "newResponse", "stringified", "val", "node", "a", "config", "getPropertyValue", "el", "property", "key", "children", "allKey", "c", "k", "getChildProperties", "properties", "child", "__spreadValues", "pci", "type", "dom", "acc", "link", "styles", "ctxA", "require", "context", "interactionModules", "modules", "module", "primaryPath", "fallbackPath", "paths", "existingPath", "path1", "path2", "path1Array", "path2Array", "str", "html", "__decorateClass", "state", "customElement", "LitElement", "css", "html", "customElement", "state", "TouchDragAndDrop", "_TouchDragAndDrop", "type", "val", "e", "_touches", "elementStyles", "style", "_this", "target", "draggables", "el", "x", "y", "_a", "event", "pointFromTouchEvent", "visited", "root", "nestedEl", "page", "touch", "clientRect", "eventType", "bubble", "property", "DroppablesMixin", "superClass", "droppablesInShadowRoot", "droppablesSelector", "DroppablesElement", "changedProps", "droppables", "d", "droppable", "mutations", "mutation", "_a", "ev", "draggableInLightDom", "draggable", "__decorateClass", "property", "FlippablesMixin", "superClass", "droppablesSel", "draggablesSel", "FlippablesElement", "property", "DragDropInteractionMixin", "superClass", "draggablesSelector", "droppablesInShadowRoot", "droppablesSelector", "DragDropInteractionElement", "FlippablesMixin", "DroppablesMixin", "ev", "d", "draggable", "dragsAdded", "dragsRemoved", "elem", "old", "dragOptions", "disabled", "s", "ch", "readonly", "changedProps", "TouchDragAndDrop", "position", "index", "interaction", "gapText", "save", "children", "disable", "response", "dropId", "dragIds", "droppable", "drop", "dragId", "associations", "dragsInDroppable", "identifiers", "droppableIdentifier", "__decorateClass", "liveQuery", "property", "watch", "QtiAssociateInteraction", "DragDropInteractionMixin", "LitElement", "html", "_", "index", "css", "__decorateClass", "state", "customElement", "html", "customElement", "property", "state", "QtiCustomInteraction", "Interaction", "uriToManifest", "removeDoubleSlashes", "response", "data", "err", "iframe", "iframeWin", "iframeDoc", "iframesInShadowRoot", "outerIFrames", "iframeSrc", "outerDoc", "e", "index", "iframeDocument", "iframes", "nestedDoc", "type", "event", "mediaData", "media", "val", "html", "__decorateClass", "property", "state", "customElement", "html", "customElement", "property", "QtiEndAttemptInteraction", "Interaction", "val", "html", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "customElement", "QtiGapMatchInteraction", "DragDropInteractionMixin", "LitElement", "html", "value", "matches", "response", "x", "split", "gap", "index", "_a", "_b", "_c", "_d", "identifier", "textIdentifier", "text", "textSpan", "css", "__decorateClass", "customElement", "css", "html", "svg", "customElement", "query", "queryAssignedElements", "state", "ifDefined", "repeat", "positionHotspots", "shape", "coordsNumber", "img", "hotspot", "centerX", "centerY", "radius", "centerXPer", "centerYPer", "radiusPer", "leftX", "topY", "rightX", "bottomY", "leftXPer", "topYPer", "rightXPer", "bottomYPer", "polycoords", "acc", "currentValue", "currentIndex", "polyC", "lastVal", "point", "polyD", "p", "QtiGraphicAssociateInteraction", "Interaction", "val", "_a", "_b", "_c", "_d", "html", "ifDefined", "repeat", "line", "index", "svg", "e", "_", "i", "img", "hotspot", "coords", "shape", "coordsNumber", "s", "positionHotspots", "event", "css", "__decorateClass", "state", "query", "queryAssignedElements", "customElement", "css", "html", "LitElement", "customElement", "QtiGraphicGapMatchInteraction", "DragDropInteractionMixin", "LitElement", "html", "e", "img", "hotspot", "coords", "shape", "coordsNumber", "s", "centerX", "centerY", "radius", "leftX", "topY", "rightX", "bottomY", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "QtiGraphicOrderInteraction", "ChoicesMixin", "LitElement", "html", "e", "identifier", "hotspot", "el", "maxSelection", "i", "img", "coords", "shape", "coordsNumber", "s", "positionHotspots", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "QtiHotspotInteraction", "ChoicesMixin", "LitElement", "html", "e", "img", "hotspot", "coords", "shape", "coordsNumber", "s", "positionHotspots", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "state", "unsafeHTML", "css", "html", "LitElement", "customElement", "property", "QtiSimpleAssociableChoice", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "QtiMatchInteraction", "DragDropInteractionMixin", "LitElement", "radio", "checkbox", "value", "name", "type", "v", "responseValue", "html", "col", "i", "unsafeHTML", "row", "rIndex", "cIndex", "rowId", "colId", "selectedInRowCount", "checked", "part", "disable", "e", "css", "__decorateClass", "state", "property", "customElement", "css", "html", "customElement", "QtiMediaInteraction", "Interaction", "val", "__spreadProps", "__spreadValues", "html", "mediaObject", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "state", "unsafeHTML", "QtiOrderInteraction", "ShuffleMixin", "DragDropInteractionMixin", "LitElement", "choices", "html", "_", "i", "unsafeHTML", "value", "response", "index", "simpleChoice", "text", "droppable", "dragsInDroppable", "d", "changedProps", "el", "css", "__decorateClass", "state", "property", "customElement", "LitElement", "css", "html", "QtiSPositionObjectInteraction", "LitElement", "css", "html", "customElement", "QtiPositionObjectStage", "LitElement", "html", "event", "deltaX", "deltaY", "a", "css", "__decorateClass", "customElement", "css", "html", "customElement", "property", "state", "repeat", "styleMap", "QtiSelectPointInteraction", "Interaction", "event", "x", "y", "html", "repeat", "point", "index", "styleMap", "e", "_", "i", "val", "css", "__decorateClass", "property", "state", "customElement", "css", "html", "nothing", "customElement", "property", "query", "QtiSliderInteraction", "Interaction", "old", "disabled", "readonly", "value", "myResponse", "valuePercentage", "html", "nothing", "event", "handleTouchMove", "x", "diffX", "handleTouchEnd", "handleMouseMove", "handleMouseUp", "valueNow", "roundedStepValue", "_touchMove", "evt", "touch", "css", "__decorateClass", "query", "property", "watch", "customElement", "consume", "LitElement", "html", "customElement", "state", "QtiCustomOperator", "LitElement", "html", "event", "_a", "_b", "_c", "commentNode", "node", "e", "fn", "responseIdentifier", "v", "item", "variableIdentifier", "outcomeIdentifier", "value", "response", "__decorateClass", "consume", "itemContext", "state", "customElement", "LitElement", "css", "html", "customElement", "QtiAssociableHotspot", "LitElement", "html", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "QtiGap", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "LitElement", "customElement", "property", "QtiGapImg", "LitElement", "css", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "customElement", "property", "QtiGapText", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "customElement", "property", "QtiHotspotChoice", "QtiChoice", "css", "__decorateClass", "property", "customElement", "css", "html", "customElement", "QtiHottext", "QtiChoice", "html", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "QtiInlineChoice", "LitElement", "css", "html", "__decorateClass", "property", "customElement", "css", "html", "nothing", "customElement", "property", "QtiSimpleChoice", "QtiChoice", "html", "nothing", "css", "__decorateClass", "property", "customElement"]
}
