@citolab/qti-components 6.9.1-beta.50 → 6.9.1-beta.52

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,20 +1,20 @@
1
- import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../chunk-NYAUPIAG.js";import{provide as gr}from"@lit/context";import{LitElement as br,html as vr}from"lit";import{customElement as yr,property as K}from"lit/decorators.js";function x(c,i){let e=b({waitUntilFirstUpdate:!1},i);return(t,r)=>{let{update:s}=t,o=Array.isArray(c)?c:[c];t.update=function(a){o.forEach(l=>{let p=l;if(a.has(p)){let d=a.get(p),u=this[p];d!==u&&(!e.waitUntilFirstUpdate||this.hasUpdated)&&this[r](d,u)}}),s.call(this,a)}}}import{createContext as fr}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"}],R=fr("item");var q=class extends br{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=C(b({},this._context),{variables:this._context.variables});this._feedbackElements=[];this._interactionElements=[];this.addEventListener("qti-register-variable",e=>{this._context=C(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=C(b({},this._context),{variables:this._context.variables.map(t=>{let r=e.find(s=>s.identifier===t.identifier);return r?b(b({},t),r):t})}),this._context.variables.forEach(t=>{if(t.type==="response"){let r=this._interactionElements.find(s=>s.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 s=this._interactionElements.find(o=>o.getAttribute("response-identifier")===t.responseIdentifier);s&&(s.response=t.response)}}render(){return vr`<slot></slot>`}showCorrectResponse(e){let r=this._context.variables.filter(s=>"correctResponse"in s&&s.correctResponse).map(s=>({responseIdentifier:s.identifier,response:s.correctResponse}));for(let s of r){let o=this._interactionElements.find(a=>a.getAttribute("response-identifier")===s.responseIdentifier);o&&(o.correctResponse=e?s.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(s=>s.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=C(b({},this._context),{variables:this._context.variables.map(r=>r.identifier!==e?r:C(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 s;let r=this.getOutcome(e);if(!r){console.warn(`Can not set qti-outcome-identifier: ${e}, it is not available`);return}this._context=C(b({},this._context),{variables:this._context.variables.map(o=>o.identifier!==e?o:C(b({},o),{value:r.cardinality==="single"?t:[...o.value,t]}))}),this._feedbackElements.forEach(o=>o.checkShowFeedback(e)),this._emit("qti-outcome-changed",{item:this.identifier,outcomeIdentifier:e,value:(s=this._context.variables.find(o=>o.identifier===e))==null?void 0:s.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}))}};n([K({type:String})],q.prototype,"title",2),n([K({type:String})],q.prototype,"identifier",2),n([K({type:String})],q.prototype,"adaptive",2),n([K({type:String})],q.prototype,"timeDependent",2),n([K({type:Boolean})],q.prototype,"disabled",2),n([x("disabled",{waitUntilFirstUpdate:!0})],q.prototype,"_handleDisabledChange",2),n([K({type:Boolean})],q.prototype,"readonly",2),n([x("readonly",{waitUntilFirstUpdate:!0})],q.prototype,"_handleReadonlyChange",2),n([gr({context:R})],q.prototype,"_context",2),q=n([yr("qti-assessment-item")],q);import{LitElement as xr}from"lit";import{customElement as Er,property as Nt}from"lit/decorators.js";var W=class extends xr{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 s=this.closest("qti-assessment-item").querySelector(`[data-stimulus-idref=${this.identifier}]`);s?await this.updateStimulusRef(s):console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`)}}async updateStimulusRef(e){let t=this.href.substring(0,this.href.lastIndexOf("/")),r=await Dt().load(this.href).then(s=>s.path(t).htmldoc());if(r){let s=r.querySelectorAll("qti-stimulus-body, qti-stylesheet");e.innerHTML="",e.append(...s)}}};n([Nt({type:String})],W.prototype,"identifier",2),n([Nt({type:String})],W.prototype,"href",2),W=n([Er("qti-assessment-stimulus-ref")],W);import{html as Cr}from"lit";import{property as Ae}from"lit/decorators.js";var Vt={toAttribute:c=>c?"true":"false",fromAttribute:c=>c==="true"};function M(c,i){class e extends c{constructor(...s){super(...s);this.identifier="";this.tabIndex=0;this.disabled=!1;this.readonly=!1;this._internals=this.attachInternals()}handleDisabledChange(s,o){this.tabIndex=o?-1:0,o&&this.blur()}setInternalState(s,o){o&&!this._internals.states.has(s)?this._internals.states.add(s):!o&&this._internals.states.has(s)&&this._internals.states.delete(s)}connectedCallback(){super.connectedCallback(),this.addEventListener("keyup",this._onKeyUp),this.addEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent(`register-${i}`,{bubbles:!0,composed:!0}))}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("keyup",this._onKeyUp),this.removeEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent(`unregister-${i}`,{bubbles:!0,composed:!0}))}_onKeyUp(s){s.altKey||s.code==="Space"&&(s.preventDefault(),this._activate())}_onClick(){this.disabled||this.readonly||(this.focus(),this._activate())}_activate(){this.disabled||this.readonly||this.dispatchEvent(new CustomEvent(`activate-${i}`,{bubbles:!0,composed:!0,detail:{identifier:this.identifier}}))}render(){return Cr`<slot></slot>`}}return n([Ae({type:String})],e.prototype,"identifier",2),n([Ae({type:Number,reflect:!0,attribute:"tabindex"})],e.prototype,"tabIndex",2),n([Ae({type:Boolean,reflect:!0,attribute:"aria-disabled",converter:Vt})],e.prototype,"disabled",2),n([Ae({type:Boolean,reflect:!0,attribute:"aria-readonly",converter:Vt})],e.prototype,"readonly",2),n([x("disabled",{waitUntilFirstUpdate:!0})],e.prototype,"handleDisabledChange",1),e}import{customElement as Tr}from"lit/decorators.js";import{html as wr,LitElement as Sr}from"lit";import{css as qr}from"lit";var $t=qr`
1
+ import{a as Rt}from"../chunk-SOXSSPDZ.js";import{a as b,b as C,c as a}from"../chunk-NYAUPIAG.js";import{provide as hr}from"@lit/context";import{LitElement as fr,html as gr}from"lit";import{customElement as br,property as K}from"lit/decorators.js";function x(c,i){let e=b({waitUntilFirstUpdate:!1},i);return(t,r)=>{let{update:s}=t,o=Array.isArray(c)?c:[c];t.update=function(n){o.forEach(l=>{let p=l;if(n.has(p)){let d=n.get(p),m=this[p];d!==m&&(!e.waitUntilFirstUpdate||this.hasUpdated)&&this[r](d,m)}}),s.call(this,n)}}}import{createContext as mr}from"@lit/context";var Lt=[{identifier:"completionStatus",cardinality:"single",baseType:"string",value:"unknown",type:"outcome"},{identifier:"numAttempts",cardinality:"single",baseType:"integer",value:"0",type:"response"}],M=mr("item");var q=class extends fr{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:Lt};this._initialContext=C(b({},this._context),{variables:this._context.variables});this._feedbackElements=[];this._interactionElements=[];this.addEventListener("qti-register-variable",e=>{this._context=C(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=C(b({},this._context),{variables:this._context.variables.map(t=>{let r=e.find(s=>s.identifier===t.identifier);return r?b(b({},t),r):t})}),this._context.variables.forEach(t=>{if(t.type==="response"){let r=this._interactionElements.find(s=>s.responseIdentifier===t.identifier);r&&(r.value=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 s=this._interactionElements.find(o=>o.getAttribute("response-identifier")===t.responseIdentifier);s&&(s.value=t.response)}}render(){return gr`<slot></slot>`}showCorrectResponse(e){let r=this._context.variables.filter(s=>"correctResponse"in s&&s.correctResponse).map(s=>({responseIdentifier:s.identifier,response:s.correctResponse}));for(let s of r){let o=this._interactionElements.find(n=>n.getAttribute("response-identifier")===s.responseIdentifier);o&&(o.correctResponse=e?s.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(s=>s.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=C(b({},this._context),{variables:this._context.variables.map(r=>r.identifier!==e?r:C(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 s;let r=this.getOutcome(e);if(!r){console.warn(`Can not set qti-outcome-identifier: ${e}, it is not available`);return}this._context=C(b({},this._context),{variables:this._context.variables.map(o=>o.identifier!==e?o:C(b({},o),{value:r.cardinality==="single"?t:[...o.value,t]}))}),this._feedbackElements.forEach(o=>o.checkShowFeedback(e)),this._emit("qti-outcome-changed",{item:this.identifier,outcomeIdentifier:e,value:(s=this._context.variables.find(o=>o.identifier===e))==null?void 0:s.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}))}};a([K({type:String})],q.prototype,"title",2),a([K({type:String})],q.prototype,"identifier",2),a([K({type:String})],q.prototype,"adaptive",2),a([K({type:String})],q.prototype,"timeDependent",2),a([K({type:Boolean})],q.prototype,"disabled",2),a([x("disabled",{waitUntilFirstUpdate:!0})],q.prototype,"_handleDisabledChange",2),a([K({type:Boolean})],q.prototype,"readonly",2),a([x("readonly",{waitUntilFirstUpdate:!0})],q.prototype,"_handleReadonlyChange",2),a([hr({context:M})],q.prototype,"_context",2),q=a([br("qti-assessment-item")],q);import{LitElement as vr}from"lit";import{customElement as yr,property as At}from"lit/decorators.js";var W=class extends vr{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 s=this.closest("qti-assessment-item").querySelector(`[data-stimulus-idref=${this.identifier}]`);s?await this.updateStimulusRef(s):console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`)}}async updateStimulusRef(e){let t=this.href.substring(0,this.href.lastIndexOf("/")),r=await Rt().load(this.href).then(s=>s.path(t).htmlDoc());if(r){let s=r.querySelectorAll("qti-stimulus-body, qti-stylesheet");e.innerHTML="",e.append(...s)}}};a([At({type:String})],W.prototype,"identifier",2),a([At({type:String})],W.prototype,"href",2),W=a([yr("qti-assessment-stimulus-ref")],W);import{html as xr}from"lit";import{property as Re}from"lit/decorators.js";var Dt={toAttribute:c=>c?"true":"false",fromAttribute:c=>c==="true"};function _(c,i){class e extends c{constructor(...s){super(...s);this.identifier="";this.tabIndex=0;this.disabled=!1;this.readonly=!1;this.internals=this.attachInternals()}handleDisabledChange(s,o){this.tabIndex=o?-1:0,o&&this.blur()}connectedCallback(){super.connectedCallback(),this.addEventListener("keyup",this._onKeyUp),this.addEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent(`register-${i}`,{bubbles:!0,composed:!0}))}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("keyup",this._onKeyUp),this.removeEventListener("click",this._onClick),this.dispatchEvent(new CustomEvent(`unregister-${i}`,{bubbles:!0,composed:!0}))}_onKeyUp(s){s.altKey||s.code==="Space"&&(s.preventDefault(),this._activate())}_onClick(){this.disabled||this.readonly||(this.focus(),this._activate())}_activate(){this.disabled||this.readonly||this.dispatchEvent(new CustomEvent(`activate-${i}`,{bubbles:!0,composed:!0,detail:{identifier:this.identifier}}))}render(){return xr`<slot></slot>`}}return a([Re({type:String})],e.prototype,"identifier",2),a([Re({type:Number,reflect:!0,attribute:"tabindex"})],e.prototype,"tabIndex",2),a([Re({type:Boolean,reflect:!0,attribute:"aria-disabled",converter:Dt})],e.prototype,"disabled",2),a([Re({type:Boolean,reflect:!0,attribute:"aria-readonly",converter:Dt})],e.prototype,"readonly",2),a([x("disabled",{waitUntilFirstUpdate:!0})],e.prototype,"handleDisabledChange",1),e}import{customElement as Cr}from"lit/decorators.js";import{html as qr,LitElement as wr}from"lit";import{css as Er}from"lit";var Vt=Er`
2
2
  :host {
3
3
  display: block;
4
4
  }
5
- `;var Z=class extends Sr{render(){return wr`<slot name="qti-rubric-block"></slot><slot></slot>`}};Z.styles=$t,Z=n([Tr("qti-item-body")],Z);import{html as kr,LitElement as Lr}from"lit";import{customElement as Rr}from"lit/decorators.js";var _e=class extends Lr{render(){return kr`<slot></slot>`}connectedCallback(){this.parentElement.tagName.endsWith("INTERACTION")&&this.setAttribute("slot","prompt")}};_e=n([Rr("qti-prompt")],_e);import{LitElement as Mr}from"lit";import{customElement as Ar}from"lit/decorators.js";var De=class extends Mr{firstUpdated(i){super.firstUpdated(i);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(i){console.log("could not remove stylesheet")}}};De=n([Ar("qti-stylesheet")],De);import{consume as Nr}from"@lit/context";import{css as Vr,html as $r}from"lit";import{customElement as Pr,property as He,state as Ir}from"lit/decorators.js";import{html as _r,LitElement as Dr}from"lit";import{customElement as Hr}from"lit/decorators.js";var O=class extends Dr{render(){return _r`<slot></slot>`}defaultValues(i){let e=Array.from(this.querySelectorAll("qti-default-value > qti-value"));if(e.length===0)return null;let t=e.map(r=>r.innerHTML.trim());return t.length>1||i.cardinality==="multiple"||i.cardinality==="ordered"?t:t[0]}};O=n([Hr("qti-variabledeclaration")],O);var A=class extends O{constructor(){super(...arguments);this.externalScored=null}render(){var t,r;let e=(r=(t=this.itemContext)==null?void 0:t.variables.find(s=>s.identifier===this.identifier))==null?void 0:r.value;return $r`${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 s=parseInt(r.getAttribute("source-value")),o=parseInt(r.getAttribute("target-value"));(isNaN(s)||isNaN(o))&&console.error("source-value or target-value is not a number in qti-interpolation-table-entry"),t.set(s,o)}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}}))}};A.styles=[Vr`
5
+ `;var ne=class extends wr{render(){return qr`<slot name="qti-rubric-block"></slot><slot></slot>`}};ne.styles=Vt,ne=a([Cr("qti-item-body")],ne);import{html as Tr,LitElement as Sr}from"lit";import{customElement as kr}from"lit/decorators.js";var Le=class extends Sr{render(){return Tr`<slot></slot>`}connectedCallback(){this.parentElement.tagName.endsWith("INTERACTION")&&this.setAttribute("slot","prompt")}};Le=a([kr("qti-prompt")],Le);import{LitElement as Mr}from"lit";import{customElement as _r}from"lit/decorators.js";var Ae=class extends Mr{constructor(){super(...arguments);this.styleElement=null}firstUpdated(e){super.firstUpdated(e);let t=this.getAttribute("href");if(t!==null&&fetch(t).then(r=>r.text()).then(r=>{let s=this.minifyCss(r);this.styleElement=document.createElement("style"),this.styleElement.media="screen",this.styleElement.textContent=`@scope {${s}}`,this.parentElement?this.parentElement.appendChild(this.styleElement):console.warn("No parent element to append the scoped stylesheet to.")}).catch(r=>{console.error("Failed to load stylesheet:",r)}),this.textContent!==null&&this.textContent.trim()!==""){let r=this.minifyCss(this.textContent);this.styleElement=document.createElement("style"),this.styleElement.media="screen",this.styleElement.textContent=`@scope {${r}}`,this.parentElement?this.parentElement.appendChild(this.styleElement):console.warn("No parent element to append the scoped stylesheet to.")}}minifyCss(e){return e.replace(/\/\*[\s\S]*?\*\//g,"").replace(/\s+/g," ").replace(/\s*([{}:;])\s*/g,"$1").trim()}disconnectedCallback(){if(this.styleElement)try{this.styleElement.remove()}catch(e){console.error("Could not remove stylesheet:",e)}super.disconnectedCallback()}};Ae=a([_r("qti-stylesheet")],Ae);import{consume as Dr}from"@lit/context";import{css as Vr,html as Hr}from"lit";import{customElement as Nr,property as De,state as $r}from"lit/decorators.js";import{html as Rr,LitElement as Lr}from"lit";import{customElement as Ar}from"lit/decorators.js";var O=class extends Lr{render(){return Rr`<slot></slot>`}defaultValues(i){let e=Array.from(this.querySelectorAll("qti-default-value > qti-value"));if(e.length===0)return null;let t=e.map(r=>r.innerHTML.trim());return t.length>1||i.cardinality==="multiple"||i.cardinality==="ordered"?t:t[0]}};O=a([Ar("qti-variabledeclaration")],O);var R=class extends O{constructor(){super(...arguments);this.externalScored=null}render(){var t,r;let e=(r=(t=this.itemContext)==null?void 0:t.variables.find(s=>s.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 s=parseInt(r.getAttribute("source-value")),o=parseInt(r.getAttribute("target-value"));(isNaN(s)||isNaN(o))&&console.error("source-value or target-value is not a number in qti-interpolation-table-entry"),t.set(s,o)}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}}))}};R.styles=[Vr`
6
6
  :host {
7
7
  display: none;
8
8
  }
9
- `],n([He({type:String,attribute:"base-type"})],A.prototype,"baseType",2),n([He({type:String,attribute:"external-scored"})],A.prototype,"externalScored",2),n([He({type:String})],A.prototype,"identifier",2),n([He({type:String})],A.prototype,"cardinality",2),n([Nr({context:R,subscribe:!0}),Ir()],A.prototype,"itemContext",2),A=n([Pr("qti-outcome-declaration")],A);import{consume as Or}from"@lit/context";import{css as Ur,html as Fr}from"lit";import{customElement as Br,property as Ge,state as Xr}from"lit/decorators.js";var P=class extends O{render(){var e,t;let i=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return Fr`${JSON.stringify(i,null,2)}`}connectedCallback(){super.connectedCallback();let i={baseType:this.baseType,identifier:this.identifier,correctResponse:this.correctResponse,cardinality:this.cardinality||"single",mapping:this.mapping,value:null,type:"response",candidateResponse:null};i.value=this.defaultValues(i),this.dispatchEvent(new CustomEvent("qti-register-variable",{bubbles:!0,composed:!0,detail:{variable:i}}))}get correctResponse(){let i,e=this.querySelector("qti-correct-response");if(e){let t=e.querySelectorAll("qti-value");if(this.cardinality==="single"&&t.length>0)i=t[0].textContent,t[0].remove();else if(this.cardinality!=="single"){i=[];for(let r=0;r<t.length;r++)i.push(t[r].textContent),t[r].remove()}}return i}get mapping(){return this.querySelector("qti-mapping")}};P.styles=[Ur`
9
+ `],a([De({type:String,attribute:"base-type"})],R.prototype,"baseType",2),a([De({type:String,attribute:"external-scored"})],R.prototype,"externalScored",2),a([De({type:String})],R.prototype,"identifier",2),a([De({type:String})],R.prototype,"cardinality",2),a([Dr({context:M,subscribe:!0}),$r()],R.prototype,"itemContext",2),R=a([Nr("qti-outcome-declaration")],R);import{consume as Ir}from"@lit/context";import{css as Pr,html as Or}from"lit";import{customElement as Ur,property as Je,state as Fr}from"lit/decorators.js";var I=class extends O{render(){var e,t;let i=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return Or`${JSON.stringify(i,null,2)}`}connectedCallback(){super.connectedCallback();let i={baseType:this.baseType,identifier:this.identifier,correctResponse:this.correctResponse,cardinality:this.cardinality||"single",mapping:this.mapping,value:null,type:"response",candidateResponse:null};i.value=this.defaultValues(i),this.dispatchEvent(new CustomEvent("qti-register-variable",{bubbles:!0,composed:!0,detail:{variable:i}}))}get correctResponse(){let i,e=this.querySelector("qti-correct-response");if(e){let t=e.querySelectorAll("qti-value");if(this.cardinality==="single"&&t.length>0)i=t[0].textContent,t[0].remove();else if(this.cardinality!=="single"){i=[];for(let r=0;r<t.length;r++)i.push(t[r].textContent),t[r].remove()}}return i}get mapping(){return this.querySelector("qti-mapping")}};I.styles=[Pr`
10
10
  :host {
11
11
  display: none;
12
12
  }
13
- `],n([Ge({type:String,attribute:"base-type"})],P.prototype,"baseType",2),n([Ge({type:String})],P.prototype,"identifier",2),n([Ge({type:String})],P.prototype,"cardinality",2),n([Or({context:R,subscribe:!0}),Xr()],P.prototype,"itemContext",2),P=n([Br("qti-response-declaration")],P);import{LitElement as Yr}from"lit";import{customElement as jr}from"lit/decorators.js";var Ne=class extends Yr{};Ne=n([jr("qti-companion-materials-info")],Ne);import{LitElement as zr,html as Kr}from"lit";import{customElement as Wr}from"lit/decorators.js";var Ve=class extends zr{render(){return Kr`<slot></slot>`}};Ve=n([Wr("qti-content-body")],Ve);import{LitElement as Zr,css as Jr,html as Gr}from"lit";import{customElement as Qr,property as $e}from"lit/decorators.js";var _=class extends Zr{handleclassNamesChange(i,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 Gr`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-rubric-block")}};_.styles=Jr`
13
+ `],a([Je({type:String,attribute:"base-type"})],I.prototype,"baseType",2),a([Je({type:String})],I.prototype,"identifier",2),a([Je({type:String})],I.prototype,"cardinality",2),a([Ir({context:M,subscribe:!0}),Fr()],I.prototype,"itemContext",2),I=a([Ur("qti-response-declaration")],I);import{LitElement as Br}from"lit";import{customElement as Xr}from"lit/decorators.js";var Ve=class extends Br{};Ve=a([Xr("qti-companion-materials-info")],Ve);import{LitElement as Yr,html as jr}from"lit";import{customElement as zr}from"lit/decorators.js";var He=class extends Yr{render(){return jr`<slot></slot>`}};He=a([zr("qti-content-body")],He);import{LitElement as Kr,css as Wr,html as Zr}from"lit";import{customElement as Jr,property as Ne}from"lit/decorators.js";var L=class extends Kr{handleclassNamesChange(i,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 Zr`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-rubric-block")}};L.styles=Wr`
14
14
  :host {
15
15
  display: block;
16
16
  }
17
- `,n([$e({type:String})],_.prototype,"id",2),n([$e({type:String})],_.prototype,"use",2),n([$e({type:String})],_.prototype,"view",2),n([$e({type:String,attribute:"class"})],_.prototype,"classNames",2),n([x("classNames",{waitUntilFirstUpdate:!0})],_.prototype,"handleclassNamesChange",1),_=n([Qr("qti-rubric-block")],_);import{css as ri,html as ii}from"lit";import{customElement as si}from"lit/decorators.js";import{LitElement as ti}from"lit";import{property as Pe}from"lit/decorators.js";var ei=()=>new Intl.NumberFormat().format(.1).replace(/\d/g,""),ce=c=>{if(typeof c=="string")return c;let i=ei();return i==="."?c.toLocaleString():c.toString().replace(".","").replace(i,".")};function Qe(c){return c==null}function pe(c){return c.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}var T=class extends ti{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-feedback",{bubbles:!0,composed:!0,detail:this}))}checkShowFeedback(i){let e=this.closest("qti-assessment-item").getOutcome(i);if(this.outcomeIdentifier!==i||!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(i){this.showStatus=i&&this.showHide==="show"||!i&&this.showHide==="hide"?"on":"off"}};n([Pe({type:String,attribute:"show-hide"})],T.prototype,"showHide",2),n([Pe({type:String,attribute:"outcome-identifier"})],T.prototype,"outcomeIdentifier",2),n([Pe({type:String})],T.prototype,"identifier",2),n([Pe({type:String,attribute:!1})],T.prototype,"showStatus",2);var de=class extends T{render(){return ii` <slot part="feedback" class="feedback ${this.showStatus}"></slot> `}firstUpdated(i){this.checkShowFeedback(this.outcomeIdentifier)}};de.styles=ri`
17
+ `,a([Ne({type:String})],L.prototype,"id",2),a([Ne({type:String})],L.prototype,"use",2),a([Ne({type:String})],L.prototype,"view",2),a([Ne({type:String,attribute:"class"})],L.prototype,"classNames",2),a([x("classNames",{waitUntilFirstUpdate:!0})],L.prototype,"handleclassNamesChange",1),L=a([Jr("qti-rubric-block")],L);import{css as ei,html as ti}from"lit";import{customElement as ri}from"lit/decorators.js";import{LitElement as Qr}from"lit";import{property as $e}from"lit/decorators.js";var Gr=()=>new Intl.NumberFormat().format(.1).replace(/\d/g,""),ae=c=>{if(typeof c=="string")return c;let i=Gr();return i==="."?c.toLocaleString():c.toString().replace(".","").replace(i,".")};function Ge(c){return c==null}function le(c){return c.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}var w=class extends Qr{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-feedback",{bubbles:!0,composed:!0,detail:this}))}checkShowFeedback(i){let e=this.closest("qti-assessment-item").getOutcome(i);if(this.outcomeIdentifier!==i||!e)return;let t=!1;Array.isArray(e.value)?t=e.value.includes(this.identifier):t=!Ge(this.identifier)&&!Ge(e==null?void 0:e.value)&&this.identifier===e.value||!1,this.showFeedback(t)}showFeedback(i){this.showStatus=i&&this.showHide==="show"||!i&&this.showHide==="hide"?"on":"off"}};a([$e({type:String,attribute:"show-hide"})],w.prototype,"showHide",2),a([$e({type:String,attribute:"outcome-identifier"})],w.prototype,"outcomeIdentifier",2),a([$e({type:String})],w.prototype,"identifier",2),a([$e({type:String,attribute:!1})],w.prototype,"showStatus",2);var ce=class extends w{render(){return ti` <slot part="feedback" class="feedback ${this.showStatus}"></slot> `}firstUpdated(i){this.checkShowFeedback(this.outcomeIdentifier)}};ce.styles=ei`
18
18
  :host {
19
19
  display: block;
20
20
  }
@@ -24,21 +24,21 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
24
24
  .off {
25
25
  display: none;
26
26
  }
27
- `,de=n([si("qti-feedback-block")],de);import{css as oi,html as ni}from"lit";import{customElement as ai}from"lit/decorators.js";var ue=class extends T{constructor(){super(...arguments);this.render=()=>ni` <slot part="feedback" class="${this.showStatus}"></slot> `}};ue.styles=oi`
27
+ `,ce=a([ri("qti-feedback-block")],ce);import{css as ii,html as si}from"lit";import{customElement as oi}from"lit/decorators.js";var pe=class extends w{constructor(){super(...arguments);this.render=()=>si` <slot part="feedback" class="${this.showStatus}"></slot> `}};pe.styles=ii`
28
28
  .on {
29
29
  display: inline-block;
30
30
  }
31
31
  .off {
32
32
  display: none;
33
33
  }
34
- `,ue=n([ai("qti-feedback-inline")],ue);import{css as li,html as ci}from"lit";import{customElement as pi}from"lit/decorators.js";var me=class extends T{constructor(){super(...arguments);this.render=()=>ci` <slot part="feedback" class="${this.showStatus}"></slot> `}};me.styles=li`
34
+ `,pe=a([oi("qti-feedback-inline")],pe);import{css as ni,html as ai}from"lit";import{customElement as li}from"lit/decorators.js";var de=class extends w{constructor(){super(...arguments);this.render=()=>ai` <slot part="feedback" class="${this.showStatus}"></slot> `}};de.styles=ni`
35
35
  .on {
36
36
  display: inline-block;
37
37
  }
38
38
  .off {
39
39
  display: none;
40
40
  }
41
- `,me=n([pi("qti-modal-feedback")],me);import{css as ui,html as mi}from"lit";import{ifDefined as tt}from"lit/directives/if-defined.js";import{property as et}from"lit/decorators.js";import{LitElement as di}from"lit";var f=class extends di{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}}))}};n([et({attribute:"response-identifier"})],f.prototype,"responseIdentifier",2),n([et({reflect:!0,type:Boolean})],f.prototype,"disabled",2),n([et({reflect:!0,type:Boolean})],f.prototype,"readonly",2);import{customElement as hi,property as Ie,state as Pt}from"lit/decorators.js";var k=class extends f{constructor(){super(...arguments);this._rows=5;this._value=""}handleclassNamesChange(e,t){t.split(" ").forEach(s=>{if(s.startsWith("qti-height-lines-")){let o=s.replace("qti-height-lines-","");this._rows=parseInt(o)}})}set response(e){this._value=e!==void 0?e:""}validate(){return this._value!==""}static get styles(){return[ui`
41
+ `,de=a([li("qti-modal-feedback")],de);import{css as di,html as ui}from"lit";import{ifDefined as mi}from"lit/directives/if-defined.js";import{property as Qe,state as ci}from"lit/decorators.js";import{LitElement as pi}from"lit";var u=class extends pi{constructor(){super();this.responseIdentifier="";this.disabled=!1;this.readonly=!1;this._correctResponse="";this._internals=this.attachInternals()}reportValidity(){return this._internals.reportValidity()}reset(){this.value=""}get correctResponse(){return this._correctResponse}set correctResponse(e){this._correctResponse=e}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}}))}};u.formAssociated=!0,a([Qe({type:String,attribute:"response-identifier"})],u.prototype,"responseIdentifier",2),a([Qe({reflect:!0,type:Boolean})],u.prototype,"disabled",2),a([Qe({reflect:!0,type:Boolean})],u.prototype,"readonly",2),a([ci()],u.prototype,"_correctResponse",2);import{customElement as hi,property as ue,state as Ht}from"lit/decorators.js";var T=class extends u{constructor(){super(...arguments);this._rows=5;this._value=""}handleclassNamesChange(e,t){let r=t.split(" "),s=!1;if(r.forEach(o=>{if(o.startsWith("qti-height-lines-")){let n=o.replace("qti-height-lines-","");this._rows=parseInt(n),s=!0}}),!s&&this.expectedLength){let o=Math.ceil(this.expectedLength/50);this._rows=o}}get value(){return this._value}set value(e){if(typeof e=="string"){this._value=e;let t=new FormData;t.append(this.responseIdentifier,e),this._internals.setFormValue(t),this.validate()}else throw new Error("Value must be a string")}validate(){let e=this.shadowRoot.querySelector("textarea");if(!e)return!1;if(this.patternMask&&this.dataPatternmaskMessage){this._internals.setValidity({}),e.setCustomValidity("");let t=this.patternMask.startsWith("^")&&this.patternMask.endsWith("$")?this.patternMask:`^${this.patternMask}$`,r=new RegExp(t);e.checkValidity()&&r.test(e.value)||(this._internals.setValidity({customError:!0},this.dataPatternmaskMessage),e.setCustomValidity(this.dataPatternmaskMessage))}else{let t=e.checkValidity();this._internals.setValidity(t?{}:{customError:!1})}return this._value!==""&&e.checkValidity()}reportValidity(){let e=this.shadowRoot.querySelector("textarea");if(!e)return!1;let t=this.validate();return t||e.reportValidity(),t}static get styles(){return[di`
42
42
  /* PK: display host as block, else design will be collapsed */
43
43
  :host {
44
44
  display: block;
@@ -49,23 +49,23 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
49
49
  height: 100%;
50
50
  border: 0;
51
51
  }
52
- `]}render(){return mi`<slot name="prompt"></slot
52
+ `]}render(){return ui`<slot name="prompt"></slot
53
53
  ><textarea
54
54
  part="textarea"
55
+ name="${this.responseIdentifier}"
55
56
  spellcheck="false"
56
57
  autocomplete="off"
58
+ maxlength="${5e3}"
57
59
  @keydown="${e=>e.stopImmediatePropagation()}"
58
60
  @keyup="${this.textChanged}"
59
61
  @change="${this.textChanged}"
60
- @blur="${e=>{let t=e.target;t.checkValidity()?t.setCustomValidity(""):(t.setCustomValidity(this.dataset.patternmaskMessage||"Invalid input"),t.reportValidity())}}"
61
- placeholder="${tt(this.placeholderText?this.placeholderText:void 0)}"
62
- maxlength="${tt(this.expectedLength?this.expectedLength:void 0)}"
63
- pattern="${tt(this.patternMask?this.patternMask:void 0)}"
62
+ @blur="${e=>{this.reportValidity()}}"
63
+ placeholder="${mi(this.placeholderText?this.placeholderText:void 0)}"
64
64
  rows="${this._rows}"
65
65
  ?disabled="${this.disabled}"
66
66
  ?readonly="${this.readonly}"
67
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")}};n([Pt()],k.prototype,"_rows",2),n([Ie({type:Number,attribute:"expected-length"})],k.prototype,"expectedLength",2),n([Ie({type:String,attribute:"pattern-mask"})],k.prototype,"patternMask",2),n([Ie({type:String,attribute:"placeholder-text"})],k.prototype,"placeholderText",2),n([Pt()],k.prototype,"_value",2),n([Ie({type:String,attribute:"class"})],k.prototype,"classNames",2),n([x("classNames")],k.prototype,"handleclassNamesChange",1),k=n([hi("qti-extended-text-interaction")],k);import{html as gi}from"lit";import{customElement as bi,property as rt,state as it}from"lit/decorators.js";import{ifDefined as Ot}from"lit/directives/if-defined.js";import{createRef as vi}from"lit/directives/ref.js";import{css as fi}from"lit";var It=fi`
68
+ ></textarea>`}textChanged(e){if(this.disabled||this.readonly)return;let t=e.target;if(this.setEmptyAttribute(t.value),this._value!==t.value){this.value=t.value;let r=this.validate();this.saveResponse(t.value)}}setEmptyAttribute(e){this.setAttribute("empty",e===""?"true":"false")}};a([Ht()],T.prototype,"_rows",2),a([ue({type:Number,attribute:"expected-length"})],T.prototype,"expectedLength",2),a([ue({type:String,attribute:"pattern-mask"})],T.prototype,"patternMask",2),a([ue({type:String,attribute:"placeholder-text"})],T.prototype,"placeholderText",2),a([ue({type:String,attribute:"data-patternmask-message"})],T.prototype,"dataPatternmaskMessage",2),a([Ht()],T.prototype,"_value",2),a([ue({type:String,attribute:"class"})],T.prototype,"classNames",2),a([x("classNames")],T.prototype,"handleclassNamesChange",1),T=a([hi("qti-extended-text-interaction")],T);import{html as gi}from"lit";import{customElement as bi,property as Ie,state as vi}from"lit/decorators.js";import{ifDefined as $t}from"lit/directives/if-defined.js";import{createRef as yi}from"lit/directives/ref.js";import{css as fi}from"lit";var Nt=fi`
69
69
  :host {
70
70
  display: inline-block;
71
71
  }
@@ -147,24 +147,26 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
147
147
  width: 57rem;
148
148
  min-width: 57rem;
149
149
  }
150
- `;var L=class extends f{constructor(){super(...arguments);this._value="";this._correctValue="";this._size=5;this.inputRef=vi()}set response(e){this._value=e!==void 0?e:""}validate(){return this._value!==""}set correctResponse(e){this._correctValue=e}render(){return gi`
150
+ `;var A=class extends u{constructor(){super(...arguments);this._value="";this.inputRef=yi()}get value(){return this._value}set value(e){if(typeof e=="string"){this._value=e;let t=new FormData;t.append(this.responseIdentifier,e),this._internals.setFormValue(t),this.validate()}else throw new Error("Value must be a string")}validate(){let e=this.shadowRoot.querySelector("input");if(!e)return!1;if(this.patternMask&&this.dataPatternmaskMessage)this._internals.setValidity({}),e.setCustomValidity(""),e.checkValidity()||(this._internals.setValidity({customError:!0},this.dataPatternmaskMessage),e.setCustomValidity(this.dataPatternmaskMessage));else{let t=e.checkValidity();this._internals.setValidity(t?{}:{customError:!1})}return this._value!==""&&e.checkValidity()}render(){return gi`
151
151
  <input
152
152
  part="input"
153
+ name="${this.responseIdentifier}"
153
154
  spellcheck="false"
154
155
  autocomplete="off"
155
- @blur="${e=>{let t=e.target;t.checkValidity()?t.setCustomValidity(""):(t.setCustomValidity(this.dataset.patternmaskMessage||"Invalid input"),t.reportValidity())}}"
156
+ @blur="${e=>{this.reportValidity()}}"
156
157
  @keydown="${e=>e.stopImmediatePropagation()}"
157
158
  @keyup="${this.textChanged}"
158
159
  @change="${this.textChanged}"
159
160
  type="${this.patternMask=="[0-9]*"?"number":"text"}"
160
- placeholder="${Ot(this.placeholderText?this.placeholderText:void 0)}"
161
+ placeholder="${$t(this.placeholderText?this.placeholderText:void 0)}"
161
162
  .value="${this._value}"
162
- pattern="${Ot(this.patternMask?this.patternMask:void 0)}"
163
+ pattern="${$t(this.patternMask?this.patternMask:void 0)}"
164
+ maxlength=${1e3}
163
165
  ?disabled="${this.disabled}"
164
166
  ?readonly="${this.readonly}"
165
167
  />
166
- <div part="correct">${this._correctValue}</div>
167
- `}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")}};L.styles=It,n([rt({type:Number,attribute:"expected-length"})],L.prototype,"expectedLength",2),n([rt({type:String,attribute:"pattern-mask"})],L.prototype,"patternMask",2),n([rt({type:String,attribute:"placeholder-text"})],L.prototype,"placeholderText",2),n([it()],L.prototype,"_value",2),n([it()],L.prototype,"_correctValue",2),n([it()],L.prototype,"_size",2),L=n([bi("qti-text-entry-interaction")],L);import{html as yi,LitElement as xi}from"lit";import{customElement as Ei}from"lit/decorators.js";import{property as he}from"lit/decorators.js";var U=(c,i)=>{class e extends c{constructor(){super(...arguments);this._choiceElements=[];this.responseIdentifier="";this.minChoices=0;this.maxChoices=1;this.disabled=!1;this._handleDisabledChange=(s,o)=>{this._choiceElements.forEach(a=>a.disabled=o)};this.readonly=!1;this._handleReadonlyChange=(s,o)=>{this._choiceElements.forEach(a=>a.readonly=o)}}_handleMaxChoicesChange(s,o){this._determineInputType()}validate(){let s=this._choiceElements.filter(o=>this._getChoiceChecked(o)).length;return this.maxChoices!==0&&s>this.maxChoices?!1:s>=this.minChoices}set response(s){let o=Array.isArray(s)?s:[s];this._choiceElements.forEach(a=>{this._setChoiceChecked(a,o.includes(a.identifier))})}set correctResponse(s){let o=Array.isArray(s)?s:[s];if(o.length===0){this._choiceElements.forEach(a=>{a.removeAttribute("data-correct-response")});return}this._choiceElements.forEach(a=>{a.setAttribute("data-correct-response",o.includes(a.identifier)?"true":"false")})}connectedCallback(){super.connectedCallback(),this.addEventListener(`register-${i}`,this._registerChoiceElement),this.addEventListener(`unregister-${i}`,this._unregisterChoiceElement),this.addEventListener(`activate-${i}`,this._choiceElementSelectedHandler),this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,composed:!0}))}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener(`register-${i}`,this._registerChoiceElement),this.removeEventListener(`unregister-${i}`,this._unregisterChoiceElement),this.removeEventListener(`activate-${i}`,this._choiceElementSelectedHandler)}_registerChoiceElement(s){s.stopPropagation();let o=s.target;o.disabled=this.disabled,this._choiceElements.push(o),this._setInputType(o)}_unregisterChoiceElement(s){s.stopPropagation();let o=s.target;this._choiceElements=this._choiceElements.filter(a=>a!==o)}_determineInputType(){this._choiceElements.forEach(s=>{this._setInputType(s)})}_setInputType(s){s.setAttribute("role",this.maxChoices===1?"radio":"checkbox")}_choiceElementSelectedHandler(s){this._toggleChoiceChecked(s.target),this.maxChoices===1&&this._choiceElements.forEach(o=>{o.identifier!==s.detail.identifier&&this._setChoiceChecked(o,!1)}),this._handleChoiceSelection()}_setChoiceChecked(s,o){s.setAttribute("aria-checked",o.toString())}_getChoiceChecked(s){return s.getAttribute("aria-checked")==="true"}_toggleChoiceChecked(s){let o=this._getChoiceChecked(s);this._setChoiceChecked(s,!o)}_handleChoiceSelection(){let s=this._choiceElements.filter(l=>this._getChoiceChecked(l)),o=s.map(l=>l.identifier);if(this.maxChoices>1&&this.maxChoices!==0){let l=s.length>=this.maxChoices;this._choiceElements.forEach(p=>{this._getChoiceChecked(p)||(p.disabled=l)})}let a=this.maxChoices===1?o[0]||void 0:o;this._saveResponse(a)}_saveResponse(s){this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:s}}))}}return n([he({attribute:"response-identifier"})],e.prototype,"responseIdentifier",2),n([he({type:Number,attribute:"min-choices"})],e.prototype,"minChoices",2),n([he({type:Number,attribute:"max-choices"})],e.prototype,"maxChoices",2),n([x("maxChoices",{waitUntilFirstUpdate:!0})],e.prototype,"_handleMaxChoicesChange",1),n([he({reflect:!0,type:Boolean})],e.prototype,"disabled",2),n([x("disabled",{waitUntilFirstUpdate:!0})],e.prototype,"_handleDisabledChange",2),n([he({reflect:!0,type:Boolean})],e.prototype,"readonly",2),n([x("readonly",{waitUntilFirstUpdate:!0})],e.prototype,"_handleReadonlyChange",2),e};var Oe=class extends U(xi,"qti-hottext"){constructor(){super(...arguments);this.render=()=>yi`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("qti-hottext-interaction","")}};Oe=n([Ei("qti-hottext-interaction")],Oe);import{css as Ci,html as Ut}from"lit";import{customElement as qi,property as Ti,state as Ft}from"lit/decorators.js";import{unsafeHTML as Bt}from"lit/directives/unsafe-html.js";var F=class extends f{constructor(){super(...arguments);this.options=[];this.correctOption="";this.dataPrompt="select"}static get styles(){return[Ci`
168
+ <div part="correct">${this._correctResponse}</div>
169
+ `}textChanged(e){if(this.disabled||this.readonly)return;let t=e.target;if(this.setEmptyAttribute(t.value),this._value!==t.value){this.value=t.value;let r=this.validate();this.saveResponse(t.value)}}reportValidity(){let e=this.shadowRoot.querySelector("input");if(!e)return!1;let t=this.validate();return t||e.reportValidity(),t}reset(){this._value=""}setEmptyAttribute(e){this.setAttribute("empty",e===""?"true":"false")}};A.styles=Nt,a([Ie({type:Number,attribute:"expected-length"})],A.prototype,"expectedLength",2),a([Ie({type:String,attribute:"pattern-mask"})],A.prototype,"patternMask",2),a([Ie({type:String,attribute:"placeholder-text"})],A.prototype,"placeholderText",2),a([Ie({type:String,attribute:"data-patternmask-message"})],A.prototype,"dataPatternmaskMessage",2),a([vi()],A.prototype,"_value",2),A=a([bi("qti-text-entry-interaction")],A);import{html as Ei}from"lit";import{customElement as Ci}from"lit/decorators.js";import{property as It,query as xi}from"lit/decorators.js";var U=(c,i)=>{class e extends c{constructor(){super(...arguments);this._choiceElements=[];this.minChoices=0;this.maxChoices=1;this._handleDisabledChange=(s,o)=>{this._choiceElements.forEach(n=>n.disabled=o)};this._handleReadonlyChange=(s,o)=>{this._choiceElements.forEach(n=>n.readonly=o)};this._value=""}_handleMaxChoicesChange(s,o){this._determineInputType()}get value(){return Array.isArray(this._value)?this._value.join(","):this._value}set value(s){if(this.maxChoices>1&&typeof s=="string"?this._value=s.split(","):this._value=s,Array.isArray(this._value)){let o=new FormData;this._value.forEach(n=>{o.append(this.responseIdentifier,n)}),this._internals.setFormValue(o)}else this._internals.setFormValue(this._value);this._updateChoiceSelection()}get correctResponse(){return this._correctResponse}set correctResponse(s){this._correctResponse=s;let o=Array.isArray(s)?s:[s];this._choiceElements.forEach(n=>{n.internals.states.delete("correct-response"),n.internals.states.delete("incorrect-response"),o.length>0&&(o.includes(n.identifier)?n.internals.states.add("correct-response"):n.internals.states.add("incorrect-response"))})}connectedCallback(){super.connectedCallback(),this.addEventListener(`register-${i}`,this._registerChoiceElement),this.addEventListener(`unregister-${i}`,this._unregisterChoiceElement),this.addEventListener(`activate-${i}`,this._choiceElementSelectedHandler)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener(`register-${i}`,this._registerChoiceElement),this.removeEventListener(`unregister-${i}`,this._unregisterChoiceElement),this.removeEventListener(`activate-${i}`,this._choiceElementSelectedHandler)}validate(){let s=this._choiceElements.filter(p=>this._getChoiceChecked(p)),o=s.length,n=!0,l="";return this.maxChoices!==0&&o>this.maxChoices?(n=!1,l=this.dataset.maxSelectionsMessage||`You can select at most ${this.maxChoices} choices.`):o<this.minChoices&&(n=!1,l=this.dataset.minSelectionsMessage||`You must select at least ${this.minChoices} choices.`),s.length>0&&this._internals.setValidity(n?{}:{customError:!0},l,s[o-1]||this._choiceElements[0]||this),this.reportValidity(),n}reportValidity(){return this._validationMessageElement&&(this._internals.validity.valid?(this._validationMessageElement.textContent="",this._validationMessageElement.style.display="none"):(this._validationMessageElement.textContent=this._internals.validationMessage,this._validationMessageElement.style.display="block")),this._internals.validity.valid}_registerChoiceElement(s){s.stopPropagation();let o=s.target;o.disabled=this.disabled,this._choiceElements.push(o),this._setInputType(o)}_unregisterChoiceElement(s){s.stopPropagation();let o=s.target;this._choiceElements=this._choiceElements.filter(n=>n!==o)}_determineInputType(){this._choiceElements.forEach(s=>{this._setInputType(s)})}_setInputType(s){s.internals.role=this.maxChoices===1?"radio":"checkbox",s.internals.states.add(s.internals.role)}_choiceElementSelectedHandler(s){this._toggleChoiceChecked(s.target),this.maxChoices===1&&this._choiceElements.forEach(o=>{o.identifier!==s.detail.identifier&&this._setChoiceChecked(o,!1)}),this._handleChoiceSelection()}_setChoiceChecked(s,o){var n;(n=s.internals)!=null&&n.states&&(o?(s.internals.states.add("--checked"),s.internals.ariaChecked="true"):(s.internals.states.delete("--checked"),s.internals.ariaChecked="false"))}_getChoiceChecked(s){return s.internals.states.has("--checked")}_toggleChoiceChecked(s){let o=this._getChoiceChecked(s);this._setChoiceChecked(s,!o)}_handleChoiceSelection(){let o=this._choiceElements.filter(n=>this._getChoiceChecked(n)).map(n=>n.identifier);this.value=this.maxChoices===1?o[0]||"":o,this.validate(),this.saveResponse(this._value)}_updateChoiceSelection(){let s=Array.isArray(this._value)?this._value:[this._value];this._choiceElements.forEach(o=>{let n=s.includes(o.identifier);this._setChoiceChecked(o,n)})}}return a([xi("#validationMessage")],e.prototype,"_validationMessageElement",2),a([It({type:Number,attribute:"min-choices"})],e.prototype,"minChoices",2),a([It({type:Number,attribute:"max-choices"})],e.prototype,"maxChoices",2),a([x("maxChoices",{waitUntilFirstUpdate:!0})],e.prototype,"_handleMaxChoicesChange",1),a([x("disabled",{waitUntilFirstUpdate:!0})],e.prototype,"_handleDisabledChange",2),a([x("readonly",{waitUntilFirstUpdate:!0})],e.prototype,"_handleReadonlyChange",2),e};var Pe=class extends U(u,"qti-hottext"){constructor(){super(...arguments);this.render=()=>Ei`<slot></slot>`}connectedCallback(){super.connectedCallback(),this.setAttribute("qti-hottext-interaction","")}};Pe=a([Ci("qti-hottext-interaction")],Pe);import{css as qi,html as Pt}from"lit";import{customElement as wi,property as Ti,state as Ot}from"lit/decorators.js";import{unsafeHTML as Ut}from"lit/directives/unsafe-html.js";var F=class extends u{constructor(){super(...arguments);this.options=[];this.correctOption="";this.dataPrompt="select"}static get styles(){return[qi`
168
170
  :host {
169
171
  display: inline-block;
170
172
  }
@@ -186,15 +188,15 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
186
188
  /* position-anchor: --infobox; */
187
189
  /* top: anchor(bottom); */
188
190
  }
189
- `]}render(){return Ut`
191
+ `]}render(){return Pt`
190
192
  <select part="select" @change="${this.choiceSelected}" ?disabled="${this.disabled}" ?readonly="${this.readonly}">
191
- ${this.options.map(e=>Ut`
192
- <option value="${e.value}" ?selected="${e.selected}">${Bt(e.textContent)}</option>
193
+ ${this.options.map(e=>Pt`
194
+ <option value="${e.value}" ?selected="${e.selected}">${Ut(e.textContent)}</option>
193
195
  `)}
194
196
  </select>
195
197
 
196
- ${Bt(this.correctOption)}
197
- `}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)=>C(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=>C(b({},r),{selected:r.value===t})),this.saveResponse(t)}};F.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"],n([Ft()],F.prototype,"options",2),n([Ft()],F.prototype,"correctOption",2),n([Ti({attribute:"data-prompt",type:String})],F.prototype,"dataPrompt",2),F=n([qi("qti-inline-choice-interaction")],F);import{html as Ri,LitElement as Mi}from"lit";import{customElement as Ai,property as _i}from"lit/decorators.js";import{property as wi}from"lit/decorators.js";var Ue=(c,i)=>{class e extends c{constructor(){super(...arguments);this._shuffle=!1}set shuffle(s){let o=this._shuffle;this._shuffle=s,s?this._shuffleChoices():this._resetShuffleChoices(),this.requestUpdate("shuffle",o)}get shuffle(){return this._shuffle}connectedCallback(){super.connectedCallback(),this.shuffle?this._shuffleChoices():this._resetShuffleChoices()}_shuffleChoices(){let s=Array.from(this.querySelectorAll(i)),o=[],a=[];if(s.forEach((h,y)=>{h.hasAttribute("fixed")?o.push({element:h,index:y}):a.push(h)}),a.length<=1){console.warn("Shuffling is not possible with fewer than 2 non-fixed elements.");return}let l=!1,p=10,d=0,u=[...a];for(;!l&&d<p;){d++;for(let h=a.length-1;h>0;h--){let y=Math.floor(Math.random()*(h+1));[a[h],a[y]]=[a[y],a[h]]}if(l=!a.every((h,y)=>h===u[y]),l)break}l||console.warn("Failed to shuffle the choices after multiple attempts.");let g=1;s.forEach((h,y)=>{h.hasAttribute("fixed")?h.style.setProperty("order",String(g++)):a.shift().style.setProperty("order",String(g++))})}_resetShuffleChoices(){Array.from(this.querySelectorAll("qti-simple-choice")).forEach((o,a)=>{o.style.setProperty("order","initial")})}}return n([wi({type:String,reflect:!0,converter:Si})],e.prototype,"shuffle",1),e},Si={fromAttribute(c){return c==="true"},toAttribute(c){return c?"true":"false"}};import{property as ki}from"lit/decorators.js";var Xt=(c,i)=>{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(s){s&&(this._classes=s.split(" "),this._addLabels())}get class(){var s;return((s=this._classes)==null?void 0:s.join(" "))||""}updated(s){super.updated(s),s.has("shuffle")&&this._addLabels()}_addLabels(){let s=this._classes.some(a=>this._allLabels.includes(a)||this._allLabelSuffixes.includes(a)),o=a=>!isNaN(+a);if(s){let l=Array.from(this.querySelectorAll("qti-simple-choice")).map(p=>p).map((p,d)=>({el:p,order:o(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(s){let o=this._classes.filter(p=>this._allLabels.includes(p)).pop(),a=this._classes.filter(p=>this._allLabelSuffixes.includes(p)).pop();!o&&a&&(o="qti-labels-upper-alpha");let l="";switch(o){case"qti-labels-decimal":l=`${s}`;break;case"qti-labels-lower-alpha":l=`${String.fromCharCode(97+s-1)}`;break;case"qti-labels-upper-alpha":l=`${String.fromCharCode(65+s-1)}`;break}return a==="qti-labels-suffix-period"?l+=".":a==="qti-labels-suffix-parenthesis"&&(l+=")"),l}}return n([ki({type:String,reflect:!0})],e.prototype,"class",1),e};import{css as Li}from"lit";var Yt=Li`
198
+ ${Ut(this.correctOption)}
199
+ `}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)=>C(b({},e),{selected:t===0}))}set value(e){this.options=this.options.map(t=>(e===t.value&&(t.selected=!0),t))}get value(){return this.options.find(e=>e.selected).value}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=>C(b({},r),{selected:r.value===t})),this.saveResponse(t)}};F.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"],a([Ot()],F.prototype,"options",2),a([Ot()],F.prototype,"correctOption",2),a([Ti({attribute:"data-prompt",type:String})],F.prototype,"dataPrompt",2),F=a([wi("qti-inline-choice-interaction")],F);import{html as Ri}from"lit";import{customElement as Li,property as Ai}from"lit/decorators.js";import{property as Si}from"lit/decorators.js";var Oe=(c,i)=>{class e extends c{constructor(){super(...arguments);this._shuffle=!1}set shuffle(s){let o=this._shuffle;this._shuffle=s,s?this._shuffleChoices():this._resetShuffleChoices(),this.requestUpdate("shuffle",o)}get shuffle(){return this._shuffle}connectedCallback(){super.connectedCallback(),this.shuffle?this._shuffleChoices():this._resetShuffleChoices()}_shuffleChoices(){let s=Array.from(this.querySelectorAll(i)),o=[],n=[];if(s.forEach((f,y)=>{f.hasAttribute("fixed")?o.push({element:f,index:y}):n.push(f)}),n.length<=1){console.warn("Shuffling is not possible with fewer than 2 non-fixed elements.");return}let l=!1,p=10,d=0,m=[...n];for(;!l&&d<p;){d++;for(let f=n.length-1;f>0;f--){let y=Math.floor(Math.random()*(f+1));[n[f],n[y]]=[n[y],n[f]]}if(l=!n.every((f,y)=>f===m[y]),l)break}l||console.warn("Failed to shuffle the choices after multiple attempts.");let g=1;s.forEach((f,y)=>{f.hasAttribute("fixed")?f.style.setProperty("order",String(g++)):n.shift().style.setProperty("order",String(g++))})}_resetShuffleChoices(){Array.from(this.querySelectorAll("qti-simple-choice")).forEach((o,n)=>{o.style.setProperty("order","initial")})}}return a([Si({type:String,reflect:!0,converter:ki})],e.prototype,"shuffle",1),e},ki={fromAttribute(c){return c==="true"},toAttribute(c){return c?"true":"false"}};import{property as Mi}from"lit/decorators.js";var Ft=(c,i)=>{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(s){s&&(this._classes=s.split(" "),this._addLabels())}get class(){var s;return((s=this._classes)==null?void 0:s.join(" "))||""}updated(s){super.updated(s),s.has("shuffle")&&this._addLabels()}_addLabels(){let s=this._classes.some(n=>this._allLabels.includes(n)||this._allLabelSuffixes.includes(n)),o=n=>!isNaN(+n);if(s){let l=Array.from(this.querySelectorAll("qti-simple-choice")).map(p=>p).map((p,d)=>({el:p,order:o(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(s){let o=this._classes.filter(p=>this._allLabels.includes(p)).pop(),n=this._classes.filter(p=>this._allLabelSuffixes.includes(p)).pop();!o&&n&&(o="qti-labels-upper-alpha");let l="";switch(o){case"qti-labels-decimal":l=`${s}`;break;case"qti-labels-lower-alpha":l=`${String.fromCharCode(97+s-1)}`;break;case"qti-labels-upper-alpha":l=`${String.fromCharCode(65+s-1)}`;break}return n==="qti-labels-suffix-period"?l+=".":n==="qti-labels-suffix-parenthesis"&&(l+=")"),l}}return a([Mi({type:String,reflect:!0})],e.prototype,"class",1),e};import{css as _i}from"lit";var Bt=_i`
198
200
  [part='slot'] {
199
201
  display: flex;
200
202
  flex-direction: column;
@@ -203,7 +205,8 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
203
205
  }
204
206
 
205
207
  ::slotted(qti-simple-choice) {
206
- flex: 0 0 calc((100% - (var(--qti-gap-size) * var(--choice-interactions-stacking))) / var(--choice-interactions-stacking)) !important;
208
+ flex: 0 0
209
+ calc((100% - (var(--qti-gap-size) * var(--choice-interactions-stacking))) / var(--choice-interactions-stacking)) !important;
207
210
  box-sizing: border-box !important;
208
211
  }
209
212
 
@@ -231,11 +234,14 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
231
234
  :host([orientation='horizontal']) [part='slot'] {
232
235
  flex-direction: row;
233
236
  }
234
- `;var J=class extends Xt(Ue(U(Mi,"qti-simple-choice"),"qti-simple-choice"),"qti-simple-choice"){render(){return Ri` <slot name="prompt"></slot><slot part="slot"></slot>`}};J.styles=Yt,n([_i({type:String})],J.prototype,"orientation",2),J=n([Ai("qti-choice-interaction")],J);import{css as Di,html as Hi,LitElement as Ni}from"lit";import{customElement as Vi}from"lit/decorators.js";var fe=class extends Ni{render(){return Hi`<slot></slot>`}process(){let i=new st,e=[...this.children];i.process(e)}};fe.styles=[Di`
237
+ `;var Z=class extends Ft(Oe(U(u,"qti-simple-choice"),"qti-simple-choice"),"qti-simple-choice"){render(){return Ri`
238
+ <slot name="prompt"></slot><slot part="slot"></slot>
239
+ <div role="alert" id="validationMessage"></div>
240
+ `}};Z.styles=Bt,a([Ai({type:String})],Z.prototype,"orientation",2),Z=a([Li("qti-choice-interaction")],Z);import{css as Di,html as Vi,LitElement as Hi}from"lit";import{customElement as Ni}from"lit/decorators.js";var me=class extends Hi{render(){return Vi`<slot></slot>`}process(){let i=new et,e=[...this.children];i.process(e)}};me.styles=[Di`
235
241
  :host {
236
242
  display: none;
237
243
  }
238
- `],fe=n([Vi("qti-outcome-processing")],fe);var st=class{process(i){for(let e of i)e.process()}};import{css as $i,html as Pi,LitElement as Ii}from"lit";import{customElement as Oi}from"lit/decorators.js";var jt=`<qti-response-processing>
244
+ `],me=a([Ni("qti-outcome-processing")],me);var et=class{process(i){for(let e of i)e.process()}};import{css as $i,html as Ii,LitElement as Pi}from"lit";import{customElement as Oi}from"lit/decorators.js";var Xt=`<qti-response-processing>
239
245
  <qti-response-condition>
240
246
  <qti-response-if>
241
247
  <qti-match>
@@ -252,7 +258,7 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
252
258
  </qti-set-outcome-value>
253
259
  </qti-response-else>
254
260
  </qti-response-condition>
255
- </qti-response-processing>`,zt=`<qti-response-processing>
261
+ </qti-response-processing>`,Yt=`<qti-response-processing>
256
262
  <qti-response-condition>
257
263
  <qti-response-if>
258
264
  <qti-is-null>
@@ -268,7 +274,7 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
268
274
  </qti-set-outcome-value>
269
275
  </qti-response-else>
270
276
  </qti-response-condition>
271
- </qti-response-processing>`,Kt=`<qti-response-processing>
277
+ </qti-response-processing>`,jt=`<qti-response-processing>
272
278
  <qti-response-condition>
273
279
  <qti-response-if>
274
280
  <qti-is-null>
@@ -284,19 +290,19 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
284
290
  </qti-set-outcome-value>
285
291
  </qti-response-else>
286
292
  </qti-response-condition>
287
- </qti-response-processing>`;var z=class extends Ii{render(){return Pi`<slot></slot>`}process(){let i=[...this.children];for(let e of i)e.process()}firstUpdated(i){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(zt).firstElementChild.firstElementChild);break}case"map_response_point":{this.appendChild(this.fragmentFromString(Kt).firstElementChild.firstElementChild);break}case"match_correct":this.appendChild(this.fragmentFromString(jt).firstElementChild.firstElementChild);break}}}fragmentFromString(i){return document.createRange().createContextualFragment(i)}};z.styles=[$i`
293
+ </qti-response-processing>`;var z=class extends Pi{render(){return Ii`<slot></slot>`}process(){let i=[...this.children];for(let e of i)e.process()}firstUpdated(i){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(i){return document.createRange().createContextualFragment(i)}};z.styles=[$i`
288
294
  :host {
289
295
  display: none;
290
296
  }
291
- `],z=n([Oi("qti-response-processing")],z);import{property as Xi}from"lit/decorators.js";import{customElement as Ui}from"lit/decorators.js";import{html as Fi,LitElement as Bi}from"lit";var D=class extends Bi{render(){return Fi`<slot></slot>`}process(){throw new Error("Not implemented")}};D=n([Ui("qti-rule")],D);var Fe=class extends D{get childExpression(){return this.firstElementChild}process(){let i=this.getAttribute("identifier"),e=this.closest("qti-assessment-item").getVariable(i),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:ce(t)}})),t)}};n([Xi({type:String})],Fe.prototype,"identifier",2);customElements.define("qti-lookup-outcome-value",Fe);import{html as Yi}from"lit";var ot=class extends D{render(){return Yi`<slot></slot>`}process(){let i=[...this.children];for(let e=0;e<i.length;e++){let t=i[e];if(t.calculate()){t.process();return}}}};customElements.define("qti-response-condition",ot);var nt=class extends D{process(){let i=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:i,value:Array.isArray(r)?r.map(s=>ce(s)):ce(r)}}))}},at=class{constructor(i){this.expression=i}process(){let i=this.expression?this.expression.calculate():null;if(i==null){console.warn("setOutcomeValue: value is null or undefined");return}return i}};customElements.define("qti-set-outcome-value",nt);import{LitElement as ji,html as zi}from"lit";var ge=class extends ji{render(){return zi`<slot></slot>`}calculate(){return!0}getSubRules(){return[...this.children]}process(){let i=this.getSubRules();for(let e=0;e<i.length;e++)i[e].process()}};customElements.define("qti-response-else",ge);import{html as Ki}from"lit";var be=class extends ge{calculate(){return this.firstElementChild.calculate()}getSubRules(){let i=[];for(let e=1;e<this.children.length;e++)i.push(this.children[e]);return i}};customElements.define("qti-response-if",be);var lt=class extends be{render(){return Ki`${super.render()}`}};customElements.define("qti-response-else-if",lt);import{LitElement as Wi,css as Zi,html as Ji}from"lit";import{state as Gi}from"lit/decorators.js";var m=class extends Wi{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.trim(),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(s=>s.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 Ji`<pre>${JSON.stringify(this.result,null,2)}</pre>
292
- <slot></slot>`}calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}get assessmentItem(){return this.closest("qti-assessment-item")}};m.styles=Zi`
297
+ `],z=a([Oi("qti-response-processing")],z);import{property as Xi}from"lit/decorators.js";import{customElement as Ui}from"lit/decorators.js";import{html as Fi,LitElement as Bi}from"lit";var D=class extends Bi{render(){return Fi`<slot></slot>`}process(){throw new Error("Not implemented")}};D=a([Ui("qti-rule")],D);var Ue=class extends D{get childExpression(){return this.firstElementChild}process(){let i=this.getAttribute("identifier"),e=this.closest("qti-assessment-item").getVariable(i),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:ae(t)}})),t)}};a([Xi({type:String})],Ue.prototype,"identifier",2);customElements.define("qti-lookup-outcome-value",Ue);import{html as Yi}from"lit";var tt=class extends D{render(){return Yi`<slot></slot>`}process(){let i=[...this.children];for(let e=0;e<i.length;e++){let t=i[e];if(t.calculate()){t.process();return}}}};customElements.define("qti-response-condition",tt);var rt=class extends D{process(){let i=this.getAttribute("identifier"),e=this.firstElementChild,r=new it(e).process();this.dispatchEvent(new CustomEvent("qti-set-outcome-value",{bubbles:!0,composed:!0,detail:{outcomeIdentifier:i,value:Array.isArray(r)?r.map(s=>ae(s)):ae(r)}}))}},it=class{constructor(i){this.expression=i}process(){let i=this.expression?this.expression.calculate():null;if(i==null){console.warn("setOutcomeValue: value is null or undefined");return}return i}};customElements.define("qti-set-outcome-value",rt);import{LitElement as ji,html as zi}from"lit";var he=class extends ji{render(){return zi`<slot></slot>`}calculate(){return!0}getSubRules(){return[...this.children]}process(){let i=this.getSubRules();for(let e=0;e<i.length;e++)i[e].process()}};customElements.define("qti-response-else",he);import{html as Ki}from"lit";var fe=class extends he{calculate(){return this.firstElementChild.calculate()}getSubRules(){let i=[];for(let e=1;e<this.children.length;e++)i.push(this.children[e]);return i}};customElements.define("qti-response-if",fe);var st=class extends fe{render(){return Ki`${super.render()}`}};customElements.define("qti-response-else-if",st);import{LitElement as Wi,css as Zi,html as Ji}from"lit";import{state as Gi}from"lit/decorators.js";var h=class extends Wi{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.trim(),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(s=>s.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 Ji`<pre>${JSON.stringify(this.result,null,2)}</pre>
298
+ <slot></slot>`}calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}get assessmentItem(){return this.closest("qti-assessment-item")}};h.styles=Zi`
293
299
  slot {
294
300
  display: none;
295
301
  }
296
- `,n([Gi()],m.prototype,"result",2);var w=class extends m{calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}};var Be=class extends Qi(w){calculate(){return this.calculateChildren(Array.from(this.children))}};function Qi(c){return class extends c{calculateChildren(e){return e.map(r=>{let s=r;if(!s.calculate)return console.error("Element doesn't implement QtiConditionExpression"),null;let o=s.calculate();if(typeof o=="string")if(o==="true")o=!0;else if(o==="false")o=!1;else return console.error("unexpected value in qti-and, expected boolean"),null;return o}).every(r=>typeof r=="boolean"&&r)}}}customElements.define("qti-and",Be);import{property as es}from"lit/decorators.js";var Xe=class extends m{constructor(){super(...arguments);this.baseType="string"}getResult(){return this.textContent.trim()}};n([es({type:String,attribute:"base-type"})],Xe.prototype,"baseType",2);customElements.define("qti-base-value",Xe);var ct=class extends w{getResult(){let i=this.getVariables();if(this.children.length===2){let e=i[0],t=i[1];if(e.baseType==="directedPair"&&t.baseType==="directedPair"&&e.cardinality==="multiple"){let r=e.value,s=t.value;return r.filter(l=>s.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 m{get interpretation(){return this.getAttribute("interpretation")||""}getResult(){let i=this.getAttribute("identifier")||"",e=this.closest("qti-assessment-item").getResponse(i);return e.correctResponse,e.cardinality!=="single"?e.correctResponse.length>0?e.correctResponse[0]:"":e.correctResponse}};customElements.define("qti-correct",pt);import{property as ts}from"lit/decorators.js";var Ye=class extends m{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 s=parseFloat(t.value),o=parseFloat(r.value);if(!isNaN(s)&&!isNaN(o))return this.roundingMode==="significantFigures"?s.toPrecision(this.figures)===o.toPrecision(this.figures):Math.round(s*Math.pow(10,this.figures))/Math.pow(10,this.figures)===Math.round(o*Math.pow(10,this.figures))/Math.pow(10,this.figures);console.error(`value cannot be casted to numeric value in equalRounded operator: ${s}, ${o}`);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}};n([ts({type:String})],Ye.prototype,"roundingMode",2);customElements.define("qti-equal-rounded",Ye);import{property as rs}from"lit/decorators.js";var S=class{static compareSingleValues(i,e,t){switch(t){case"identifier":case"string":return i===e;case"integer":{let r=parseInt(i,10),s=parseInt(e,10);if(!isNaN(r)&&!isNaN(s))return r===s;console.error(`Cannot convert ${i} and/or ${e} to int.`);break}case"float":{let r=parseFloat(i),s=parseFloat(e);if(!isNaN(r)&&!isNaN(s))return r===s;console.error(`couldn't convert ${i} and/or ${e} to float.`);break}case"pair":case"directedPair":{let r=i.split(" ").sort(),s=e.split(" ").sort();if(r.length===2&&s.length===2)return t==="pair"&&(r.sort(),s.sort()),r.join(" ")===s.join(" ");console.error(`compared two pair but one of the values does not have 2 values: 1: ${i} 2: ${e}`);break}}return!1}};var je=class extends m{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):S.compareSingleValues(t.value,r.value,t.baseType)}return console.error("unexpected number of children in qti-equal"),null}};n([rs({type:String})],je.prototype,"toleranceMode",2);customElements.define("qti-equal",je);var dt=class extends m{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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 i=this.getVariables(),e=i[0],t=i[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 m{getResult(){if(this.children.length===1){let i=this.getVariables();if(!i)return!0;let e=i[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 m{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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 i=this.getVariables(),e=i[0],t=i[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 is}from"lit/decorators.js";var ze=class extends m{getResult(){let i=this.assessmentItem.getResponse(this.identifier);if(!i)return console.warn(`Response ${this.identifier} can not be found`),null;let e=i.mapping,t=Array.isArray(i.value)?i.value:[i.value],r=0;for(let s of t){let o=e.mapEntries.find(a=>S.compareSingleValues(a.mapKey,s,i.baseType));o==null||o.mappedValue==null?r+=e.defaultValue:r+=o.mappedValue}return e.lowerBound!=null&&(r=Math.max(e.lowerBound,r)),e.upperBound!=null&&(r=Math.min(e.upperBound,r)),r}};n([is({type:String})],ze.prototype,"identifier",2);customElements.define("qti-map-response",ze);import{property as gt}from"lit/decorators.js";import{LitElement as ss}from"lit";var G=class extends ss{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")}))}};n([gt({attribute:"default-value",type:Number})],G.prototype,"defaultValue",2),n([gt({attribute:"lower-bound",type:Number})],G.prototype,"lowerBound",2),n([gt({attribute:"upper-bound",type:Number})],G.prototype,"upperBound",2);customElements.define("qti-mapping",G);var bt=class c extends m{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[1];return c.match(e,t)}return console.error("unexpected number of children in match"),null}static match(i,e){var t;switch(e.cardinality){case"single":return i.value===null?!1:Array.isArray(i.value)||Array.isArray(e.value)?(console.error("unexpected cardinality in qti match"),!1):S.compareSingleValues((t=i.value)==null?void 0:t.toString(),e.value.toString(),e.baseType);case"ordered":{if(!Array.isArray(i.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(i.value.length!==e.value.length)return!1;for(let r=0;r<i.value.length;r++)if(!S.compareSingleValues(e.value[r],i.value[r],e.baseType))return!1;return!0}case"multiple":{if(!Array.isArray(i.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(i.value.length!==e.value.length)return!1;let r=0;for(let s of e.value){let o=null,a=[...i.value];for(let l of a)if(S.compareSingleValues(s,l,e.baseType)){o=l;break}if(o!==null)a.splice(a.indexOf(o),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 m{getResult(){let i=this.getVariables();this.children.length!==2&&console.warn("The member operator takes two sub-expressions");let[e,t]=i;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 m{getResult(){let i=this.getVariables();if(i.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of i)if(e.cardinality!=="multiple"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti multiple"),[];return i}};customElements.define("qti-multiple",yt);import{html as os}from"lit";var xt=class extends m{render(){return os`${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 Ct=class extends m{getResult(){let i=this.getVariables();if(i.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of i)if(e.cardinality!=="ordered"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti ordered"),[];return i}};customElements.define("qti-ordered",Ct);import{consume as ns}from"@lit/context";import{LitElement as as,html as ls}from"lit";import{property as cs,state as ps}from"lit/decorators.js";var ve=class extends as{render(){var e,t;let i=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return ls`${JSON.stringify(i,null,2)}`}calculate(){let i=this.closest("qti-assessment-item"),e=this.identifier;return i.getVariable(e).value}};n([cs({type:String})],ve.prototype,"identifier",2),n([ns({context:R,subscribe:!0}),ps()],ve.prototype,"itemContext",2);customElements.define("qti-printed-variable",ve);var qt=class extends m{getResult(){return this.getVariables().reduce((t,r)=>{if(r.baseType=="float"||r.baseType=="integer")try{return t*parseInt(r.value.toString())}catch(s){console.warn("can not convert to number")}else console.warn(`has another baseType ${r.baseType}`);return t},1)}};customElements.define("qti-product",qt);import{property as ds}from"lit/decorators.js";var Ke=class extends m{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 s=this.caseSensitive==="true"?t.value:t.value.toLowerCase(),o=this.caseSensitive==="true"?r.value:r.value.toLowerCase();return S.compareSingleValues(s,o,t.baseType)}return console.error("unexpected number of children in qti-string-match"),null}};n([ds({type:String,attribute:"case-sensitive"})],Ke.prototype,"caseSensitive",2);customElements.define("qti-string-match",Ke);var Tt=class extends m{constructor(){super(),this._expression=new wt(Array.from(this.children))}getResult(){return this._expression.calculate()}},wt=class{constructor(i){this.expressions=i}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",Tt);var St=class extends m{getResult(){let i=this.getAttribute("identifier");return this.closest("qti-assessment-item").getVariable(i).value}};customElements.define("qti-variable",St);import{html as Wt}from"lit";import{customElement as us,property as kt,state as ms}from"lit/decorators.js";var B=class extends f{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 o=await r.json();for(let a in o.paths)t&&(o.paths[a]=this.getResolvablePath(o.paths[a],t));return o}}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 s in r)if(r.hasOwnProperty(s)){let o=r[s];if(Array.isArray(o))return o.map(String);if(o!=null)return String(o)}}}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 s=this.convertQtiVariableJSON(t);this.response=s,this.saveResponse(s)}},200)}stopChecking(){this.intervalId!==void 0&&clearInterval(this.intervalId)}validate(){return!0}set response(e){}getTAOConfig(e){let t=e.querySelectorAll("properties"),r={},s=a=>{let l={},p=a.getAttribute("key");if(p){let d=Array.from(a.children),u=d.map(h=>h.getAttribute("key"));u.length>0&&!u.find(h=>!Number.isInteger(+h))?l[p]=d.map(h=>o(h)):l[p]=a.textContent}return l},o=a=>{if(a){let l={};for(let p of a.children)l=b(b({},l),s(p));return l}};for(let a of t)return a.getAttribute("key")||(r=b(b({},r),o(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 s=t=="IMS"?{properties:this.dataset,onready:()=>{console.log("onready")}}:this.getTAOConfig(this);t=="IMS"?e.getInstance(r,s,void 0):e.initialize(this.customInteractionTypeIdentifier,r.firstElementChild,s),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 s=r.querySelectorAll("qti-interaction-module");for(let o of s){let a=o.getAttribute("id"),l=o.getAttribute("primary-path"),p=o.getAttribute("fallback-path");if(a&&l){let d=p?this.combineRequireResolvePaths(this.getResolvablePath(l,t),this.getResolvablePath(p,t)):this.getResolvablePath(l,t),u=e.paths[a]||[];e.paths[a]=this.combineRequireResolvePaths(u,d)}}}return e}combineRequireResolvePaths(e,t){let r=Array.isArray(e)?e:[e],s=Array.isArray(t)?t:[t];return r.concat(s)}removeDoubleSlashes(e){return e.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}render(){return Wt`<slot></slot>${this._errorMessage&&Wt`<div style="color:red">
302
+ `,a([Gi()],h.prototype,"result",2);var S=class extends h{calculate(){return this.result=this.getResult(),this.result}getResult(){throw new Error("Not implemented")}};var Fe=class extends Qi(S){calculate(){return this.calculateChildren(Array.from(this.children))}};function Qi(c){return class extends c{calculateChildren(e){return e.map(r=>{let s=r;if(!s.calculate)return console.error("Element doesn't implement QtiConditionExpression"),null;let o=s.calculate(),n=!1;if(typeof o=="string")if(o==="true")n=!0;else if(o==="false")n=!1;else return console.error("unexpected val in qti-or, expected boolean"),null;else typeof o=="boolean"&&(n=o);return n}).every(r=>typeof r=="boolean"&&r)}}}customElements.define("qti-and",Fe);import{property as es}from"lit/decorators.js";var Be=class extends h{constructor(){super(...arguments);this.baseType="string"}getResult(){return this.textContent.trim()}};a([es({type:String,attribute:"base-type"})],Be.prototype,"baseType",2);customElements.define("qti-base-value",Be);var ot=class extends S{getResult(){let i=this.getVariables();if(this.children.length===2){let e=i[0],t=i[1];if(e.baseType==="directedPair"&&t.baseType==="directedPair"&&e.cardinality==="multiple"){let r=e.value,s=t.value;return r.filter(l=>s.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",ot);var nt=class extends h{get interpretation(){return this.getAttribute("interpretation")||""}getResult(){let i=this.getAttribute("identifier")||"",e=this.closest("qti-assessment-item").getResponse(i);return e.cardinality!=="single"?e.correctResponse.length>0?e.correctResponse[0]:"":e.correctResponse}};customElements.define("qti-correct",nt);import{property as ts}from"lit/decorators.js";var Xe=class extends h{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 s=parseFloat(t.value),o=parseFloat(r.value);if(!isNaN(s)&&!isNaN(o))return this.roundingMode==="significantFigures"?s.toPrecision(this.figures)===o.toPrecision(this.figures):Math.round(s*Math.pow(10,this.figures))/Math.pow(10,this.figures)===Math.round(o*Math.pow(10,this.figures))/Math.pow(10,this.figures);console.error(`value cannot be casted to numeric value in equalRounded operator: ${s}, ${o}`);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}};a([ts({type:String})],Xe.prototype,"roundingMode",2);customElements.define("qti-equal-rounded",Xe);import{property as rs}from"lit/decorators.js";var k=class{static compareSingleValues(i,e,t){switch(t){case"identifier":case"string":return i===e;case"integer":{let r=parseInt(i,10),s=parseInt(e,10);if(!isNaN(r)&&!isNaN(s))return r===s;console.error(`Cannot convert ${i} and/or ${e} to int.`);break}case"float":{let r=parseFloat(i),s=parseFloat(e);if(!isNaN(r)&&!isNaN(s))return r===s;console.error(`couldn't convert ${i} and/or ${e} to float.`);break}case"pair":case"directedPair":{let r=i.split(" ").sort(),s=e.split(" ").sort();if(r.length===2&&s.length===2)return t==="pair"&&(r.sort(),s.sort()),r.join(" ")===s.join(" ");console.error(`compared two pair but one of the values does not have 2 values: 1: ${i} 2: ${e}`);break}}return!1}};var Ye=class extends h{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):k.compareSingleValues(t.value,r.value,t.baseType)}return console.error("unexpected number of children in qti-equal"),null}};a([rs({type:String})],Ye.prototype,"toleranceMode",2);customElements.define("qti-equal",Ye);var at=class extends h{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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",at);var lt=class extends S{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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",lt);var ct=class extends h{getResult(){if(this.children.length===1){let i=this.getVariables();if(!i)return!0;let e=i[0].value;return e==null||e==null||e===""}return console.error("unexpected number of children in qti Null"),null}};customElements.define("qti-is-null",ct);var pt=class extends h{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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",pt);var dt=class extends S{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[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",dt);import{property as is}from"lit/decorators.js";var je=class extends h{getResult(){let i=this.assessmentItem.getResponse(this.identifier);if(!i)return console.warn(`Response ${this.identifier} can not be found`),null;let e=i.mapping,t=Array.isArray(i.value)?i.value:[i.value],r=0;for(let s of t){let o=e.mapEntries.find(n=>k.compareSingleValues(n.mapKey,s,i.baseType));o==null||o.mappedValue==null?r+=e.defaultValue:r+=o.mappedValue}return e.lowerBound!=null&&(r=Math.max(e.lowerBound,r)),e.upperBound!=null&&(r=Math.min(e.upperBound,r)),r}};a([is({type:String})],je.prototype,"identifier",2);customElements.define("qti-map-response",je);import{property as ut}from"lit/decorators.js";import{LitElement as ss}from"lit";var J=class extends ss{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")}))}};a([ut({attribute:"default-value",type:Number})],J.prototype,"defaultValue",2),a([ut({attribute:"lower-bound",type:Number})],J.prototype,"lowerBound",2),a([ut({attribute:"upper-bound",type:Number})],J.prototype,"upperBound",2);customElements.define("qti-mapping",J);var mt=class c extends h{getResult(){if(this.children.length===2){let i=this.getVariables(),e=i[0],t=i[1];return c.match(e,t)}return console.error("unexpected number of children in match"),null}static match(i,e){var t;switch(e.cardinality){case"single":return i.value===null?!1:Array.isArray(i.value)||Array.isArray(e.value)?(console.error("unexpected cardinality in qti match"),!1):k.compareSingleValues((t=i.value)==null?void 0:t.toString(),e.value.toString(),e.baseType);case"ordered":{if(!Array.isArray(i.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(i.value.length!==e.value.length)return!1;for(let r=0;r<i.value.length;r++)if(!k.compareSingleValues(e.value[r],i.value[r],e.baseType))return!1;return!0}case"multiple":{if(!Array.isArray(i.value)||!Array.isArray(e.value))return console.error("unexpected cardinality in qti match"),!1;if(i.value.length!==e.value.length)return!1;let r=0;for(let s of e.value){let o=null,n=[...i.value];for(let l of n)if(k.compareSingleValues(s,l,e.baseType)){o=l;break}if(o!==null)n.splice(n.indexOf(o),1);else return!1;r++}return!0}default:return console.error("unexpected cardinality in qti match"),!1}}};customElements.define("qti-match",mt);var ht=class extends h{getResult(){let i=this.getVariables();this.children.length!==2&&console.warn("The member operator takes two sub-expressions");let[e,t]=i;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",ht);var ft=class extends h{getResult(){let i=this.getVariables();if(i.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of i)if(e.cardinality!=="multiple"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti multiple"),[];return i}};customElements.define("qti-multiple",ft);import{html as os}from"lit";var gt=class extends h{render(){return os`${super.render()}`}getResult(){return!this.firstElementChild.calculate()}};customElements.define("qti-not",gt);var bt=class extends S{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(),s=!1;if(typeof r=="string")if(r==="true")s=!0;else if(r==="false")s=!1;else return console.error("unexpected val in qti-or, expected boolean"),null;else typeof r=="boolean"&&(s=r);return s}).some(e=>typeof e=="boolean"&&e)}};customElements.define("qti-or",bt);var vt=class extends h{getResult(){let i=this.getVariables();if(i.length===0)return console.error("unexpected number of children in qti multiple"),null;for(let e of i)if(e.cardinality!=="ordered"&&e.cardinality!=="single")return console.error("unexpected cardinality in qti ordered"),[];return i}};customElements.define("qti-ordered",vt);import{consume as ns}from"@lit/context";import{LitElement as as,html as ls}from"lit";import{property as cs,state as ps}from"lit/decorators.js";var ge=class extends as{render(){var e,t;let i=(t=(e=this.itemContext)==null?void 0:e.variables.find(r=>r.identifier===this.identifier))==null?void 0:t.value;return ls`${JSON.stringify(i,null,2)}`}calculate(){let i=this.closest("qti-assessment-item"),e=this.identifier;return i.getVariable(e).value}};a([cs({type:String})],ge.prototype,"identifier",2),a([ns({context:M,subscribe:!0}),ps()],ge.prototype,"itemContext",2);customElements.define("qti-printed-variable",ge);var yt=class extends h{getResult(){return this.getVariables().reduce((t,r)=>{if(r.baseType=="float"||r.baseType=="integer")try{return t*parseInt(r.value.toString())}catch(s){console.warn("can not convert to number")}else console.warn(`has another baseType ${r.baseType}`);return t},1)}};customElements.define("qti-product",yt);import{property as ds}from"lit/decorators.js";var ze=class extends h{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 s=this.caseSensitive==="true"?t.value:t.value.toLowerCase(),o=this.caseSensitive==="true"?r.value:r.value.toLowerCase();return k.compareSingleValues(s,o,t.baseType)}return console.error("unexpected number of children in qti-string-match"),null}};a([ds({type:String,attribute:"case-sensitive"})],ze.prototype,"caseSensitive",2);customElements.define("qti-string-match",ze);var xt=class extends h{constructor(){super(),this._expression=new Et(Array.from(this.children))}getResult(){return this._expression.calculate()}},Et=class{constructor(i){this.expressions=i}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",xt);var Ct=class extends h{getResult(){let i=this.getAttribute("identifier");return this.closest("qti-assessment-item").getVariable(i).value}};customElements.define("qti-variable",Ct);import{html as zt}from"lit";import{customElement as us,property as qt,state as ms}from"lit/decorators.js";var B=class extends u{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 o=await r.json();for(let n in o.paths)t&&(o.paths[n]=this.getResolvablePath(o.paths[n],t));return o}}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 s in r)if(r.hasOwnProperty(s)){let o=r[s];if(Array.isArray(o))return o.map(String);if(o!=null)return String(o)}}}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 s=this.convertQtiVariableJSON(t);this.value=s,this.saveResponse(s)}},200)}stopChecking(){this.intervalId!==void 0&&clearInterval(this.intervalId)}validate(){return!0}set value(e){}get value(){return this.rawResponse}getTAOConfig(e){let t=e.querySelectorAll("properties"),r={},s=n=>{let l={},p=n.getAttribute("key");if(p){let d=Array.from(n.children),m=d.map(f=>f.getAttribute("key"));m.length>0&&!m.find(f=>!Number.isInteger(+f))?l[p]=d.map(f=>o(f)):l[p]=n.textContent}return l},o=n=>{if(n){let l={};for(let p of n.children)l=b(b({},l),s(p));return l}};for(let n of t)return n.getAttribute("key")||(r=b(b({},r),o(n))),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 s=t=="IMS"?{properties:this.dataset,onready:()=>{console.log("onready")}}:this.getTAOConfig(this);t=="IMS"?e.getInstance(r,s,void 0):e.initialize(this.customInteractionTypeIdentifier,r.firstElementChild,s),t=="TAO"&&Array.from(this.querySelectorAll("link")).map(n=>n.getAttribute("href")).forEach(n=>{let l=document.createElement("link");l.rel="stylesheet",l.type="text/css",l.media="screen",l.href=n,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 s=r.querySelectorAll("qti-interaction-module");for(let o of s){let n=o.getAttribute("id"),l=o.getAttribute("primary-path"),p=o.getAttribute("fallback-path");if(n&&l){let d=p?this.combineRequireResolvePaths(this.getResolvablePath(l,t),this.getResolvablePath(p,t)):this.getResolvablePath(l,t),m=e.paths[n]||[];e.paths[n]=this.combineRequireResolvePaths(m,d)}}}return e}combineRequireResolvePaths(e,t){let r=Array.isArray(e)?e:[e],s=Array.isArray(t)?t:[t];return r.concat(s)}removeDoubleSlashes(e){return e.replace(/([^:]\/)\/+/g,"$1").replace(/\/\//g,"/").replace("http:/","http://").replace("https:/","https://")}render(){return zt`<slot></slot>${this._errorMessage&&zt`<div style="color:red">
297
303
  <h1>Error</h1>
298
304
  ${this._errorMessage}
299
- </div>`}`}};n([kt({type:String,attribute:"response-identifier"})],B.prototype,"responseIdentifier",2),n([kt({type:String,attribute:"module"})],B.prototype,"module",2),n([kt({type:String,attribute:"custom-interaction-type-identifier"})],B.prototype,"customInteractionTypeIdentifier",2),n([ms()],B.prototype,"_errorMessage",2),B=n([us("qti-portable-custom-interaction")],B);import{LitElement as gs,html as er}from"lit";import{customElement as bs,state as vs}from"lit/decorators.js";var We=class c{constructor(){this.touchStartTime=0;this.touchStartPoint=null;this.lastClickTime=0;this.isDraggable=!1;this.dragSource=null;this.dragClone=null;this.touchEndTriggered=!1;this.isDragging=!1;this.initialTransform="";this.hasDispatchedDragStart=!1;this.rootNode=null;this.focusedElement=null;this.focusableDropZones=[];this.currentDropZoneIndex=-1;this.dataTransfer={data:{},setData(i,e){this.data[i]=e},getData(i){return this.data[i]},effectAllowed:"move"};this.cloneOffset={x:0,y:0};this.lastTarget=null;this.currentDropTarget=null;this.allowClick=!0;this.copyStylesForDragClone=!0;this.dragOnClickEnabled=!1;this.useDragClone=!1;this.MIN_DRAG_DISTANCE=5;this.DRAG_CLONE_OPACITY=1;if(c.instance)return c.instance;c.instance=this,document.addEventListener("touchmove",this.handleTouchMove.bind(this),{passive:!1}),document.addEventListener("mousemove",this.handleTouchMove.bind(this),{passive:!1}),document.addEventListener("touchend",this.handleTouchEnd.bind(this),{passive:!1}),document.addEventListener("mouseup",this.handleTouchEnd.bind(this),{passive:!1}),document.addEventListener("touchcancel",this.handleTouchCancel.bind(this),{passive:!1}),document.addEventListener("keydown",this.handleKeyDown.bind(this)),document.addEventListener("keyup",this.handleKeyUp.bind(this))}addDraggableElements(i){i.forEach(e=>{e.setAttribute("tabindex","0"),e.addEventListener("focus",()=>this.focusedElement=e),e.addEventListener("blur",()=>this.focusedElement=null),e.addEventListener("touchstart",this.handleTouchStart.bind(this),{passive:!1}),e.addEventListener("mousedown",this.handleTouchStart.bind(this),{passive:!1})})}handleTouchStart(i){this.touchStartTime=Date.now();let{x:e,y:t}=this.getEventCoordinates(i);if(this.touchStartPoint={x:e,y:t},this.dragSource=i.currentTarget,this.isDraggable=!0,this.rootNode=this.dragSource.getRootNode(),this.dragOnClickEnabled&&(this.isDragging=!0,this.createDragClone(i,{clientX:e,clientY:t})),!this.useDragClone){let r=window.getComputedStyle(this.dragSource);this.initialTransform=r.transform==="none"?"":r.transform,this.initialTransition=r.transition||"",this.dragSource.style.transition="none";let s=this.dragSource.getBoundingClientRect();this.cloneOffset.x=e-s.left,this.cloneOffset.y=t-s.top,this.dragSource.style.zIndex="9999",this.dragSource.focus()}i.preventDefault()}handleTouchMove(i){if(this.isDraggable&&this.dragSource){let{x:e,y:t}=this.getEventCoordinates(i),r={clientX:e,clientY:t};this.calculateDragDistance(r)>=this.MIN_DRAG_DISTANCE&&(this.dragSource.style.pointerEvents="none",this.isDragging=!0),this.createDragClone(i,r),i.preventDefault()}}createDragClone(i,e){if(!this.isDragging)return;if(this.useDragClone){if(!this.dragClone){if(this.dragSource.style.opacity=this.DRAG_CLONE_OPACITY.toString(),this.dragClone=this.dragSource.cloneNode(!0),this.copyStylesForDragClone){let r=window.getComputedStyle(this.dragSource);for(let s of r)this.dragClone.style[s]=r.getPropertyValue(s)}this.rootNode instanceof ShadowRoot?this.rootNode.host.appendChild(this.dragClone):this.rootNode instanceof Document&&document.body.appendChild(this.dragClone),this.calculateClonePosition(e),this.setDragCloneStyles(e),this.dispatchCustomEvent(this.dragSource,"dragstart")}this.updateDragClonePosition(e)}else if(this.touchStartPoint){let r=e.clientX-this.touchStartPoint.x,s=e.clientY-this.touchStartPoint.y;this.dragSource.style.transform=`${this.initialTransform} translate(${r}px, ${s}px)`,this.hasDispatchedDragStart||(this.dispatchCustomEvent(this.dragSource,"dragstart"),this.hasDispatchedDragStart=!0)}let t=this.findDropTarget(i);t!==this.lastTarget&&(this.dispatchCustomEvent(t,"dragenter"),this.dispatchCustomEvent(this.lastTarget,"dragleave"),this.lastTarget=t),this.currentDropTarget=t,this.currentDropTarget&&this.dispatchCustomEvent(t,"dragover")}handleTouchEnd(i){var t;this.touchEndTriggered=!0,this.isDraggable=!1;let e=!1;if(this.currentDropTarget)this.dispatchCustomEvent(this.currentDropTarget,"drop"),this.dispatchCustomEvent(this.dragSource,"dragend"),e=!0;else if(this.isDragging){let r=new CustomEvent("dragend",{bubbles:!0,cancelable:!0});r.dataTransfer={dropEffect:"none"},(t=this.dragSource)==null||t.dispatchEvent(r)}this.resetDragState(e)}handleTouchCancel(i){this.resetDragState()}findDropTarget(i){let{x:e,y:t}=this.getEventCoordinates(i);return this.getDropTargetAtPoint(document,e,t)}getDropTargetAtPoint(i,e,t,r=0){if(r>2)return null;let o=i.elementFromPoint(e,t);if(!o)return null;if(o.hasAttribute("dropzone"))return o;let a=o.parentElement;for(;a;){if(a.hasAttribute("dropzone"))return a;a=a.parentElement}if(o.shadowRoot&&r<2){let l=this.getDropTargetAtPoint(o.shadowRoot,e,t,r+1);if(l)return l}return null}handleKeyDown(i){this.focusedElement&&(i.key===" "&&!this.isDragging?(i.preventDefault(),this.isDraggable=!0,this.dragSource=this.focusedElement,this.isDragging=!0,this.collectDropZones(),this.dispatchCustomEvent(this.dragSource,"dragstart")):i.key==="Tab"&&this.isDragging&&(i.preventDefault(),this.moveToNextDropZone()))}handleKeyUp(i){i.key===" "&&this.isDragging&&this.currentDropTarget&&(i.preventDefault(),this.dispatchCustomEvent(this.currentDropTarget,"drop"),this.dispatchCustomEvent(this.dragSource,"dragend"),this.resetDragState(!0))}collectDropZones(){this.focusableDropZones=Array.from(document.querySelectorAll("[dropzone]")),this.currentDropZoneIndex=-1}moveToNextDropZone(){if(this.focusableDropZones.length===0)return;this.currentDropZoneIndex=(this.currentDropZoneIndex+1)%this.focusableDropZones.length;let i=this.focusableDropZones[this.currentDropZoneIndex];i.focus(),this.currentDropTarget=i,this.dispatchCustomEvent(i,"dragenter")}getEventCoordinates(i,e=!1){let t=i.touches?i.touches[0]:i;return{x:e?t.pageX:t.clientX,y:e?t.pageY:t.clientY}}calculateClonePosition(i){let e=this.dragSource.getBoundingClientRect();this.cloneOffset.x=i.clientX-e.left,this.cloneOffset.y=i.clientY-e.top}setDragCloneStyles(i){this.dragClone.style.position="fixed",this.dragClone.style.top=`${i.clientY-this.cloneOffset.y}px`,this.dragClone.style.left=`${i.clientX-this.cloneOffset.x}px`,this.dragClone.style.pointerEvents="none",this.dragClone.style.zIndex="999999"}updateDragClonePosition(i){requestAnimationFrame(()=>{if(this.touchEndTriggered||!this.dragClone)return;let e=i.clientX-this.cloneOffset.x,t=i.clientY-this.cloneOffset.y,{newLeft:r,newTop:s}=this.applyBoundaries(e,t,this.dragClone);this.dragClone.style.left=`${r}px`,this.dragClone.style.top=`${s}px`})}applyTransformBoundaries(i,e){let t;this.rootNode instanceof ShadowRoot?t=this.rootNode.host.getBoundingClientRect():this.rootNode instanceof Document?t=document.documentElement.getBoundingClientRect():t=new DOMRect(0,0,window.innerWidth,window.innerHeight);let r=this.dragSource.getBoundingClientRect(),s=r.width,o=r.height,a=r.left+i,l=r.top+e,p=Math.max(t.left,Math.min(a,t.right-s)),d=Math.max(t.top,Math.min(l,t.bottom-o)),u=p-r.left,g=d-r.top;return{boundedDeltaX:u,boundedDeltaY:g}}applyBoundaries(i,e,t){let r;this.rootNode instanceof ShadowRoot?r=this.rootNode.host.getBoundingClientRect():this.rootNode instanceof Document?r=document.documentElement.getBoundingClientRect():r=new DOMRect(0,0,window.innerWidth,window.innerHeight);let s=t.getBoundingClientRect(),o=s.width,a=s.height,l=Math.max(r.left,Math.min(i,r.right-o)),p=Math.max(r.top,Math.min(e,r.bottom-a));return{newLeft:l,newTop:p}}calculateDragDistance(i){let e=Math.abs(i.clientX-this.touchStartPoint.x),t=Math.abs(i.clientY-this.touchStartPoint.y);return e+t}dispatchCustomEvent(i,e,t=!0){if(!i)return;let r=new CustomEvent(e,{bubbles:t,cancelable:!0});r.dataTransfer=this.dataTransfer,i.dispatchEvent(r)}resetDragState(i=!1){var e;this.isDragging&&(this.useDragClone?(this.dragSource.style.opacity="1.0",(e=this.dragClone)==null||e.parentElement.removeChild(this.dragClone)):(i||(this.dragSource.style.transform="translate(0, 0)"),this.dragSource.style.zIndex="",this.dragSource.style.pointerEvents="",this.dragSource.style.transition=this.initialTransition,this.initialTransition="")),this.isDragging=!1,this.dragSource=null,this.dragClone=null,this.isDraggable=!1,this.touchStartTime=0,this.touchStartPoint=null,this.touchEndTriggered=!1,this.dataTransfer={data:{},setData(t,r){this.data[t]=r},getData(t){return this.data[t]},effectAllowed:"move"},this.cloneOffset={x:0,y:0},this.lastTarget=null,this.currentDropTarget=null,this.allowClick=!0,this.initialTransform="",this.hasDispatchedDragStart=!1,this.rootNode=null}};import{property as hs}from"lit/decorators.js";var Zt=(c,i,e)=>{class t extends c{constructor(){super(...arguments);this.disabled=!1}firstUpdated(o){if(this.isMatchTabular())return;super.firstUpdated(o);let a=this.getDroppableElements();this.initializeEventHandlers(),a.forEach(l=>{this.prepareDroppable(l),this.observeDroppableAttributes(l)})}isMatchTabular(){return this.classList.contains("qti-match-tabular")}getDroppableElements(){return Array.from(i?this.shadowRoot.querySelectorAll(e):this.querySelectorAll(e))}initializeEventHandlers(){this.dragoverHandler=this.dragoverHandler.bind(this),this.dragleaveHandler=this.dragleaveHandler.bind(this),this.dragenterHandler=this.dragenterHandler.bind(this),this.dropHandler=this.dropHandler.bind(this)}prepareDroppable(o){o.setAttribute("dropzone","move"),o.addEventListener("dragleave",this.dragleaveHandler),this.attachEventListeners(o)}observeDroppableAttributes(o){this.observer=new MutationObserver(a=>{a.forEach(({attributeName:l})=>{l==="disabled"&&this.toggleDroppableHandlers(o)})}),this.observer.observe(o,{attributes:!0})}toggleDroppableHandlers(o){o.hasAttribute("disabled")?this.removeEventListeners(o):this.attachEventListeners(o)}attachEventListeners(o){o.addEventListener("dragover",this.dragoverHandler),o.addEventListener("dragenter",this.dragenterHandler),o.addEventListener("drop",this.dropHandler)}removeEventListeners(o){o.removeEventListener("dragover",this.dragoverHandler),o.removeEventListener("dragenter",this.dragenterHandler),o.removeEventListener("drop",this.dropHandler)}disconnectedCallback(){var o;this.isMatchTabular()||(super.disconnectedCallback(),(o=this.observer)==null||o.disconnect())}dragenterHandler(o){o.preventDefault()}dragoverHandler(o){return o.preventDefault(),this.activateDroppable(o.currentTarget),o.dataTransfer.dropEffect="move",!1}activateDroppable(o){o.setAttribute("active","")}async dropHandler(o){o.preventDefault();let a=o.currentTarget,l=o.dataTransfer.getData("text"),p=this.findDraggable(l);return p?p&&!this.isValidDrop(a,p)?(p.style.transform="translate(0, 0)",!1):(await this.moveDraggableToDroppable(p,a),this.deactivateDroppable(a),!1):!1}findDraggable(o){return o?this.querySelector(`[identifier=${o}]`)||this.shadowRoot.querySelector(`[identifier=${o}]`):null}isValidDrop(o,a){return a.parentElement.getAttribute("identifier")!==o.getAttribute("identifier")}async moveDraggableToDroppable(o,a){let l=()=>{o.style.transform="translate(0, 0)",a.appendChild(o),this.checkMaxAssociations(),this.saveResponse()};if(!document.startViewTransition){l();return}await document.startViewTransition(l).finished}deactivateDroppable(o){o.removeAttribute("active")}dragleaveHandler(o){return o.preventDefault(),this.deactivateDroppable(o.currentTarget),o.dataTransfer.dropEffect="none",!1}}return n([hs({type:Boolean,reflect:!0})],t.prototype,"disabled",2),t};var Jt=(c,i,e)=>{class t extends c{}return t};import{property as Q}from"lit/decorators.js";function Gt(c,i){let e,t=b({},i);return(r,s)=>{let{connectedCallback:o,disconnectedCallback:a}=r;r.connectedCallback=function(){var d;o.call(this);let l=u=>{let g=Array.from(this.querySelectorAll(c));for(let h of u){let y=Array.from(h.addedNodes).map($=>$),v=Array.from(h.addedNodes).map($=>$);h.type==="childList"&&y.find($=>g.includes($))&&this[s](y,v)}};e=new MutationObserver(l),e.observe(this,{childList:!0,subtree:!0});let p=(d=this.querySelectorAll(c))!=null?d:[];this[s](Array.from(p),[])},r.disconnectedCallback=function(){a.call(this),e.disconnect()}}}var H=(c,i,e,t)=>{class r extends Jt(Zt(c,e,t),t,i){constructor(){super(...arguments);this.draggables=new Map;this.droppables=[];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=>{let l=a.currentTarget;a.dataTransfer.setData("text",l.getAttribute("identifier")),l.setAttribute("dragging",""),this.activateDroppables()};this.handleDragEnd=async a=>{a.preventDefault(),this.deactivateDroppables();let l=a.currentTarget;l.removeAttribute("dragging"),await this.wasDropped(a)||this.configuration.dragCanBePlacedBack&&this.restoreInitialDraggablePosition(l)};this.checkForMoveTestItem=a=>a.dataTransfer.items?new Promise(l=>{let p=!1,d=Array.from(a.dataTransfer.items),u=d.length;if(u===0){l(!1);return}d.forEach(g=>{g.kind==="string"&&g.type==="text"?g.getAsString(h=>{h==="move-test"&&(p=!0),u===0&&l(p)}):u===0&&l(p)})}):Promise.resolve(!1)}handleDraggablesChange(a,l){if(this.isMatchTabular())return;let p=this.filterExistingDraggables(a);p.length>0&&this.addNewDraggables(p)}firstUpdated(a){super.firstUpdated(a),this.initializeDroppables()}connectedCallback(){super.connectedCallback(),this.initializeDragDropApi()}initializeDragDropApi(){this.dragDropApi=new We,this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,composed:!0,detail:this}))}isMatchTabular(){return this.classList.contains("qti-match-tabular")}filterExistingDraggables(a){return a.filter(l=>!this.draggables.has(l))}addNewDraggables(a){this.dragDropApi.addDraggableElements(a),a.forEach(l=>this.storeDraggable(l))}storeDraggable(a){let l=Array.from(a.parentNode.children).indexOf(a);this.draggables.set(a,{parent:a.parentElement,index:l}),a.style.viewTransitionName=`drag-${l}-${this.getAttribute("identifier")||crypto.randomUUID()}`,a.setAttribute("qti-draggable","true"),a.addEventListener("dragstart",this.handleDragStart),a.addEventListener("dragend",this.handleDragEnd)}initializeDroppables(){this.droppables=Array.from(e?this.shadowRoot.querySelectorAll(t):this.querySelectorAll(t))}activateDroppables(){this.droppables.forEach(a=>a.setAttribute("enabled",""))}deactivateDroppables(){this.droppables.forEach(a=>a.removeAttribute("enabled"))}async wasDropped(a){let l=await this.checkForMoveTestItem(a);return a.dataTransfer.dropEffect!=="none"||l}wasMoved(a){return a.dataTransfer.dropEffect==="move"}async restoreInitialDraggablePosition(a){let{parent:l,index:p}=this.draggables.get(a),d=Math.min(p,l.children.length),u=(h,y,v)=>{let $=Math.min(v,y.children.length);y.insertBefore(h,y.children[$]),h.style.transform="translate(0, 0)",this.checkMaxAssociations()};if(!document.startViewTransition){u(a,l,p);return}let g=document.startViewTransition(()=>{a.style.transform="",u(a,l,p)})}checkMaxAssociations(){this.droppables.forEach((a,l)=>{let p=+(a.getAttribute("match-max")||1);a.querySelectorAll('[qti-draggable="true"]').length>=p?this.disableDroppable(a):this.enableDroppable(a)})}disableDroppable(a){a.setAttribute("disabled",""),a.removeAttribute("dropzone")}enableDroppable(a){a.removeAttribute("disabled"),a.setAttribute("dropzone","move")}get response(){return this.collectResponseData()}set response(a){this.isMatchTabular()||(this.resetDroppables(),a==null||a.forEach(l=>this.placeResponse(l)))}placeResponse(a){let[l,...p]=a.split(" ").reverse(),d=this.findDroppableById(l);p.forEach(u=>this.placeDraggableInDroppable(u,d))}findDroppableById(a){return this.droppables.find(l=>l.getAttribute("identifier")===a)}async placeDraggableInDroppable(a,l){let p=this.querySelector(`[identifier=${a}]`);if(!l||!p){console.error(`Cannot find draggable or droppable with the given identifier: ${a}`);return}let d=()=>{p.style.transform="translate(0, 0)",l.appendChild(p),this.checkMaxAssociations()};document.startViewTransition?await document.startViewTransition(d).finished:d()}validate(){let a=this.getValidAssociations();return this.minAssociations<=0||this.minAssociations<=a}getValidAssociations(){return this.droppables.filter(a=>a.childElementCount>0).length}saveResponse(){let a=this.collectResponseData();this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:a}}))}collectResponseData(){return this.droppables.map(l=>{let p=l.querySelectorAll('[qti-draggable="true"]'),d=Array.from(p).map(g=>g.getAttribute("identifier")),u=l.getAttribute("identifier");return d.map(g=>`${g} ${u}`)}).flat()}reset(a=!0){this.resetDroppables(),a&&this.saveResponse()}async resetDroppables(){let a=(p,d,u)=>{p.style.transform="translate(0, 0)";let g=Math.min(u,d.children.length);d.insertBefore(p,d.children[g])};if(!document.startViewTransition){this.draggables.forEach(({parent:p,index:d},u)=>{a(u,p,d)});return}await document.startViewTransition(()=>{this.draggables.forEach(({parent:p,index:d},u)=>{a(u,p,d)})}).finished}}return n([Q({type:String,attribute:"response-identifier"})],r.prototype,"responseIdentifier",2),n([Q({attribute:!1,type:Object})],r.prototype,"configuration",2),n([Q({type:Boolean,reflect:!0})],r.prototype,"disabled",2),n([Q({type:Boolean,reflect:!0})],r.prototype,"readonly",2),n([Q({type:Number,reflect:!0,attribute:"min-associations"})],r.prototype,"minAssociations",2),n([Q({type:Number,reflect:!0,attribute:"max-associations"})],r.prototype,"maxAssociations",2),n([Gt(i)],r.prototype,"handleDraggablesChange",1),r};import{css as fs}from"lit";var Qt=fs`
305
+ </div>`}`}};a([qt({type:String,attribute:"response-identifier"})],B.prototype,"responseIdentifier",2),a([qt({type:String,attribute:"module"})],B.prototype,"module",2),a([qt({type:String,attribute:"custom-interaction-type-identifier"})],B.prototype,"customInteractionTypeIdentifier",2),a([ms()],B.prototype,"_errorMessage",2),B=a([us("qti-portable-custom-interaction")],B);import{html as Gt}from"lit";import{customElement as gs,state as bs}from"lit/decorators.js";var Ke=class c{constructor(){this.touchStartTime=0;this.touchStartPoint=null;this.lastClickTime=0;this.isDraggable=!1;this.dragSource=null;this.dragClone=null;this.touchEndTriggered=!1;this.isDragging=!1;this.initialTransform="";this.hasDispatchedDragStart=!1;this.rootNode=null;this.focusedElement=null;this.focusableDropZones=[];this.currentDropZoneIndex=-1;this.dataTransfer={data:{},setData(i,e){this.data[i]=e},getData(i){return this.data[i]},effectAllowed:"move"};this.cloneOffset={x:0,y:0};this.lastTarget=null;this.currentDropTarget=null;this.allowClick=!0;this.copyStylesForDragClone=!0;this.dragOnClickEnabled=!1;this.useDragClone=!1;this.MIN_DRAG_DISTANCE=5;this.DRAG_CLONE_OPACITY=1;if(c.instance)return c.instance;c.instance=this,document.addEventListener("touchmove",this.handleTouchMove.bind(this),{passive:!1}),document.addEventListener("mousemove",this.handleTouchMove.bind(this),{passive:!1}),document.addEventListener("touchend",this.handleTouchEnd.bind(this),{passive:!1}),document.addEventListener("mouseup",this.handleTouchEnd.bind(this),{passive:!1}),document.addEventListener("touchcancel",this.handleTouchCancel.bind(this),{passive:!1}),document.addEventListener("keydown",this.handleKeyDown.bind(this)),document.addEventListener("keyup",this.handleKeyUp.bind(this))}addDraggableElements(i){i.forEach(e=>{e.setAttribute("tabindex","0"),e.addEventListener("focus",()=>this.focusedElement=e),e.addEventListener("blur",()=>this.focusedElement=null),e.addEventListener("touchstart",this.handleTouchStart.bind(this),{passive:!1}),e.addEventListener("mousedown",this.handleTouchStart.bind(this),{passive:!1})})}handleTouchStart(i){this.touchStartTime=Date.now();let{x:e,y:t}=this.getEventCoordinates(i);if(this.touchStartPoint={x:e,y:t},this.dragSource=i.currentTarget,this.isDraggable=!0,this.rootNode=this.dragSource.getRootNode(),this.dragOnClickEnabled&&(this.isDragging=!0,this.createDragClone(i,{clientX:e,clientY:t})),!this.useDragClone){let r=window.getComputedStyle(this.dragSource);this.initialTransform=r.transform==="none"?"":r.transform,this.initialTransition=r.transition||"",this.dragSource.style.transition="none";let s=this.dragSource.getBoundingClientRect();this.cloneOffset.x=e-s.left,this.cloneOffset.y=t-s.top,this.dragSource.style.zIndex="9999",this.dragSource.focus()}i.preventDefault()}handleTouchMove(i){if(this.isDraggable&&this.dragSource){let{x:e,y:t}=this.getEventCoordinates(i),r={clientX:e,clientY:t};this.calculateDragDistance(r)>=this.MIN_DRAG_DISTANCE&&(this.dragSource.style.pointerEvents="none",this.isDragging=!0),this.createDragClone(i,r),i.preventDefault()}}createDragClone(i,e){if(!this.isDragging)return;if(this.useDragClone){if(!this.dragClone){if(this.dragSource.style.opacity=this.DRAG_CLONE_OPACITY.toString(),this.dragClone=this.dragSource.cloneNode(!0),this.copyStylesForDragClone){let r=window.getComputedStyle(this.dragSource);for(let s of r)this.dragClone.style[s]=r.getPropertyValue(s)}this.rootNode instanceof ShadowRoot?this.rootNode.host.appendChild(this.dragClone):this.rootNode instanceof Document&&document.body.appendChild(this.dragClone),this.calculateClonePosition(e),this.setDragCloneStyles(e),this.dispatchCustomEvent(this.dragSource,"dragstart")}this.updateDragClonePosition(e)}else if(this.touchStartPoint){let r=e.clientX-this.touchStartPoint.x,s=e.clientY-this.touchStartPoint.y;this.dragSource.style.transform=`${this.initialTransform} translate(${r}px, ${s}px)`,this.hasDispatchedDragStart||(this.dispatchCustomEvent(this.dragSource,"dragstart"),this.hasDispatchedDragStart=!0)}let t=this.findDropTarget(i);t!==this.lastTarget&&(this.dispatchCustomEvent(t,"dragenter"),this.dispatchCustomEvent(this.lastTarget,"dragleave"),this.lastTarget=t),this.currentDropTarget=t,this.currentDropTarget&&this.dispatchCustomEvent(t,"dragover")}handleTouchEnd(i){var t;this.touchEndTriggered=!0,this.isDraggable=!1;let e=!1;if(this.currentDropTarget)this.dispatchCustomEvent(this.currentDropTarget,"drop"),this.dispatchCustomEvent(this.dragSource,"dragend"),e=!0;else if(this.isDragging){let r=new CustomEvent("dragend",{bubbles:!0,cancelable:!0});r.dataTransfer={dropEffect:"none"},(t=this.dragSource)==null||t.dispatchEvent(r)}this.resetDragState(e)}handleTouchCancel(i){this.resetDragState()}findDropTarget(i){let{x:e,y:t}=this.getEventCoordinates(i);return this.getDropTargetAtPoint(document,e,t)}getDropTargetAtPoint(i,e,t,r=0){if(r>2)return null;let o=i.elementFromPoint(e,t);if(!o)return null;if(o.hasAttribute("dropzone"))return o;let n=o.parentElement;for(;n;){if(n.hasAttribute("dropzone"))return n;n=n.parentElement}if(o.shadowRoot&&r<2){let l=this.getDropTargetAtPoint(o.shadowRoot,e,t,r+1);if(l)return l}return null}handleKeyDown(i){this.focusedElement&&(i.key===" "&&!this.isDragging?(i.preventDefault(),this.isDraggable=!0,this.dragSource=this.focusedElement,this.isDragging=!0,this.collectDropZones(),this.dispatchCustomEvent(this.dragSource,"dragstart")):i.key==="Tab"&&this.isDragging&&(i.preventDefault(),this.moveToNextDropZone()))}handleKeyUp(i){i.key===" "&&this.isDragging&&this.currentDropTarget&&(i.preventDefault(),this.dispatchCustomEvent(this.currentDropTarget,"drop"),this.dispatchCustomEvent(this.dragSource,"dragend"),this.resetDragState(!0))}collectDropZones(){this.focusableDropZones=Array.from(document.querySelectorAll("[dropzone]")),this.currentDropZoneIndex=-1}moveToNextDropZone(){if(this.focusableDropZones.length===0)return;this.currentDropZoneIndex=(this.currentDropZoneIndex+1)%this.focusableDropZones.length;let i=this.focusableDropZones[this.currentDropZoneIndex];i.focus(),this.currentDropTarget=i,this.dispatchCustomEvent(i,"dragenter")}getEventCoordinates(i,e=!1){let t=i.touches?i.touches[0]:i;return{x:e?t.pageX:t.clientX,y:e?t.pageY:t.clientY}}calculateClonePosition(i){let e=this.dragSource.getBoundingClientRect();this.cloneOffset.x=i.clientX-e.left,this.cloneOffset.y=i.clientY-e.top}setDragCloneStyles(i){this.dragClone.style.position="fixed",this.dragClone.style.top=`${i.clientY-this.cloneOffset.y}px`,this.dragClone.style.left=`${i.clientX-this.cloneOffset.x}px`,this.dragClone.style.pointerEvents="none",this.dragClone.style.zIndex="999999"}updateDragClonePosition(i){requestAnimationFrame(()=>{if(this.touchEndTriggered||!this.dragClone)return;let e=i.clientX-this.cloneOffset.x,t=i.clientY-this.cloneOffset.y,{newLeft:r,newTop:s}=this.applyBoundaries(e,t,this.dragClone);this.dragClone.style.left=`${r}px`,this.dragClone.style.top=`${s}px`})}applyTransformBoundaries(i,e){let t;this.rootNode instanceof ShadowRoot?t=this.rootNode.host.getBoundingClientRect():this.rootNode instanceof Document?t=document.documentElement.getBoundingClientRect():t=new DOMRect(0,0,window.innerWidth,window.innerHeight);let r=this.dragSource.getBoundingClientRect(),s=r.width,o=r.height,n=r.left+i,l=r.top+e,p=Math.max(t.left,Math.min(n,t.right-s)),d=Math.max(t.top,Math.min(l,t.bottom-o)),m=p-r.left,g=d-r.top;return{boundedDeltaX:m,boundedDeltaY:g}}applyBoundaries(i,e,t){let r;this.rootNode instanceof ShadowRoot?r=this.rootNode.host.getBoundingClientRect():this.rootNode instanceof Document?r=document.documentElement.getBoundingClientRect():r=new DOMRect(0,0,window.innerWidth,window.innerHeight);let s=t.getBoundingClientRect(),o=s.width,n=s.height,l=Math.max(r.left,Math.min(i,r.right-o)),p=Math.max(r.top,Math.min(e,r.bottom-n));return{newLeft:l,newTop:p}}calculateDragDistance(i){let e=Math.abs(i.clientX-this.touchStartPoint.x),t=Math.abs(i.clientY-this.touchStartPoint.y);return e+t}dispatchCustomEvent(i,e,t=!0){if(!i)return;let r=new CustomEvent(e,{bubbles:t,cancelable:!0});r.dataTransfer=this.dataTransfer,i.dispatchEvent(r)}resetDragState(i=!1){var e;this.isDragging&&(this.useDragClone?(this.dragSource.style.opacity="1.0",(e=this.dragClone)==null||e.parentElement.removeChild(this.dragClone)):(i||(this.dragSource.style.transform="translate(0, 0)"),this.dragSource.style.zIndex="",this.dragSource.style.pointerEvents="",this.dragSource.style.transition=this.initialTransition,this.initialTransition="")),this.isDragging=!1,this.dragSource=null,this.dragClone=null,this.isDraggable=!1,this.touchStartTime=0,this.touchStartPoint=null,this.touchEndTriggered=!1,this.dataTransfer={data:{},setData(t,r){this.data[t]=r},getData(t){return this.data[t]},effectAllowed:"move"},this.cloneOffset={x:0,y:0},this.lastTarget=null,this.currentDropTarget=null,this.allowClick=!0,this.initialTransform="",this.hasDispatchedDragStart=!1,this.rootNode=null}};import{property as hs}from"lit/decorators.js";var Kt=(c,i,e)=>{class t extends c{constructor(){super(...arguments);this.disabled=!1}firstUpdated(o){if(this.isMatchTabular())return;super.firstUpdated(o);let n=this.getDroppableElements();this.initializeEventHandlers(),n.forEach(l=>{this.prepareDroppable(l),this.observeDroppableAttributes(l)})}isMatchTabular(){return this.classList.contains("qti-match-tabular")}getDroppableElements(){return Array.from(i?this.shadowRoot.querySelectorAll(e):this.querySelectorAll(e))}initializeEventHandlers(){this.dragoverHandler=this.dragoverHandler.bind(this),this.dragleaveHandler=this.dragleaveHandler.bind(this),this.dragenterHandler=this.dragenterHandler.bind(this),this.dropHandler=this.dropHandler.bind(this)}prepareDroppable(o){o.setAttribute("dropzone","move"),o.addEventListener("dragleave",this.dragleaveHandler),this.attachEventListeners(o)}observeDroppableAttributes(o){this.observer=new MutationObserver(n=>{n.forEach(({attributeName:l})=>{l==="disabled"&&this.toggleDroppableHandlers(o)})}),this.observer.observe(o,{attributes:!0})}toggleDroppableHandlers(o){o.hasAttribute("disabled")?this.removeEventListeners(o):this.attachEventListeners(o)}attachEventListeners(o){o.addEventListener("dragover",this.dragoverHandler),o.addEventListener("dragenter",this.dragenterHandler),o.addEventListener("drop",this.dropHandler)}removeEventListeners(o){o.removeEventListener("dragover",this.dragoverHandler),o.removeEventListener("dragenter",this.dragenterHandler),o.removeEventListener("drop",this.dropHandler)}disconnectedCallback(){var o;this.isMatchTabular()||(super.disconnectedCallback(),(o=this.observer)==null||o.disconnect())}dragenterHandler(o){o.preventDefault()}dragoverHandler(o){return o.preventDefault(),this.activateDroppable(o.currentTarget),o.dataTransfer.dropEffect="move",!1}activateDroppable(o){o.setAttribute("active","")}async dropHandler(o){o.preventDefault();let n=o.currentTarget,l=o.dataTransfer.getData("text"),p=this.findDraggable(l);return p?p&&!this.isValidDrop(n,p)?(p.style.transform="translate(0, 0)",!1):(await this.moveDraggableToDroppable(p,n),this.deactivateDroppable(n),!1):!1}findDraggable(o){return o?this.querySelector(`[identifier=${o}]`)||this.shadowRoot.querySelector(`[identifier=${o}]`):null}isValidDrop(o,n){return n.parentElement.getAttribute("identifier")!==o.getAttribute("identifier")}async moveDraggableToDroppable(o,n){let l=()=>{o.style.transform="translate(0, 0)",n.appendChild(o),this.checkMaxAssociations(),this.saveResponse(null)};if(!document.startViewTransition){l();return}await document.startViewTransition(l).finished}deactivateDroppable(o){o.removeAttribute("active")}dragleaveHandler(o){return o.preventDefault(),this.deactivateDroppable(o.currentTarget),o.dataTransfer.dropEffect="none",!1}}return a([hs({type:Boolean,reflect:!0})],t.prototype,"disabled",2),t};var Wt=(c,i,e)=>{class t extends c{}return t};import{property as wt}from"lit/decorators.js";function Zt(c,i){let e,t=b({},i);return(r,s)=>{let{connectedCallback:o,disconnectedCallback:n}=r;r.connectedCallback=function(){var d;o.call(this);let l=m=>{let g=Array.from(this.querySelectorAll(c));for(let f of m){let y=Array.from(f.addedNodes).map($=>$),v=Array.from(f.addedNodes).map($=>$);f.type==="childList"&&y.find($=>g.includes($))&&this[s](y,v)}};e=new MutationObserver(l),e.observe(this,{childList:!0,subtree:!0});let p=(d=this.querySelectorAll(c))!=null?d:[];this[s](Array.from(p),[])},r.disconnectedCallback=function(){n.call(this),e.disconnect()}}}var V=(c,i,e,t)=>{class r extends Wt(Kt(c,e,t),t,i){constructor(){super(...arguments);this.draggables=new Map;this.droppables=[];this.configuration={copyStylesDragClone:!0,dragCanBePlacedBack:!0,dragOnClick:!1};this.minAssociations=1;this.maxAssociations=1;this.handleDragStart=n=>{let l=n.currentTarget;n.dataTransfer.setData("text",l.getAttribute("identifier")),l.setAttribute("dragging",""),this.activateDroppables()};this.handleDragEnd=async n=>{n.preventDefault(),this.deactivateDroppables();let l=n.currentTarget;l.removeAttribute("dragging"),await this.wasDropped(n)||this.configuration.dragCanBePlacedBack&&this.restoreInitialDraggablePosition(l)};this.checkForMoveTestItem=n=>n.dataTransfer.items?new Promise(l=>{let p=!1,d=Array.from(n.dataTransfer.items),m=d.length;if(m===0){l(!1);return}d.forEach(g=>{g.kind==="string"&&g.type==="text"?g.getAsString(f=>{f==="move-test"&&(p=!0),m===0&&l(p)}):m===0&&l(p)})}):Promise.resolve(!1)}handleDraggablesChange(n,l){if(this.isMatchTabular())return;let p=this.filterExistingDraggables(n);p.length>0&&this.addNewDraggables(p)}firstUpdated(n){super.firstUpdated(n),this.initializeDroppables()}connectedCallback(){super.connectedCallback(),this.initializeDragDropApi()}initializeDragDropApi(){this.dragDropApi=new Ke,this.dispatchEvent(new CustomEvent("qti-register-interaction",{bubbles:!0,composed:!0,detail:this}))}isMatchTabular(){return this.classList.contains("qti-match-tabular")}filterExistingDraggables(n){return n.filter(l=>!this.draggables.has(l))}addNewDraggables(n){this.dragDropApi.addDraggableElements(n),n.forEach(l=>this.storeDraggable(l))}storeDraggable(n){let l=Array.from(n.parentNode.children).indexOf(n);this.draggables.set(n,{parent:n.parentElement,index:l}),n.style.viewTransitionName=`drag-${l}-${this.getAttribute("identifier")||crypto.randomUUID()}`,n.setAttribute("qti-draggable","true"),n.addEventListener("dragstart",this.handleDragStart),n.addEventListener("dragend",this.handleDragEnd)}initializeDroppables(){this.droppables=Array.from(e?this.shadowRoot.querySelectorAll(t):this.querySelectorAll(t))}activateDroppables(){this.droppables.forEach(n=>n.setAttribute("enabled",""))}deactivateDroppables(){this.droppables.forEach(n=>n.removeAttribute("enabled"))}async wasDropped(n){let l=await this.checkForMoveTestItem(n);return n.dataTransfer.dropEffect!=="none"||l}wasMoved(n){return n.dataTransfer.dropEffect==="move"}async restoreInitialDraggablePosition(n){let{parent:l,index:p}=this.draggables.get(n),d=Math.min(p,l.children.length),m=(f,y,v)=>{let $=Math.min(v,y.children.length);y.insertBefore(f,y.children[$]),f.style.transform="translate(0, 0)",this.checkMaxAssociations()};if(!document.startViewTransition){m(n,l,p);return}let g=document.startViewTransition(()=>{n.style.transform="",m(n,l,p)})}checkMaxAssociations(){this.droppables.forEach((n,l)=>{let p=+(n.getAttribute("match-max")||1);n.querySelectorAll('[qti-draggable="true"]').length>=p?this.disableDroppable(n):this.enableDroppable(n)})}disableDroppable(n){n.setAttribute("disabled",""),n.removeAttribute("dropzone")}enableDroppable(n){n.removeAttribute("disabled"),n.setAttribute("dropzone","move")}get value(){return this.collectResponseData()}set value(n){this.isMatchTabular()||(this.resetDroppables(),n==null||n.forEach(l=>this.placeResponse(l)))}placeResponse(n){let[l,...p]=n.split(" ").reverse(),d=this.findDroppableById(l);p.forEach(m=>this.placeDraggableInDroppable(m,d))}findDroppableById(n){return this.droppables.find(l=>l.getAttribute("identifier")===n)}async placeDraggableInDroppable(n,l){let p=this.querySelector(`[identifier=${n}]`);if(!l||!p){console.error(`Cannot find draggable or droppable with the given identifier: ${n}`);return}let d=()=>{p.style.transform="translate(0, 0)",l.appendChild(p),this.checkMaxAssociations()};document.startViewTransition?await document.startViewTransition(d).finished:d()}validate(){let n=this.getValidAssociations();return this.minAssociations<=0||this.minAssociations<=n}getValidAssociations(){return this.droppables.filter(n=>n.childElementCount>0).length}saveResponse(){let n=this.collectResponseData();this.dispatchEvent(new CustomEvent("qti-interaction-response",{bubbles:!0,composed:!0,detail:{responseIdentifier:this.responseIdentifier,response:n}}))}collectResponseData(){return this.droppables.map(l=>{let p=l.querySelectorAll('[qti-draggable="true"]'),d=Array.from(p).map(g=>g.getAttribute("identifier")),m=l.getAttribute("identifier");return d.map(g=>`${g} ${m}`)}).flat()}reset(n=!0){this.resetDroppables(),n&&this.saveResponse()}async resetDroppables(){let n=(p,d,m)=>{p.style.transform="translate(0, 0)";let g=Math.min(m,d.children.length);d.insertBefore(p,d.children[g])};if(!document.startViewTransition){this.draggables.forEach(({parent:p,index:d},m)=>{n(m,p,d)});return}await document.startViewTransition(()=>{this.draggables.forEach(({parent:p,index:d},m)=>{n(m,p,d)})}).finished}}return a([wt({attribute:!1,type:Object})],r.prototype,"configuration",2),a([wt({type:Number,reflect:!0,attribute:"min-associations"})],r.prototype,"minAssociations",2),a([wt({type:Number,reflect:!0,attribute:"max-associations"})],r.prototype,"maxAssociations",2),a([Zt(i)],r.prototype,"handleDraggablesChange",1),r};import{css as fs}from"lit";var Jt=fs`
300
306
  :host {
301
307
  display: block; /* necessary to calculate scaling position */
302
308
  }
@@ -316,22 +322,22 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
316
322
  rgb(0 0 0 / 0%) calc(50% + 1px)
317
323
  );
318
324
  }
319
- `;var ee=class extends H(gs,"qti-simple-associable-choice",!0,".dl"){constructor(){super();this._childrenMap=[];this.addEventListener("register-qti-simple-associable-choice",e=>{let t=e.target;this._childrenMap.push(t)})}render(){return er` <slot name="prompt"></slot>
325
+ `;var G=class extends V(u,"qti-simple-associable-choice",!0,".dl"){constructor(){super();this._childrenMap=[];this._registerChoiceHandler=this._registerChoice.bind(this),this.addEventListener("register-qti-simple-associable-choice",this._registerChoiceHandler)}_registerChoice(e){let t=e.target;this._childrenMap.push(t)}render(){return Gt` <slot name="prompt"></slot>
320
326
  <slot name="qti-simple-associable-choice"></slot>
321
327
  <div part="drop-container">
322
- ${this._childrenMap.length>0&&Array.from(Array(Math.ceil(this._childrenMap.length/2)).keys()).map((e,t)=>er`<div part="associables-container">
328
+ ${this._childrenMap.length>0&&Array.from(Array(Math.ceil(this._childrenMap.length/2)).keys()).map((e,t)=>Gt`<div part="associables-container">
323
329
  <div name="left${t}" part="drop-list" class="dl" identifier="droplist${t}_left"></div>
324
330
  <div name="right${t}" part="drop-list" class="dl" identifier="droplist${t}_right"></div>
325
331
  </div>`)}
326
- </div>`}};ee.styles=Qt,n([vs()],ee.prototype,"_childrenMap",2),ee=n([bs("qti-associate-interaction")],ee);import{html as tr}from"lit";import{customElement as ys,property as ye,state as xs}from"lit/decorators.js";var N=class extends f{constructor(){super();this._errorMessage=null;this.handlePostMessage=this.handlePostMessage.bind(this)}connectedCallback(){super.connectedCallback();let e=this.data.startsWith("http")?this.data:pe(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(`
332
+ </div>`}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("register-qti-simple-associable-choice",this._registerChoiceHandler)}};G.styles=Jt,a([bs()],G.prototype,"_childrenMap",2),G=a([gs("qti-associate-interaction")],G);import{html as Qt}from"lit";import{customElement as vs,property as be,state as ys}from"lit/decorators.js";var H=class extends u{constructor(){super();this._errorMessage=null;this.handlePostMessage=this.handlePostMessage.bind(this)}connectedCallback(){super.connectedCallback();let e=this.data.startsWith("http")?this.data:le(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(`
327
333
  <html>
328
334
  <head>
329
- <link href='${pe(`${this.baseRefUrl}/${this.manifest.style[0]}`)}' rel="stylesheet" />
330
- <script src='${pe(`${this.baseRefUrl}/${this.manifest.script[0]}`)}'></script>
335
+ <link href='${le(`${this.baseRefUrl}/${this.manifest.style[0]}`)}' rel="stylesheet" />
336
+ <script src='${le(`${this.baseRefUrl}/${this.manifest.script[0]}`)}'></script>
331
337
  </head>
332
338
  <body></body>
333
339
  </html>
334
- `),r.close()}getIFrames(){let e=this.shadowRoot.querySelectorAll("iframe"),t=this.querySelectorAll("iframe"),r=[...e,...t];for(let s of r){let o=s.src;if(new URL(o,window.location.href).origin===window.location.origin)try{let l=s.contentDocument||s.contentWindow.document;l&&this.getInnerIFrames(l,r)}catch(l){console.error("Error accessing nested iframe:",l)}}return r.forEach((s,o)=>{r.indexOf(s)!==o&&r.splice(o,1)}),r}getInnerIFrames(e,t=[]){return e.querySelectorAll("iframe").forEach(s=>{t.push(s);let o=s.src;if(new URL(o,window.location.href).origin===window.location.origin)try{let l=s.contentDocument||s.contentWindow.document;this.getInnerIFrames(l,t)}catch(l){console.error("Error accessing nested iframe:",l)}else console.warn("Skipped cross-origin iframe:",o)}),t}postToWindowAndIframes(e,t){window.postMessage({type:e,data:t},"*");let r=this.getIFrames();for(let s of r)s.contentWindow&&s.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 s=this.manifest.media.map(o=>o.startsWith("http")?o:pe(this.baseRefUrl+"/"+o));this.postToWindowAndIframes("mediaData",s);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 tr`<iframe
340
+ `),r.close()}getIFrames(){let e=this.shadowRoot.querySelectorAll("iframe"),t=this.querySelectorAll("iframe"),r=[...e,...t];for(let s of r){let o=s.src;if(new URL(o,window.location.href).origin===window.location.origin)try{let l=s.contentDocument||s.contentWindow.document;l&&this.getInnerIFrames(l,r)}catch(l){console.error("Error accessing nested iframe:",l)}}return r.forEach((s,o)=>{r.indexOf(s)!==o&&r.splice(o,1)}),r}getInnerIFrames(e,t=[]){return e.querySelectorAll("iframe").forEach(s=>{t.push(s);let o=s.src;if(new URL(o,window.location.href).origin===window.location.origin)try{let l=s.contentDocument||s.contentWindow.document;this.getInnerIFrames(l,t)}catch(l){console.error("Error accessing nested iframe:",l)}else console.warn("Skipped cross-origin iframe:",o)}),t}postToWindowAndIframes(e,t){window.postMessage({type:e,data:t},"*");let r=this.getIFrames();for(let s of r)s.contentWindow&&s.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 s=this.manifest.media.map(o=>o.startsWith("http")?o:le(this.baseRefUrl+"/"+o));this.postToWindowAndIframes("mediaData",s);break}case"setStageHeight":console.log("setStageHeight not implemented");break}}validate(){return this.rawResponse!==""}get value(){return this.rawResponse}set value(e){if(typeof e=="string")this.rawResponse=e,this.saveResponse(e);else throw new Error("Value must be a string")}disconnectedCallback(){window.removeEventListener("message",this.handlePostMessage),super.disconnectedCallback()}render(){return Qt`<iframe
335
341
  width=${this.getAttribute("width")}
336
342
  height=${this.getAttribute("height")}
337
343
  frameborder="0"
@@ -339,10 +345,10 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
339
345
  id="pciContainer"
340
346
  >
341
347
  </iframe>
342
- ${this._errorMessage&&tr`<div style="color:red">
348
+ ${this._errorMessage&&Qt`<div style="color:red">
343
349
  <h1>Error</h1>
344
350
  ${this._errorMessage}
345
- </div>`}`}};n([ye({type:String,attribute:"response-identifier"})],N.prototype,"responseIdentifier",2),n([ye({type:String,attribute:"data"})],N.prototype,"data",2),n([ye({type:String,attribute:"data-base-item"})],N.prototype,"baseItemUrl",2),n([ye({type:String,attribute:"data-base-ref"})],N.prototype,"baseRefUrl",2),n([ye({type:String,attribute:"id"})],N.prototype,"id",2),n([xs()],N.prototype,"_errorMessage",2),N=n([ys("qti-custom-interaction")],N);import{html as Es}from"lit";import{customElement as Cs,property as rr}from"lit/decorators.js";var te=class extends f{constructor(){super(...arguments);this.countAttempt="true"}validate(){return!0}set response(e){}render(){return Es`<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"}}))}};n([rr({type:String,attribute:"count-attempt"})],te.prototype,"countAttempt",2),n([rr({type:String})],te.prototype,"title",2),te=n([Cs("qti-end-attempt-interaction")],te);import{css as qs,html as Ts,LitElement as ws}from"lit";import{customElement as Ss}from"lit/decorators.js";var xe=class extends H(ws,"qti-gap-text",!1,"qti-gap"){render(){return Ts`<slot name="prompt"> </slot><slot part="drags" name="qti-gap-text"></slot> <slot part="drops"></slot>`}set correctResponse(i){let e=[],t=Array.isArray(i)?i:[i];t&&(e=t.map(s=>{let o=s.split(" ");return{text:o[0],gap:o[1]}})),this.querySelectorAll("qti-gap").forEach((s,o)=>{var d,u,g,h;let a=s.getAttribute("identifier"),l=(d=e.find(y=>y.gap===a))==null?void 0:d.text,p=(u=this.querySelector(`qti-gap-text[identifier="${l}"]`))==null?void 0:u.textContent.trim();if(l&&p){if(!((g=s.nextElementSibling)!=null&&g.classList.contains("correct-option"))){let y=document.createElement("span");y.classList.add("correct-option"),y.textContent=p,s.insertAdjacentElement("afterend",y)}}else(h=s.nextElementSibling)!=null&&h.classList.contains("correct-option")&&s.nextElementSibling.remove()})}};xe.styles=[qs`
351
+ </div>`}`}};a([be({type:String,attribute:"response-identifier"})],H.prototype,"responseIdentifier",2),a([be({type:String,attribute:"data"})],H.prototype,"data",2),a([be({type:String,attribute:"data-base-item"})],H.prototype,"baseItemUrl",2),a([be({type:String,attribute:"data-base-ref"})],H.prototype,"baseRefUrl",2),a([be({type:String,attribute:"id"})],H.prototype,"id",2),a([ys()],H.prototype,"_errorMessage",2),H=a([vs("qti-custom-interaction")],H);import{html as xs}from"lit";import{customElement as Es,property as er}from"lit/decorators.js";var Q=class extends u{constructor(){super(...arguments);this.countAttempt="true"}validate(){return!0}get value(){return""}set value(e){}render(){return xs`<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"}}))}};a([er({type:String,attribute:"count-attempt"})],Q.prototype,"countAttempt",2),a([er({type:String})],Q.prototype,"title",2),Q=a([Es("qti-end-attempt-interaction")],Q);import{css as Cs,html as qs}from"lit";import{customElement as ws}from"lit/decorators.js";var ve=class extends V(u,"qti-gap-text",!1,"qti-gap"){render(){return qs`<slot name="prompt"> </slot><slot part="drags" name="qti-gap-text"></slot> <slot part="drops"></slot>`}set correctResponse(i){let e=[],t=Array.isArray(i)?i:[i];t&&(e=t.map(s=>{let o=s.split(" ");return{text:o[0],gap:o[1]}})),this.querySelectorAll("qti-gap").forEach((s,o)=>{var d,m,g,f;let n=s.getAttribute("identifier"),l=(d=e.find(y=>y.gap===n))==null?void 0:d.text,p=(m=this.querySelector(`qti-gap-text[identifier="${l}"]`))==null?void 0:m.textContent.trim();if(l&&p){if(!((g=s.nextElementSibling)!=null&&g.classList.contains("correct-option"))){let y=document.createElement("span");y.classList.add("correct-option"),y.textContent=p,s.insertAdjacentElement("afterend",y)}}else(f=s.nextElementSibling)!=null&&f.classList.contains("correct-option")&&s.nextElementSibling.remove()})}};ve.styles=[Cs`
346
352
  :host {
347
353
  display: flex;
348
354
  align-items: flex-start;
@@ -369,14 +375,14 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
369
375
  flex: 1;
370
376
  gap: 0.5rem;
371
377
  }
372
- `],xe=n([Ss("qti-gap-match-interaction")],xe);import{css as ks,html as Ls,svg as ir}from"lit";import{customElement as Rs,query as Ms,queryAssignedElements as As,state as Lt}from"lit/decorators.js";import{ifDefined as sr}from"lit/directives/if-defined.js";import{repeat as _s}from"lit/directives/repeat.js";function re(c,i,e,t){switch(c){case"circle":{let[r,s,o]=i,a=r/e.width*100,l=s/e.height*100,p=o/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,s,o,a]=i,l=r/e.width*100,p=s/e.height*100,d=o/e.width*100,u=a/e.height*100;t.style.left=l+"%",t.style.top=p+"%",t.style.width=d-l+"%",t.style.height=u-p+"%"}break;case"poly":{let r=i.reduce((v,$,_t,mr)=>{if(_t%2===1){let hr=v.pop();v[v.length]={x:hr,y:mr[_t]}}else v.push($);return v},[]),s=Math.min(...r.map(v=>v.x)),o=Math.max(...r.map(v=>v.x)),a=Math.min(...r.map(v=>v.y)),l=Math.max(...r.map(v=>v.y)),p=s/e.width*100,d=a/e.height*100,u=o/e.width*100,g=l/e.height*100;t.style.left=s/e.width*100+"%",t.style.top=a/e.height*100+"%",t.style.width=u-p+"%",t.style.height=g-d+"%";let y=r.map(v=>({x:(v.x-s)/(o-s)*100,y:(v.y-a)/(l-a)*100})).map(v=>Math.round(v.x)+"% "+Math.round(v.y)+"%").join(",");t.style.clipPath=`polygon(${y})`}break;default:break}}var V=class extends f{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,s;return Ls`<slot name="prompt"></slot>
378
+ `],ve=a([ws("qti-gap-match-interaction")],ve);import{css as Ts,html as Ss,svg as tr}from"lit";import{customElement as ks,query as Ms,queryAssignedElements as _s,state as Tt}from"lit/decorators.js";import{ifDefined as rr}from"lit/directives/if-defined.js";import{repeat as Rs}from"lit/directives/repeat.js";function ee(c,i,e,t){switch(c){case"circle":{let[r,s,o]=i,n=r/e.width*100,l=s/e.height*100,p=o/e.width*100;t.style.left=n-p+"%",t.style.top=l-p+"%",t.style.width=t.style.height=4*p+"px",t.style.borderRadius="9999px"}break;case"rect":{let[r,s,o,n]=i,l=r/e.width*100,p=s/e.height*100,d=o/e.width*100,m=n/e.height*100;t.style.left=l+"%",t.style.top=p+"%",t.style.width=d-l+"%",t.style.height=m-p+"%"}break;case"poly":{let r=i.reduce((v,$,_t,dr)=>{if(_t%2===1){let ur=v.pop();v[v.length]={x:ur,y:dr[_t]}}else v.push($);return v},[]),s=Math.min(...r.map(v=>v.x)),o=Math.max(...r.map(v=>v.x)),n=Math.min(...r.map(v=>v.y)),l=Math.max(...r.map(v=>v.y)),p=s/e.width*100,d=n/e.height*100,m=o/e.width*100,g=l/e.height*100;t.style.left=s/e.width*100+"%",t.style.top=n/e.height*100+"%",t.style.width=m-p+"%",t.style.height=g-d+"%";let y=r.map(v=>({x:(v.x-s)/(o-s)*100,y:(v.y-n)/(l-n)*100})).map(v=>Math.round(v.x)+"% "+Math.round(v.y)+"%").join(",");t.style.clipPath=`polygon(${y})`}break;default:break}}var N=class extends u{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 value(e){Array.isArray(e)&&(this._lines=e)}get value(){return this._lines}render(){var e,t,r,s;return Ss`<slot name="prompt"></slot>
373
379
  <line-container>
374
380
  <svg
375
- width=${sr((e=this.grImage[0])==null?void 0:e.width)}
376
- height=${sr((t=this.grImage[0])==null?void 0:t.height)}
381
+ width=${rr((e=this.grImage[0])==null?void 0:e.width)}
382
+ height=${rr((t=this.grImage[0])==null?void 0:t.height)}
377
383
  viewbox="0 0 ${(r=this.grImage[0])==null?void 0:r.width} ${(s=this.grImage[0])==null?void 0:s.height}"
378
384
  >
379
- ${_s(this._lines,o=>o,(o,a)=>ir`
385
+ ${Rs(this._lines,o=>o,(o,n)=>tr`
380
386
  <line
381
387
  part="line"
382
388
  x1=${parseInt(this.querySelector("[identifier="+o.split(" ")[0]+"]").style.left)}
@@ -385,10 +391,10 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
385
391
  y2=${parseInt(this.querySelector("[identifier="+o.split(" ")[1]+"]").style.top)}
386
392
  stroke="red"
387
393
  stroke-width="3"
388
- @click=${l=>{l.stopPropagation(),this._lines=this._lines.filter((p,d)=>d!==a),this.saveResponse(this._lines)}}
394
+ @click=${l=>{l.stopPropagation(),this._lines=this._lines.filter((p,d)=>d!==n),this.saveResponse(this._lines)}}
389
395
  />
390
396
  `)}
391
- ${this.startPoint&&ir`<line
397
+ ${this.startPoint&&tr`<line
392
398
  part="point"
393
399
  x1=${this.startCoord.x}
394
400
  y1=${this.startCoord.y}
@@ -399,7 +405,7 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
399
405
  />`}
400
406
  </svg>
401
407
  <slot></slot>
402
- </line-container>`}positionHotspotOnRegister(e){let t=this.querySelector("img"),r=e.target,s=r.getAttribute("coords"),o=r.getAttribute("shape"),a=s.split(",").map(l=>parseInt(l));re(o,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)}};V.styles=[ks`
408
+ </line-container>`}positionHotspotOnRegister(e){let t=this.querySelector("img"),r=e.target,s=r.getAttribute("coords"),o=r.getAttribute("shape"),n=s.split(",").map(l=>parseInt(l));ee(o,n,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)}};N.styles=[Ts`
403
409
  slot:not([name='prompt']) {
404
410
  // position: relative; /* qti-hotspot-choice relative to the slot */
405
411
  display: block;
@@ -422,9 +428,9 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
422
428
  top: 0px;
423
429
  left: 0px;
424
430
  }
425
- `],n([Lt()],V.prototype,"_lines",2),n([Lt()],V.prototype,"startCoord",2),n([Lt()],V.prototype,"mouseCoord",2),n([Ms("svg")],V.prototype,"svgContainer",2),n([As({selector:"img"})],V.prototype,"grImage",2),V=n([Rs("qti-graphic-associate-interaction")],V);import{css as Ds,html as Hs,LitElement as Ns}from"lit";import{customElement as Vs}from"lit/decorators.js";var Ee=class extends H(Ns,"qti-gap-img",!1,"qti-associable-hotspot"){render(){return Hs` <slot name="prompt"></slot>
431
+ `],a([Tt()],N.prototype,"_lines",2),a([Tt()],N.prototype,"startCoord",2),a([Tt()],N.prototype,"mouseCoord",2),a([Ms("svg")],N.prototype,"svgContainer",2),a([_s({selector:"img"})],N.prototype,"grImage",2),N=a([ks("qti-graphic-associate-interaction")],N);import{css as Ls,html as As}from"lit";import{customElement as Ds}from"lit/decorators.js";var ye=class extends V(u,"qti-gap-img",!1,"qti-associable-hotspot"){render(){return As` <slot name="prompt"></slot>
426
432
  <slot></slot>
427
- <slot name="qti-gap-img"></slot>`}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(a=>parseInt(a));switch(s){case"circle":{let[a,l,p]=o;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]=o;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=Ds`
433
+ <slot name="qti-gap-img"></slot>`}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(n=>parseInt(n));switch(s){case"circle":{let[n,l,p]=o;t.style.left=n-p+"px",t.style.top=l-p+"px",t.style.width=t.style.height=2*p+"px"}break;case"rect":{let[n,l,p,d]=o;t.style.left=n+"px",t.style.top=l+"px",t.style.width=p-n+"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)}};ye.styles=Ls`
428
434
  :host {
429
435
  display: inline-block;
430
436
  position: relative;
@@ -433,12 +439,12 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
433
439
  display: flex;
434
440
  gap: 1rem;
435
441
  }
436
- `,Ee=n([Vs("qti-graphic-gap-match-interaction")],Ee);import{css as $s,html as Ps,LitElement as Is}from"lit";import{customElement as Os}from"lit/decorators.js";var Ce=class extends U(Is,"qti-hotspot-choice"){render(){return Ps`
442
+ `,ye=a([Ds("qti-graphic-gap-match-interaction")],ye);import{css as Vs,html as Hs}from"lit";import{customElement as Ns}from"lit/decorators.js";var xe=class extends U(u,"qti-hotspot-choice"){render(){return Hs`
437
443
  <slot name="prompt"></slot>
438
444
  <!-- slot for the prompt -->
439
445
  <slot></slot>
440
446
  <!-- slot for the image and hotspots -->
441
- `}setHotspotOrder(i){let{identifier:e}=i.detail,t=this._choiceElements.find(s=>s.getAttribute("identifier")===e),r=this._choiceElements.length;if(!this.choiceOrdering){if(this.choiceOrdering=!0,t.order==null){if(this._choiceElements.filter(s=>s.order>0).length>=r){this.choiceOrdering=!1;return}t.order=this._choiceElements.filter(s=>!!s.order).length+1,this.choiceOrdering=!1;return}else this._choiceElements.forEach(s=>(s.order>s.order&&s.order--,s)),t.order=null;this.choiceOrdering=!1}}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(a=>parseInt(a));re(s,o,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("activate-qti-hotspot-choice",this.setHotspotOrder),this.addEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("activate-qti-hotspot-choice",this.setHotspotOrder),this.removeEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}};Ce.styles=[$s`
447
+ `}setHotspotOrder(i){let{identifier:e}=i.detail,t=this._choiceElements.find(s=>s.getAttribute("identifier")===e),r=this._choiceElements.length;if(!this.choiceOrdering){if(this.choiceOrdering=!0,t.order==null){if(this._choiceElements.filter(s=>s.order>0).length>=r){this.choiceOrdering=!1;return}t.order=this._choiceElements.filter(s=>!!s.order).length+1,this.choiceOrdering=!1;return}else this._choiceElements.forEach(s=>(s.order>s.order&&s.order--,s)),t.order=null;this.choiceOrdering=!1}}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(n=>parseInt(n));ee(s,o,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("activate-qti-hotspot-choice",this.setHotspotOrder),this.addEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("activate-qti-hotspot-choice",this.setHotspotOrder),this.removeEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}};xe.styles=[Vs`
442
448
  slot:not([name='prompt']) {
443
449
  position: relative; /* qti-hotspot-choice relative to the slot */
444
450
  display: block;
@@ -449,12 +455,12 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
449
455
  pointer-events: none;
450
456
  user-select: none;
451
457
  }
452
- `],Ce=n([Os("qti-graphic-order-interaction")],Ce);import{css as Us,html as Fs,LitElement as Bs}from"lit";import{customElement as Xs}from"lit/decorators.js";var qe=class extends U(Bs,"qti-hotspot-choice"){render(){return Fs`
458
+ `],xe=a([Ns("qti-graphic-order-interaction")],xe);import{css as $s,html as Is}from"lit";import{customElement as Ps}from"lit/decorators.js";var Ee=class extends U(u,"qti-hotspot-choice"){render(){return Is`
453
459
  <slot name="prompt"></slot>
454
460
  <!-- slot for the prompt -->
455
461
  <slot></slot>
456
462
  <!-- slot for the image and hotspots -->
457
- `}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(a=>parseInt(a));re(s,o,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("register-qti-hotspot-choice",this.positionHotspotOnRegister)}};qe.styles=[Us`
463
+ `}positionHotspotOnRegister(i){let e=this.querySelector("img"),t=i.target,r=t.getAttribute("coords"),s=t.getAttribute("shape"),o=r.split(",").map(n=>parseInt(n));ee(s,o,e,t)}connectedCallback(){super.connectedCallback(),this.addEventListener("qti-register-choice",this.positionHotspotOnRegister)}disconnectedCallback(){super.disconnectedCallback(),this.removeEventListener("qti-register-choice",this.positionHotspotOnRegister)}};Ee.styles=[$s`
458
464
  slot:not([name='prompt']) {
459
465
  position: relative; /* qti-hotspot-choice relative to the slot */
460
466
  display: block;
@@ -466,10 +472,10 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
466
472
  user-select: none;
467
473
  /* width:100%; */
468
474
  }
469
- `],qe=n([Xs("qti-hotspot-interaction")],qe);import{html as Te,LitElement as Zs}from"lit";import{customElement as Js,property as Gs,state as nr}from"lit/decorators.js";import{unsafeHTML as ar}from"lit/directives/unsafe-html.js";import{css as Ys,html as js,LitElement as zs}from"lit";import{customElement as Ks,property as Rt}from"lit/decorators.js";var X=class extends M(zs,"qti-simple-associable-choice"){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 js`
475
+ `],Ee=a([Ps("qti-hotspot-interaction")],Ee);import{html as Ce}from"lit";import{customElement as Ys,property as js,state as sr}from"lit/decorators.js";import{unsafeHTML as or}from"lit/directives/unsafe-html.js";import{css as Os,html as Us,LitElement as Fs}from"lit";import{customElement as Bs,property as St}from"lit/decorators.js";var X=class extends _(Fs,"qti-simple-associable-choice"){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 Us`
470
476
  <slot part="slot"></slot>
471
477
  <slot part="dropslot" name="qti-simple-associable-choice"></slot>
472
- `}};X.styles=Ys`
478
+ `}};X.styles=Os`
473
479
  :host {
474
480
  display: flex;
475
481
  user-select: none;
@@ -481,7 +487,7 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
481
487
  slot[name='qti-simple-associable-choice'] {
482
488
  width: 100%;
483
489
  }
484
- `,n([Rt({type:Number,attribute:"match-min"})],X.prototype,"matchMin",2),n([Rt({type:Number,attribute:"match-max"})],X.prototype,"matchMax",2),n([Rt({type:Boolean,attribute:"fixed"})],X.prototype,"fixed",2),X=n([Ks("qti-simple-associable-choice")],X);import{css as Ws}from"lit";var or=Ws`
490
+ `,a([St({type:Number,attribute:"match-min"})],X.prototype,"matchMin",2),a([St({type:Number,attribute:"match-max"})],X.prototype,"matchMax",2),a([St({type:Boolean,attribute:"fixed"})],X.prototype,"fixed",2),X=a([Bs("qti-simple-associable-choice")],X);import{css as Xs}from"lit";var ir=Xs`
485
491
  slot {
486
492
  /* slot where the */
487
493
  display: flex;
@@ -508,37 +514,37 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
508
514
  /* Make sure the drag and drop container slots have the same width */
509
515
  flex: 1;
510
516
  }
511
- `;var Y=class extends H(Zs,"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,s=t.name,o=t.type;t.checked?(this.response?this.response.indexOf(r)===-1&&(o==="radio"&&(this.response=this.response.filter(a=>a.indexOf(s)===-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}}))}}get response(){return this.classList.contains("qti-match-tabular")?this._response:super.response}set response(e){this.classList.contains("qti-match-tabular")?this._response=e:super.response=e}async 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")?Te`
517
+ `;var Y=class extends V(u,"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,s=t.name,o=t.type;t.checked?(this.value?this.value.indexOf(r)===-1&&(o==="radio"&&(this.value=this.value.filter(n=>n.indexOf(s)===-1)),this.value=[...this.value,r]):this.value=[r],this.lastCheckedRadio=t):(this.value=this.value.filter(n=>n!==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.value)?[...this.value]:this.value}}))}}get value(){return this.classList.contains("qti-match-tabular")?this._response:super.value}set value(e){this.classList.contains("qti-match-tabular")?this._response=e:super.value=e}async 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.value=[]}set correctResponse(e){if(e===""){this.correctOptions=[];return}else Array.isArray(e)&&(this.correctOptions=e)}render(){return this.classList.contains("qti-match-tabular")?Ce`
512
518
  <slot name="prompt"></slot>
513
519
  <table>
514
520
  <tr>
515
521
  <td></td>
516
- ${this.cols.map((e,t)=>Te`<th part="r-header">${ar(e.innerHTML)}</th>`)}
522
+ ${this.cols.map((e,t)=>Ce`<th part="r-header">${or(e.innerHTML)}</th>`)}
517
523
  </tr>
518
524
 
519
- ${this.rows.map((e,t)=>Te`<tr>
520
- <td part="c-header">${ar(e.innerHTML)}</td>
521
- ${this.cols.map((r,s)=>{let o=e.getAttribute("identifier"),a=r.getAttribute("identifier"),l=`${o} ${a}`,p=this.response.filter(h=>h.split(" ")[0]===o).length||0,d=this.response.includes(l),u=`rb ${d?"rb-checked":""} ${this.correctOptions.includes(l)?"rb-correct":""}`,g=this.correctOptions.length>0?!0:e.matchMax===1?!1:p>=e.matchMax&&!d;return Te`<td>
525
+ ${this.rows.map((e,t)=>Ce`<tr>
526
+ <td part="c-header">${or(e.innerHTML)}</td>
527
+ ${this.cols.map((r,s)=>{let o=e.getAttribute("identifier"),n=r.getAttribute("identifier"),l=`${o} ${n}`,p=this.value.filter(f=>f.split(" ")[0]===o).length||0,d=this.value.includes(l),m=`rb ${d?"rb-checked":""} ${this.correctOptions.includes(l)?"rb-correct":""}`,g=this.correctOptions.length>0?!0:e.matchMax===1?!1:p>=e.matchMax&&!d;return Ce`<td>
522
528
  <input
523
529
  type=${e.matchMax===1?"radio":"checkbox"}
524
- part=${u}
530
+ part=${m}
525
531
  name=${o}
526
532
  value=${l}
527
533
  .disabled=${g}
528
- @change=${h=>this.handleRadioChange(h)}
529
- @click=${h=>e.matchMax===1?this.handleRadioClick(h):null}
534
+ @change=${f=>this.handleRadioChange(f)}
535
+ @click=${f=>e.matchMax===1?this.handleRadioClick(f):null}
530
536
  />
531
537
  </td>`})}
532
538
  </tr>`)}
533
539
  </table>
534
- `:Te`<slot name="prompt"></slot> <slot></slot>`}};Y.styles=or,n([nr()],Y.prototype,"_response",2),n([nr()],Y.prototype,"correctOptions",2),n([Gs({type:String,attribute:"response-identifier"})],Y.prototype,"responseIdentifier",2),Y=n([Js("qti-match-interaction")],Y);import{css as Qs,html as eo}from"lit";import{customElement as to}from"lit/decorators.js";var we=class extends f{constructor(){super();this.value=0}reset(){}validate(){return!0}set response(e){}static get properties(){return C(b({},f.properties),{step:{type:Number,attribute:"step",default:10}})}render(){return eo` <slot name="prompt"></slot>
535
- <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())})}};we.styles=[Qs``],we=n([to("qti-media-interaction")],we);import{css as ro,html as lr,LitElement as io}from"lit";import{customElement as so,property as oo,state as Mt}from"lit/decorators.js";import{unsafeHTML as no}from"lit/directives/unsafe-html.js";var I=class extends Ue(H(io,"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),lr` <slot name="prompt"> </slot>
540
+ `:Ce`<slot name="prompt"></slot> <slot></slot>`}};Y.styles=ir,a([sr()],Y.prototype,"_response",2),a([sr()],Y.prototype,"correctOptions",2),a([js({type:String,attribute:"response-identifier"})],Y.prototype,"responseIdentifier",2),Y=a([Ys("qti-match-interaction")],Y);import{css as zs,html as Ks}from"lit";import{customElement as Ws}from"lit/decorators.js";var qe=class extends u{constructor(){super();this._value=0}reset(){}validate(){return!0}get value(){return this._value.toString()}set value(e){if(!isNaN(parseInt(e.toString())))this._value=parseInt(e.toString());else throw new Error("Value must be a number")}static get properties(){return C(b({},u.properties),{step:{type:Number,attribute:"step",default:10}})}render(){return Ks` <slot name="prompt"></slot>
541
+ <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)})}};qe.styles=[zs``],qe=a([Ws("qti-media-interaction")],qe);import{css as Zs,html as nr}from"lit";import{customElement as Js,property as Gs,state as kt}from"lit/decorators.js";import{unsafeHTML as Qs}from"lit/directives/unsafe-html.js";var P=class extends Oe(V(u,"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),nr` <slot name="prompt"> </slot>
536
542
  <div part="container">
537
543
  <slot part="drags"> </slot>
538
544
  <div part="drops">
539
- ${Array.from(Array(this.nrChoices)).map((t,r)=>lr`<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>`):""}`)}
545
+ ${Array.from(Array(this.nrChoices)).map((t,r)=>nr`<drop-list part="drop-list" identifier="droplist${r}"></drop-list>${this.showCorrectResponses&&this.correctResponses.length>r?Qs(`<span part='correct-response'>${this.correctResponses[r]}</span>`):""}`)}
540
546
  </div>
541
- </div>`}set correctResponse(e){if(e===""){this.showCorrectResponses=!1;return}this.correctResponses.length===0&&(Array.isArray(e)?e:[e]).forEach((r,s)=>{let o=this.querySelector(`qti-simple-choice[identifier="${r}"]`);o||(o=this.shadowRoot.querySelector(`qti-simple-choice[identifier="${r}"]`));let a=o==null?void 0:o.textContent.trim();this.correctResponses=[...this.correctResponses,a]}),this.showCorrectResponses=!0}getResponse(){return Array.from(this.shadowRoot.querySelectorAll("drop-list")).map(r=>{let s=r.querySelectorAll('[qti-draggable="true"]');return[...Array.from(s).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"))}};I.styles=[ro`
547
+ </div>`}set correctResponse(e){if(e===""){this.showCorrectResponses=!1;return}this.correctResponses.length===0&&(Array.isArray(e)?e:[e]).forEach((r,s)=>{let o=this.querySelector(`qti-simple-choice[identifier="${r}"]`);o||(o=this.shadowRoot.querySelector(`qti-simple-choice[identifier="${r}"]`));let n=o==null?void 0:o.textContent.trim();this.correctResponses=[...this.correctResponses,n]}),this.showCorrectResponses=!0}getResponse(){return Array.from(this.shadowRoot.querySelectorAll("drop-list")).map(r=>{let s=r.querySelectorAll('[qti-draggable="true"]');return[...Array.from(s).map(n=>n.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"))}};P.styles=[Zs`
542
548
  [part='drags'] {
543
549
  display: flex;
544
550
  align-items: flex-start;
@@ -586,7 +592,7 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
586
592
  :host(.qti-choices-right) [part='container'] {
587
593
  flex-direction: row-reverse;
588
594
  }
589
- `],n([Mt()],I.prototype,"nrChoices",2),n([Mt()],I.prototype,"correctResponses",2),n([Mt()],I.prototype,"showCorrectResponses",2),n([oo({type:String})],I.prototype,"orientation",2),I=n([so("qti-order-interaction")],I);import{LitElement as ao,css as lo,html as co}from"lit";var Ze=class extends ao{render(){return co`<slot></slot>`}};Ze.styles=[lo`
595
+ `],a([kt()],P.prototype,"nrChoices",2),a([kt()],P.prototype,"correctResponses",2),a([kt()],P.prototype,"showCorrectResponses",2),a([Gs({type:String})],P.prototype,"orientation",2),P=a([Js("qti-order-interaction")],P);import{LitElement as eo,css as to,html as ro}from"lit";var We=class extends eo{render(){return ro`<slot></slot>`}};We.styles=[to`
590
596
  :host {
591
597
  display: block;
592
598
  }
@@ -597,23 +603,23 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
597
603
  left: 50%;
598
604
  transform: translateX(-50%);
599
605
  }
600
- `];customElements.define("qti-position-object-interaction",Ze);import{LitElement as po,css as uo,html as mo}from"lit";import{customElement as ho}from"lit/decorators.js";var Se=class extends po{render(){return mo`<slot></slot>`}constructor(){super(),this.removeMoveListener=this.removeMoveListener.bind(this),this.dragElementHandler=this.dragElementHandler.bind(this)}dragElementHandler(i){i.preventDefault();let e=i.clientX-this.startX,t=i.clientY-this.startY;this.dragElement.style.left=this.dragElement.offsetLeft+e+"px",this.dragElement.style.top=this.dragElement.offsetTop+t+"px",this.startX=i.clientX,this.startY=i.clientY}firstUpdated(i){super.firstUpdated(i),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(i){document.removeEventListener("mousemove",this.dragElementHandler,!0)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("mousemove",this.dragElementHandler),document.removeEventListener("mouseup",this.removeMoveListener)}};Se.styles=[uo`
606
+ `];customElements.define("qti-position-object-interaction",We);import{LitElement as io,css as so,html as oo}from"lit";import{customElement as no}from"lit/decorators.js";var we=class extends io{render(){return oo`<slot></slot>`}constructor(){super(),this.removeMoveListener=this.removeMoveListener.bind(this),this.dragElementHandler=this.dragElementHandler.bind(this)}dragElementHandler(i){i.preventDefault();let e=i.clientX-this.startX,t=i.clientY-this.startY;this.dragElement.style.left=this.dragElement.offsetLeft+e+"px",this.dragElement.style.top=this.dragElement.offsetTop+t+"px",this.startX=i.clientX,this.startY=i.clientY}firstUpdated(i){super.firstUpdated(i),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(i){document.removeEventListener("mousemove",this.dragElementHandler,!0)}disconnectedCallback(){super.disconnectedCallback(),document.removeEventListener("mousemove",this.dragElementHandler),document.removeEventListener("mouseup",this.removeMoveListener)}};we.styles=[so`
601
607
  :host {
602
608
  display: inline-block;
603
609
  position: relative;
604
610
  }
605
- `],Se=n([ho("qti-position-object-stage")],Se);import{css as fo,html as cr}from"lit";import{customElement as go,property as pr,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 j=class extends f{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 cr` <slot name="prompt"></slot>
611
+ `],we=a([no("qti-position-object-stage")],we);import{css as ao,html as ar}from"lit";import{customElement as lo,property as lr,state as co}from"lit/decorators.js";import{repeat as po}from"lit/directives/repeat.js";import{styleMap as uo}from"lit/directives/style-map.js";var j=class extends u{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 ar` <slot name="prompt"></slot>
606
612
  <point-container>
607
- ${vo(this._points,e=>e,(e,t)=>cr`
613
+ ${po(this._points,e=>e,(e,t)=>ar`
608
614
  <button
609
615
  part="point"
610
- style=${yo({position:"absolute",transform:"translate(-50%, -50%)",left:`${e.split(" ")[0]}px`,top:`${e.split(" ")[1]}px`})}
616
+ style=${uo({position:"absolute",transform:"translate(-50%, -50%)",left:`${e.split(" ")[0]}px`,top:`${e.split(" ")[1]}px`})}
611
617
  aria-label="Remove point at ${e}"
612
618
  @click=${r=>{r.stopPropagation(),this._points=this._points.filter((s,o)=>o!==t),this.saveResponse(this._points)}}
613
619
  ></button>
614
620
  `)}
615
621
  <slot></slot>
616
- </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)}};j.styles=[fo`
622
+ </point-container>`}reset(){this._points=[]}validate(){return this._points.length>=this.minChoices&&this._points.length<=this.maxChoices}set value(e){this._points=Array.isArray(e)?e:[e]}get value(){return this._points}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)}};j.styles=[ao`
617
623
  :host {
618
624
  display: block;
619
625
  }
@@ -621,61 +627,61 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
621
627
  display: block;
622
628
  position: relative;
623
629
  }
624
- `],n([pr({type:Number,attribute:"max-choices"})],j.prototype,"maxChoices",2),n([pr({type:Number,attribute:"min-choices"})],j.prototype,"minChoices",2),n([bo()],j.prototype,"_points",2),j=n([go("qti-select-point-interaction")],j);import{css as xo,html as Je,nothing as At}from"lit";import{customElement as Eo,property as ie,query as dr}from"lit/decorators.js";var E=class extends f{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()),Je`<slot name="prompt"></slot>
630
+ `],a([lr({type:Number,attribute:"max-choices"})],j.prototype,"maxChoices",2),a([lr({type:Number,attribute:"min-choices"})],j.prototype,"minChoices",2),a([co()],j.prototype,"_points",2),j=a([lo("qti-select-point-interaction")],j);import{css as mo,html as Ze,nothing as Mt}from"lit";import{customElement as ho,property as Te,query as cr}from"lit/decorators.js";var E=class extends u{constructor(){super();this._value=0;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}get value(){return this._value.toString()}set value(e){if(!isNaN(parseInt(e.toString())))this._value=parseInt(e.toString());else throw new Error("Value must be a number")}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>
625
631
  <div id="slider" part="slider">
626
- ${this.csLive.getPropertyValue("--show-bounds")=="true"?Je`<div id="bounds" part="bounds">
632
+ ${this.csLive.getPropertyValue("--show-bounds")=="true"?Ze`<div id="bounds" part="bounds">
627
633
  <div>${this._min}</div>
628
634
  <div>${this._max}</div>
629
- </div>`:At}
630
- ${this.csLive.getPropertyValue("--show-ticks")=="true"?Je`<div id="ticks" part="ticks"></div>`:At}
635
+ </div>`:Mt}
636
+ ${this.csLive.getPropertyValue("--show-ticks")=="true"?Ze`<div id="ticks" part="ticks"></div>`:Mt}
631
637
  <div id="rail" part="rail" @mousedown=${this._onMouseDown} @touchstart=${this._onTouchMove}>
632
638
  <div id="knob" part="knob">
633
- ${this.csLive.getPropertyValue("--show-value")=="true"?Je`<div id="value" part="value">${this.value}</div>`:At}
639
+ ${this.csLive.getPropertyValue("--show-value")=="true"?Ze`<div id="value" part="value">${this.value}</div>`:Mt}
634
640
  </div>
635
641
  </div>
636
- </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:s}=this.getPositionFromEvent(e),o=s-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(o),e.stopPropagation()}_onMouseDown(e){let t=o=>{let a=o.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(a),o.preventDefault(),o.stopPropagation()},r=()=>{document.removeEventListener("mousemove",t),document.removeEventListener("mouseup",r),this.saveResponse(this.value.toString())};document.addEventListener("mousemove",t),document.addEventListener("mouseup",r);let s=e.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(s),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,s=r.touches[0]||r.changedTouches[0];t={x:s.pageX,y:s.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}};E.styles=[xo``],n([dr("#knob")],E.prototype,"_knob",2),n([dr("#rail")],E.prototype,"_rail",2),n([ie({type:Number})],E.prototype,"value",2),n([ie({type:Boolean,attribute:"step-label"})],E.prototype,"stepLabel",2),n([ie({type:Boolean})],E.prototype,"reverse",2),n([ie({type:Number,attribute:"lower-bound"})],E.prototype,"min",1),n([ie({type:Number,attribute:"upper-bound"})],E.prototype,"max",1),n([ie({type:Number,attribute:"step"})],E.prototype,"step",1),n([x("disabled",{waitUntilFirstUpdate:!0})],E.prototype,"_handleDisabledChange",2),n([x("readonly",{waitUntilFirstUpdate:!0})],E.prototype,"_handleReadonlyChange",2),E=n([Eo("qti-slider-interaction")],E);import{consume as Co}from"@lit/context";import{LitElement as qo,html as To}from"lit";import{customElement as wo,state as So}from"lit/decorators.js";var ke=class extends qo{render(){return To`<slot @slotchange=${this.handleSlotChange}></slot>`}handleSlotChange(i){var t,r,s;let e=Array.from((r=(t=this.firstElementChild)==null?void 0:t.childNodes)!=null?r:[]).find(o=>o.nodeType===Node.COMMENT_NODE);try{this.operatorFunction=new Function("context","fn","item",(s=e.textContent)!=null?s:"")}catch(o){console.error("custom-operator contains invalid javascript code",o)}}calculate(){let i={variable:t=>{var r,s,o;return(o=(s=(r=this._context)==null?void 0:r.variables.find(a=>a.identifier===t))==null?void 0:s.value)!=null?o:""},correct:t=>{var r,s,o;return(o=(s=(r=this._context)==null?void 0:r.variables.find(a=>a.identifier===t))==null?void 0:s.correctResponse)!=null?o:""}},e={getVariable:t=>{var r;return(r=this._context)==null?void 0:r.variables.find(s=>s.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,i,e)}};n([Co({context:R,subscribe:!0}),So()],ke.prototype,"_context",2),ke=n([wo("qti-custom-operator")],ke);import{LitElement as ko,css as Lo,html as Ro}from"lit";import{customElement as Mo}from"lit/decorators.js";var Le=class extends ko{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-hotspot",{bubbles:!0,cancelable:!1,composed:!0}))}render(){return Ro` <slot name="qti-gap-img"></slot> `}};Le.styles=Lo`
642
+ </div>`}connectedCallback(){super.connectedCallback(),this.step=1,this.setAttribute("tabindex","0"),this.setAttribute("role","slider")}_onTouchMove(e){let t=n=>{let{x:l}=this.getPositionFromEvent(n),p=l-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(p),n.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:s}=this.getPositionFromEvent(e),o=s-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(o),e.stopPropagation()}_onMouseDown(e){let t=o=>{let n=o.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(n),o.preventDefault(),o.stopPropagation()},r=()=>{document.removeEventListener("mousemove",t),document.removeEventListener("mouseup",r),this.saveResponse(this.value.toString())};document.addEventListener("mousemove",t),document.addEventListener("mouseup",r);let s=e.pageX-this._rail.getBoundingClientRect().left-document.documentElement.scrollLeft;this.calculateValue(s),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,s=r.touches[0]||r.changedTouches[0];t={x:s.pageX,y:s.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}};E.styles=[mo``],a([cr("#knob")],E.prototype,"_knob",2),a([cr("#rail")],E.prototype,"_rail",2),a([Te({type:Boolean,attribute:"step-label"})],E.prototype,"stepLabel",2),a([Te({type:Boolean})],E.prototype,"reverse",2),a([Te({type:Number,attribute:"lower-bound"})],E.prototype,"min",1),a([Te({type:Number,attribute:"upper-bound"})],E.prototype,"max",1),a([Te({type:Number,attribute:"step"})],E.prototype,"step",1),a([x("disabled",{waitUntilFirstUpdate:!0})],E.prototype,"_handleDisabledChange",2),a([x("readonly",{waitUntilFirstUpdate:!0})],E.prototype,"_handleReadonlyChange",2),E=a([ho("qti-slider-interaction")],E);import{consume as fo}from"@lit/context";import{LitElement as go,html as bo}from"lit";import{customElement as vo,state as yo}from"lit/decorators.js";var Se=class extends go{render(){return bo`<slot @slotchange=${this.handleSlotChange}></slot>`}handleSlotChange(i){var t,r,s;let e=Array.from((r=(t=this.firstElementChild)==null?void 0:t.childNodes)!=null?r:[]).find(o=>o.nodeType===Node.COMMENT_NODE);try{this.operatorFunction=new Function("context","fn","item",(s=e.textContent)!=null?s:"")}catch(o){console.error("custom-operator contains invalid javascript code",o)}}calculate(){let i={variable:t=>{var r,s,o;return(o=(s=(r=this._context)==null?void 0:r.variables.find(n=>n.identifier===t))==null?void 0:s.value)!=null?o:""},correct:t=>{var r,s,o;return(o=(s=(r=this._context)==null?void 0:r.variables.find(n=>n.identifier===t))==null?void 0:s.correctResponse)!=null?o:""}},e={getVariable:t=>{var r;return(r=this._context)==null?void 0:r.variables.find(s=>s.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,i,e)}};a([fo({context:M,subscribe:!0}),yo()],Se.prototype,"_context",2),Se=a([vo("qti-custom-operator")],Se);import{LitElement as xo,css as Eo,html as Co}from"lit";import{customElement as qo}from"lit/decorators.js";var ke=class extends xo{connectedCallback(){super.connectedCallback(),this.dispatchEvent(new CustomEvent("qti-register-hotspot",{bubbles:!0,cancelable:!1,composed:!0}))}render(){return Co` <slot name="qti-gap-img"></slot> `}};ke.styles=Eo`
637
643
  :host {
638
644
  display: flex;
639
645
  user-select: none;
640
646
  position: absolute;
641
647
  }
642
- `,Le=n([Mo("qti-associable-hotspot")],Le);import{css as Ao,html as _o,LitElement as Do}from"lit";import{customElement as Ho,property as No}from"lit/decorators.js";var se=class extends Do{constructor(){super(...arguments);this.tabindex=0}render(){return _o` <slot name="qti-gap-text"></slot>`}};se.styles=Ao`
648
+ `,ke=a([qo("qti-associable-hotspot")],ke);import{css as wo,html as To,LitElement as So}from"lit";import{customElement as ko,property as Mo}from"lit/decorators.js";var te=class extends So{constructor(){super(...arguments);this.tabindex=0}render(){return To` <slot name="qti-gap-text"></slot>`}};te.styles=wo`
643
649
  :host {
644
650
  display: flex;
645
651
  user-select: none;
646
652
  }
647
- `,n([No({type:Number,reflect:!0})],se.prototype,"tabindex",2),se=n([Ho("qti-gap")],se);import{css as Vo,LitElement as $o}from"lit";import{customElement as Po,property as Io}from"lit/decorators.js";var oe=class extends $o{constructor(){super(...arguments);this.tabindex=0}connectedCallback(){this.setAttribute("slot","qti-gap-img")}};oe.styles=Vo`
653
+ `,a([Mo({type:Number,reflect:!0})],te.prototype,"tabindex",2),te=a([ko("qti-gap")],te);import{css as _o,LitElement as Ro}from"lit";import{customElement as Lo,property as Ao}from"lit/decorators.js";var re=class extends Ro{constructor(){super(...arguments);this.tabindex=0}connectedCallback(){this.setAttribute("slot","qti-gap-img")}};re.styles=_o`
648
654
  :host {
649
655
  display: flex;
650
656
  user-select: none;
651
657
  }
652
- `,n([Io({type:Number,reflect:!0})],oe.prototype,"tabindex",2),oe=n([Po("qti-gap-img")],oe);import{css as Oo,html as Uo,LitElement as Fo}from"lit";import{customElement as Bo,property as Xo}from"lit/decorators.js";var ne=class extends M(Fo,"qti-gap-text"){constructor(){super(...arguments);this.tabindex=0}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-gap-text")}render(){return Uo`<slot></slot>`}};ne.styles=Oo`
658
+ `,a([Ao({type:Number,reflect:!0})],re.prototype,"tabindex",2),re=a([Lo("qti-gap-img")],re);import{css as Do,html as Vo,LitElement as Ho}from"lit";import{customElement as No,property as $o}from"lit/decorators.js";var ie=class extends _(Ho,"qti-gap-text"){constructor(){super(...arguments);this.tabindex=0}connectedCallback(){super.connectedCallback(),this.setAttribute("slot","qti-gap-text")}render(){return Vo`<slot></slot>`}};ie.styles=Do`
653
659
  :host {
654
660
  display: inline-flex;
655
661
  user-select: none;
656
662
  }
657
- `,n([Xo({type:Number,reflect:!0})],ne.prototype,"tabindex",2),ne=n([Bo("qti-gap-text")],ne);import{css as Yo,LitElement as jo}from"lit";import{customElement as zo,property as Ko}from"lit/decorators.js";var ae=class extends M(jo,"qti-hotspot-choice"){};ae.styles=Yo`
663
+ `,a([$o({type:Number,reflect:!0})],ie.prototype,"tabindex",2),ie=a([No("qti-gap-text")],ie);import{css as Io,LitElement as Po}from"lit";import{customElement as Oo,property as Uo}from"lit/decorators.js";var se=class extends _(Po,"qti-hotspot-choice"){};se.styles=Io`
658
664
  :host {
659
665
  display: flex;
660
666
  user-select: none;
661
667
  position: absolute;
662
668
  }
663
- `,n([Ko({attribute:"aria-ordervalue",type:Number,reflect:!0})],ae.prototype,"order",2),ae=n([zo("qti-hotspot-choice")],ae);import{css as Wo,html as Zo,LitElement as Jo}from"lit";import{customElement as Go}from"lit/decorators.js";var Re=class extends M(Jo,"qti-hottext"){render(){return Zo`<div part="ch"><div part="cha"></div></div>
664
- <slot></slot> `}};Re.styles=Wo`
669
+ `,a([Uo({attribute:"aria-ordervalue",type:Number,reflect:!0})],se.prototype,"order",2),se=a([Oo("qti-hotspot-choice")],se);import{css as Fo,html as Bo,LitElement as Xo}from"lit";import{customElement as Yo}from"lit/decorators.js";var Me=class extends _(Xo,"qti-hottext"){render(){return Bo`<div part="ch"><div part="cha"></div></div>
670
+ <slot></slot> `}};Me.styles=Fo`
665
671
  :host {
666
672
  display: flex;
667
673
  user-select: none;
668
674
  }
669
- `,Re=n([Go("qti-hottext")],Re);import{css as Qo,html as en,LitElement as tn}from"lit";import{customElement as rn,property as sn}from"lit/decorators.js";var Me=class extends tn{static get styles(){return[Qo`
675
+ `,Me=a([Yo("qti-hottext")],Me);import{css as jo,html as zo,LitElement as Ko}from"lit";import{customElement as Wo,property as Zo}from"lit/decorators.js";var _e=class extends Ko{static get styles(){return[jo`
670
676
  :host {
671
677
  display: block;
672
678
  cursor: pointer;
673
679
  }
674
- `]}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 en` <slot></slot> `}_onSelectInlineChoice(){this.dispatchEvent(new CustomEvent("qti-inline-choice-select",{bubbles:!0,cancelable:!1,composed:!0,detail:{identifier:this.identifier}}))}};n([sn({type:String})],Me.prototype,"identifier",2),Me=n([rn("qti-inline-choice")],Me);import{css as on,html as ur,LitElement as nn,nothing as an}from"lit";import{customElement as ln,property as cn}from"lit/decorators.js";var le=class extends M(nn,"qti-simple-choice"){render(){return ur`<div part="ch">
680
+ `]}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 zo` <slot></slot> `}_onSelectInlineChoice(){this.dispatchEvent(new CustomEvent("qti-inline-choice-select",{bubbles:!0,cancelable:!1,composed:!0,detail:{identifier:this.identifier}}))}};a([Zo({type:String})],_e.prototype,"identifier",2),_e=a([Wo("qti-inline-choice")],_e);import{css as Jo,html as pr,LitElement as Go,nothing as Qo}from"lit";import{customElement as en,property as tn}from"lit/decorators.js";var oe=class extends _(Go,"qti-simple-choice"){get checked(){return this.internals.states.has("--checked")}render(){return pr`<div part="ch">
675
681
  <div part="cha"></div>
676
682
  </div>
677
- ${this.marker?ur`<div id="label">${this.marker}</div>`:an}
678
- <slot part="slot"></slot> `}};le.styles=on`
683
+ ${this.marker?pr`<div id="label">${this.marker}</div>`:Qo}
684
+ <slot part="slot"></slot> `}};oe.styles=Jo`
679
685
  :host {
680
686
  display: flex;
681
687
  align-items: center;
@@ -692,5 +698,5 @@ import{a as Dt}from"../chunk-IRTOORT6.js";import{a as b,b as C,c as n}from"../ch
692
698
  align-items: center;
693
699
  justify-content: center;
694
700
  }
695
- `,n([cn({type:String,attribute:!1})],le.prototype,"marker",2),le=n([ln("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{M as ActiveElementMixin,f as Interaction,Be as QtiAnd,q as QtiAssessmentItem,W as QtiAssessmentStimulusRef,Le as QtiAssociableHotspot,ee as QtiAssociateInteraction,Xe as QtiBaseValue,J as QtiChoiceInteraction,Ne as QtiCompanionMaterialsInfo,w as QtiConditionExpression,ct as QtiContains,Ve as QtiContentBody,pt as QtiCorrect,N as QtiCustomInteraction,ke as QtiCustomOperator,te as QtiEndAttemptInteraction,je as QtiEqual,Ye as QtiEqualRounded,m as QtiExpression,k as QtiExtendedTextInteraction,de as QtiFeedbackBlock,ue as QtiFeedbackInline,se as QtiGap,oe as QtiGapImg,xe as QtiGapMatchInteraction,ne as QtiGapText,V as QtiGraphicAssociateInteraction,Ee as QtiGraphicGapMatchInteraction,Ce as QtiGraphicOrderInteraction,dt as QtiGt,ut as QtiGte,ae as QtiHotspotChoice,qe as QtiHotspotInteraction,Re as QtiHottext,Oe as QtiHottextInteraction,Me as QtiInlineChoice,F as QtiInlineChoiceInteraction,mt as QtiIsNull,Fe as QtiLookupOutcomeValue,ht as QtiLt,ft as QtiLte,ze as QtiMapResponse,G as QtiMapping,bt as QtiMatch,Y as QtiMatchInteraction,we as QtiMediaInteraction,vt as QtiMember,me as QtiModalFeedback,yt as QtiMultiple,xt as QtiNot,Et as QtiOr,I as QtiOrderInteraction,Ct as QtiOrdered,A as QtiOutcomeDeclaration,fe as QtiOutcomeProcessing,st as QtiOutcomeProcessingProcessor,B as QtiPortableCustomInteraction,Se as QtiPositionObjectStage,ve as QtiPrintedVariable,qt as QtiProduct,_e as QtiPrompt,ot as QtiResponseCondition,P as QtiResponseDeclaration,ge as QtiResponseElse,lt as QtiResponseElseIf,be as QtiResponseIf,z as QtiResponseProcessing,_ as QtiRubricBlock,D as QtiRule,Ze as QtiSPositionObjectInteraction,j as QtiSelectPointInteraction,nt as QtiSetOutcomeValue,at as QtiSetOutcomeValueRule,X as QtiSimpleAssociableChoice,le as QtiSimpleChoice,E as QtiSliderInteraction,Ke as QtiStringMatch,De as QtiStylesheet,Tt as QtiSum,wt as QtiSumExpression,L as QtiTextEntryInteraction,St as QtiVariable,R as itemContext,Ht as itemContextVariables,Qi as qtiAndMixin};
696
- //# 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/active-element/active-element.mixin.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.styles.ts", "../../src/lib/qti-components/qti-prompt/qti-prompt.ts", "../../src/lib/qti-components/qti-stylesheet/qti-stylesheet.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-variable-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-response-declaration/qti-response-declaration.ts", "../../src/lib/qti-components/qti-companion-materials-info/qti-companion-materials-info.ts", "../../src/lib/qti-components/qti-rubric-block/qti-content-body.ts", "../../src/lib/qti-components/qti-rubric-block/qti-rubric-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-block/qti-feedback-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback.ts", "../../src/lib/qti-components/internal/utils.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-inline/qti-feedback-inline.ts", "../../src/lib/qti-components/qti-feedback/qti-modal-feedback/qti-modal-feedback.ts", "../../src/lib/qti-components/qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/interaction/interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext-interaction/qti-hottext-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/choices/choices.mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/shuffle/shuffle-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/vocabulary/vocabulary-mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.styles.ts", "../../src/lib/qti-components/qti-outcome-processing/qti-outcome-processing.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-processing/qti-response-processing.ts", "../../src/lib/qti-components/internal/template-strings.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-lookup-outcome-value/qti-lookup-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-rule.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-response-condition/qti-response-condition.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-set-outcome-value/qti-set-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-else.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-else-if/qti-response-else-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-condition-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/qti-and.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/index.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-basevalue/qti-basevalue.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-contains/qti-contains.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-correct/qti-correct.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal-rounded/qti-equal-rounded.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal/qti-equal.ts", "../../src/lib/qti-components/qti-response-processing/utilities/scoring-helper.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gt/qti-gt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gte/qti-gte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-is-null/qti-is-null.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lt/qti-lt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lte/qti-lte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-map-response/qti-map-response.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-mapping/qti-mapping.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-match/qti-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-member/qti-member.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-multiple/qti-multiple.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-not/qti-not.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-or/qti-or.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-ordered/qti-ordered.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-printed-variable/qti-printed-variable.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-product/qti-product.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-string-match/qti-string-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-sum/qti-sum.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-variable/qti-variable.ts", "../../src/lib/qti-components/qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-api.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/droppables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/flippables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-interaction-mixin.ts", "../../src/lib/decorators/live-query.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-custom-interaction/qti-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/hotspots/hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-associable-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-media-interaction/qti-media-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-order-interaction/qti-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-stage.ts", "../../src/lib/qti-components/qti-interaction/qti-select-point-interaction/qti-select-point-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-slider-interaction/qti-slider-interaction.ts", "../../src/lib/qti-components/qti-custom-operator/qti-custom-operator.ts", "../../src/lib/qti-components/qti-interaction/qti-associable-hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-gap.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-img.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-text.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-choice.ts", "../../src/lib/qti-components/index.ts"],
  "sourcesContent": ["import { provide } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\nimport type { InteractionChangedDetails, OutcomeChangedDetails } from '../internal/event-types';\nimport type { ResponseInteraction } from '../internal/expression-result';\nimport type { VariableDeclaration, VariableValue } from '../internal/variables';\nimport { OutcomeVariable, ResponseVariable } from '../internal/variables';\nimport type { QtiFeedback } from '../qti-feedback/qti-feedback';\nimport type { Interaction } from '../qti-interaction/internal/interaction/interaction';\nimport type { QtiResponseProcessing } from '../qti-response-processing';\nimport { ItemContext, itemContext, itemContextVariables } from './qti-assessment-item.context';\n\n/**\n * @summary The qti-assessment-item element contains all the other QTI 3 item structures.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.dltnnj87l0yj\n * @status stable\n * @since 4.0\n *\n * @dependency qti-feedback\n * @dependency qti-responseprocessing\n *\n * @slot - The default slot where all the other QTI 3 item structures go.\n *\n * @event qti-interaction-changed - Emitted when an interaction is changed.\n * @event qti-outcome-changed - Emitted when an outcome has changed.\n * @event qti-response-processing - Emitted when response-processing is called.\n *\n */\n@customElement('qti-assessment-item')\nexport class QtiAssessmentItem extends LitElement {\n  @property({ type: String }) title: string;\n  @property({ type: String }) identifier: string = '';\n  @property({ type: String }) adaptive: 'true' | 'false' = 'false';\n  @property({ type: String }) timeDependent: 'true' | 'false' | null = null;\n\n  @property({ type: Boolean }) disabled: boolean;\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  _handleDisabledChange = (_: boolean, disabled: boolean) => {\n    this._interactionElements.forEach(ch => (ch.disabled = disabled));\n  };\n\n  @property({ type: Boolean }) readonly: boolean;\n  @watch('readonly', { waitUntilFirstUpdate: true })\n  _handleReadonlyChange = (_: boolean, readonly: boolean) =>\n    this._interactionElements.forEach(ch => (ch.readonly = readonly));\n\n  @provide({ context: itemContext })\n  private _context: ItemContext = {\n    identifier: this.getAttribute('identifier'),\n    variables: itemContextVariables\n  };\n\n  public get variables(): VariableValue<string | string[] | null>[] {\n    return this._context.variables.map(v => ({\n      identifier: v.identifier,\n      value: v.value,\n      type: v.type,\n      // add externalscored, a fixed prop to the test, so the testcontext can read and decide how to score this item\n      ...(v.type === 'outcome' && v.identifier === 'SCORE'\n        ? { externalScored: (v as OutcomeVariable).externalScored }\n        : {})\n    }));\n  }\n\n  public set variables(value: VariableValue<string | string[] | null>[]) {\n    if (!Array.isArray(value) || value.some(v => !('identifier' in v))) {\n      console.warn('variables property should be an array of VariableDeclaration');\n      return;\n    }\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(variable => {\n        const matchingValue = value.find(v => v.identifier === variable.identifier);\n        if (matchingValue) {\n          return { ...variable, ...matchingValue };\n        }\n        return variable;\n      })\n    };\n\n    this._context.variables.forEach(variable => {\n      if (variable.type === 'response') {\n        const interactionElement = this._interactionElements.find(\n          (el: Interaction) => el.responseIdentifier === variable.identifier\n        );\n        if (interactionElement) {\n          interactionElement.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.updateStimulusRef(stimulusRef);\n      } else {\n        console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`);\n      }\n    }\n  }\n\n  /**\n   * Loads and appends the stimulus to the specified element.\n   * @param stimulusRef - The element to which the stimulus will be appended.\n   */\n  public async updateStimulusRef(stimulusRef: Element) {\n    const path = this.href.substring(0, this.href.lastIndexOf('/'));\n    const stimulus = await qtiTransformItem()\n      .load(this.href)\n      .then(api => api.path(path).htmldoc());\n    if (stimulus) {      \n      const elements = stimulus.querySelectorAll('qti-stimulus-body, qti-stylesheet');\n      stimulusRef.innerHTML = '';\n      stimulusRef.append(...elements);\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-stimulus-ref': QtiAssessmentStimulusRef;\n  }\n}\n", "import { ComplexAttributeConverter, LitElement, html } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\ntype Constructor<T = {}> = new (...args: any[]) => T;\n\nexport interface ChoiceInterface {\n  identifier: string;\n  disabled: boolean;\n  readonly: boolean;\n}\n\n/**\n * Converter to handle boolean attributes for ARIA properties,\n * ensuring they are set as 'true' or 'false' strings.\n */\nconst ariaBooleanConverter: ComplexAttributeConverter<boolean, boolean> = {\n  toAttribute: (value: boolean) => (value ? 'true' : 'false'),\n  fromAttribute: (value: string | null) => value === 'true'\n};\n\n/**\n * A mixin that adds choice functionality to a LitElement-based class.\n * It dispatches events with a custom `type` and handles selection logic.\n *\n * @param Base - The base class to extend.\n * @param type - The type of the choice, used in event names.\n * @returns A new class extending the base class with choice functionality.\n */\nexport function ActiveElementMixin<T extends Constructor<LitElement>>(Base: T, type: string) {\n  class QtiChoice extends Base {\n    @property({ type: String })\n    public identifier = '';\n\n    @property({ type: Number, reflect: true, attribute: 'tabindex' })\n    public tabIndex = 0;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-disabled',\n      converter: ariaBooleanConverter\n    })\n    public disabled = false;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-readonly',\n      converter: ariaBooleanConverter\n    })\n    public readonly = false;\n\n    private _internals: ElementInternals;\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    handleDisabledChange(_oldValue: boolean, disabled: boolean) {\n      this.tabIndex = disabled ? -1 : 0;\n      if (disabled) {\n        this.blur();\n      }\n    }\n\n    constructor(...args: any[]) {\n      super(...args);\n      this._internals = this.attachInternals();\n    }\n\n    public setInternalState(key: string, value: boolean) {\n      if (value && !this._internals.states.has(key)) {\n        this._internals.states.add(key);\n      } else if (!value && this._internals.states.has(key)) {\n        this._internals.states.delete(key);\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(`register-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener('keyup', this._onKeyUp);\n      this.removeEventListener('click', this._onClick);\n      this.dispatchEvent(\n        new CustomEvent(`unregister-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    private _onKeyUp(event: KeyboardEvent) {\n      if (event.altKey) return;\n\n      if (event.code === 'Space') {\n        event.preventDefault();\n        this._activate();\n      }\n    }\n\n    private _onClick() {\n      if (this.disabled || this.readonly) return;\n      this.focus();\n      this._activate();\n    }\n\n    private _activate() {\n      if (this.disabled || this.readonly) return;\n\n      this.dispatchEvent(\n        new CustomEvent<{ identifier: string }>(`activate-${type}`, {\n          bubbles: true,\n          composed: true,\n          detail: { identifier: this.identifier }\n        })\n      );\n    }\n\n    override render() {\n      return html`<slot></slot>`;\n    }\n  }\n  return QtiChoice as Constructor<ChoiceInterface> & T;\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\nimport styles from './qti-item-body.styles';\nimport type { CSSResultGroup } from 'lit';\n\n/**\n * @summary The qti-item-body node contains the text, graphics, media objects and interactions that describe the item's content and information about how it is structured.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.sphpo6lu6zqi\n * @status stable\n * @since 4.0\n *\n * @slot - item body content.\n * @slot qti-rubric-block - the qti rubric block is placed above the item\n *\n */\n@customElement('qti-item-body')\nexport 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.trim());\n    if (defaultValues.length > 1 || variable.cardinality === 'multiple' || variable.cardinality === 'ordered') {\n      return defaultValues;\n    }\n    return defaultValues[0];\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-variabledeclaration': QtiVariableDeclaration;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { BaseType, Cardinality } from '../../internal/expression-result';\nimport { ResponseVariable } from '../../internal/variables';\nimport { ItemContext, itemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiMapping } from '../../qti-response-processing/qti-expression/qti-mapping/qti-mapping';\nimport { QtiVariableDeclaration } from '../qti-variable-declaration';\n\n@customElement('qti-response-declaration')\nexport class QtiResponseDeclaration extends QtiVariableDeclaration {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType;\n\n  @property({ type: String }) identifier: string;\n\n  @property({ type: String }) cardinality: Cardinality;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\n\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    const value = this.itemContext?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n\n    const responseVariable: ResponseVariable = {\n      baseType: this.baseType,\n      identifier: this.identifier,\n      correctResponse: this.correctResponse,\n      cardinality: this.cardinality || 'single',\n      mapping: this.mapping,\n      value: null,\n      type: 'response',\n      candidateResponse: null\n    };\n    responseVariable.value = this.defaultValues(responseVariable);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-register-variable', {\n        bubbles: true,\n        composed: true,\n        detail: { variable: responseVariable }\n      })\n    );\n  }\n\n  private get correctResponse(): string | string[] {\n    let result: string | string[];\n    const correctResponse = this.querySelector('qti-correct-response');\n    if (correctResponse) {\n      const values = correctResponse.querySelectorAll('qti-value');\n      if (this.cardinality === 'single' && values.length > 0) {\n        result = values[0].textContent;\n        values[0].remove();\n      } else if (this.cardinality !== 'single') {\n        result = [];\n        for (let i = 0; i < values.length; i++) {\n          result.push(values[i].textContent);\n          values[i].remove();\n        }\n      }\n    }\n    return result;\n  }\n\n  private get mapping() {\n    return this.querySelector('qti-mapping') as QtiMapping;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-declaration': QtiResponseDeclaration;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-companion-materials-info')\nexport class QtiCompanionMaterialsInfo extends LitElement {\n  // static override styles = css`\n  //   slot {\n  //     display: hidden;\n  //   }\n  // `;\n  // override render() {\n  //   return html` <slot></slot> `;\n  // }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-companion-materials-info': QtiCompanionMaterialsInfo;\n  }\n}\n", "import { LitElement, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-content-body')\nexport class QtiContentBody extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-content-body': QtiContentBody;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\n\n@customElement('qti-rubric-block')\nexport class QtiRubricBlock extends LitElement {\n  @property({ type: String }) override id; // =\"qtiAspectInhoudRubricBlock\"\n\n  @property({ type: String }) use: 'instructions' | 'scoring' | 'navigation'; //  = \"scoring\"\n\n  @property({ type: String }) view: 'author' | 'candidate' | 'proctor' | 'scorer' | 'testConstructor' | 'tutor';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames', { waitUntilFirstUpdate: true })\n  handleclassNamesChange(old, disabled: boolean) {\n    const classNames = this.classNames.split(' ');\n    classNames.forEach((className: string) => {\n      switch (className) {\n        case 'qti-rubric-discretionary-placement':\n          this.setAttribute('slot', 'qti-rubric-block');\n          break;\n        case 'qti-rubric-inline':\n          this.setAttribute('slot', '');\n          break;\n        default:\n          break;\n      }\n    });\n  }\n\n  static override styles = css`\n    :host {\n      display: block;\n    }\n  `;\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    // by default put this in a slot in the item-body\n    this.setAttribute('slot', 'qti-rubric-block');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rubric-block': QtiRubricBlock;\n  }\n}\n", "import { PropertyValueMap, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiFeedback } from '../qti-feedback';\n\n@customElement('qti-feedback-block')\nexport class QtiFeedbackBlock extends QtiFeedback {\n  static override styles = css`\n    :host {\n      display: block;\n    }\n    .on {\n      display: block;\n    }\n    .off {\n      display: none;\n    }\n  `;\n\n  override render() {\n    return html` <slot part=\"feedback\" class=\"feedback ${this.showStatus}\"></slot> `;\n  }\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    this.checkShowFeedback(this.outcomeIdentifier);\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-feedback-block': QtiFeedbackBlock;\n  }\n}\n", "import { 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  @state()\n  private _rows = 5;\n\n  /** expected length is mapped to the property maxlength on the textarea */\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  /** text appearing in the extended-text-nteraction if it is empty */\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @state()\n  private _value = '';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames')\n  handleclassNamesChange(old, classes: string) {\n    const classNames = classes.split(' ');\n    classNames.forEach((className: string) => {\n      if (className.startsWith('qti-height-lines-')) {\n        const nrRows = className.replace('qti-height-lines-', '');\n        this._rows = parseInt(nrRows);\n      }\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        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        rows=\"${this._rows}\"\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n        .value=${this._value}\n      ></textarea>`;\n  }\n\n  protected textChanged(event: Event) {\n    if (this.disabled || this.readonly) return;\n    const input = event.target as HTMLInputElement;\n    this.setEmptyAttribute(input.value);\n    if (this._value !== input.value) {\n      this._value = input.value;\n      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 { CSSResultGroup, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { createRef } from 'lit/directives/ref.js';\nimport { watch } from '../../../decorators';\nimport { Interaction } from '../internal/interaction/interaction';\nimport styles from './qti-text-entry-interaction.styles';\n@customElement('qti-text-entry-interaction')\nexport class QtiTextEntryInteraction extends Interaction {\n  static styles: CSSResultGroup = styles;\n\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @state()\n  private _value = '';\n\n  @state()\n  private _correctValue = '';\n\n  @state()\n  private _size = 5;\n\n  inputRef = createRef<HTMLInputElement>();\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  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        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", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: inline-block;\n  }\n  [part='correct'] {\n    position: absolute;\n    width: 100%;\n  }\n  :host(.qti-input-width-1) [part='input'] {\n    width: 1.1rem;\n    min-width: 1.1rem;\n  }\n\n  :host(.qti-input-width-2) [part='input'] {\n    width: 2.3rem;\n    min-width: 2.3rem;\n  }\n\n  :host(.qti-input-width-3) [part='input'] {\n    width: 3.3rem;\n    min-width: 3.3rem;\n  }\n\n  :host(.qti-input-width-4) [part='input'] {\n    width: 4.2rem;\n    min-width: 4.2rem;\n  }\n\n  :host(.qti-input-width-6) [part='input'] {\n    width: 6.6rem;\n    min-width: 6.6rem;\n  }\n\n  :host(.qti-input-width-10) [part='input'] {\n    width: 8rem;\n    min-width: 8rem;\n  }\n\n  :host(.qti-input-width-15) [part='input'] {\n    width: 12rem;\n    min-width: 12rem;\n  }\n\n  :host(.qti-input-width-20) [part='input'] {\n    width: 17rem;\n    min-width: 17rem;\n  }\n\n  :host(.qti-input-width-25) [part='input'] {\n    width: 20rem;\n    min-width: 20rem;\n  }\n\n  :host(.qti-input-width-30) [part='input'] {\n    width: 24rem;\n    min-width: 24rem;\n  }\n\n  :host(.qti-input-width-35) [part='input'] {\n    width: 28rem;\n    min-width: 28rem;\n  }\n\n  :host(.qti-input-width-40) [part='input'] {\n    width: 32rem;\n    min-width: 32rem;\n  }\n\n  :host(.qti-input-width-45) [part='input'] {\n    width: 36rem;\n    min-width: 36rem;\n  }\n\n  :host(.qti-input-width-50) [part='input'] {\n    width: 40rem;\n    min-width: 40rem;\n  }\n\n  :host(.qti-input-width-72) [part='input'] {\n    width: 57rem;\n    min-width: 57rem;\n  }\n`;\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\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 { ChoiceInterface } from '../active-element/active-element.mixin';\n\ntype Constructor<T = {}> = new (...args: any[]) => T;\n\ntype Choice = HTMLElement & ChoiceInterface;\n\nexport interface ChoicesInterface {\n  validate(): boolean;\n  _choiceElements: Array<Choice>;\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: Choice[] = [];\n\n    @property({ attribute: 'response-identifier' })\n    public responseIdentifier = '';\n\n    @property({ type: Number, attribute: 'min-choices' })\n    public minChoices = 0;\n\n    @property({ type: Number, attribute: 'max-choices' }) maxChoices = 1;\n    @watch('maxChoices', { waitUntilFirstUpdate: true })\n    _handleMaxChoicesChange(_oldValue: number, _newValue: number) {\n      this._determineInputType();\n    }\n\n    @property({ reflect: true, type: Boolean }) disabled = false;\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    _handleDisabledChange = (_: boolean, disabled: boolean) => {\n      this._choiceElements.forEach(ch => (ch.disabled = disabled));\n    };\n\n    @property({ reflect: true, type: Boolean }) readonly = false;\n    @watch('readonly', { waitUntilFirstUpdate: true })\n    _handleReadonlyChange = (_: boolean, readonly: boolean) => {\n      this._choiceElements.forEach(choice => (choice.readonly = readonly));\n    };\n\n    public validate(): boolean {\n      const selectedCount = this._choiceElements.filter(choice => this._getChoiceChecked(choice)).length;\n      if (this.maxChoices !== 0 && selectedCount > this.maxChoices) {\n        return false;\n      }\n      return selectedCount >= this.minChoices;\n    }\n\n    public set response(responseValue: string | string[]) {\n      const responseArray = Array.isArray(responseValue) ? responseValue : [responseValue];\n      this._choiceElements.forEach(choice => {\n        this._setChoiceChecked(choice, responseArray.includes(choice.identifier));\n      });\n    }\n\n    public set correctResponse(responseValue: string | string[]) {\n      const responseArray = Array.isArray(responseValue) ? responseValue : [responseValue];\n      if (responseArray.length === 0) {\n        this._choiceElements.forEach(choice => {\n          choice.removeAttribute('data-correct-response');\n        });\n        return;\n      }\n      this._choiceElements.forEach(choice => {\n        choice.setAttribute('data-correct-response', responseArray.includes(choice.identifier) ? 'true' : 'false');\n      });\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.addEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.addEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.addEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n      this.dispatchEvent(\n        new CustomEvent(`qti-register-interaction`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.removeEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.removeEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n    }\n\n    private _registerChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      choiceElement.disabled = this.disabled;\n      this._choiceElements.push(choiceElement);\n      this._setInputType(choiceElement);\n    }\n\n    private _unregisterChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      this._choiceElements = this._choiceElements.filter(choice => choice !== choiceElement);\n    }\n\n    private _determineInputType() {\n      this._choiceElements.forEach(choice => {\n        this._setInputType(choice);\n      });\n    }\n\n    private _setInputType(choiceElement: Choice) {\n      choiceElement.setAttribute('role', this.maxChoices === 1 ? 'radio' : 'checkbox');\n    }\n\n    protected _choiceElementSelectedHandler(event: CustomEvent<{ identifier: string }>) {\n      this._toggleChoiceChecked(event.target as Choice);\n      if (this.maxChoices === 1) {\n        this._choiceElements.forEach(choice => {\n          if (choice.identifier !== event.detail.identifier) {\n            this._setChoiceChecked(choice, false);\n          }\n        });\n      }\n      this._handleChoiceSelection();\n    }\n\n    private _setChoiceChecked(choice: Choice, checked: boolean) {\n      choice.setAttribute('aria-checked', checked.toString());\n    }\n\n    private _getChoiceChecked(choice: Choice): boolean {\n      return choice.getAttribute('aria-checked') === 'true';\n    }\n\n    private _toggleChoiceChecked(choice: Choice) {\n      const checked = this._getChoiceChecked(choice);\n      this._setChoiceChecked(choice, !checked);\n    }\n\n    /**\n     * Handles the selection of choices.\n     *\n     * This method filters the choice elements based on their checked state and retrieves the selected identifiers.\n     * If the `maxChoices` property is set to a value greater than 1 and not equal to 0, it disables unselected choices\n     * when the maximum number of choices is reached.\n     * Finally, it saves the response based on the `maxChoices` property.\n     */\n    protected _handleChoiceSelection() {\n      const selectedChoices = this._choiceElements.filter(choice => this._getChoiceChecked(choice));\n      const selectedIdentifiers = selectedChoices.map(choice => choice.identifier);\n\n      if (this.maxChoices > 1 && this.maxChoices !== 0) {\n        const disableUnselected = selectedChoices.length >= this.maxChoices;\n        this._choiceElements.forEach(choice => {\n          if (!this._getChoiceChecked(choice)) {\n            choice.disabled = disableUnselected;\n          }\n        });\n      }\n\n      /**\n       * The response from the interaction.\n       * If `maxChoices` is 1, it will be the selected identifier or `undefined` if no identifier is selected.\n       * If `maxChoices` is greater than 1, it will be an array of selected identifiers.\n       */\n      const response = this.maxChoices === 1 ? selectedIdentifiers[0] || undefined : selectedIdentifiers;\n      this._saveResponse(response);\n    }\n\n    protected _saveResponse(response: string | string[] | undefined) {\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.mixin';\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      const fixedElements: Array<{ element: HTMLElement; index: number }> = [];\n      const nonFixedElements: Array<HTMLElement> = [];\n\n      // Separate fixed and non-fixed elements\n      choices.forEach((choice, index) => {\n        if (choice.hasAttribute('fixed')) {\n          fixedElements.push({ element: choice, index: index });\n        } else {\n          nonFixedElements.push(choice);\n        }\n      });\n\n      // If there are 1 or fewer non-fixed elements, throw an error (no shuffle possible)\n      if (nonFixedElements.length <= 1) {\n        console.warn('Shuffling is not possible with fewer than 2 non-fixed elements.');\n        return;\n      }\n\n      let isShuffled = false;\n      const maxAttempts = 10; // Max attempts to prevent infinite loops\n      let attempt = 0;\n\n      // Create a copy of the original order for comparison\n      const originalOrder = [...nonFixedElements];\n\n      // Shuffle until the result is different or maxAttempts is reached\n      while (!isShuffled && attempt < maxAttempts) {\n        attempt++;\n\n        // Shuffle non-fixed elements\n        for (let i = nonFixedElements.length - 1; i > 0; i--) {\n          const j = Math.floor(Math.random() * (i + 1));\n          [nonFixedElements[i], nonFixedElements[j]] = [nonFixedElements[j], nonFixedElements[i]];\n        }\n\n        // Check if the shuffled result is different from the original order\n        isShuffled = !nonFixedElements.every((choice, index) => choice === originalOrder[index]);\n\n        if (isShuffled) break;\n      }\n\n      if (!isShuffled) {\n        console.warn('Failed to shuffle the choices after multiple attempts.');\n      }\n\n      // Assign order to each element\n      let order = 1;\n      choices.forEach((choice: HTMLElement, index) => {\n        if (choice.hasAttribute('fixed')) {\n          choice.style.setProperty('order', String(order++));\n        } else {\n          const nonFixedChoice = nonFixedElements.shift();\n          nonFixedChoice!.style.setProperty('order', String(order++));\n        }\n      });\n    }\n\n    private _resetShuffleChoices() {\n      const choices = Array.from(this.querySelectorAll('qti-simple-choice'));\n      choices.forEach((choice, index) => {\n        choice.style.setProperty('order', 'initial'); // choice.style.order = 'initial';\n      });\n    }\n  }\n  return ShuffleElement as Constructor<ShuffleInterface> & T;\n};\n\nconst stringToBooleanConverter = {\n  fromAttribute(value: string | null): boolean {\n    return value === 'true';\n  },\n  toAttribute(value: boolean): string {\n    return value ? 'true' : 'false';\n  }\n};\n", "/**\n * Mixin that provides shuffling functionality for a LitElement.\n * @template T - The type of the LitElement subclass.\n * @param {T} superClass - The superclass to extend.\n * @param {string} selector - The CSS selector for the elements to shuffle.\n * @returns {Constructor<ShuffleInterface> & T} - The extended class with shuffling functionality.\n *\n * adds a shuffle property to the class with an attribute converter\n *\n * qti-inline-choice-interaction\n * qti-choice-interaction\n * qti-match-interaction\n */\nimport { LitElement, PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\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\nexport default css`\n  [part='slot'] {\n    display: flex;\n    flex-direction: column;\n    gap: var(--qti-gap-size);\n    flex-wrap: wrap;\n  }\n\n  ::slotted(qti-simple-choice) {\n    flex: 0 0 calc((100% - (var(--qti-gap-size) * var(--choice-interactions-stacking))) / var(--choice-interactions-stacking)) !important; \n    box-sizing: border-box !important;\n  }\n\n  :host(.qti-choices-stacking-1) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 1;\n  }\n\n  :host(.qti-choices-stacking-2) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 2;\n  }\n  :host(.qti-choices-stacking-3) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 3;\n  }\n  :host(.qti-choices-stacking-4) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 4;\n  }\n  :host(.qti-choices-stacking-5) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 5;\n  }\n  :host([orientation='horizontal']) [part='slot'] {\n    flex-direction: row;\n  }\n`;\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiRule, QtiRuleBase } from '..';\n\n@customElement('qti-outcome-processing')\nexport class QtiOutcomeProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const logic = new QtiOutcomeProcessingProcessor();\n    const rules = [...this.children] as QtiRule[];\n    logic.process(rules);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-outcome-processing': QtiOutcomeProcessing;\n  }\n}\n\nexport class QtiOutcomeProcessingProcessor {\n  public process(rules: QtiRuleBase[]) {\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n}\n", "import { css, html, LitElement, PropertyValueMap } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { mapResponse, mapResponsePoint, matchCorrect } from '../../internal/template-strings';\nimport { type QtiRule } from '../qti-rule/qti-rule';\n\n@customElement('qti-response-processing')\nexport default class QtiResponseProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const rules = [...this.children] as QtiRule[];\n\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n\n  public firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    if (this.getAttribute('template')) {\n      const splittedTemplateName = this.getAttribute('template')!.split('/');\n      const templateName = splittedTemplateName[splittedTemplateName.length - 1].replace('.xml', '');\n      this.innerHTML = '';\n      switch (templateName) {\n        case 'map_response': {\n          this.appendChild(this.fragmentFromString(mapResponse).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'map_response_point': {\n          this.appendChild(this.fragmentFromString(mapResponsePoint).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'match_correct':\n          this.appendChild(this.fragmentFromString(matchCorrect).firstElementChild.firstElementChild);\n          break;\n      }\n    }\n  }\n\n  private fragmentFromString(strHTML: string) {\n    return document.createRange().createContextualFragment(strHTML);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-processing': QtiResponseProcessing;\n  }\n}\n", "export const matchCorrect = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-match>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n        <qti-correct identifier=\"RESPONSE\"></qti-correct>\n      </qti-match>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">1</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponse = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0.0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response identifier=\"RESPONSE\"> </qti-map-response>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponsePoint = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response-point identifier=\"RESPONSE\"></qti-map-response-point>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n", "import { OutcomeVariable } from '@citolab/qti-components/qti-components';\nimport { property } from 'lit/decorators.js';\nimport { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\n/**\n * The lookupOutcomeValue rule sets the value of an outcome variable to the value obtained\n * by looking up the value of the associated expression in the lookupTable associated\n * with the outcome's declaration.\n */\nexport class QtiLookupOutcomeValue extends QtiRule {\n  @property({ type: String }) identifier: string;\n\n  get childExpression(): QtiExpression<string> {\n    return this.firstElementChild as QtiExpression<string>;\n  }\n\n  public override process(): number {\n    const identifier = this.getAttribute('identifier');\n    const outcomeVariable = this.closest('qti-assessment-item').getVariable(identifier) as OutcomeVariable;\n    let value;\n    if (outcomeVariable.interpolationTable) {\n      value = outcomeVariable.interpolationTable.get(parseInt(this.childExpression.calculate()));\n    }\n    if (value === null || value === undefined) {\n      console.warn('lookupOutcomeValue: value is null or undefined');\n      return 0;\n    }\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier: this.identifier,\n          value: convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n    return value;\n  }\n}\ncustomElements.define('qti-lookup-outcome-value', QtiLookupOutcomeValue);\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-lookup-outcome-value': QtiLookupOutcomeValue;\n  }\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\n\n@customElement('qti-rule')\nexport class QtiRule extends LitElement implements QtiRuleBase {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    throw new Error('Not implemented');\n  }\n}\n\nexport interface QtiRuleBase {\n  process(): any;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rule': QtiRule;\n  }\n}\n", "import { html } from 'lit';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\nexport class QtiResponseCondition extends QtiRule {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public override process() {\n    const branches = [...this.children] as QtiExpression<any>[];\n\n    for (let i = 0; i < branches.length; i++) {\n      const branch = branches[i];\n\n      if (branch.calculate()) {\n        (branch as unknown as QtiRule).process();\n\n        return;\n      }\n    }\n  }\n}\n\ncustomElements.define('qti-response-condition', QtiResponseCondition);\n", "import { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression, QtiExpressionBase } from '../../qti-expression/qti-expression';\nimport { QtiRule, QtiRuleBase } from '../qti-rule';\n\nexport class QtiSetOutcomeValue extends QtiRule {\n  public override process() {\n    const outcomeIdentifier = this.getAttribute('identifier');\n\n    const expression = this.firstElementChild as QtiExpression<string>;\n\n    const rule = new QtiSetOutcomeValueRule(expression);\n    const value = rule.process();\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier,\n          value: Array.isArray(value)\n            ? value.map((v: string) => convertNumberToUniveralFormat(v))\n            : convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n  }\n}\n\nexport class QtiSetOutcomeValueRule<T> implements QtiRuleBase {\n  constructor(private expression: QtiExpressionBase<T>) {}\n\n  process(): any {\n    const value = this.expression ? this.expression.calculate() : null;\n\n    if (value === null || value === undefined) {\n      console.warn('setOutcomeValue: value is null or undefined');\n      return;\n    }\n    return value;\n  }\n}\n\ncustomElements.define('qti-set-outcome-value', QtiSetOutcomeValue);\n", "import { LitElement, html } from 'lit';\nimport { QtiRule } from '../qti-rule/qti-rule';\n\nexport class QtiResponseElse extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public calculate() {\n    const result = true;\n    return true;\n  }\n\n  public getSubRules(): QtiRule[] {\n    return [...this.children] as QtiRule[];\n  }\n\n  public process() {\n    const subRules = this.getSubRules();\n    for (let i = 0; i < subRules.length; i++) {\n      const subRule = subRules[i];\n      subRule.process();\n    }\n  }\n}\n\ncustomElements.define('qti-response-else', QtiResponseElse);\n", "import { html } from 'lit';\nimport { QtiResponseIf } from '../qti-response-if';\n\nexport class QtiResponseElseIf extends QtiResponseIf {\n  override render() {\n    return html`${super.render()}`;\n  }\n}\n\ncustomElements.define('qti-response-else-if', QtiResponseElseIf);\n", "import { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../../qti-rule/qti-rule';\nimport { QtiResponseElse } from '../qti-response-else';\n\nexport class QtiResponseIf extends QtiResponseElse {\n  public override calculate() {\n    const expression = this.firstElementChild as QtiExpression<boolean>;\n    const result = expression.calculate() as boolean;\n    return result;\n  }\n\n  public override getSubRules(): QtiRule[] {\n    const result = [];\n    for (let i = 1; i < this.children.length; i++) {\n      result.push(this.children[i]);\n    }\n    return result;\n  }\n}\n\ncustomElements.define('qti-response-if', QtiResponseIf);\n", "import { 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.trim(),\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.trim();\n    return value;\n  }\n}\n\ncustomElements.define('qti-base-value', QtiBaseValue);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiConditionExpression } from '../qti-condition-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiContains extends QtiConditionExpression {\n  public override getResult() {\n    // TODO: implement this for other types than directedPair\n    const values = this.getVariables() as ResponseVariable[];\n    if (this.children.length === 2) {\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'multiple'\n      ) {\n        const projection1 = value1.value as string[];\n        const projection2 = value2.value as string[];\n        const enumerable = projection1.filter(x => projection2.includes(x));\n\n        const result = enumerable.length > 0;\n        return result;\n      } else if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'single'\n      ) {\n        const projection1 = value1.value as string;\n        const projection2 = value2.value as string[];\n        return projection2.includes(projection1);\n      } else {\n        console.error(\n          'unsupported baseType or cardinality in qti contains, only baseType: directedPair and cardinality: multiple is supported'\n        );\n      }\n    } else {\n      console.error('unexpected number of children in qti contains');\n    }\n    return false;\n  }\n}\n\ncustomElements.define('qti-contains', QtiContains);\n", "import { 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 QtiPrintedVariable 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  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', QtiPrintedVariable);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiProduct extends QtiExpression<number> {\n  public override getResult() {\n    const values = this.getVariables() as ResponseVariable[];\n    const product = values.reduce((accumulator, currentValue) => {\n      if (currentValue.baseType == 'float' || currentValue.baseType == 'integer') {\n        try {\n          return accumulator * parseInt(currentValue.value.toString());\n        } catch (error) {\n          console.warn(`can not convert to number`);\n        }\n      } else {\n        console.warn(`has another baseType ${currentValue.baseType}`);\n      }\n      return accumulator;\n    }, 1);\n    return product;\n  }\n}\n\ncustomElements.define('qti-product', QtiProduct);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from '../../../internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiStringMatch extends QtiExpression<boolean> {\n  @property({ type: String, attribute: 'case-sensitive' }) caseSensitive = 'true';\n\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.cardinality !== 'single' ||\n        value2.cardinality !== 'single' ||\n        Array.isArray(value1.value) ||\n        Array.isArray(value2.value)\n      ) {\n        console.error('unexpected cardinality in qti string-match');\n        return false;\n      }\n      const v1 = this.caseSensitive === 'true' ? value1.value : (value1.value as string).toLowerCase();\n      const v2 = this.caseSensitive === 'true' ? value2.value : (value2.value as string).toLowerCase();\n      return ScoringHelper.compareSingleValues(v1 as string, v2 as string, value1.baseType);\n    }\n    console.error('unexpected number of children in qti-string-match');\n    return null;\n  }\n}\n\ncustomElements.define('qti-string-match', QtiStringMatch);\n", "import { QtiExpression, QtiExpressionBase } from '../qti-expression';\n\nexport class QtiSum extends QtiExpression<number> {\n  private _expression: QtiSumExpression;\n  constructor() {\n    super();\n    this._expression = new QtiSumExpression(Array.from(this.children as unknown as QtiExpressionBase<number>[]));\n  }\n\n  public override getResult() {\n    // children can be a mix of qti-expression and qti-condition-expression\n    const value = this._expression.calculate();\n    return value;\n  }\n}\n\nexport class QtiSumExpression implements QtiExpressionBase<number> {\n  constructor(private expressions: QtiExpressionBase<number>[]) {}\n\n  public calculate() {\n    const values = this.expressions.map(c => {\n      if (!c.calculate) {\n        console.error(\"Element doesn't implement QtiConditionExpression\");\n        return null;\n      }\n      const value = c.calculate();\n      if (Number.isNaN(value)) {\n        console.error('unexpected value in qti-sum, expected number');\n        return null;\n      }\n\n      return Number(value);\n    });\n    return values.reduce((a, b) => a + b, 0);\n  }\n}\n\ncustomElements.define('qti-sum', QtiSum);\n", "import { 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 { CSSResultGroup, LitElement, html } from 'lit';\n\nimport { customElement, state } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-associate-interaction.styles';\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 styles: CSSResultGroup = styles;\n  // dragDropApi: TouchDragAndDrop;\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  // async connectedCallback(): Promise<void> {\n  //   super.connectedCallback();\n  //   await this.updateComplete;\n  //   this.dragDropApi = new TouchDragAndDrop();\n  //   this.dragDropApi.addDraggableElements(this.querySelectorAll('qti-simple-associable-choice'));\n  //   this.dragDropApi.addDroppableElements(this.shadowRoot.querySelectorAll('.dl'));\n  // }\n\n  constructor() {\n    super();\n    this.addEventListener('register-qti-simple-associable-choice', (event: CustomEvent) => {\n      const choice = event.target as QtiSimpleAssociableChoice;\n      this._childrenMap.push(choice);\n    });\n\n    // this.addEventListener('unregister-qti-simple-associable-choice', (event: CustomEvent) => {\n    //   console.log('test');\n    //   const choice = event.target as QtiSimpleAssociableChoice;\n    //   const index = this._childrenMap.indexOf(choice);\n    //   if (index !== -1) {\n    //     this._childrenMap.splice(index, 1);\n    //   }\n    // });\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-associate-interaction': QtiAssociateInteraction;\n  }\n}\n", "export class TouchDragAndDrop {\n  private touchStartTime = 0; // Timestamp of the first touch\n  private touchStartPoint = null; // Point of the first touch\n  private lastClickTime = 0; // Timestamp of the previous click\n  private isDraggable = false; // Whether a draggable element is active\n  private dragSource: HTMLElement = null; // The source element being dragged\n  private dragClone: HTMLElement = null; // Clone of drag source for visual feedback\n  private touchEndTriggered = false; // Flag for touchEnd event\n  private isDragging = false; // Whether a drag operation is ongoing\n  private initialTransform = ''; // Original transform style\n  private hasDispatchedDragStart = false; // Flag to ensure dragstart event is dispatched once\n  private rootNode: Node = null; // Root node for boundary calculations\n\n  private focusedElement: HTMLElement = null; // To keep track of the currently focused draggable element\n  private focusableDropZones: HTMLElement[] = []; // All dropzones for keyboard navigation\n  private currentDropZoneIndex = -1; // Index for tabbing through drop zones\n\n  private dataTransfer = {\n    data: {},\n    setData(type, val) {\n      this.data[type] = val;\n    },\n    getData(type) {\n      return this.data[type];\n    },\n    effectAllowed: 'move'\n  };\n  private cloneOffset = { x: 0, y: 0 }; // Offset for positioning the drag clone\n\n  private lastTarget = null; // Last touch target\n  private currentDropTarget = null; // Current droppable element\n  private allowClick = true; // Flag to allow or prevent click\n  private static instance: TouchDragAndDrop;\n\n  copyStylesForDragClone = true;\n  dragOnClickEnabled = false;\n  useDragClone = false; // Set to true to drag with a clone; set to false to drag the original element\n\n  private readonly MIN_DRAG_DISTANCE = 5; // Minimum pixel movement to start dragging\n  private readonly DRAG_CLONE_OPACITY = 1; // Opacity of the drag clone element\n  initialTransition: string;\n  // droppables: Element[];\n\n  constructor() {\n    if (TouchDragAndDrop.instance) {\n      return TouchDragAndDrop.instance;\n    }\n    TouchDragAndDrop.instance = this;\n\n    // Add event listeners for touch and mouse interactions\n    document.addEventListener('touchmove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('mousemove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('touchend', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('mouseup', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('touchcancel', this.handleTouchCancel.bind(this), { passive: false });\n\n    document.addEventListener('keydown', this.handleKeyDown.bind(this));\n    document.addEventListener('keyup', this.handleKeyUp.bind(this));\n  }\n\n  addDraggableElements(draggables: Element[]) {\n    draggables.forEach(el => {\n      el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n      el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n      el.addEventListener('blur', () => (this.focusedElement = null));\n\n      el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n      el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n    });\n  }\n\n  // addDroppableElements(droppables: Element[]) {\n  //   // this.droppables = droppables;\n  //   droppables.forEach(el => {\n  //     el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n  //     el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n  //     el.addEventListener('blur', () => (this.focusedElement = null));\n\n  //     // el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n  //     // el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n  //   });\n  // }\n\n  private handleTouchStart(e) {\n    this.touchStartTime = Date.now();\n    const { x, y } = this.getEventCoordinates(e);\n    this.touchStartPoint = { x, y };\n    this.dragSource = e.currentTarget;\n    this.isDraggable = true;\n\n    // Get the root node\n    this.rootNode = this.dragSource.getRootNode();\n\n    if (this.dragOnClickEnabled) {\n      this.isDragging = true;\n      this.createDragClone(e, { clientX: x, clientY: y });\n    }\n\n    if (!this.useDragClone) {\n      // Save initial transform\n      const computedStyle = window.getComputedStyle(this.dragSource);\n      this.initialTransform = computedStyle.transform === 'none' ? '' : computedStyle.transform;\n\n      // Save the original transition style\n      this.initialTransition = computedStyle.transition || '';\n\n      // Disable transitions\n      this.dragSource.style.transition = 'none';\n\n      // Calculate clone offset\n      const rect = this.dragSource.getBoundingClientRect();\n      this.cloneOffset.x = x - rect.left;\n      this.cloneOffset.y = y - rect.top;\n\n      // Set higher z-index to bring it on top\n      this.dragSource.style.zIndex = '9999';\n      // this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n      this.dragSource.focus();\n    }\n\n    e.preventDefault();\n  }\n\n  private handleTouchMove(e) {\n    if (this.isDraggable && this.dragSource) {\n      const { x, y } = this.getEventCoordinates(e);\n      const currentTouch = { clientX: x, clientY: y };\n\n      if (this.calculateDragDistance(currentTouch) >= this.MIN_DRAG_DISTANCE) {\n        this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n        this.isDragging = true;\n      }\n\n      this.createDragClone(e, currentTouch);\n      e.preventDefault();\n    }\n  }\n\n  private createDragClone(e, currentTouch: { clientX: number; clientY: number }) {\n    if (!this.isDragging) return;\n\n    if (this.useDragClone) {\n      // Existing code for creating and handling the drag clone\n      if (!this.dragClone) {\n        this.dragSource.style.opacity = this.DRAG_CLONE_OPACITY.toString();\n        this.dragClone = this.dragSource.cloneNode(true) as HTMLElement;\n\n        if (this.copyStylesForDragClone) {\n          const computedStyles = window.getComputedStyle(this.dragSource);\n          for (const style of computedStyles) {\n            this.dragClone.style[style] = computedStyles.getPropertyValue(style);\n          }\n        }\n\n        // Move the drag clone to the root node\n        if (this.rootNode instanceof ShadowRoot) {\n          // Append to the host of the shadow root\n          this.rootNode.host.appendChild(this.dragClone);\n        } else if (this.rootNode instanceof Document) {\n          document.body.appendChild(this.dragClone);\n        }\n\n        this.calculateClonePosition(currentTouch);\n        this.setDragCloneStyles(currentTouch);\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      }\n\n      this.updateDragClonePosition(currentTouch);\n    } else {\n      // Handle dragging the original element using CSS transforms\n      if (this.touchStartPoint) {\n        const deltaX = currentTouch.clientX - this.touchStartPoint.x;\n        const deltaY = currentTouch.clientY - this.touchStartPoint.y;\n\n        // Apply boundaries\n        // const { boundedDeltaX, boundedDeltaY } = this.applyTransformBoundaries(deltaX, deltaY);\n        // this.dragSource.style.transform = `${this.initialTransform} translate(${boundedDeltaX}px, ${boundedDeltaY}px)`;\n\n        this.dragSource.style.transform = `${this.initialTransform} translate(${deltaX}px, ${deltaY}px)`;\n\n        if (!this.hasDispatchedDragStart) {\n          this.dispatchCustomEvent(this.dragSource, 'dragstart');\n          this.hasDispatchedDragStart = true;\n        }\n      }\n    }\n\n    const dropTarget = this.findDropTarget(e);\n\n    if (dropTarget !== this.lastTarget) {\n      this.dispatchCustomEvent(dropTarget, 'dragenter');\n      this.dispatchCustomEvent(this.lastTarget, 'dragleave');\n      this.lastTarget = dropTarget;\n    }\n\n    this.currentDropTarget = dropTarget;\n    if (this.currentDropTarget) this.dispatchCustomEvent(dropTarget, 'dragover');\n  }\n\n  private handleTouchEnd(e) {\n    this.touchEndTriggered = true;\n    this.isDraggable = false;\n    let dropFound = false;\n\n    // console.log('dropFound', dropFound);\n\n    if (this.currentDropTarget) {\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      dropFound = true;\n    } else if (this.isDragging) {\n      const dragEndEvent = new CustomEvent('dragend', { bubbles: true, cancelable: true });\n      dragEndEvent['dataTransfer'] = { dropEffect: 'none' };\n      this.dragSource?.dispatchEvent(dragEndEvent);\n    }\n\n    this.resetDragState(dropFound);\n  }\n\n  private handleTouchCancel(e) {\n    this.resetDragState();\n  }\n\n  private findDropTarget(event) {\n    const { x, y } = this.getEventCoordinates(event);\n    return this.getDropTargetAtPoint(document, x, y);\n  }\n\n  private getDropTargetAtPoint(root: DocumentOrShadowRoot, x: number, y: number, depth: number = 0): Element | null {\n    // Limit the recursion depth\n    const MAX_DEPTH = 2;\n    if (depth > MAX_DEPTH) {\n      return null;\n    }\n\n    const element = root.elementFromPoint(x, y) as HTMLElement;\n\n    if (!element) {\n      return null;\n    }\n\n    if (element.hasAttribute('dropzone')) {\n      return element;\n    }\n\n    // Traverse up the DOM tree to find an ancestor with 'dropzone' attribute\n    let currentElement = element.parentElement;\n    while (currentElement) {\n      if (currentElement.hasAttribute('dropzone')) {\n        return currentElement;\n      }\n      currentElement = currentElement.parentElement;\n    }\n\n    // If the element has a Shadow DOM and depth limit not reached, traverse it\n    if (element.shadowRoot && depth < MAX_DEPTH) {\n      const shadowElement = this.getDropTargetAtPoint(element.shadowRoot, x, y, depth + 1);\n      if (shadowElement) {\n        return shadowElement;\n      }\n    }\n\n    // No element with 'dropzone' found\n    return null;\n  }\n\n  private handleKeyDown(e: KeyboardEvent) {\n    if (this.focusedElement) {\n      if (e.key === ' ' && !this.isDragging) {\n        // Spacebar pressed to start dragging\n        e.preventDefault();\n        this.isDraggable = true;\n        this.dragSource = this.focusedElement;\n        this.isDragging = true;\n\n        // Store the drop zones for navigation\n        this.collectDropZones();\n\n        // Trigger dragstart event\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      } else if (e.key === 'Tab' && this.isDragging) {\n        // Tab key to navigate through drop zones\n        e.preventDefault();\n        this.moveToNextDropZone();\n      }\n    }\n  }\n\n  private handleKeyUp(e: KeyboardEvent) {\n    if (e.key === ' ' && this.isDragging && this.currentDropTarget) {\n      // Spacebar pressed again to drop the element\n      e.preventDefault();\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      this.resetDragState(true);\n    }\n  }\n\n  private collectDropZones() {\n    // Collect all elements with dropzone attribute\n    this.focusableDropZones = Array.from(document.querySelectorAll('[dropzone]')) as HTMLElement[]; // Array.from(this.droppables);\n    this.currentDropZoneIndex = -1; // Reset navigation index\n  }\n\n  private moveToNextDropZone() {\n    if (this.focusableDropZones.length === 0) return;\n\n    // Update index for the next drop zone\n    this.currentDropZoneIndex = (this.currentDropZoneIndex + 1) % this.focusableDropZones.length;\n\n    // Focus the next drop zone\n    const nextDropZone = this.focusableDropZones[this.currentDropZoneIndex];\n    nextDropZone.focus();\n\n    // Update current drop target\n    this.currentDropTarget = nextDropZone;\n\n    // Dispatch dragenter event\n    this.dispatchCustomEvent(nextDropZone, 'dragenter');\n  }\n\n  private getEventCoordinates(event, page = false) {\n    const touch = event.touches ? event.touches[0] : event;\n    return {\n      x: page ? touch.pageX : touch.clientX,\n      y: page ? touch.pageY : touch.clientY\n    };\n  }\n\n  private calculateClonePosition(touch) {\n    const rect = this.dragSource.getBoundingClientRect();\n    this.cloneOffset.x = touch.clientX - rect.left;\n    this.cloneOffset.y = touch.clientY - rect.top;\n  }\n\n  private setDragCloneStyles(touch) {\n    this.dragClone.style.position = 'fixed';\n    this.dragClone.style.top = `${touch.clientY - this.cloneOffset.y}px`;\n    this.dragClone.style.left = `${touch.clientX - this.cloneOffset.x}px`;\n    this.dragClone.style.pointerEvents = 'none';\n    this.dragClone.style.zIndex = '999999';\n  }\n\n  private updateDragClonePosition(touch) {\n    requestAnimationFrame(() => {\n      if (this.touchEndTriggered || !this.dragClone) return;\n\n      const newLeft = touch.clientX - this.cloneOffset.x;\n      const newTop = touch.clientY - this.cloneOffset.y;\n\n      // Apply boundaries\n      const { newLeft: boundedLeft, newTop: boundedTop } = this.applyBoundaries(newLeft, newTop, this.dragClone);\n\n      this.dragClone.style.left = `${boundedLeft}px`;\n      this.dragClone.style.top = `${boundedTop}px`;\n    });\n  }\n\n  private applyTransformBoundaries(deltaX: number, deltaY: number) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions and position of the element\n    const elementRect = this.dragSource.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Calculate potential new position\n    const newLeft = elementRect.left + deltaX;\n    const newTop = elementRect.top + deltaY;\n\n    // Limit the new position within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    // Calculate the bounded delta values\n    const boundedDeltaX = boundedLeft - elementRect.left;\n    const boundedDeltaY = boundedTop - elementRect.top;\n\n    return { boundedDeltaX, boundedDeltaY };\n  }\n\n  private applyBoundaries(newLeft: number, newTop: number, element: HTMLElement) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions of the element\n    const elementRect = element.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Limit the newLeft and newTop within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    return { newLeft: boundedLeft, newTop: boundedTop };\n  }\n\n  private calculateDragDistance(touch): number {\n    const xDist = Math.abs(touch.clientX - this.touchStartPoint.x);\n    const yDist = Math.abs(touch.clientY - this.touchStartPoint.y);\n    return xDist + yDist;\n  }\n\n  private dispatchCustomEvent(element, eventType, bubble = true) {\n    if (!element) return;\n    const event = new CustomEvent(eventType, { bubbles: bubble, cancelable: true });\n    event['dataTransfer'] = this.dataTransfer;\n    element.dispatchEvent(event);\n  }\n\n  private resetDragState(dropFound: boolean = false) {\n    if (this.isDragging) {\n      if (this.useDragClone) {\n        this.dragSource.style.opacity = '1.0';\n        this.dragClone?.parentElement.removeChild(this.dragClone);\n      } else {\n        // Restore original styles\n        if (!dropFound) this.dragSource.style.transform = 'translate(0, 0)';\n        this.dragSource.style.zIndex = '';\n        this.dragSource.style.pointerEvents = '';\n        // Restore the original transition style\n        this.dragSource.style.transition = this.initialTransition;\n\n        // Reset the original transition property\n        this.initialTransition = '';\n      }\n    }\n\n    this.isDragging = false;\n    this.dragSource = null;\n    this.dragClone = null;\n    this.isDraggable = false;\n    this.touchStartTime = 0;\n    this.touchStartPoint = null;\n    this.touchEndTriggered = false;\n    this.dataTransfer = {\n      data: {},\n      setData(type, val) {\n        this.data[type] = val;\n      },\n      getData(type) {\n        return this.data[type];\n      },\n      effectAllowed: 'move'\n    };\n    this.cloneOffset = { x: 0, y: 0 };\n    this.lastTarget = null;\n    this.currentDropTarget = null;\n    this.allowClick = true;\n    this.initialTransform = '';\n    this.hasDispatchedDragStart = false;\n\n    this.rootNode = null;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\n\ntype Constructor<T> = new (...args: any[]) => T;\n\ndeclare class DroppablesInterface {}\n\nexport const DroppablesMixin = <T extends Constructor<LitElement>>(\n  superClass: T,\n  useShadowRoot: 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      if (this.isMatchTabular()) return;\n      super.firstUpdated(changedProps);\n\n      const droppables = this.getDroppableElements();\n      this.initializeEventHandlers();\n      droppables.forEach(droppable => {\n        this.prepareDroppable(droppable);\n        this.observeDroppableAttributes(droppable);\n      });\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private getDroppableElements(): Element[] {\n      return Array.from(\n        useShadowRoot ? this.shadowRoot.querySelectorAll(droppablesSelector) : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private initializeEventHandlers(): void {\n      this.dragoverHandler = this.dragoverHandler.bind(this);\n      this.dragleaveHandler = this.dragleaveHandler.bind(this);\n      this.dragenterHandler = this.dragenterHandler.bind(this);\n      this.dropHandler = this.dropHandler.bind(this);\n    }\n\n    private prepareDroppable(droppable: Element): void {\n      droppable.setAttribute('dropzone', 'move');\n      droppable.addEventListener('dragleave', this.dragleaveHandler);\n      this.attachEventListeners(droppable);\n    }\n\n    private observeDroppableAttributes(droppable: Element): void {\n      this.observer = new MutationObserver(mutations => {\n        mutations.forEach(({ attributeName }) => {\n          if (attributeName === 'disabled') {\n            this.toggleDroppableHandlers(droppable);\n          }\n        });\n      });\n      this.observer.observe(droppable, { attributes: true });\n    }\n\n    private toggleDroppableHandlers(droppable: Element): void {\n      const disabled = droppable.hasAttribute('disabled');\n      disabled ? this.removeEventListeners(droppable) : this.attachEventListeners(droppable);\n    }\n\n    private attachEventListeners(droppable: Element): void {\n      droppable.addEventListener('dragover', this.dragoverHandler);\n      droppable.addEventListener('dragenter', this.dragenterHandler);\n      droppable.addEventListener('drop', this.dropHandler);\n    }\n\n    private removeEventListeners(droppable: Element): void {\n      droppable.removeEventListener('dragover', this.dragoverHandler);\n      droppable.removeEventListener('dragenter', this.dragenterHandler);\n      droppable.removeEventListener('drop', this.dropHandler);\n    }\n\n    override disconnectedCallback(): void {\n      if (this.isMatchTabular()) return;\n      super.disconnectedCallback();\n      this.observer?.disconnect();\n    }\n\n    private dragenterHandler(ev: DragEvent): void {\n      ev.preventDefault();\n    }\n\n    private dragoverHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.activateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'move';\n      return false;\n    }\n\n    private activateDroppable(droppable: HTMLElement): void {\n      droppable.setAttribute('active', '');\n    }\n\n    private async dropHandler(ev: DragEvent): Promise<boolean> {\n      ev.preventDefault();\n      const droppable = ev.currentTarget as HTMLElement;\n      const identifier = ev.dataTransfer.getData('text');\n      const draggable = this.findDraggable(identifier);\n      // console.log(this.isValidDrop(droppable, draggable));\n\n      if (!draggable) return false;\n      if (draggable && !this.isValidDrop(droppable, draggable)) {\n        draggable.style.transform = 'translate(0, 0)';\n        return false;\n      }\n\n      await this.moveDraggableToDroppable(draggable, droppable);\n      this.deactivateDroppable(droppable);\n      return false;\n    }\n\n    private findDraggable(identifier: string): HTMLElement | null {\n      if (!identifier) return null;\n      return (\n        this.querySelector(`[identifier=${identifier}]`) || this.shadowRoot.querySelector(`[identifier=${identifier}]`)\n      );\n    }\n\n    private isValidDrop(droppable: HTMLElement, draggable: HTMLElement): boolean {\n      return draggable.parentElement.getAttribute('identifier') !== droppable.getAttribute('identifier');\n    }\n\n    private async moveDraggableToDroppable(draggable: HTMLElement, droppable: HTMLElement): Promise<void> {\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n        this['checkMaxAssociations']();\n\n        this['saveResponse']();\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n        return;\n      }\n\n      const transition = document.startViewTransition(moveElement);\n      await transition.finished;\n\n      // this['checkMaxAssociations']();\n    }\n\n    private deactivateDroppable(droppable: HTMLElement): void {\n      droppable.removeAttribute('active');\n    }\n\n    private dragleaveHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.deactivateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'none';\n      return false;\n    }\n  }\n  return DroppablesElement as Constructor<DroppablesInterface> & T;\n};\n", "// THIS IS A MIXIN, THIS IS A MIXIN\n// USE LIKE THIS\n// ```class DropList extends Flippables(LitElement) {```\n// mixin which animates children with FLIP\n// a combination between this directive:\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\n// and a tutorial how to make a mixin\n// https://lit.dev/docs/composition/mixins/\n\nimport { LitElement } from 'lit';\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 { TouchDragAndDrop } from './drag-drop-api';\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  useShadowRootForDroppables: boolean,\n  droppablesSelector: string\n) => {\n  class DragDropInteractionElement extends FlippablesMixin(\n    DroppablesMixin(superClass, useShadowRootForDroppables, droppablesSelector),\n    droppablesSelector,\n    draggablesSelector\n  ) {\n    protected draggables = new Map<HTMLElement, { parent: HTMLElement; index: number }>();\n    protected droppables: HTMLElement[] = [];\n    dragDropApi: TouchDragAndDrop;\n\n    @property({ type: String, attribute: 'response-identifier' }) responseIdentifier = '';\n\n    @property({ attribute: false, type: Object }) configuration: InteractionConfiguration = {\n      copyStylesDragClone: true,\n      dragCanBePlacedBack: true,\n      dragOnClick: false\n    };\n\n    @property({ type: Boolean, reflect: true }) disabled = false;\n    @property({ type: Boolean, reflect: true }) readonly = false;\n    @property({ type: Number, reflect: true, attribute: 'min-associations' }) minAssociations = 1;\n    @property({ type: Number, reflect: true, attribute: 'max-associations' }) maxAssociations = 1;\n\n    @liveQuery(draggablesSelector)\n    handleDraggablesChange(dragsAdded: HTMLElement[], dragsRemoved: Element[]) {\n      if (this.isMatchTabular()) return;\n      const newDraggables = this.filterExistingDraggables(dragsAdded);\n\n      if (newDraggables.length > 0) {\n        this.addNewDraggables(newDraggables);\n      }\n    }\n\n    override firstUpdated(changedProps): void {\n      super.firstUpdated(changedProps);\n      this.initializeDroppables();\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.initializeDragDropApi();\n    }\n\n    private initializeDragDropApi() {\n      this.dragDropApi = new TouchDragAndDrop();\n      this.dispatchEvent(\n        new CustomEvent<DragDropInteractionElement>('qti-register-interaction', {\n          bubbles: true,\n          composed: true,\n          detail: this\n        })\n      );\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private filterExistingDraggables(draggables: HTMLElement[]): HTMLElement[] {\n      return draggables.filter(d => !this.draggables.has(d));\n    }\n\n    private addNewDraggables(draggables: HTMLElement[]): void {\n      this.dragDropApi.addDraggableElements(draggables);\n      draggables.forEach(draggable => this.storeDraggable(draggable));\n    }\n\n    private storeDraggable(draggable: HTMLElement): void {\n      const index = Array.from(draggable.parentNode.children).indexOf(draggable);\n      this.draggables.set(draggable, {\n        parent: draggable.parentElement,\n        index\n      });\n      draggable.style.viewTransitionName = `drag-${index}-${this.getAttribute('identifier') || crypto.randomUUID()}`;\n      draggable.setAttribute('qti-draggable', 'true');\n      draggable.addEventListener('dragstart', this.handleDragStart);\n      draggable.addEventListener('dragend', this.handleDragEnd);\n    }\n\n    private initializeDroppables(): void {\n      this.droppables = Array.from(\n        useShadowRootForDroppables\n          ? this.shadowRoot.querySelectorAll(droppablesSelector)\n          : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private handleDragStart = (ev: DragEvent) => {\n      const target = ev.currentTarget as HTMLElement;\n      ev.dataTransfer.setData('text', target.getAttribute('identifier'));\n      target.setAttribute('dragging', '');\n      this.activateDroppables();\n    };\n\n    private handleDragEnd = async (ev: DragEvent) => {\n      ev.preventDefault();\n      this.deactivateDroppables();\n      const draggable = ev.currentTarget as HTMLElement;\n      draggable.removeAttribute('dragging');\n      const wasDropped = await this.wasDropped(ev);\n      if (!wasDropped) {\n        if (this.configuration.dragCanBePlacedBack) {\n          this.restoreInitialDraggablePosition(draggable);\n        }\n      }\n    };\n\n    private activateDroppables(): void {\n      this.droppables.forEach(d => d.setAttribute('enabled', ''));\n    }\n\n    private deactivateDroppables(): void {\n      this.droppables.forEach(d => d.removeAttribute('enabled'));\n    }\n\n    // MH: This method is just to make sure this can be tested.\n    // because I can't get the dropEffect to be 'move' in the test\n    private checkForMoveTestItem = (ev: DragEvent): Promise<boolean> => {\n      if (!ev.dataTransfer.items) {\n        return Promise.resolve(false);\n      }\n      return new Promise(resolve => {\n        let hasMoveTestItem = false;\n\n        // Iterate over all dataTransfer items\n        const items = Array.from(ev.dataTransfer.items);\n        const pending = items.length;\n\n        // If there are no items, resolve immediately\n        if (pending === 0) {\n          resolve(false);\n          return;\n        }\n\n        items.forEach(item => {\n          if (item.kind === 'string' && item.type === 'text') {\n            item.getAsString(data => {\n              if (data === 'move-test') {\n                hasMoveTestItem = true;\n              }\n\n              // Resolve the promise after processing all items\n              if (pending === 0) {\n                resolve(hasMoveTestItem);\n              }\n            });\n          } else {\n            // If the item is not 'string', still count down pending\n            if (pending === 0) {\n              resolve(hasMoveTestItem);\n            }\n          }\n        });\n      });\n    };\n\n    private async wasDropped(ev: DragEvent): Promise<boolean> {\n      const hasMoveTestItem = await this.checkForMoveTestItem(ev);\n      return ev.dataTransfer.dropEffect !== 'none' || hasMoveTestItem;\n    }\n\n    private wasMoved(ev: DragEvent): boolean {\n      return ev.dataTransfer.dropEffect === 'move';\n    }\n\n    private async restoreInitialDraggablePosition(draggable: HTMLElement): Promise<void> {\n      const { parent, index } = this.draggables.get(draggable);\n      const targetIndex = Math.min(index, parent.children.length);\n\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n        draggable.style.transform = 'translate(0, 0)';\n        this.checkMaxAssociations();\n      };\n\n      // Fallback if view transitions are not supported\n      if (!document.startViewTransition) {\n        moveDraggable(draggable, parent, index);\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        draggable.style.transform = '';\n        moveDraggable(draggable, parent, index);\n      });\n      // transition.finished.then(() => {\n      //   draggable.style.transition = '';\n      // });\n    }\n\n    protected checkMaxAssociations(): void {\n      this.droppables.forEach((d, index) => {\n        const maxMatch = +(d.getAttribute('match-max') || 1);\n        const currentAssociations = d.querySelectorAll('[qti-draggable=\"true\"]').length;\n        const disableDroppable = currentAssociations >= maxMatch;\n        disableDroppable ? this.disableDroppable(d) : this.enableDroppable(d);\n      });\n    }\n\n    private disableDroppable(droppable: Element): void {\n      droppable.setAttribute('disabled', '');\n      droppable.removeAttribute('dropzone');\n    }\n\n    private enableDroppable(droppable: Element): void {\n      droppable.removeAttribute('disabled');\n      droppable.setAttribute('dropzone', 'move');\n    }\n\n    get response(): string[] {\n      return this.collectResponseData();\n    }\n\n    set response(response: string[]) {\n      if (this.isMatchTabular()) return;\n\n      this.resetDroppables();\n      response?.forEach(entry => this.placeResponse(entry));\n    }\n\n    private placeResponse(response: string): void {\n      const [dropId, ...dragIds] = response.split(' ').reverse();\n      const droppable = this.findDroppableById(dropId);\n      dragIds.forEach(dragId => this.placeDraggableInDroppable(dragId, droppable));\n    }\n\n    private findDroppableById(identifier: string): Element | undefined {\n      return this.droppables.find(drop => drop.getAttribute('identifier') === identifier);\n    }\n\n    private async placeDraggableInDroppable(dragId: string, droppable: Element): Promise<void> {\n      const draggable = this.querySelector<HTMLElement>(`[identifier=${dragId}]`);\n      if (!droppable || !draggable) {\n        console.error(`Cannot find draggable or droppable with the given identifier: ${dragId}`);\n        return;\n      }\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n        this.checkMaxAssociations();\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n      } else {\n        const transition = document.startViewTransition(moveElement);\n        await transition.finished;\n      }\n    }\n\n    validate(): boolean {\n      const validAssociations = this.getValidAssociations();\n      return this.minAssociations <= 0 || this.minAssociations <= validAssociations;\n    }\n\n    private getValidAssociations(): number {\n      return this.droppables.filter(d => d.childElementCount > 0).length;\n    }\n\n    protected saveResponse(): void {\n      const response = this.collectResponseData();\n      this.dispatchEvent(\n        new CustomEvent('qti-interaction-response', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            responseIdentifier: this.responseIdentifier,\n            response\n          }\n        })\n      );\n    }\n\n    private collectResponseData(): string[] {\n      const response = this.droppables\n        .map(droppable => {\n          const draggablesInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n          const identifiers = Array.from(draggablesInDroppable).map(d => d.getAttribute('identifier'));\n          const droppableIdentifier = droppable.getAttribute('identifier');\n          return identifiers.map(id => `${id} ${droppableIdentifier}`);\n        })\n        .flat();\n      return response;\n    }\n\n    reset(save = true): void {\n      this.resetDroppables();\n      if (save) this.saveResponse();\n    }\n\n    private async resetDroppables(): Promise<void> {\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        draggable.style.transform = 'translate(0, 0)';\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n      };\n\n      if (!document.startViewTransition) {\n        // Fallback if view transitions are not supported\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n      });\n\n      await transition.finished;\n    }\n  }\n\n  return DragDropInteractionElement as Constructor<IInteraction> & T;\n};\n``;\n", "// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n//  @watch('propName')\n//  handlePropChange(oldValue, newValue) {\n//    ...\n//  }\n\nimport type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\n\ntype NonUndefined<A> = A extends undefined ? never : A;\n\ntype UpdateHandlerFunctionKeys<T extends object> = {\n  [K in keyof T]-?: NonUndefined<T[K]> extends UpdateHandler ? K : never;\n}[keyof T];\n\ninterface LiveQueryOptions {\n  /**\n   * If true, will only start watching after the initial update/render\n   */\n}\n\nexport function liveQuery(querySelector: string, options?: LiveQueryOptions) {\n  let observer: MutationObserver;\n  const resolvedOptions: Required<LiveQueryOptions> = {\n    ...options\n  };\n  return <ElemClass extends LitElement>(\n    proto: ElemClass,\n    decoratedFnName: UpdateHandlerFunctionKeys<ElemClass>\n  ): void => {\n    const { connectedCallback, disconnectedCallback } = proto;\n\n    proto.connectedCallback = function (this: ElemClass) {\n      connectedCallback.call(this);\n      const callback = (mutationList: MutationRecord[]) => {\n        const elementsToWatch = Array.from(this.querySelectorAll(querySelector));\n        for (const mutation of mutationList) {\n          const addedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          const removedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          if (mutation.type === 'childList' && addedNodes.find(n => elementsToWatch.includes(n))) {\n            (this[decoratedFnName] as unknown as UpdateHandler)(addedNodes, removedNodes);\n          }\n        }\n      };\n      observer = new MutationObserver(callback);\n      observer.observe(this, { childList: true, subtree: true });\n\n      const elementsAdded = this.querySelectorAll(querySelector) ?? [];\n      (this[decoratedFnName] as unknown as UpdateHandler)(Array.from(elementsAdded), []);\n    };\n\n    proto.disconnectedCallback = function (this: ElemClass) {\n      disconnectedCallback.call(this);\n      observer.disconnect();\n    };\n  };\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: block; /* necessary to calculate scaling position */\n  }\n  slot[name='qti-simple-associable-choice'] {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 0.5rem;\n  }\n\n  :host::part(associables-container) {\n    display: flex;\n    justify-content: space-between;\n    background: linear-gradient(\n      180deg,\n      rgb(0 0 0 / 0%) calc(50% - 1px),\n      var(--qti-border-color-gray) calc(50%),\n      rgb(0 0 0 / 0%) calc(50% + 1px)\n    );\n  }\n`;\n", "import { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { removeDoubleSlashes } from '../../internal/utils';\n\n@customElement('qti-custom-interaction')\nexport class QtiCustomInteraction extends Interaction {\n  // This custom-interaction support the CES API which is use in FACET\n  //\n  // It works like this:\n  // 1. The CI manifest is fetched\n  // 2. An iframe is created and the first style and first script from the manifest are loaded\n  // 3. The first script is bootstrap.js which also creates an iframe and loads the first media from the manifest\n  // 4. Communication is done via the CES API but because the iframe is not allowed to access the global CES object we need to use window.postMessage\n\n  // To achieve this we change the package by replacing the bootstrap.js with our own and inject a proxy CES API that communicates via postMessage\n  // Because we also want to run this in storybook, we cannot use window.top because to send messages there, because in case of storybook that is not the top window.\n  // So we send messages to all parent windows\n  private rawResponse: string;\n\n  constructor() {\n    super();\n    this.handlePostMessage = this.handlePostMessage.bind(this);\n  }\n\n  @property({ type: String, attribute: '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 name=\"prompt\"> </slot><slot part=\"drags\" name=\"qti-gap-text\"></slot> <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 name=\"prompt\"></slot>\n      <slot></slot>\n      <slot name=\"qti-gap-img\"></slot>`;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<null>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    // positionHotspots(shape, coordsNumber, img, hotspot);\n    switch (shape) {\n      case 'circle':\n        {\n          const [centerX, centerY, radius] = coordsNumber;\n          hotspot.style.left = centerX - radius + 'px';\n          hotspot.style.top = centerY - radius + 'px';\n          hotspot.style.width = hotspot.style.height = 2 * radius + 'px';\n        }\n        break;\n\n      case 'rect':\n        {\n          const [leftX, topY, rightX, bottomY] = coordsNumber;\n          hotspot.style.left = leftX + 'px';\n          hotspot.style.top = topY + 'px';\n          hotspot.style.width = rightX - leftX + 'px';\n          hotspot.style.height = bottomY - topY + 'px';\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-gap-match-interaction': QtiGraphicGapMatchInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\nimport { customElement } from 'lit/decorators.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\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('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.addEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.removeEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-order-interaction': QtiGraphicOrderInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\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('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-interaction': QtiHotspotInteraction;\n  }\n}\n", "import { CSSResultGroup, html, LitElement } from 'lit';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { ResponseInteraction } from '../../internal/expression-result';\n// import { TouchDragAndDrop } from '../internal/drag-drop';\nimport '../qti-simple-associable-choice';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-match-interaction.styles';\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 styles: CSSResultGroup = styles;\n\n  rows: QtiSimpleAssociableChoice[];\n  cols: QtiSimpleAssociableChoice[];\n  lastCheckedRadio: HTMLInputElement | null = null;\n\n  @state() _response: string | string[] = [];\n  // dragDropApi: TouchDragAndDrop;\n  get response(): string[] {\n    if (!this.classList.contains('qti-match-tabular')) return super.response as string[];\n    else return this._response as string[];\n  }\n  set response(val: string[]) {\n    if (!this.classList.contains('qti-match-tabular')) super.response = val;\n    else this._response = val;\n  }\n  @state() correctOptions: string[] = [];\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n  async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n    // await this.updateComplete;\n    // this.dragDropApi = new TouchDragAndDrop();\n    // this.dragDropApi.addDraggableElements(\n    //   this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    // );\n    // this.dragDropApi.addDroppableElements(\n    //   this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    // );\n    this.rows = Array.from<QtiSimpleAssociableChoice>(\n      // 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></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';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/* \nqti-match-interaction\nqti-associate-interaction\n*/\n@customElement('qti-simple-associable-choice')\n// tslint:disable: indent\nexport class QtiSimpleAssociableChoice extends ActiveElementMixin(LitElement, 'qti-simple-associable-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: block;\n    }\n    slot[name='qti-simple-associable-choice'] {\n      width: 100%;\n    }\n  `;\n\n  /** the minimal number of selections a candidate must make */\n  @property({\n    type: Number,\n    attribute: 'match-min'\n  })\n  public matchMin: number = 0;\n\n  /** the maximum number of selections a candidate must make, the other options will be disabled when max options is checked */\n  @property({\n    type: Number,\n    attribute: 'match-max'\n  })\n  public matchMax: number = 1;\n\n  @property({\n    type: Boolean,\n    attribute: 'fixed'\n  })\n  public fixed = false;\n\n  // pk: This needs some explanation\n  // in the associate interaction there is a special slot for these qti-simple-associable-choices\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-simple-associable-choice');\n    this.setAttribute('part', 'qti-simple-associable-choice');\n  }\n\n  // pk: This needs some explanation\n  // in qti-match-interaction, qti-simple-associable-choice is used to denote the\n  // draggable, but also the droppable. WEIRD.. but lets deal with it.\n  // So we have a slot for whenever another qti-simple-associable-choice is dropped in here.\n  // And we have slot for content like in this associate interaction\n  override render() {\n    return html`\n      <slot part=\"slot\"></slot>\n      <slot part=\"dropslot\" name=\"qti-simple-associable-choice\"></slot>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-associable-choice': QtiSimpleAssociableChoice;\n  }\n}\n", "import { css } from 'lit';\n// import componentStyles from '../../utilities/styles/component.styles';\n\n/* ${componentStyles} */\nexport default css`\n  slot {\n    /* slot where the */\n    display: flex;\n    flex-direction: column;\n    gap: 0.5rem;\n    align-items: flex-start; /* prevents the drag and drop container slots having the same height */\n  }\n  :host(.qti-choices-top) slot {\n    flex-direction: column;\n  }\n  :host(.qti-choices-bottom) slot {\n    flex-direction: column-reverse;\n  }\n  :host(.qti-choices-left) slot {\n    flex-direction: row;\n  }\n  :host(.qti-choices-right) slot {\n    flex-direction: row-reverse;\n  }\n  slot[name='prompt'] {\n    display: block;\n  }\n  ::slotted(qti-simple-match-set) {\n    /* Make sure the drag and drop container slots have the same width */\n    flex: 1;\n  }\n`;\n", "import { css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-media-interaction')\nexport class QtiMediaInteraction extends Interaction {\n  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    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';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-gap-text')\nexport class QtiGapText extends ActiveElementMixin(LitElement, 'qti-gap-text') {\n  static styles = css`\n    :host {\n      display: inline-flex;\n      user-select: none;\n    }\n  `;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-gap-text');\n  }\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-text': QtiGapText;\n  }\n}\n", "import { css, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n// type shape = { shape: 'rect' | 'circle' | 'poly'; coords: number[] };\n\n@customElement('qti-hotspot-choice')\nexport class QtiHotspotChoice extends ActiveElementMixin(LitElement, 'qti-hotspot-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n      position: absolute;\n    }\n  `;\n  @property({ attribute: 'aria-ordervalue', type: Number, reflect: true }) order: number;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-choice': QtiHotspotChoice;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-hottext')\nexport class QtiHottext extends ActiveElementMixin(LitElement, 'qti-hottext') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n  `;\n\n  override render() {\n    return html`<div part=\"ch\"><div part=\"cha\"></div></div>\n      <slot></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hottext': QtiHottext;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('qti-inline-choice')\nexport class QtiInlineChoice extends LitElement {\n  static override get styles() {\n    return [\n      css`\n        :host {\n          display: block;\n          cursor: pointer;\n        }\n      `\n    ];\n  }\n\n  @property({ type: String })\n  identifier: string;\n\n  override connectedCallback() {\n    super.connectedCallback();\n\n    this.addEventListener('click', this._onSelectInlineChoice);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-inline-choice-register', {\n        bubbles: true,\n        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, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/**\n * qti-order-interaction\n * qti-choice-interaction\n */\n@customElement('qti-simple-choice')\nexport class QtiSimpleChoice extends ActiveElementMixin(LitElement, 'qti-simple-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      align-items: center;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: flex;\n      align-items: center;\n    }\n    [part='ch'] {\n      display: flex;\n      flex-shrink: 0;\n      align-items: center;\n      justify-content: center;\n    }\n  `;\n\n  // property label\n  @property({ type: String, attribute: false })\n  public marker: string;\n\n  override render() {\n    return html`<div part=\"ch\">\n        <div part=\"cha\"></div>\n      </div>\n      ${this.marker ? html`<div id=\"label\">${this.marker}</div>` : nothing}\n      <slot part=\"slot\"></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-choice': QtiSimpleChoice;\n  }\n}\n", "/* only exported to override or extend for specific purposes */\nexport * from './internal/event-types';\nexport * from './internal/events';\nexport * from './internal/expression-result';\nexport * from './internal/variables';\n/* only exported to override or extend for specific purposes */\nexport * from './qti-assessment-item/qti-assessment-item';\nexport * from './qti-assessment-stimulus-ref/qti-assessment-stimulus-ref';\nexport * from './qti-interaction/internal/active-element/active-element.mixin';\nexport * from './qti-item-body/qti-item-body';\nexport * from './qti-prompt/qti-prompt';\nexport * from './qti-stylesheet/qti-stylesheet';\n/* start response and outcome */\nexport * from './qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration';\nexport * from './qti-variable-declaration/qti-response-declaration/qti-response-declaration';\n/* end response and outcome */\nexport * from './qti-companion-materials-info/qti-companion-materials-info';\nexport * from './qti-rubric-block/qti-content-body';\nexport * from './qti-rubric-block/qti-rubric-block';\n/* start feedback */\nexport * from './qti-feedback/qti-feedback-block/qti-feedback-block';\nexport * from './qti-feedback/qti-feedback-inline/qti-feedback-inline';\nexport * from './qti-feedback/qti-modal-feedback/qti-modal-feedback';\n/* end feedback */\n/* start textentryinteraction */\nexport * from './qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction';\nexport * from './qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction';\n/* end textentryinteraction */\n/* start hottext */\nexport * from './qti-interaction/qti-hottext-interaction/qti-hottext-interaction';\n/* end hottext */\n/* start inlinechoice */\nexport * from './qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction';\n/* end inlinechoice */\n/* start choiceinteraction */\nexport * from './qti-interaction/qti-choice-interaction/qti-choice-interaction';\n/* end choiceinteraction */\nexport * from './qti-outcome-processing/qti-outcome-processing';\nexport * from './qti-response-processing';\n/* start custom interactions */\nexport * from './qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction';\n/* end custom interactions */\n/* start only preview items */\nexport * from './qti-interaction/qti-associate-interaction/qti-associate-interaction';\nexport * from './qti-interaction/qti-custom-interaction/qti-custom-interaction';\nexport * from './qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction';\nexport * from './qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction';\nexport * from './qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction';\nexport * from './qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction';\nexport * from './qti-interaction/qti-match-interaction/qti-match-interaction';\nexport * from './qti-interaction/qti-media-interaction/qti-media-interaction';\nexport * from './qti-interaction/qti-order-interaction/qti-order-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-stage';\nexport * from './qti-interaction/qti-select-point-interaction/qti-select-point-interaction';\nexport * from './qti-interaction/qti-slider-interaction/qti-slider-interaction';\n/* end only preview items */\nexport * from './qti-assessment-item/qti-assessment-item.context';\nexport * from './qti-custom-operator/qti-custom-operator';\nexport * from './qti-interaction/internal/interaction/interaction';\nexport * from './qti-interaction/qti-associable-hotspot';\nexport * from './qti-interaction/qti-gap';\nexport * from './qti-interaction/qti-gap-img';\nexport * from './qti-interaction/qti-gap-text';\nexport * from './qti-interaction/qti-hotspot-choice';\nexport * from './qti-interaction/qti-hottext';\nexport * from './qti-interaction/qti-inline-choice';\nexport * from './qti-interaction/qti-simple-associable-choice';\nexport * from './qti-interaction/qti-simple-choice';\n\nconsole.log(\n  '%cC\u00BFTO%cLab%c: qti-components loaded',\n  'font-weight:bold; color:green',\n  'font-family: \"PT Sans\", font-weight:bold; color:green; font-size: smaller;vertical-align: sub',\n  'font-weight:unset'\n);\n\n// css for font pt-sans and subscript and green\n"],
  "mappings": "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",
  "names": ["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", "path", "stimulus", "qtiTransformItem", "api", "elements", "__decorateClass", "property", "customElement", "html", "property", "ariaBooleanConverter", "value", "ActiveElementMixin", "Base", "type", "QtiChoice", "args", "_oldValue", "disabled", "key", "event", "html", "__decorateClass", "property", "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", "customElement", "property", "state", "QtiExtendedTextInteraction", "Interaction", "old", "classes", "className", "nrRows", "value", "css", "html", "event", "input", "ifDefined", "text", "__decorateClass", "state", "property", "watch", "customElement", "html", "customElement", "property", "state", "ifDefined", "createRef", "css", "qti_text_entry_interaction_styles_default", "QtiTextEntryInteraction", "Interaction", "createRef", "value", "html", "event", "input", "ifDefined", "text", "qti_text_entry_interaction_styles_default", "__decorateClass", "property", "state", "customElement", "html", "LitElement", "customElement", "property", "ChoicesMixin", "superClass", "selector", "ChoicesMixinElement", "_", "disabled", "ch", "readonly", "choice", "_oldValue", "_newValue", "selectedCount", "responseValue", "responseArray", "event", "choiceElement", "checked", "selectedChoices", "selectedIdentifiers", "disableUnselected", "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", "originalOrder", "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", "QtiPrintedVariable", "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", "html", "customElement", "state", "TouchDragAndDrop", "_TouchDragAndDrop", "type", "val", "draggables", "el", "e", "x", "y", "computedStyle", "rect", "currentTouch", "computedStyles", "style", "deltaX", "deltaY", "dropTarget", "_a", "dropFound", "dragEndEvent", "event", "root", "depth", "element", "currentElement", "shadowElement", "nextDropZone", "page", "touch", "newLeft", "newTop", "boundedLeft", "boundedTop", "boundaryRect", "elementRect", "elementWidth", "elementHeight", "boundedDeltaX", "boundedDeltaY", "xDist", "yDist", "eventType", "bubble", "property", "DroppablesMixin", "superClass", "useShadowRoot", "droppablesSelector", "DroppablesElement", "changedProps", "droppables", "droppable", "mutations", "attributeName", "_a", "ev", "identifier", "draggable", "moveElement", "__decorateClass", "property", "FlippablesMixin", "superClass", "droppablesSel", "draggablesSel", "FlippablesElement", "property", "liveQuery", "querySelector", "options", "observer", "resolvedOptions", "__spreadValues", "proto", "decoratedFnName", "connectedCallback", "disconnectedCallback", "_a", "callback", "mutationList", "elementsToWatch", "mutation", "addedNodes", "e", "removedNodes", "n", "elementsAdded", "DragDropInteractionMixin", "superClass", "draggablesSelector", "useShadowRootForDroppables", "droppablesSelector", "DragDropInteractionElement", "FlippablesMixin", "DroppablesMixin", "ev", "target", "draggable", "resolve", "hasMoveTestItem", "items", "pending", "item", "data", "dragsAdded", "dragsRemoved", "newDraggables", "changedProps", "TouchDragAndDrop", "draggables", "d", "index", "parent", "targetIndex", "moveDraggable", "transition", "maxMatch", "droppable", "response", "entry", "dropId", "dragIds", "dragId", "identifier", "drop", "moveElement", "validAssociations", "draggablesInDroppable", "identifiers", "droppableIdentifier", "id", "save", "__decorateClass", "property", "liveQuery", "css", "qti_associate_interaction_styles_default", "QtiAssociateInteraction", "DragDropInteractionMixin", "LitElement", "event", "choice", "html", "_", "index", "qti_associate_interaction_styles_default", "__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", "html", "LitElement", "customElement", "property", "state", "unsafeHTML", "css", "html", "LitElement", "customElement", "property", "QtiSimpleAssociableChoice", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "qti_match_interaction_styles_default", "QtiMatchInteraction", "DragDropInteractionMixin", "LitElement", "radio", "checkbox", "value", "name", "type", "v", "val", "responseValue", "html", "col", "i", "unsafeHTML", "row", "rIndex", "cIndex", "rowId", "colId", "selectedInRowCount", "checked", "part", "disable", "e", "qti_match_interaction_styles_default", "__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", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "LitElement", "customElement", "property", "QtiHotspotChoice", "ActiveElementMixin", "LitElement", "css", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "customElement", "QtiHottext", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "QtiInlineChoice", "LitElement", "css", "html", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "nothing", "customElement", "property", "QtiSimpleChoice", "ActiveElementMixin", "LitElement", "html", "nothing", "css", "__decorateClass", "property", "customElement"]
}

701
+ `,a([tn({type:String,attribute:!1})],oe.prototype,"marker",2),oe=a([en("qti-simple-choice")],oe);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{_ as ActiveElementMixin,u as Interaction,Fe as QtiAnd,q as QtiAssessmentItem,W as QtiAssessmentStimulusRef,ke as QtiAssociableHotspot,G as QtiAssociateInteraction,Be as QtiBaseValue,Z as QtiChoiceInteraction,Ve as QtiCompanionMaterialsInfo,S as QtiConditionExpression,ot as QtiContains,He as QtiContentBody,nt as QtiCorrect,H as QtiCustomInteraction,Se as QtiCustomOperator,Q as QtiEndAttemptInteraction,Ye as QtiEqual,Xe as QtiEqualRounded,h as QtiExpression,T as QtiExtendedTextInteraction,ce as QtiFeedbackBlock,pe as QtiFeedbackInline,te as QtiGap,re as QtiGapImg,ve as QtiGapMatchInteraction,ie as QtiGapText,N as QtiGraphicAssociateInteraction,ye as QtiGraphicGapMatchInteraction,xe as QtiGraphicOrderInteraction,at as QtiGt,lt as QtiGte,se as QtiHotspotChoice,Ee as QtiHotspotInteraction,Me as QtiHottext,Pe as QtiHottextInteraction,_e as QtiInlineChoice,F as QtiInlineChoiceInteraction,ct as QtiIsNull,ne as QtiItemBody,Ue as QtiLookupOutcomeValue,pt as QtiLt,dt as QtiLte,je as QtiMapResponse,J as QtiMapping,mt as QtiMatch,Y as QtiMatchInteraction,qe as QtiMediaInteraction,ht as QtiMember,de as QtiModalFeedback,ft as QtiMultiple,gt as QtiNot,bt as QtiOr,P as QtiOrderInteraction,vt as QtiOrdered,R as QtiOutcomeDeclaration,me as QtiOutcomeProcessing,et as QtiOutcomeProcessingProcessor,B as QtiPortableCustomInteraction,we as QtiPositionObjectStage,ge as QtiPrintedVariable,yt as QtiProduct,Le as QtiPrompt,tt as QtiResponseCondition,I as QtiResponseDeclaration,he as QtiResponseElse,st as QtiResponseElseIf,fe as QtiResponseIf,z as QtiResponseProcessing,L as QtiRubricBlock,D as QtiRule,We as QtiSPositionObjectInteraction,j as QtiSelectPointInteraction,rt as QtiSetOutcomeValue,it as QtiSetOutcomeValueRule,X as QtiSimpleAssociableChoice,oe as QtiSimpleChoice,E as QtiSliderInteraction,ze as QtiStringMatch,Ae as QtiStylesheet,xt as QtiSum,Et as QtiSumExpression,A as QtiTextEntryInteraction,Ct as QtiVariable,M as itemContext,Lt as itemContextVariables,Qi as qtiAndMixin};
702
+ //# 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/active-element/active-element.mixin.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.ts", "../../src/lib/qti-components/qti-item-body/qti-item-body.styles.ts", "../../src/lib/qti-components/qti-prompt/qti-prompt.ts", "../../src/lib/qti-components/qti-stylesheet/qti-stylesheet.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-variable-declaration.ts", "../../src/lib/qti-components/qti-variable-declaration/qti-response-declaration/qti-response-declaration.ts", "../../src/lib/qti-components/qti-companion-materials-info/qti-companion-materials-info.ts", "../../src/lib/qti-components/qti-rubric-block/qti-content-body.ts", "../../src/lib/qti-components/qti-rubric-block/qti-rubric-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-block/qti-feedback-block.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback.ts", "../../src/lib/qti-components/internal/utils.ts", "../../src/lib/qti-components/qti-feedback/qti-feedback-inline/qti-feedback-inline.ts", "../../src/lib/qti-components/qti-feedback/qti-modal-feedback/qti-modal-feedback.ts", "../../src/lib/qti-components/qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/interaction/interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext-interaction/qti-hottext-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/choices/choices.mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/shuffle/shuffle-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/vocabulary/vocabulary-mixin.ts", "../../src/lib/qti-components/qti-interaction/qti-choice-interaction/qti-choice-interaction.styles.ts", "../../src/lib/qti-components/qti-outcome-processing/qti-outcome-processing.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-processing/qti-response-processing.ts", "../../src/lib/qti-components/internal/template-strings.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-lookup-outcome-value/qti-lookup-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-rule.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-response-condition/qti-response-condition.ts", "../../src/lib/qti-components/qti-response-processing/qti-rule/qti-set-outcome-value/qti-set-outcome-value.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-else.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-else-if/qti-response-else-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-response-else/qti-response-if/qti-response-if.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-condition-expression.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/qti-and.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-and/index.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-basevalue/qti-basevalue.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-contains/qti-contains.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-correct/qti-correct.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal-rounded/qti-equal-rounded.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-equal/qti-equal.ts", "../../src/lib/qti-components/qti-response-processing/utilities/scoring-helper.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gt/qti-gt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-gte/qti-gte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-is-null/qti-is-null.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lt/qti-lt.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-lte/qti-lte.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-map-response/qti-map-response.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-mapping/qti-mapping.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-match/qti-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-member/qti-member.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-multiple/qti-multiple.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-not/qti-not.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-or/qti-or.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-ordered/qti-ordered.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-printed-variable/qti-printed-variable.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-product/qti-product.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-string-match/qti-string-match.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-sum/qti-sum.ts", "../../src/lib/qti-components/qti-response-processing/qti-expression/qti-variable/qti-variable.ts", "../../src/lib/qti-components/qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-api.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/droppables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/flippables-mixin.ts", "../../src/lib/qti-components/qti-interaction/internal/drag-drop/drag-drop-interaction-mixin.ts", "../../src/lib/decorators/live-query.ts", "../../src/lib/qti-components/qti-interaction/qti-associate-interaction/qti-associate-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-custom-interaction/qti-custom-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction.ts", "../../src/lib/qti-components/qti-interaction/internal/hotspots/hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-associable-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-match-interaction/qti-match-interaction.styles.ts", "../../src/lib/qti-components/qti-interaction/qti-media-interaction/qti-media-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-order-interaction/qti-order-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-position-object-interaction/qti-position-object-stage.ts", "../../src/lib/qti-components/qti-interaction/qti-select-point-interaction/qti-select-point-interaction.ts", "../../src/lib/qti-components/qti-interaction/qti-slider-interaction/qti-slider-interaction.ts", "../../src/lib/qti-components/qti-custom-operator/qti-custom-operator.ts", "../../src/lib/qti-components/qti-interaction/qti-associable-hotspot.ts", "../../src/lib/qti-components/qti-interaction/qti-gap.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-img.ts", "../../src/lib/qti-components/qti-interaction/qti-gap-text.ts", "../../src/lib/qti-components/qti-interaction/qti-hotspot-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-hottext.ts", "../../src/lib/qti-components/qti-interaction/qti-inline-choice.ts", "../../src/lib/qti-components/qti-interaction/qti-simple-choice.ts", "../../src/lib/qti-components/index.ts"],
  "sourcesContent": ["import { provide } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\nimport type { InteractionChangedDetails, OutcomeChangedDetails } from '../internal/event-types';\nimport type { ResponseInteraction } from '../internal/expression-result';\nimport type { VariableDeclaration, VariableValue } from '../internal/variables';\nimport { OutcomeVariable, ResponseVariable } from '../internal/variables';\nimport type { QtiFeedback } from '../qti-feedback/qti-feedback';\nimport type { Interaction } from '../qti-interaction/internal/interaction/interaction';\nimport type { QtiResponseProcessing } from '../qti-response-processing';\nimport { ItemContext, itemContext, itemContextVariables } from './qti-assessment-item.context';\n\n/**\n * @summary The qti-assessment-item element contains all the other QTI 3 item structures.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.dltnnj87l0yj\n * @status stable\n * @since 4.0\n *\n * @dependency qti-feedback\n * @dependency qti-responseprocessing\n *\n * @slot - The default slot where all the other QTI 3 item structures go.\n *\n * @event qti-interaction-changed - Emitted when an interaction is changed.\n * @event qti-outcome-changed - Emitted when an outcome has changed.\n * @event qti-response-processing - Emitted when response-processing is called.\n *\n */\n@customElement('qti-assessment-item')\nexport class QtiAssessmentItem extends LitElement {\n  @property({ type: String }) title: string;\n  @property({ type: String }) identifier: string = '';\n  @property({ type: String }) adaptive: 'true' | 'false' = 'false';\n  @property({ type: String }) timeDependent: 'true' | 'false' | null = null;\n\n  @property({ type: Boolean }) disabled: boolean;\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  _handleDisabledChange = (_: boolean, disabled: boolean) => {\n    this._interactionElements.forEach(ch => (ch.disabled = disabled));\n  };\n\n  @property({ type: Boolean }) readonly: boolean;\n  @watch('readonly', { waitUntilFirstUpdate: true })\n  _handleReadonlyChange = (_: boolean, readonly: boolean) =>\n    this._interactionElements.forEach(ch => (ch.readonly = readonly));\n\n  @provide({ context: itemContext })\n  private _context: ItemContext = {\n    identifier: this.getAttribute('identifier'),\n    variables: itemContextVariables\n  };\n\n  public get variables(): VariableValue<string | string[] | null>[] {\n    return this._context.variables.map(v => ({\n      identifier: v.identifier,\n      value: v.value,\n      type: v.type,\n      // add externalscored, a fixed prop to the test, so the testcontext can read and decide how to score this item\n      ...(v.type === 'outcome' && v.identifier === 'SCORE'\n        ? { externalScored: (v as OutcomeVariable).externalScored }\n        : {})\n    }));\n  }\n\n  public set variables(value: VariableValue<string | string[] | null>[]) {\n    if (!Array.isArray(value) || value.some(v => !('identifier' in v))) {\n      console.warn('variables property should be an array of VariableDeclaration');\n      return;\n    }\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(variable => {\n        const matchingValue = value.find(v => v.identifier === variable.identifier);\n        if (matchingValue) {\n          return { ...variable, ...matchingValue };\n        }\n        return variable;\n      })\n    };\n\n    this._context.variables.forEach(variable => {\n      if (variable.type === 'response') {\n        const interactionElement = this._interactionElements.find(\n          (el: Interaction) => el.responseIdentifier === variable.identifier\n        );\n        if (interactionElement) {\n          interactionElement.value = variable.value as string | string[];\n        }\n      }\n\n      if (variable.type === 'outcome') {\n        this._feedbackElements.forEach(fe => fe.checkShowFeedback(variable.identifier));\n      }\n    });\n  }\n\n  private _initialContext: Readonly<ItemContext> = { ...this._context, variables: this._context.variables };\n  private _feedbackElements: QtiFeedback[] = [];\n  private _interactionElements: Interaction[] = [];\n\n  async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n    await this.updateComplete;\n    this._emit<{ detail: QtiAssessmentItem }>('qti-assessment-item-connected', this);\n  }\n\n  /** @deprecated use variables property instead */\n  set responses(myResponses: ResponseInteraction[]) {\n    if (myResponses) {\n      for (const response of myResponses) {\n        const responseVariable = this.getResponse(response.responseIdentifier);\n        if (responseVariable) {\n          this.updateResponseVariable(response.responseIdentifier, response.response);\n        }\n\n        const interaction: Interaction | undefined = this._interactionElements.find(\n          i => i.getAttribute('response-identifier') === response.responseIdentifier\n        );\n        if (interaction) {\n          interaction.value = response.response;\n        }\n      }\n    }\n  }\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  constructor() {\n    super();\n    this.addEventListener('qti-register-variable', e => {\n      this._context = { ...this._context, variables: [...this._context.variables, e.detail.variable] };\n      this._initialContext = this._context;\n      e.stopPropagation();\n    });\n    this.addEventListener('qti-register-feedback', (e: CustomEvent<QtiFeedback>) => {\n      e.stopPropagation();\n      const feedbackElement = e.detail;\n      this._feedbackElements.push(feedbackElement);\n      feedbackElement.checkShowFeedback(feedbackElement.outcomeIdentifier);\n    });\n    this.addEventListener('qti-register-interaction', (e: CustomEvent<null>) => {\n      e.stopPropagation();\n      this._interactionElements.push(e.target as Interaction);\n    });\n    this.addEventListener('end-attempt', (e: CustomEvent<{ responseIdentifier: string; countAttempt: boolean }>) => {\n      const { responseIdentifier, countAttempt } = e.detail;\n      this.updateResponseVariable(responseIdentifier, 'true');\n      this.processResponse(countAttempt);\n    });\n\n    this.addEventListener(\n      // wordt aangeroepen vanuit de processingtemplate\n      'qti-set-outcome-value',\n      (e: CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>) => {\n        const { outcomeIdentifier, value } = e.detail;\n        this.updateOutcomeVariable(outcomeIdentifier, value);\n        e.stopPropagation();\n      }\n    );\n\n    this.addEventListener('qti-interaction-response', this.handleUpdateResponseVariable);\n  }\n\n  public showCorrectResponse(show: boolean) {\n    const responseVariables = this._context.variables.filter(\n      (vari: ResponseVariable | OutcomeVariable) => 'correctResponse' in vari && vari.correctResponse\n    ) as ResponseVariable[];\n    const responses = responseVariables.map(cr => {\n      return {\n        responseIdentifier: cr.identifier,\n        response: cr.correctResponse\n      };\n    });\n    for (const response of responses) {\n      const interaction: Interaction | undefined = this._interactionElements.find(\n        i => i.getAttribute('response-identifier') === response.responseIdentifier\n      );\n      if (interaction) {\n        interaction.correctResponse = show ? response.response : '';\n      }\n    }\n  }\n\n  public processResponse(countNumAttempts: boolean = true): boolean {\n    const responseProcessor = this.querySelector<QtiResponseProcessing>('qti-response-processing');\n    if (!responseProcessor) {\n      // console.info('Client side response processing template not available');\n      return false;\n    }\n\n    if (!responseProcessor.process) {\n      // console.info('Client side response webcomponents not available');\n      return false;\n    }\n\n    responseProcessor.process();\n\n    if (this.adaptive === 'false') {\n      // if adaptive, completionStatus is set by the processing template\n      this.updateOutcomeVariable('completionStatus', this._getCompletionStatus());\n    }\n\n    if (countNumAttempts) {\n      this.updateOutcomeVariable(\n        'numAttempts',\n        (+this._context.variables.find(v => v.identifier === 'numAttempts')?.value + 1).toString()\n      );\n    }\n\n    this._emit('qti-response-processed');\n    return true;\n  }\n\n  public resetResponses() {\n    this._context = this._initialContext;\n  }\n\n  public getResponse(identifier: string): Readonly<ResponseVariable> {\n    return this.getVariable(identifier) as ResponseVariable;\n  }\n\n  public getOutcome(identifier: string): Readonly<OutcomeVariable> {\n    return this.getVariable(identifier) as OutcomeVariable;\n  }\n\n  public getVariable(identifier: string): Readonly<VariableDeclaration<string | string[] | null>> {\n    return this._context.variables.find(v => v.identifier === identifier) || null;\n  }\n\n  // saving privates here: ------------------------------------------------------------------------------\n\n  private handleUpdateResponseVariable(event: CustomEvent<ResponseInteraction>) {\n    const { responseIdentifier, response } = event.detail;\n    this.updateResponseVariable(responseIdentifier, response);\n  }\n\n  public updateResponseVariable(identifier: string, value: string | string[] | undefined) {\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(v => (v.identifier !== identifier ? v : { ...v, value: value }))\n    };\n\n    this._emit<InteractionChangedDetails>('qti-interaction-changed', {\n      item: this.identifier,\n      responseIdentifier: identifier,\n      response: Array.isArray(value) ? [...value] : value\n    });\n\n    if (this.adaptive === 'false') {\n      // if adapative, completionStatus is set by the processing template\n      this.updateOutcomeVariable('completionStatus', this._getCompletionStatus());\n    }\n  }\n\n  public updateOutcomeVariable(identifier: string, value: string | string[] | undefined) {\n    const outcomeVariable = this.getOutcome(identifier);\n\n    if (!outcomeVariable) {\n      console.warn(`Can not set qti-outcome-identifier: ${identifier}, it is not available`);\n      return;\n    }\n\n    this._context = {\n      ...this._context,\n      variables: this._context.variables.map(v => {\n        if (v.identifier !== identifier) {\n          return v;\n        }\n        return {\n          ...v,\n          value: outcomeVariable.cardinality === 'single' ? value : [...v.value, value as string]\n        };\n      })\n    };\n    this._feedbackElements.forEach(fe => fe.checkShowFeedback(identifier));\n\n    this._emit<OutcomeChangedDetails>('qti-outcome-changed', {\n      item: this.identifier,\n      outcomeIdentifier: identifier,\n      value: this._context.variables.find(v => v.identifier === identifier)?.value\n    });\n  }\n\n  private _getCompletionStatus(): 'completed' | 'incomplete' | 'not_attempted' | 'unknown' {\n    if (this._interactionElements.every(interactionElement => interactionElement.validate())) return 'completed';\n    if (this._interactionElements.some(interactionElement => interactionElement.validate())) return 'incomplete';\n    return 'not_attempted';\n  }\n\n  private _emit<T>(name, detail = null) {\n    this.dispatchEvent(\n      new CustomEvent<T>(name, {\n        bubbles: true,\n        composed: true,\n        detail\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-item': QtiAssessmentItem;\n  }\n}\n", "import type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\n\ntype NonUndefined<A> = A extends undefined ? never : A;\n\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.updateStimulusRef(stimulusRef);\n      } else {\n        console.warn(`Stimulus with data-stimulus-idref ${this.identifier} not found`);\n      }\n    }\n  }\n\n  /**\n   * Loads and appends the stimulus to the specified element.\n   * @param stimulusRef - The element to which the stimulus will be appended.\n   */\n  public async updateStimulusRef(stimulusRef: Element) {\n    const path = this.href.substring(0, this.href.lastIndexOf('/'));\n    const stimulus = await qtiTransformItem()\n      .load(this.href)\n      .then(api => api.path(path).htmlDoc());\n    if (stimulus) {      \n      const elements = stimulus.querySelectorAll('qti-stimulus-body, qti-stylesheet');\n      stimulusRef.innerHTML = '';\n      stimulusRef.append(...elements);\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-assessment-stimulus-ref': QtiAssessmentStimulusRef;\n  }\n}\n", "import { ComplexAttributeConverter, LitElement, html } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport interface ChoiceInterface {\n  identifier: string;\n  disabled: boolean;\n  readonly: boolean;\n}\n\n/**\n * Converter to handle boolean attributes for ARIA properties,\n * ensuring they are set as 'true' or 'false' strings.\n */\nconst ariaBooleanConverter: ComplexAttributeConverter<boolean, boolean> = {\n  toAttribute: (value: boolean) => (value ? 'true' : 'false'),\n  fromAttribute: (value: string | null) => value === 'true'\n};\n\n/**\n * A mixin that adds choice functionality to a LitElement-based class.\n * It dispatches events with a custom `type` and handles selection logic.\n *\n * @param Base - The base class to extend.\n * @param type - The type of the choice, used in event names.\n * @returns A new class extending the base class with choice functionality.\n */\nexport interface ActiveElementMixinInterface {\n  identifier: string;\n  tabIndex: number;\n  disabled: boolean;\n  readonly: boolean;\n  internals: ElementInternals;\n}\n\n\nexport function ActiveElementMixin<T extends Constructor<LitElement>>(Base: T, type: string) {\n  abstract class QtiChoice extends Base {\n    @property({ type: String })\n    public identifier = '';\n\n    @property({ type: Number, reflect: true, attribute: 'tabindex' })\n    public tabIndex = 0;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-disabled',\n      converter: ariaBooleanConverter\n    })\n    public disabled = false;\n\n    @property({\n      type: Boolean,\n      reflect: true,\n      attribute: 'aria-readonly',\n      converter: ariaBooleanConverter\n    })\n    public readonly = false;\n\n    public internals: ElementInternals;\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    handleDisabledChange(_oldValue: boolean, disabled: boolean) {\n      this.tabIndex = disabled ? -1 : 0;\n      if (disabled) {\n        this.blur();\n      }\n    }\n\n    constructor(...args: any[]) {\n      super(...args);\n      this.internals = this.attachInternals();\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n\n      this.addEventListener('keyup', this._onKeyUp);\n      this.addEventListener('click', this._onClick);\n\n      this.dispatchEvent(\n        new CustomEvent(`register-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener('keyup', this._onKeyUp);\n      this.removeEventListener('click', this._onClick);\n      this.dispatchEvent(\n        new CustomEvent(`unregister-${type}`, {\n          bubbles: true,\n          composed: true\n        })\n      );\n    }\n\n    private _onKeyUp(event: KeyboardEvent) {\n      if (event.altKey) return;\n\n      if (event.code === 'Space') {\n        event.preventDefault();\n        this._activate();\n      }\n    }\n\n    private _onClick() {\n      if (this.disabled || this.readonly) return;\n      this.focus();\n      this._activate();\n    }\n\n    private _activate() {\n      if (this.disabled || this.readonly) return;\n\n      this.dispatchEvent(\n        new CustomEvent<{ identifier: string }>(`activate-${type}`, {\n          bubbles: true,\n          composed: true,\n          detail: { identifier: this.identifier }\n        })\n      );\n    }\n\n    override render() {\n      return html`<slot></slot>`;\n    }\n  }\n  return QtiChoice as Constructor<ActiveElementMixinInterface> & T;\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\nimport styles from './qti-item-body.styles';\nimport type { CSSResultGroup } from 'lit';\n\n/**\n * @summary The qti-item-body node contains the text, graphics, media objects and interactions that describe the item's content and information about how it is structured.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.sphpo6lu6zqi\n * @status stable\n * @since 4.0\n *\n * @slot - item body content.\n * @slot qti-rubric-block - the qti rubric block is placed above the item\n *\n */\n@customElement('qti-item-body')\nexport class QtiItemBody extends LitElement {\n  static styles: CSSResultGroup = styles;\n\n  override render() {\n    return html`<slot name=\"qti-rubric-block\"></slot><slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-item-body': QtiItemBody;\n  }\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: block;\n  }\n`;\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n@customElement('qti-prompt')\nexport class QtiPrompt extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  override connectedCallback(): void {\n    // if prompts are in interactions they should have a slot, so the prompt has to go there\n    // if prompt is in the body, then just display the prompt there.\n    // A better check would be the latter, but not can't get through the shadowroot to find the slot\n    const inInteraction = this.parentElement.tagName.endsWith('INTERACTION');\n    if (inInteraction) {\n      this.setAttribute('slot', 'prompt');\n    }\n    // const promptSlot = this.parentElement.shadowRoot.querySelector(\"[name='prompt']\");\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-prompt': QtiPrompt;\n  }\n}\n", "import { LitElement, PropertyValueMap } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-stylesheet')\nexport class QtiStylesheet extends LitElement {\n  private styleElement: HTMLStyleElement | null = null;\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    super.firstUpdated(_changedProperties);\n\n    const link = this.getAttribute('href');\n\n    if (link !== null) {\n      // Fetch the stylesheet content\n      fetch(link)\n        .then(response => response.text())\n        .then(cssContent => {\n          // Minify the CSS content by removing whitespace and comments\n          const minifiedCss = this.minifyCss(cssContent);\n\n          // Create a <style> element with @scope surrounding the minified CSS\n          this.styleElement = document.createElement('style');\n          this.styleElement.media = 'screen';\n          this.styleElement.textContent = `@scope {${minifiedCss}}`;\n          \n          // Append the style element to the parent element of this component\n          if (this.parentElement) {\n            this.parentElement.appendChild(this.styleElement);\n          } else {\n            console.warn('No parent element to append the scoped stylesheet to.');\n          }\n        })\n        .catch(error => {\n          console.error('Failed to load stylesheet:', error);\n        });\n    }\n\n    if (this.textContent !== null && this.textContent.trim() !== '') {\n      // Minify the inline CSS content\n      const minifiedCss = this.minifyCss(this.textContent);\n\n      // Directly create a <style> element with the @scope surrounding the minified inline styles\n      this.styleElement = document.createElement('style');\n      this.styleElement.media = 'screen';\n      this.styleElement.textContent = `@scope {${minifiedCss}}`;\n\n      // Append the style element to the parent element of this component\n      if (this.parentElement) {\n        this.parentElement.appendChild(this.styleElement);\n      } else {\n        console.warn('No parent element to append the scoped stylesheet to.');\n      }\n    }\n  }\n\n  private minifyCss(cssContent: string): string {\n    // Remove comments, whitespace, and newline characters\n    return cssContent\n      .replace(/\\/\\*[\\s\\S]*?\\*\\//g, '') // Remove comments\n      .replace(/\\s+/g, ' ') // Collapse whitespace\n      .replace(/\\s*([{}:;])\\s*/g, '$1') // Remove spaces around {}, :, ;\n      .trim(); // Trim leading/trailing whitespace\n  }\n\n  override disconnectedCallback() {\n    if (this.styleElement) {\n      try {\n        this.styleElement.remove();\n      } catch (error) {\n        console.error('Could not remove stylesheet:', error);\n      }\n    }\n    super.disconnectedCallback();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-stylesheet': QtiStylesheet;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { BaseType, Cardinality } from '../../internal/expression-result';\nimport { OutcomeVariable } from '../../internal/variables';\nimport { ItemContext, itemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiVariableDeclaration } from '../qti-variable-declaration';\n\n@customElement('qti-outcome-declaration')\nexport class QtiOutcomeDeclaration extends QtiVariableDeclaration {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType;\n  @property({ type: String, attribute: 'external-scored' }) externalScored: 'human' | 'externalMachine' | null = null;\n  @property({ type: String }) identifier: string;\n  @property({ type: String }) cardinality: Cardinality;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\n\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    const value = this.itemContext?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  get interpolationTable(): Map<number, number> | null {\n    const table = this.querySelector('qti-interpolation-table');\n    if (table) {\n      const entries = new Map<number, number>();\n      for (const entry of table.querySelectorAll('qti-interpolation-table-entry')) {\n        if (!entry.getAttribute('source-value') && entry.getAttribute('target-value')) {\n          console.error('source-value or target-value is missing in qti-interpolation-table-entry');\n        }\n        const sourceValue = parseInt(entry.getAttribute('source-value'));\n        const targetValue = parseInt(entry.getAttribute('target-value'));\n        if (isNaN(sourceValue) || isNaN(targetValue)) {\n          console.error('source-value or target-value is not a number in qti-interpolation-table-entry');\n        }\n        entries.set(sourceValue, targetValue);\n      }\n      return entries;\n    }\n    return null;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n    const outcomeVariable: OutcomeVariable = {\n      identifier: this.identifier,\n      cardinality: this.cardinality,\n      baseType: this.baseType,\n      type: 'outcome',\n      value: null,\n      interpolationTable: this.interpolationTable,\n      externalScored: this.externalScored\n    };\n    outcomeVariable.value = this.defaultValues(outcomeVariable);\n    this.dispatchEvent(\n      new CustomEvent('qti-register-variable', {\n        bubbles: true,\n        composed: true,\n        detail: { variable: outcomeVariable }\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-outcome-declaration': QtiOutcomeDeclaration;\n  }\n}\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { VariableDeclaration } from '../internal/variables';\n\n@customElement('qti-variabledeclaration')\nexport class QtiVariableDeclaration extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  protected defaultValues(variable: VariableDeclaration<string | string[] | null>) {\n    const htmlValues = Array.from(this.querySelectorAll('qti-default-value > qti-value'));\n\n    if (htmlValues.length === 0) {\n      return null;\n    }\n\n    const defaultValues = htmlValues.map(n => n.innerHTML.trim());\n    if (defaultValues.length > 1 || variable.cardinality === 'multiple' || variable.cardinality === 'ordered') {\n      return defaultValues;\n    }\n    return defaultValues[0];\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-variabledeclaration': QtiVariableDeclaration;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { BaseType, Cardinality } from '../../internal/expression-result';\nimport { ResponseVariable } from '../../internal/variables';\nimport { ItemContext, itemContext } from '../../qti-assessment-item/qti-assessment-item.context';\nimport { QtiMapping } from '../../qti-response-processing/qti-expression/qti-mapping/qti-mapping';\nimport { QtiVariableDeclaration } from '../qti-variable-declaration';\n\n@customElement('qti-response-declaration')\nexport class QtiResponseDeclaration extends QtiVariableDeclaration {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType;\n\n  @property({ type: String }) identifier: string;\n\n  @property({ type: String }) cardinality: Cardinality;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  public itemContext?: ItemContext;\n\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    const value = this.itemContext?.variables.find(v => v.identifier === this.identifier)?.value;\n    return html`${JSON.stringify(value, null, 2)}`;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n\n    const responseVariable: ResponseVariable = {\n      baseType: this.baseType,\n      identifier: this.identifier,\n      correctResponse: this.correctResponse,\n      cardinality: this.cardinality || 'single',\n      mapping: this.mapping,\n      value: null,\n      type: 'response',\n      candidateResponse: null\n    };\n    responseVariable.value = this.defaultValues(responseVariable);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-register-variable', {\n        bubbles: true,\n        composed: true,\n        detail: { variable: responseVariable }\n      })\n    );\n  }\n\n  private get correctResponse(): string | string[] {\n    let result: string | string[];\n    const correctResponse = this.querySelector('qti-correct-response');\n    if (correctResponse) {\n      const values = correctResponse.querySelectorAll('qti-value');\n      if (this.cardinality === 'single' && values.length > 0) {\n        result = values[0].textContent;\n        values[0].remove();\n      } else if (this.cardinality !== 'single') {\n        result = [];\n        for (let i = 0; i < values.length; i++) {\n          result.push(values[i].textContent);\n          values[i].remove();\n        }\n      }\n    }\n    return result;\n  }\n\n  private get mapping() {\n    return this.querySelector('qti-mapping') as QtiMapping;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-declaration': QtiResponseDeclaration;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-companion-materials-info')\nexport class QtiCompanionMaterialsInfo extends LitElement {\n  // static override styles = css`\n  //   slot {\n  //     display: hidden;\n  //   }\n  // `;\n  // override render() {\n  //   return html` <slot></slot> `;\n  // }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-companion-materials-info': QtiCompanionMaterialsInfo;\n  }\n}\n", "import { LitElement, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-content-body')\nexport class QtiContentBody extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-content-body': QtiContentBody;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { watch } from '../../decorators/watch';\n\n@customElement('qti-rubric-block')\nexport class QtiRubricBlock extends LitElement {\n  @property({ type: String }) override id; // =\"qtiAspectInhoudRubricBlock\"\n\n  @property({ type: String }) use: 'instructions' | 'scoring' | 'navigation'; //  = \"scoring\"\n\n  @property({ type: String }) view: 'author' | 'candidate' | 'proctor' | 'scorer' | 'testConstructor' | 'tutor';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames', { waitUntilFirstUpdate: true })\n  handleclassNamesChange(old, disabled: boolean) {\n    const classNames = this.classNames.split(' ');\n    classNames.forEach((className: string) => {\n      switch (className) {\n        case 'qti-rubric-discretionary-placement':\n          this.setAttribute('slot', 'qti-rubric-block');\n          break;\n        case 'qti-rubric-inline':\n          this.setAttribute('slot', '');\n          break;\n        default:\n          break;\n      }\n    });\n  }\n\n  static override styles = css`\n    :host {\n      display: block;\n    }\n  `;\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    // by default put this in a slot in the item-body\n    this.setAttribute('slot', 'qti-rubric-block');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rubric-block': QtiRubricBlock;\n  }\n}\n", "import { PropertyValueMap, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiFeedback } from '../qti-feedback';\n\n@customElement('qti-feedback-block')\nexport class QtiFeedbackBlock extends QtiFeedback {\n  static override styles = css`\n    :host {\n      display: block;\n    }\n    .on {\n      display: block;\n    }\n    .off {\n      display: none;\n    }\n  `;\n\n  override render() {\n    return html` <slot part=\"feedback\" class=\"feedback ${this.showStatus}\"></slot> `;\n  }\n\n  protected firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    this.checkShowFeedback(this.outcomeIdentifier);\n  }\n}\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-feedback-block': QtiFeedbackBlock;\n  }\n}\n", "import { 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 { customElement, property, state } from 'lit/decorators.js';\nimport { watch } from '../../../decorators/watch';\n\n@customElement('qti-extended-text-interaction')\nexport class QtiExtendedTextInteraction extends Interaction {\n  @state()\n  private _rows = 5;\n\n  /** expected length is mapped to the property maxlength on the textarea */\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  /** text appearing in the extended-text-nteraction if it is empty */\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @property({ type: String, attribute: 'data-patternmask-message' }) dataPatternmaskMessage: string;\n\n  @state()\n  private _value = '';\n\n  @property({ type: String, attribute: 'class' }) classNames;\n  @watch('classNames')\n  handleclassNamesChange(old, classes: string) {\n    const classNames = classes.split(' ');\n    let rowsSet = false;\n    classNames.forEach((className: string) => {\n      if (className.startsWith('qti-height-lines-')) {\n        const nrRows = className.replace('qti-height-lines-', '');\n        this._rows = parseInt(nrRows);\n        rowsSet = true;\n      }\n    });\n    // If no qti-height-lines class is set, calculate rows based on expectedLength\n    if (!rowsSet && this.expectedLength) {\n      const estimatedRows = Math.ceil(this.expectedLength / 50); //  '50' based on an estimate for characters per row\n      this._rows = estimatedRows;\n    }\n  }\n\n  get value(): string | string[] {\n    return this._value;\n  }\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this._value = val;\n      const formData = new FormData();\n      formData.append(this.responseIdentifier, val);\n      this._internals.setFormValue(formData);\n      this.validate();\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  public override validate() {\n    const textarea = this.shadowRoot.querySelector('textarea');\n    if (!textarea) return false;\n\n    if (this.patternMask && this.dataPatternmaskMessage) {\n      // Clear any custom error initially\n      this._internals.setValidity({});\n      textarea.setCustomValidity('');\n      const patternSource =\n        this.patternMask.startsWith('^') && this.patternMask.endsWith('$') ? this.patternMask : `^${this.patternMask}$`;\n\n      const pattern = new RegExp(patternSource);\n      const isValid = textarea.checkValidity() && pattern.test(textarea.value);\n\n      if (!isValid) {\n        // Set custom error if invalid\n        this._internals.setValidity({ customError: true }, this.dataPatternmaskMessage);\n        textarea.setCustomValidity(this.dataPatternmaskMessage);\n      }\n    } else {\n      const isValid = textarea.checkValidity();\n      this._internals.setValidity(isValid ? {} : { customError: false });\n    }\n\n    return this._value !== '' && textarea.checkValidity();\n  }\n\n  override reportValidity() {\n    const textarea = this.shadowRoot.querySelector('textarea');\n    if (!textarea) return false;\n\n    // Run the validate function to ensure the custom validity state is up to date\n    const isValid = this.validate();\n    if (!isValid) {\n      textarea.reportValidity();\n    }\n    return isValid;\n  }\n\n  static override get styles() {\n    return [\n      css`\n        /* PK: display host as block, else design will be collapsed */\n        :host {\n          display: block;\n        }\n        textarea {\n          box-sizing: border-box;\n          width: 100%;\n          height: 100%;\n          border: 0;\n        }\n      `\n    ];\n  }\n\n  override render() {\n    return html`<slot name=\"prompt\"></slot\n      ><textarea\n        part=\"textarea\"\n        name=\"${this.responseIdentifier}\"\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        maxlength=\"${5000}\"\n        @keydown=\"${event => event.stopImmediatePropagation()}\"\n        @keyup=\"${this.textChanged}\"\n        @change=\"${this.textChanged}\"\n        @blur=\"${(event: FocusEvent) => {\n          this.reportValidity();\n        }}\"\n        placeholder=\"${ifDefined(this.placeholderText ? this.placeholderText : undefined)}\"\n        rows=\"${this._rows}\"\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n        .value=${this._value}\n      ></textarea>`;\n  }\n\n  protected textChanged(event: Event) {\n    if (this.disabled || this.readonly) return;\n    const input = event.target as HTMLInputElement;\n    this.setEmptyAttribute(input.value);\n    if (this._value !== input.value) {\n      this.value = input.value;\n      const isValid = this.validate();\n      this.saveResponse(input.value);\n    }\n  }\n\n  private setEmptyAttribute(text: string) {\n    this.setAttribute('empty', text === '' ? 'true' : 'false');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-extended-text-interaction': QtiExtendedTextInteraction;\n  }\n}\n", "import { property, state } from 'lit/decorators.js';\nimport { LitElement } from 'lit';\nimport { IInteraction } from './interaction.interface';\n\nexport abstract class Interaction extends LitElement implements IInteraction {\n  static formAssociated = true; // Enable form association\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier = '';\n  /** disabled should be exposed to the attributes and accessible as property */\n  @property({ reflect: true, type: Boolean }) disabled = false;\n\n  /** readonly should be exposed to the attributes and accessible as property */\n  @property({ reflect: true, type: Boolean }) readonly = false;\n\n  @state()\n  protected _correctResponse: string | string[] = '';\n  protected _internals: ElementInternals;\n\n  constructor() {\n    super();\n    this._internals = this.attachInternals();\n  }\n\n  abstract validate(): boolean;\n\n  public reportValidity(): boolean {\n    return this._internals.reportValidity();\n  }\n\n  public reset(): void {\n    this.value = '';\n  }\n\n  abstract get value(): string | string[];\n  abstract set value(val: string | string[]);\n\n  public get correctResponse(): string | string[] {\n    return this._correctResponse;\n  }\n  set correctResponse(value: string | string[]) {\n    this._correctResponse = value;\n  }\n\n  public override connectedCallback() {\n    super.connectedCallback();\n\n    this.dispatchEvent(\n      new CustomEvent('qti-register-interaction', {\n        bubbles: true,\n        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 { CSSResultGroup, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { createRef } from 'lit/directives/ref.js';\nimport { watch } from '../../../decorators';\nimport { Interaction } from '../internal/interaction/interaction';\nimport styles from './qti-text-entry-interaction.styles';\n@customElement('qti-text-entry-interaction')\nexport class QtiTextEntryInteraction extends Interaction {\n  static styles: CSSResultGroup = styles;\n\n  @property({ type: Number, attribute: 'expected-length' }) expectedLength: number;\n\n  @property({ type: String, attribute: 'pattern-mask' }) patternMask: string;\n\n  @property({ type: String, attribute: 'placeholder-text' }) placeholderText: string;\n\n  @property({ type: String, attribute: 'data-patternmask-message' }) dataPatternmaskMessage: string;\n\n  @state()\n  private _value = '';\n\n  inputRef = createRef<HTMLInputElement>();\n\n  get value(): string | string[] {\n    return this._value;\n  }\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this._value = val;\n      const formData = new FormData();\n      formData.append(this.responseIdentifier, val);\n      this._internals.setFormValue(formData);\n      this.validate();\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  public override validate() {\n    const input = this.shadowRoot.querySelector('input');\n    if (!input) return false;\n    if (this.patternMask && this.dataPatternmaskMessage) {\n      // Clear any custom error if the input is valid\n      this._internals.setValidity({});\n      input.setCustomValidity(''); // Clear the custom message\n      const isValid = input.checkValidity();\n      if (!isValid) {\n        // Set custom error if invalid\n        this._internals.setValidity({ customError: true }, this.dataPatternmaskMessage);\n        input.setCustomValidity(this.dataPatternmaskMessage); // Set custom message only if invalid\n      }\n    } else {\n      const isValid = input.checkValidity();\n      this._internals.setValidity(isValid ? {} : { customError: false });\n    }\n    return this._value !== '' && input.checkValidity();\n  }\n\n  override render() {\n    return html`\n      <input\n        part=\"input\"\n        name=\"${this.responseIdentifier}\"\n        spellcheck=\"false\"\n        autocomplete=\"off\"\n        @blur=\"${(event: FocusEvent) => {\n          this.reportValidity();\n        }}\"\n        @keydown=\"${event => event.stopImmediatePropagation()}\"\n        @keyup=\"${this.textChanged}\"\n        @change=\"${this.textChanged}\"\n        type=\"${this.patternMask == '[0-9]*' ? 'number' : 'text'}\"\n        placeholder=\"${ifDefined(this.placeholderText ? this.placeholderText : undefined)}\"\n        .value=\"${this._value}\"\n        pattern=\"${ifDefined(this.patternMask ? this.patternMask : undefined)}\"\n        maxlength=${1000}\n        ?disabled=\"${this.disabled}\"\n        ?readonly=\"${this.readonly}\"\n      />\n      <div part=\"correct\">${this._correctResponse}</div>\n    `;\n  }\n  protected textChanged(event: Event) {\n    if (this.disabled || this.readonly) return;\n    const input = event.target as HTMLInputElement;\n    this.setEmptyAttribute(input.value);\n    if (this._value !== input.value) {\n      this.value = input.value;\n      const isValid = this.validate();\n      this.saveResponse(input.value);\n    }\n  }\n\n  override reportValidity() {\n    const input = this.shadowRoot.querySelector('input');\n    if (!input) return false;\n\n    // Run the validate function to ensure the custom validity state is up to date\n    const isValid = this.validate();\n    if (!isValid) {\n      input.reportValidity();\n    }\n    return isValid;\n  }\n\n  reset(): void {\n    this._value = '';\n  }\n\n  private setEmptyAttribute(text: string) {\n    this.setAttribute('empty', text === '' ? 'true' : 'false');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-text-entry-interaction': QtiTextEntryInteraction;\n  }\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: inline-block;\n  }\n  [part='correct'] {\n    position: absolute;\n    width: 100%;\n  }\n  :host(.qti-input-width-1) [part='input'] {\n    width: 1.1rem;\n    min-width: 1.1rem;\n  }\n\n  :host(.qti-input-width-2) [part='input'] {\n    width: 2.3rem;\n    min-width: 2.3rem;\n  }\n\n  :host(.qti-input-width-3) [part='input'] {\n    width: 3.3rem;\n    min-width: 3.3rem;\n  }\n\n  :host(.qti-input-width-4) [part='input'] {\n    width: 4.2rem;\n    min-width: 4.2rem;\n  }\n\n  :host(.qti-input-width-6) [part='input'] {\n    width: 6.6rem;\n    min-width: 6.6rem;\n  }\n\n  :host(.qti-input-width-10) [part='input'] {\n    width: 8rem;\n    min-width: 8rem;\n  }\n\n  :host(.qti-input-width-15) [part='input'] {\n    width: 12rem;\n    min-width: 12rem;\n  }\n\n  :host(.qti-input-width-20) [part='input'] {\n    width: 17rem;\n    min-width: 17rem;\n  }\n\n  :host(.qti-input-width-25) [part='input'] {\n    width: 20rem;\n    min-width: 20rem;\n  }\n\n  :host(.qti-input-width-30) [part='input'] {\n    width: 24rem;\n    min-width: 24rem;\n  }\n\n  :host(.qti-input-width-35) [part='input'] {\n    width: 28rem;\n    min-width: 28rem;\n  }\n\n  :host(.qti-input-width-40) [part='input'] {\n    width: 32rem;\n    min-width: 32rem;\n  }\n\n  :host(.qti-input-width-45) [part='input'] {\n    width: 36rem;\n    min-width: 36rem;\n  }\n\n  :host(.qti-input-width-50) [part='input'] {\n    width: 40rem;\n    min-width: 40rem;\n  }\n\n  :host(.qti-input-width-72) [part='input'] {\n    width: 57rem;\n    min-width: 57rem;\n  }\n`;\n", "import { html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-hottext-interaction')\nexport class QtiHottextInteraction extends ChoicesMixin(Interaction, 'qti-hottext') {\n  override connectedCallback() {\n    super.connectedCallback();\n    this.setAttribute('qti-hottext-interaction', '');\n  }\n\n  override render = () => html`<slot></slot>`;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hottext-interaction': QtiHottextInteraction;\n  }\n}\n", "import { property, query } from 'lit/decorators.js';\nimport { watch } from '../../../../decorators/watch';\n\nimport { ChoiceInterface } from '../active-element/active-element.mixin';\nimport { Interaction } from '../interaction/interaction';\nimport { IInteraction } from '../interaction/interaction.interface';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport type Choice = HTMLElement & ChoiceInterface & { internals: ElementInternals };\n\nexport interface ChoicesInterface extends IInteraction {\n  _choiceElements: Array<Choice>;\n  correctResponse: string | string[];\n}\n\nexport const ChoicesMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class ChoicesMixinElement extends superClass implements ChoicesInterface {\n    public _choiceElements: Choice[] = [];\n\n    @query('#validationMessage')\n    private _validationMessageElement!: HTMLElement;\n\n    @property({ type: Number, attribute: 'min-choices' })\n    public minChoices = 0;\n\n    @property({ type: Number, attribute: 'max-choices' })\n    public maxChoices = 1;\n\n    @watch('maxChoices', { waitUntilFirstUpdate: true })\n    _handleMaxChoicesChange(_oldValue: number, _newValue: number) {\n      this._determineInputType();\n    }\n\n    @watch('disabled', { waitUntilFirstUpdate: true })\n    _handleDisabledChange = (_: boolean, disabled: boolean) => {\n      this._choiceElements.forEach(ch => (ch.disabled = disabled));\n    };\n\n    @watch('readonly', { waitUntilFirstUpdate: true })\n    _handleReadonlyChange = (_: boolean, readonly: boolean) => {\n      this._choiceElements.forEach(choice => (choice.readonly = readonly));\n    };\n\n    private _value: string | string[] = '';\n\n    get value(): string | string[] {\n      return Array.isArray(this._value) ? this._value.join(',') : this._value;\n    }\n\n    set value(val: string | string[]) {\n      if (this.maxChoices > 1 && typeof val === 'string') {\n        this._value = val.split(',');\n      } else {\n        this._value = val;\n      }\n      // Assuming this.value is an array of strings\n      if (Array.isArray(this._value)) {\n        const formData = new FormData();\n        this._value.forEach(response => {\n          formData.append(this.responseIdentifier, response);\n        });\n        this._internals.setFormValue(formData);\n      } else {\n        // Handle the case where this.value is not an array\n        this._internals.setFormValue(this._value);\n      }\n      this._updateChoiceSelection();\n    }\n\n    public get correctResponse(): string | string[] {\n      return this._correctResponse;\n    }\n\n    public set correctResponse(value: string | string[]) {\n      this._correctResponse = value;\n      const responseArray = Array.isArray(value) ? value : [value];\n      this._choiceElements.forEach(choice => {\n        choice.internals.states.delete('correct-response');\n        choice.internals.states.delete('incorrect-response');\n        if (responseArray.length > 0) {\n          if (responseArray.includes(choice.identifier)) {\n            choice.internals.states.add('correct-response');\n          } else {\n            choice.internals.states.add('incorrect-response');\n          }\n        }\n      });\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.addEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.addEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.addEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n    }\n\n    override disconnectedCallback() {\n      super.disconnectedCallback();\n      this.removeEventListener(`register-${selector}`, this._registerChoiceElement);\n      this.removeEventListener(`unregister-${selector}`, this._unregisterChoiceElement);\n      this.removeEventListener(`activate-${selector}`, this._choiceElementSelectedHandler);\n    }\n\n    public validate(): boolean {\n      const selectedChoices = this._choiceElements.filter(choice => this._getChoiceChecked(choice));\n      const selectedCount = selectedChoices.length;\n      let isValid = true;\n      let validityMessage = '';\n      if (this.maxChoices !== 0 && selectedCount > this.maxChoices) {\n        isValid = false;\n        validityMessage = this.dataset.maxSelectionsMessage || `You can select at most ${this.maxChoices} choices.`;\n      } else if (selectedCount < this.minChoices) {\n        isValid = false;\n        validityMessage = this.dataset.minSelectionsMessage || `You must select at least ${this.minChoices} choices.`;\n      }\n\n      if (selectedChoices.length > 0) {\n        this._internals.setValidity(\n          isValid ? {} : { customError: true },\n          validityMessage,\n          selectedChoices[selectedCount - 1] || this._choiceElements[0] || this\n        );\n      }\n      this.reportValidity();\n      return isValid;\n    }\n\n    override reportValidity() {\n      if (this._validationMessageElement) {\n        if (!this._internals.validity.valid) {\n          this._validationMessageElement.textContent = this._internals.validationMessage;\n          this._validationMessageElement.style.display = 'block';\n        } else {\n          this._validationMessageElement.textContent = '';\n          this._validationMessageElement.style.display = 'none';\n        }\n      }\n      return this._internals.validity.valid;\n    }\n\n    private _registerChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      choiceElement.disabled = this.disabled;\n\n\n      \n      this._choiceElements.push(choiceElement);\n      this._setInputType(choiceElement);\n    }\n\n    private _unregisterChoiceElement(event: CustomEvent) {\n      event.stopPropagation();\n      const choiceElement = event.target as Choice;\n      this._choiceElements = this._choiceElements.filter(choice => choice !== choiceElement);\n    }\n\n    private _determineInputType() {\n      this._choiceElements.forEach(choice => {\n        this._setInputType(choice);\n      });\n    }\n\n    private _setInputType(choiceElement: Choice) {\n      // choiceElement.setAttribute('role', this.maxChoices === 1 ? 'radio' : 'checkbox');\n      choiceElement.internals.role = this.maxChoices === 1 ? 'radio' : 'checkbox';\n      choiceElement.internals.states.add(choiceElement.internals.role)\n      // choiceElement.internals.ariaChecked = 'false';\n      // choiceElement.ariaReadOnly = this.readonly == true ? 'true' : 'false';\n    }\n\n    protected _choiceElementSelectedHandler(event: CustomEvent<{ identifier: string }>) {\n      this._toggleChoiceChecked(event.target as Choice);\n      if (this.maxChoices === 1) {\n        this._choiceElements.forEach(choice => {\n          if (choice.identifier !== event.detail.identifier) {\n            this._setChoiceChecked(choice, false);\n          }\n        });\n      }\n      this._handleChoiceSelection();\n    }\n\n    private _setChoiceChecked(choice: Choice, checked: boolean) {\n      if (choice.internals?.states) {\n        if (checked) {\n          choice.internals.states.add('--checked');\n          choice.internals.ariaChecked = 'true';\n        } else {\n          choice.internals.states.delete('--checked');\n          choice.internals.ariaChecked = 'false';\n        }\n      }\n    }\n\n    private _getChoiceChecked(choice: Choice): boolean {\n      return choice.internals.states.has('--checked');\n    }\n\n    private _toggleChoiceChecked(choice: Choice) {\n      const checked = this._getChoiceChecked(choice);\n      this._setChoiceChecked(choice, !checked);\n    }\n\n    private _handleChoiceSelection() {\n      const selectedChoices = this._choiceElements.filter(choice => this._getChoiceChecked(choice));\n      const selectedIdentifiers = selectedChoices.map(choice => choice.identifier);\n\n      this.value = this.maxChoices === 1 ? selectedIdentifiers[0] || '' : selectedIdentifiers;\n      this.validate();\n      this.saveResponse(this._value);\n    }\n\n    /**\n     * Updates the selection state of each choice element based on the current response.\n     */\n    private _updateChoiceSelection() {\n      const responseArray = Array.isArray(this._value) ? this._value : [this._value];\n      this._choiceElements.forEach(choice => {\n        const isSelected = responseArray.includes(choice.identifier);\n        this._setChoiceChecked(choice, isSelected);\n      });\n    }\n  }\n  return ChoicesMixinElement as Constructor<ChoicesInterface> & T;\n};\n", "import { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\ninterface OptionType {\n  textContent: string;\n  value: string;\n  selected: boolean;\n}\n\n@customElement('qti-inline-choice-interaction')\nexport class QtiInlineChoiceInteraction extends Interaction {\n  static override get styles() {\n    return [\n      css`\n        :host {\n          display: inline-block;\n        }\n        slot {\n          display: flex;\n          flex-direction: column;\n        }\n        [role='menu'] {\n          position: absolute;\n          z-index: 1000;\n        }\n        .anchor {\n          /* anchor-name: --infobox; */\n          width: fit-content;\n        }\n\n        .positionedElement {\n          position: absolute;\n          /* position-anchor: --infobox; */\n          /* top: anchor(bottom); */\n        }\n      `\n    ];\n  }\n\n  public static inputWidthClass = [\n    '',\n    'qti-input-width-2',\n    'qti-input-width-1',\n    'qti-input-width-3',\n    'qti-input-width-4',\n    'qti-input-width-6',\n    'qti-input-width-10',\n    'qti-input-width-15',\n    'qti-input-width-20',\n    'qti-input-width-72'\n  ];\n\n  @state() options: OptionType[] = [];\n\n  @state() correctOption: string = '';\n\n  @property({ attribute: 'data-prompt', type: String })\n  dataPrompt: string = 'select';\n\n  override render() {\n    return html`\n      <select part=\"select\" @change=\"${this.choiceSelected}\" ?disabled=\"${this.disabled}\" ?readonly=\"${this.readonly}\">\n        ${this.options.map(\n          option => html`\n            <option value=\"${option.value}\" ?selected=\"${option.selected}\">${unsafeHTML(option.textContent)}</option>\n          `\n        )}\n      </select>\n\n      ${unsafeHTML(this.correctOption)}\n    `;\n  }\n\n  connectedCallback() {\n    super.connectedCallback();\n    this.addEventListener('on-dropdown-selected', this.choiceSelected);\n    const choices = Array.from(this.querySelectorAll('qti-inline-choice'));\n    this.options = [\n      {\n        textContent: this.dataPrompt,\n        value: '',\n        selected: false\n      },\n      ...choices.map(choice => ({\n        textContent: choice.innerHTML,\n        value: choice.getAttribute('identifier'),\n        selected: false\n      }))\n    ];\n  }\n\n  disconnectedCallback() {\n    this.removeEventListener('on-dropdown-selected', this.choiceSelected);\n  }\n\n  public validate(): boolean {\n    const selectedOption = this.options.find(option => option.selected);\n    return selectedOption ? selectedOption.value !== '' : false;\n  }\n\n  public reset() {\n    this.options = this.options.map((option, i) => ({ ...option, selected: i === 0 }));\n  }\n\n  public set value(value: string) {\n    this.options = this.options.map(option => {\n      if (value === option.value) {\n        option.selected = true;\n      }\n      return option;\n    });\n  }\n  get value(): string {\n    return this.options.find(option => option.selected).value;\n  }\n\n  set correctResponse(value: string | string[]) {\n    if (value === '') {\n      this.correctOption = '';\n      return;\n    }\n    this.correctOption = `<span part=\"correct-option\">${\n      this.options.find(option => value === option.value).textContent\n    }</span>`;\n  }\n\n  public choiceSelected(event: Event) {\n    const selectedOptionValue = (event.target as HTMLSelectElement).value;\n    this.options = this.options.map(option => ({ ...option, selected: option.value === selectedOptionValue }));\n    this.saveResponse(selectedOptionValue);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-inline-choice-interaction': QtiInlineChoiceInteraction;\n  }\n}\n", "import type { CSSResultGroup } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ChoicesInterface, ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { ShuffleMixin } from '../internal/shuffle/shuffle-mixin';\nimport { VocabularyMixin } from '../internal/vocabulary/vocabulary-mixin';\nimport styles from './qti-choice-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-choice-interaction')\nexport class QtiChoiceInteraction\n  extends VocabularyMixin(\n    ShuffleMixin(ChoicesMixin(Interaction, 'qti-simple-choice'), 'qti-simple-choice'),\n    'qti-simple-choice'\n  )\n  implements ChoicesInterface\n{\n  static styles: CSSResultGroup = styles;\n\n  /** orientation of choices */\n  @property({ type: String })\n  public orientation: 'horizontal' | 'vertical';\n\n  render() {\n    return html`\n      <slot name=\"prompt\"></slot><slot part=\"slot\"></slot>\n      <div role=\"alert\" id=\"validationMessage\"></div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-choice-interaction': QtiChoiceInteraction;\n  }\n}\n", "/**\n * Mixin that provides shuffling functionality for a LitElement.\n * @template T - The type of the LitElement subclass.\n * @param {T} superClass - The superclass to extend.\n * @param {string} selector - The CSS selector for the elements to shuffle.\n * @returns {Constructor<ShuffleInterface> & T} - The extended class with shuffling functionality.\n *\n * adds a shuffle property to the class with an attribute converter\n *\n * qti-inline-choice-interaction\n * qti-choice-interaction\n * qti-match-interaction\n */\nimport { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class ShuffleInterface {}\nexport const ShuffleMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class ShuffleElement extends superClass {\n    private _shuffle: boolean = false;\n\n    // Define the property with the custom converter\n    @property({\n      type: String,\n      reflect: true,\n      converter: stringToBooleanConverter\n    })\n    set shuffle(value: boolean) {\n      const oldValue = this._shuffle;\n      this._shuffle = value;\n      if (value) {\n        this._shuffleChoices();\n      } else {\n        this._resetShuffleChoices();\n      }\n      this.requestUpdate('shuffle', oldValue);\n    }\n\n    get shuffle(): boolean {\n      return this._shuffle;\n    }\n\n    connectedCallback() {\n      super.connectedCallback();\n      // Call _resetShuffleChoices initially to set the CSS order to initial.\n      // If shuffle is true, _shuffleChoices will be called automatically via the setter.\n      if (this.shuffle) {\n        this._shuffleChoices();\n      } else {\n        this._resetShuffleChoices();\n      }\n    }\n\n    private _shuffleChoices() {\n      const choices = Array.from(this.querySelectorAll<HTMLElement>(selector));\n      const fixedElements: Array<{ element: HTMLElement; index: number }> = [];\n      const nonFixedElements: Array<HTMLElement> = [];\n\n      // Separate fixed and non-fixed elements\n      choices.forEach((choice, index) => {\n        if (choice.hasAttribute('fixed')) {\n          fixedElements.push({ element: choice, index: index });\n        } else {\n          nonFixedElements.push(choice);\n        }\n      });\n\n      // If there are 1 or fewer non-fixed elements, throw an error (no shuffle possible)\n      if (nonFixedElements.length <= 1) {\n        console.warn('Shuffling is not possible with fewer than 2 non-fixed elements.');\n        return;\n      }\n\n      let isShuffled = false;\n      const maxAttempts = 10; // Max attempts to prevent infinite loops\n      let attempt = 0;\n\n      // Create a copy of the original order for comparison\n      const originalOrder = [...nonFixedElements];\n\n      // Shuffle until the result is different or maxAttempts is reached\n      while (!isShuffled && attempt < maxAttempts) {\n        attempt++;\n\n        // Shuffle non-fixed elements\n        for (let i = nonFixedElements.length - 1; i > 0; i--) {\n          const j = Math.floor(Math.random() * (i + 1));\n          [nonFixedElements[i], nonFixedElements[j]] = [nonFixedElements[j], nonFixedElements[i]];\n        }\n\n        // Check if the shuffled result is different from the original order\n        isShuffled = !nonFixedElements.every((choice, index) => choice === originalOrder[index]);\n\n        if (isShuffled) break;\n      }\n\n      if (!isShuffled) {\n        console.warn('Failed to shuffle the choices after multiple attempts.');\n      }\n\n      // Assign order to each element\n      let order = 1;\n      choices.forEach((choice: HTMLElement, index) => {\n        if (choice.hasAttribute('fixed')) {\n          choice.style.setProperty('order', String(order++));\n        } else {\n          const nonFixedChoice = nonFixedElements.shift();\n          nonFixedChoice!.style.setProperty('order', String(order++));\n        }\n      });\n    }\n\n    private _resetShuffleChoices() {\n      const choices = Array.from(this.querySelectorAll('qti-simple-choice'));\n      choices.forEach((choice, index) => {\n        choice.style.setProperty('order', 'initial'); // choice.style.order = 'initial';\n      });\n    }\n  }\n  return ShuffleElement as Constructor<ShuffleInterface> & T;\n};\n\nconst stringToBooleanConverter = {\n  fromAttribute(value: string | null): boolean {\n    return value === 'true';\n  },\n  toAttribute(value: boolean): string {\n    return value ? 'true' : 'false';\n  }\n};\n", "/**\n * Mixin that provides shuffling functionality for a LitElement.\n * @template T - The type of the LitElement subclass.\n * @param {T} superClass - The superclass to extend.\n * @param {string} selector - The CSS selector for the elements to shuffle.\n * @returns {Constructor<ShuffleInterface> & T} - The extended class with shuffling functionality.\n *\n * adds a shuffle property to the class with an attribute converter\n *\n * qti-inline-choice-interaction\n * qti-choice-interaction\n * qti-match-interaction\n */\nimport { PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { QtiSimpleChoice } from '../../qti-simple-choice';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ntype LabelType = 'qti-labels-decimal' | 'qti-labels-lower-alpha' | 'qti-labels-upper-alpha';\ntype LabelSuffixType = 'qti-labels-suffix-period' | 'qti-labels-suffix-parenthesis';\n\ndeclare class VocabularyInterface {}\n\nexport const VocabularyMixin = <T extends Constructor<Interaction>>(superClass: T, selector: string) => {\n  abstract class VocabularyElement extends superClass {\n    private _classes: string[] = [];\n    private _allLabels = ['qti-labels-decimal', 'qti-labels-lower-alpha', 'qti-labels-upper-alpha'];\n    private _allLabelSuffixes = ['qti-labels-suffix-period', 'qti-labels-suffix-parenthesis'] as LabelSuffixType[];\n    // Define the property with the custom converter\n    @property({\n      type: String,\n      reflect: true\n    })\n    set class(value: string) {\n      if (!value) {\n        return;\n      }\n      // const oldValue = this._classes.join(' ');\n      this._classes = value.split(' ');\n\n      this._addLabels();\n      // this.requestUpdate('class', oldValue);\n    }\n    get class(): string {\n      return this._classes?.join(' ') || '';\n    }\n\n    protected override updated(_changedProperties: PropertyValues): void {\n      super.updated(_changedProperties);\n      if (_changedProperties.has('shuffle')) {\n        this._addLabels();\n      }\n    }\n\n    private _addLabels() {\n      const classContainsLabel = this._classes.some(\n        cls => this._allLabels.includes(cls) || this._allLabelSuffixes.includes(cls as LabelSuffixType)\n      );\n      const isNumber = value => {\n        return !isNaN(+value);\n      };\n      if (classContainsLabel) {\n        const choiceElements = Array.from(this.querySelectorAll('qti-simple-choice')).map(c => c as QtiSimpleChoice);\n        const choices = choiceElements\n          .map((choice: HTMLElement, index) => {\n            return { el: choice, order: isNumber(choice.style.order) ? +choice.style.order : index + 1 };\n          })\n          .sort((a, b) => a.order - b.order)\n          .map(choice => choice.el);\n        for (let i = 0; i < choices.length; i++) {\n          (choices[i] as QtiSimpleChoice).marker = this._getLabel(i + 1);\n        }\n      }\n    }\n    private _getLabel(index: number) {\n      let lastLabel = this._classes.filter(c => this._allLabels.includes(c)).pop() as LabelType;\n      const lastLabelSuffix = this._classes.filter(c => this._allLabelSuffixes.includes(c as LabelSuffixType)).pop();\n\n      if (!lastLabel && lastLabelSuffix) {\n        // a suffix without a label is strange so add qti-labels-upper-alpha\n        lastLabel = 'qti-labels-upper-alpha';\n      }\n      let label = '';\n      switch (lastLabel) {\n        case 'qti-labels-decimal':\n          label = `${index}`;\n          break;\n        case 'qti-labels-lower-alpha':\n          label = `${String.fromCharCode(97 + index - 1)}`;\n          break;\n        case 'qti-labels-upper-alpha':\n          label = `${String.fromCharCode(65 + index - 1)}`;\n          break;\n      }\n      if (lastLabelSuffix === 'qti-labels-suffix-period') {\n        label += '.';\n      } else if (lastLabelSuffix === 'qti-labels-suffix-parenthesis') {\n        label += `)`;\n      }\n      return label;\n    }\n  }\n  return VocabularyElement as Constructor<VocabularyInterface> & T;\n};\n", "import { css } from 'lit';\n\nexport default css`\n  [part='slot'] {\n    display: flex;\n    flex-direction: column;\n    gap: var(--qti-gap-size);\n    flex-wrap: wrap;\n  }\n\n  ::slotted(qti-simple-choice) {\n    flex: 0 0\n      calc((100% - (var(--qti-gap-size) * var(--choice-interactions-stacking))) / var(--choice-interactions-stacking)) !important;\n    box-sizing: border-box !important;\n  }\n\n  :host(.qti-choices-stacking-1) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 1;\n  }\n\n  :host(.qti-choices-stacking-2) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 2;\n  }\n  :host(.qti-choices-stacking-3) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 3;\n  }\n  :host(.qti-choices-stacking-4) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 4;\n  }\n  :host(.qti-choices-stacking-5) [part='slot'] {\n    flex-direction: row;\n    --choice-interactions-stacking: 5;\n  }\n  :host([orientation='horizontal']) [part='slot'] {\n    flex-direction: row;\n  }\n`;\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { QtiRule, QtiRuleBase } from '..';\n\n@customElement('qti-outcome-processing')\nexport class QtiOutcomeProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const logic = new QtiOutcomeProcessingProcessor();\n    const rules = [...this.children] as QtiRule[];\n    logic.process(rules);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-outcome-processing': QtiOutcomeProcessing;\n  }\n}\n\nexport class QtiOutcomeProcessingProcessor {\n  public process(rules: QtiRuleBase[]) {\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n}\n", "import { css, html, LitElement, PropertyValueMap } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { mapResponse, mapResponsePoint, matchCorrect } from '../../internal/template-strings';\nimport { type QtiRule } from '../qti-rule/qti-rule';\n\n@customElement('qti-response-processing')\nexport default class QtiResponseProcessing extends LitElement {\n  static styles = [\n    css`\n      :host {\n        display: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    const rules = [...this.children] as QtiRule[];\n\n    for (const rule of rules) {\n      rule.process();\n    }\n  }\n\n  public firstUpdated(_changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n    if (this.getAttribute('template')) {\n      const splittedTemplateName = this.getAttribute('template')!.split('/');\n      const templateName = splittedTemplateName[splittedTemplateName.length - 1].replace('.xml', '');\n      this.innerHTML = '';\n      switch (templateName) {\n        case 'map_response': {\n          this.appendChild(this.fragmentFromString(mapResponse).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'map_response_point': {\n          this.appendChild(this.fragmentFromString(mapResponsePoint).firstElementChild.firstElementChild);\n          break;\n        }\n        case 'match_correct':\n          this.appendChild(this.fragmentFromString(matchCorrect).firstElementChild.firstElementChild);\n          break;\n      }\n    }\n  }\n\n  private fragmentFromString(strHTML: string) {\n    return document.createRange().createContextualFragment(strHTML);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-response-processing': QtiResponseProcessing;\n  }\n}\n", "export const matchCorrect = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-match>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n        <qti-correct identifier=\"RESPONSE\"></qti-correct>\n      </qti-match>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">1</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponse = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0.0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response identifier=\"RESPONSE\"> </qti-map-response>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n\nexport const mapResponsePoint = `<qti-response-processing>\n  <qti-response-condition>\n    <qti-response-if>\n      <qti-is-null>\n        <qti-variable identifier=\"RESPONSE\"></qti-variable>\n      </qti-is-null>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-base-value base-type=\"float\">0</qti-base-value>\n      </qti-set-outcome-value>\n    </qti-response-if>\n    <qti-response-else>\n      <qti-set-outcome-value identifier=\"SCORE\">\n        <qti-map-response-point identifier=\"RESPONSE\"></qti-map-response-point>\n      </qti-set-outcome-value>\n    </qti-response-else>\n  </qti-response-condition>\n</qti-response-processing>`;\n", "import { OutcomeVariable } from '@citolab/qti-components/qti-components';\nimport { property } from 'lit/decorators.js';\nimport { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\n/**\n * The lookupOutcomeValue rule sets the value of an outcome variable to the value obtained\n * by looking up the value of the associated expression in the lookupTable associated\n * with the outcome's declaration.\n */\nexport class QtiLookupOutcomeValue extends QtiRule {\n  @property({ type: String }) identifier: string;\n\n  get childExpression(): QtiExpression<string> {\n    return this.firstElementChild as QtiExpression<string>;\n  }\n\n  public override process(): number {\n    const identifier = this.getAttribute('identifier');\n    const outcomeVariable = this.closest('qti-assessment-item').getVariable(identifier) as OutcomeVariable;\n    let value;\n    if (outcomeVariable.interpolationTable) {\n      value = outcomeVariable.interpolationTable.get(parseInt(this.childExpression.calculate()));\n    }\n    if (value === null || value === undefined) {\n      console.warn('lookupOutcomeValue: value is null or undefined');\n      return 0;\n    }\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier: this.identifier,\n          value: convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n    return value;\n  }\n}\ncustomElements.define('qti-lookup-outcome-value', QtiLookupOutcomeValue);\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-lookup-outcome-value': QtiLookupOutcomeValue;\n  }\n}\n", "import { customElement } from 'lit/decorators.js';\nimport { html, LitElement } from 'lit';\n\n@customElement('qti-rule')\nexport class QtiRule extends LitElement implements QtiRuleBase {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public process() {\n    throw new Error('Not implemented');\n  }\n}\n\nexport interface QtiRuleBase {\n  process(): any;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-rule': QtiRule;\n  }\n}\n", "import { html } from 'lit';\nimport { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../qti-rule';\n\nexport class QtiResponseCondition extends QtiRule {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public override process() {\n    const branches = [...this.children] as QtiExpression<any>[];\n\n    for (let i = 0; i < branches.length; i++) {\n      const branch = branches[i];\n\n      if (branch.calculate()) {\n        (branch as unknown as QtiRule).process();\n\n        return;\n      }\n    }\n  }\n}\n\ncustomElements.define('qti-response-condition', QtiResponseCondition);\n", "import { convertNumberToUniveralFormat } from '../../../internal/utils';\nimport { QtiExpression, QtiExpressionBase } from '../../qti-expression/qti-expression';\nimport { QtiRule, QtiRuleBase } from '../qti-rule';\n\nexport class QtiSetOutcomeValue extends QtiRule {\n  public override process() {\n    const outcomeIdentifier = this.getAttribute('identifier');\n\n    const expression = this.firstElementChild as QtiExpression<string>;\n\n    const rule = new QtiSetOutcomeValueRule(expression);\n    const value = rule.process();\n    this.dispatchEvent(\n      new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          outcomeIdentifier,\n          value: Array.isArray(value)\n            ? value.map((v: string) => convertNumberToUniveralFormat(v))\n            : convertNumberToUniveralFormat(value)\n        }\n      })\n    );\n  }\n}\n\nexport class QtiSetOutcomeValueRule<T> implements QtiRuleBase {\n  constructor(private expression: QtiExpressionBase<T>) {}\n\n  process(): any {\n    const value = this.expression ? this.expression.calculate() : null;\n\n    if (value === null || value === undefined) {\n      console.warn('setOutcomeValue: value is null or undefined');\n      return;\n    }\n    return value;\n  }\n}\n\ncustomElements.define('qti-set-outcome-value', QtiSetOutcomeValue);\n", "import { LitElement, html } from 'lit';\nimport { QtiRule } from '../qti-rule/qti-rule';\n\nexport class QtiResponseElse extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  public calculate() {\n    const result = true;\n    return true;\n  }\n\n  public getSubRules(): QtiRule[] {\n    return [...this.children] as QtiRule[];\n  }\n\n  public process() {\n    const subRules = this.getSubRules();\n    for (let i = 0; i < subRules.length; i++) {\n      const subRule = subRules[i];\n      subRule.process();\n    }\n  }\n}\n\ncustomElements.define('qti-response-else', QtiResponseElse);\n", "import { html } from 'lit';\nimport { QtiResponseIf } from '../qti-response-if';\n\nexport class QtiResponseElseIf extends QtiResponseIf {\n  override render() {\n    return html`${super.render()}`;\n  }\n}\n\ncustomElements.define('qti-response-else-if', QtiResponseElseIf);\n", "import { QtiExpression } from '../../qti-expression/qti-expression';\nimport { QtiRule } from '../../qti-rule/qti-rule';\nimport { QtiResponseElse } from '../qti-response-else';\n\nexport class QtiResponseIf extends QtiResponseElse {\n  public override calculate() {\n    const expression = this.firstElementChild as QtiExpression<boolean>;\n    const result = expression.calculate() as boolean;\n    return result;\n  }\n\n  public override getSubRules(): QtiRule[] {\n    const result = [];\n    for (let i = 1; i < this.children.length; i++) {\n      result.push(this.children[i]);\n    }\n    return result;\n  }\n}\n\ncustomElements.define('qti-response-if', QtiResponseIf);\n", "import { 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.trim(),\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        const value = condition.calculate();\n        let val = false;\n        // convert string value to boolean and return null if not possible\n        if (typeof value === 'string') {\n          if (value === 'true') {\n            val = true;\n          } else if (value === 'false') {\n            val = false;\n          } else {\n            console.error('unexpected val in qti-or, expected boolean');\n            return null;\n          }\n        } else {\n          if (typeof value === 'boolean') {\n            val = value;\n          }\n        }\n        return val;\n      });\n      return values.every(e => {\n        return typeof e === 'boolean' && e;\n      });\n    }\n  };\n}\n", "import { QtiAnd } from './qti-and';\ncustomElements.define('qti-and', QtiAnd);\n\nexport * from './qti-and';\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-and': QtiAnd;\n  }\n}\n", "import { property } from 'lit/decorators.js';\nimport { BaseType } from '../../../internal/expression-result';\nimport { QtiExpression } from '../qti-expression';\nexport class QtiBaseValue extends QtiExpression<string> {\n  @property({ type: String, attribute: 'base-type' }) baseType: BaseType = 'string';\n\n  public override getResult(): string {\n    const value = this.textContent.trim();\n    return value;\n  }\n}\n\ncustomElements.define('qti-base-value', QtiBaseValue);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiConditionExpression } from '../qti-condition-expression';\n\n// PK: For the contains we assume the expressions to calculate are all directedPairs\n// I don't know it this in QTI is always the case however?\nexport class QtiContains extends QtiConditionExpression {\n  public override getResult() {\n    // TODO: implement this for other types than directedPair\n    const values = this.getVariables() as ResponseVariable[];\n    if (this.children.length === 2) {\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'multiple'\n      ) {\n        const projection1 = value1.value as string[];\n        const projection2 = value2.value as string[];\n        const enumerable = projection1.filter(x => projection2.includes(x));\n\n        const result = enumerable.length > 0;\n        return result;\n      } else if (\n        value1.baseType === 'directedPair' &&\n        value2.baseType === 'directedPair' &&\n        value1.cardinality === 'single'\n      ) {\n        const projection1 = value1.value as string;\n        const projection2 = value2.value as string[];\n        return projection2.includes(projection1);\n      } else {\n        console.error(\n          'unsupported baseType or cardinality in qti contains, only baseType: directedPair and cardinality: multiple is supported'\n        );\n      }\n    } else {\n      console.error('unexpected number of children in qti contains');\n    }\n    return false;\n  }\n}\n\ncustomElements.define('qti-contains', QtiContains);\n", "import { 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    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      const value = condition.calculate();\n      let val = false;\n      // convert string value to boolean and return null if not possible\n      if (typeof value === 'string') {\n        if (value === 'true') {\n          val = true;\n        } else if (value === 'false') {\n          val = false;\n        } else {\n          console.error('unexpected val in qti-or, expected boolean');\n          return null;\n        }\n      } else {\n        if (typeof value === 'boolean') {\n          val = value;\n        }\n      }\n      return val;\n    });\n    return values.some(e => {\n      return typeof e === 'boolean' && e;\n    });\n  }\n}\n\ncustomElements.define('qti-or', QtiOr);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\nexport class QtiOrdered extends QtiExpression<ResponseVariable[]> {\n  public override getResult(): ResponseVariable[] {\n    const variables = this.getVariables() as ResponseVariable[];\n    if (variables.length === 0) {\n      console.error('unexpected number of children in qti multiple');\n      return null;\n    }\n    for (const variable of variables) {\n      if (variable.cardinality !== 'ordered' && variable.cardinality !== 'single') {\n        console.error('unexpected cardinality in qti ordered');\n        return [];\n      }\n    }\n    return variables;\n  }\n}\n\ncustomElements.define('qti-ordered', QtiOrdered);\n", "import { consume } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { QtiAssessmentItem } from '../../../qti-assessment-item/qti-assessment-item';\nimport { ItemContext, itemContext } from '../../../qti-assessment-item/qti-assessment-item.context';\n\nexport class QtiPrintedVariable extends LitElement {\n  @property({ type: String })\n  identifier: string;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  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  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', QtiPrintedVariable);\n", "import { ResponseVariable } from '../../../internal/variables';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiProduct extends QtiExpression<number> {\n  public override getResult() {\n    const values = this.getVariables() as ResponseVariable[];\n    const product = values.reduce((accumulator, currentValue) => {\n      if (currentValue.baseType == 'float' || currentValue.baseType == 'integer') {\n        try {\n          return accumulator * parseInt(currentValue.value.toString());\n        } catch (error) {\n          console.warn(`can not convert to number`);\n        }\n      } else {\n        console.warn(`has another baseType ${currentValue.baseType}`);\n      }\n      return accumulator;\n    }, 1);\n    return product;\n  }\n}\n\ncustomElements.define('qti-product', QtiProduct);\n", "import { property } from 'lit/decorators.js';\nimport { ResponseVariable } from '../../../internal/variables';\nimport { ScoringHelper } from '../../utilities/scoring-helper';\nimport { QtiExpression } from '../qti-expression';\n\nexport class QtiStringMatch extends QtiExpression<boolean> {\n  @property({ type: String, attribute: 'case-sensitive' }) caseSensitive = 'true';\n\n  public override getResult() {\n    if (this.children.length === 2) {\n      const values = this.getVariables() as ResponseVariable[];\n      const value1 = values[0];\n      const value2 = values[1];\n      if (\n        value1.cardinality !== 'single' ||\n        value2.cardinality !== 'single' ||\n        Array.isArray(value1.value) ||\n        Array.isArray(value2.value)\n      ) {\n        console.error('unexpected cardinality in qti string-match');\n        return false;\n      }\n      const v1 = this.caseSensitive === 'true' ? value1.value : (value1.value as string).toLowerCase();\n      const v2 = this.caseSensitive === 'true' ? value2.value : (value2.value as string).toLowerCase();\n      return ScoringHelper.compareSingleValues(v1 as string, v2 as string, value1.baseType);\n    }\n    console.error('unexpected number of children in qti-string-match');\n    return null;\n  }\n}\n\ncustomElements.define('qti-string-match', QtiStringMatch);\n", "import { QtiExpression, QtiExpressionBase } from '../qti-expression';\n\nexport class QtiSum extends QtiExpression<number> {\n  private _expression: QtiSumExpression;\n  constructor() {\n    super();\n    this._expression = new QtiSumExpression(Array.from(this.children as unknown as QtiExpressionBase<number>[]));\n  }\n\n  public override getResult() {\n    // children can be a mix of qti-expression and qti-condition-expression\n    const value = this._expression.calculate();\n    return value;\n  }\n}\n\nexport class QtiSumExpression implements QtiExpressionBase<number> {\n  constructor(private expressions: QtiExpressionBase<number>[]) {}\n\n  public calculate() {\n    const values = this.expressions.map(c => {\n      if (!c.calculate) {\n        console.error(\"Element doesn't implement QtiConditionExpression\");\n        return null;\n      }\n      const value = c.calculate();\n      if (Number.isNaN(value)) {\n        console.error('unexpected value in qti-sum, expected number');\n        return null;\n      }\n\n      return Number(value);\n    });\n    return values.reduce((a, b) => a + b, 0);\n  }\n}\n\ncustomElements.define('qti-sum', QtiSum);\n", "import { 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.value = value;\n        this.saveResponse(value);\n      }\n    }, 200);\n  }\n\n  private stopChecking(): void {\n    if (this.intervalId !== undefined) {\n      clearInterval(this.intervalId);\n    }\n  }\n\n  validate(): boolean {\n    return true; // FOR NOW\n  }\n  set value(val: string | string[]) {\n    // Only set state is supported in a PCI\n  }\n  get value(): string | string[] {\n    return this.rawResponse;\n  }\n\n  getTAOConfig(node) {\n    const a = node.querySelectorAll('properties');\n    let config = {};\n\n    const getPropertyValue = el => {\n      const property = {};\n      const key = el.getAttribute('key');\n      if (key) {\n        const children = Array.from(el.children);\n        const allKey = children.map((c: HTMLElement) => c.getAttribute('key'));\n        const isArray = allKey.length > 0 && !allKey.find(k => !Number.isInteger(+k));\n        if (isArray) {\n          property[key] = children.map(c => getChildProperties(c));\n        } else {\n          property[key] = el.textContent;\n        }\n      }\n      return property;\n    };\n\n    const getChildProperties = (el): {} | void => {\n      if (el) {\n        let properties = {};\n        for (const child of el.children) {\n          properties = { ...properties, ...getPropertyValue(child) };\n        }\n        return properties;\n      }\n    };\n\n    for (const properties of a) {\n      const key = properties.getAttribute('key');\n      if (!key) {\n        config = { ...config, ...getChildProperties(properties) };\n      }\n      return config;\n    }\n    console.log('Can not find qti-custom-interaction config');\n    return null;\n  }\n\n  register(pci: IMSpci<unknown>) {\n    this.pci = pci;\n\n    const type = this.parentElement.tagName === 'QTI-CUSTOM-INTERACTION' ? 'TAO' : 'IMS';\n    const dom: HTMLElement =\n      type == 'IMS' ? this.querySelector('qti-interaction-markup') : this.querySelector('markup');\n    dom.classList.add('qti-customInteraction');\n\n    if (type == 'TAO' && this.querySelector('properties')) {\n      (this.querySelector('properties') as HTMLElement).style.display = 'none';\n    }\n\n    const config: any =\n      type == 'IMS'\n        ? {\n            properties: this.dataset,\n            onready: () => {\n              console.log('onready');\n            }\n          }\n        : this.getTAOConfig(this);\n    if (type == 'IMS') {\n      pci.getInstance(dom, config, undefined);\n    } else {\n      (pci as any).initialize(this.customInteractionTypeIdentifier, dom.firstElementChild, config);\n    }\n    if (type == 'TAO') {\n      const links = Array.from(this.querySelectorAll('link')).map(acc => acc.getAttribute('href'));\n      links.forEach(link => {\n        const styles = document.createElement('link');\n        styles.rel = 'stylesheet';\n        styles.type = 'text/css';\n        styles.media = 'screen';\n        styles.href = link;\n        dom.appendChild(styles);\n      });\n    }\n    this.startChecking();\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n\n    define('qtiCustomInteractionContext', () => {\n      return {\n        register: ctxA => {\n          this.register(ctxA);\n        },\n        notifyReady: () => {\n          /* only used in the TAO version */\n        }\n      };\n    });\n\n    const config = this.buildRequireConfig();\n    const requirePCI = requirejs.config(config);\n    requirePCI(['require'], require => {\n      // eslint-disable-next-line import/no-dynamic-require\n      require([this.module]);\n    });\n  }\n\n  override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    requirejs.undef(this.customInteractionTypeIdentifier);\n    // Clear the modules in the context\n    const context = requirejs.s.contexts;\n    delete context[this.customInteractionTypeIdentifier];\n    this.stopChecking();\n  }\n\n  buildRequireConfig() {\n    // Set RequireJS paths and shim configuration if available\n    const config: ModuleResolutionConfig = {\n      context: this.customInteractionTypeIdentifier,\n      catchError: true,\n      paths: window['requirePaths'] || {},\n      shim: window['requireShim'] || {}\n    };\n    // Check if RequireJS is available, if not, set an error message\n    if (!globalThis.require) {\n      this._errorMessage = `RequireJS not found. Please load it via CDN: https://cdnjs.com/libraries/require.js`;\n      return null;\n    }\n    const baseUrl = this.getAttribute('data-base-url');\n    const interactionModules = this.querySelector('qti-interaction-modules');\n\n    if (interactionModules) {\n      const modules = interactionModules.querySelectorAll('qti-interaction-module');\n      for (const module of modules) {\n        const moduleId = module.getAttribute('id');\n        const primaryPath = module.getAttribute('primary-path');\n        const fallbackPath = module.getAttribute('fallback-path');\n\n        if (moduleId && primaryPath) {\n          // Set the paths using RequireJS's fallback array\n          const paths = fallbackPath\n            ? this.combineRequireResolvePaths(\n                this.getResolvablePath(primaryPath, baseUrl),\n                this.getResolvablePath(fallbackPath, baseUrl)\n              )\n            : this.getResolvablePath(primaryPath, baseUrl);\n          const existingPath = config.paths[moduleId] || [];\n          config.paths[moduleId] = this.combineRequireResolvePaths(existingPath, paths);\n        }\n      }\n    }\n    return config;\n  }\n\n  private combineRequireResolvePaths(path1: string | string[], path2: string | string[]) {\n    const path1Array = Array.isArray(path1) ? path1 : [path1];\n    const path2Array = Array.isArray(path2) ? path2 : [path2];\n    return path1Array.concat(path2Array);\n  }\n\n  private removeDoubleSlashes(str: string) {\n    const singleForwardSlashes = str\n      .replace(/([^:]\\/)\\/+/g, '$1')\n      .replace(/\\/\\//g, '/')\n      .replace('http:/', 'http://')\n      .replace('https:/', 'https://');\n    return singleForwardSlashes;\n  }\n\n  loadConfig = async (url: string, baseUrl?: string): Promise<ModuleResolutionConfig> => {\n    url = this.removeDoubleSlashes(url);\n    try {\n      const requireConfig = await fetch(url);\n      if (requireConfig.ok) {\n        const config = await requireConfig.json();\n        const moduleCong = config as ModuleResolutionConfig;\n        for (const moduleId in moduleCong.paths) {\n          if (baseUrl) {\n            moduleCong.paths[moduleId] = this.getResolvablePath(moduleCong.paths[moduleId], baseUrl);\n          }\n        }\n        return moduleCong;\n      }\n    } catch (e) {\n      // do nothing\n    }\n    return null;\n  };\n\n  getResolvablePathString = (path: string, basePath?: string) => {\n    path = path.replace(/\\.js$/, '');\n    return path?.toLocaleLowerCase().startsWith('http') || !basePath\n      ? path\n      : this.removeDoubleSlashes(`${basePath}/${path}`);\n  };\n\n  getResolvablePath = (path: string | string[], basePath?: string) => {\n    return Array.isArray(path)\n      ? path.map(p => this.getResolvablePathString(p, basePath))\n      : this.getResolvablePathString(path, basePath);\n  };\n\n  override render() {\n    return html`<slot></slot>${this._errorMessage &&\n      html`<div style=\"color:red\">\n        <h1>Error</h1>\n        ${this._errorMessage}\n      </div>`}`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-portable-custom-interaction': QtiPortableCustomInteraction;\n  }\n}\n", "import { CSSResultGroup, LitElement, html } from 'lit';\n\nimport { customElement, state } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-associate-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n@customElement('qti-associate-interaction')\nexport class QtiAssociateInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-simple-associable-choice',\n  true,\n  '.dl'\n) {\n  @state() private _childrenMap: Element[] = [];\n\n  static styles: CSSResultGroup = styles;\n  // dragDropApi: TouchDragAndDrop;\n\n  private _registerChoiceHandler: (event: CustomEvent) => void;\n\n  constructor() {\n    super();\n    this._registerChoiceHandler = this._registerChoice.bind(this);\n    this.addEventListener('register-qti-simple-associable-choice', this._registerChoiceHandler);\n  }\n\n  private _registerChoice(event: CustomEvent) {\n    const choice = event.target as QtiSimpleAssociableChoice;\n    this._childrenMap.push(choice);\n  }\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot name=\"qti-simple-associable-choice\"></slot>\n      <div part=\"drop-container\">\n        ${this._childrenMap.length > 0 &&\n        Array.from(Array(Math.ceil(this._childrenMap.length / 2)).keys()).map(\n          (_, index) =>\n            html`<div part=\"associables-container\">\n              <div name=\"left${index}\" part=\"drop-list\" class=\"dl\" identifier=\"droplist${index}_left\"></div>\n              <div name=\"right${index}\" part=\"drop-list\" class=\"dl\" identifier=\"droplist${index}_right\"></div>\n            </div>`\n        )}\n      </div>`;\n  }\n\n  disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('register-qti-simple-associable-choice', this._registerChoiceHandler);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-associate-interaction': QtiAssociateInteraction;\n  }\n}\n", "export class TouchDragAndDrop {\n  private touchStartTime = 0; // Timestamp of the first touch\n  private touchStartPoint = null; // Point of the first touch\n  private lastClickTime = 0; // Timestamp of the previous click\n  private isDraggable = false; // Whether a draggable element is active\n  private dragSource: HTMLElement = null; // The source element being dragged\n  private dragClone: HTMLElement = null; // Clone of drag source for visual feedback\n  private touchEndTriggered = false; // Flag for touchEnd event\n  private isDragging = false; // Whether a drag operation is ongoing\n  private initialTransform = ''; // Original transform style\n  private hasDispatchedDragStart = false; // Flag to ensure dragstart event is dispatched once\n  private rootNode: Node = null; // Root node for boundary calculations\n\n  private focusedElement: HTMLElement = null; // To keep track of the currently focused draggable element\n  private focusableDropZones: HTMLElement[] = []; // All dropzones for keyboard navigation\n  private currentDropZoneIndex = -1; // Index for tabbing through drop zones\n\n  private dataTransfer = {\n    data: {},\n    setData(type, val) {\n      this.data[type] = val;\n    },\n    getData(type) {\n      return this.data[type];\n    },\n    effectAllowed: 'move'\n  };\n  private cloneOffset = { x: 0, y: 0 }; // Offset for positioning the drag clone\n\n  private lastTarget = null; // Last touch target\n  private currentDropTarget = null; // Current droppable element\n  private allowClick = true; // Flag to allow or prevent click\n  private static instance: TouchDragAndDrop;\n\n  copyStylesForDragClone = true;\n  dragOnClickEnabled = false;\n  useDragClone = false; // Set to true to drag with a clone; set to false to drag the original element\n\n  private readonly MIN_DRAG_DISTANCE = 5; // Minimum pixel movement to start dragging\n  private readonly DRAG_CLONE_OPACITY = 1; // Opacity of the drag clone element\n  initialTransition: string;\n  // droppables: Element[];\n\n  constructor() {\n    if (TouchDragAndDrop.instance) {\n      return TouchDragAndDrop.instance;\n    }\n    TouchDragAndDrop.instance = this;\n\n    // Add event listeners for touch and mouse interactions\n    document.addEventListener('touchmove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('mousemove', this.handleTouchMove.bind(this), { passive: false });\n    document.addEventListener('touchend', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('mouseup', this.handleTouchEnd.bind(this), { passive: false });\n    document.addEventListener('touchcancel', this.handleTouchCancel.bind(this), { passive: false });\n\n    document.addEventListener('keydown', this.handleKeyDown.bind(this));\n    document.addEventListener('keyup', this.handleKeyUp.bind(this));\n  }\n\n  addDraggableElements(draggables: Element[]) {\n    draggables.forEach(el => {\n      el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n      el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n      el.addEventListener('blur', () => (this.focusedElement = null));\n\n      el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n      el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n    });\n  }\n\n  // addDroppableElements(droppables: Element[]) {\n  //   // this.droppables = droppables;\n  //   droppables.forEach(el => {\n  //     el.setAttribute('tabindex', '0'); // Make draggable elements focusable\n  //     el.addEventListener('focus', () => (this.focusedElement = el as HTMLElement));\n  //     el.addEventListener('blur', () => (this.focusedElement = null));\n\n  //     // el.addEventListener('touchstart', this.handleTouchStart.bind(this), { passive: false });\n  //     // el.addEventListener('mousedown', this.handleTouchStart.bind(this), { passive: false });\n  //   });\n  // }\n\n  private handleTouchStart(e) {\n    this.touchStartTime = Date.now();\n    const { x, y } = this.getEventCoordinates(e);\n    this.touchStartPoint = { x, y };\n    this.dragSource = e.currentTarget;\n    this.isDraggable = true;\n\n    // Get the root node\n    this.rootNode = this.dragSource.getRootNode();\n\n    if (this.dragOnClickEnabled) {\n      this.isDragging = true;\n      this.createDragClone(e, { clientX: x, clientY: y });\n    }\n\n    if (!this.useDragClone) {\n      // Save initial transform\n      const computedStyle = window.getComputedStyle(this.dragSource);\n      this.initialTransform = computedStyle.transform === 'none' ? '' : computedStyle.transform;\n\n      // Save the original transition style\n      this.initialTransition = computedStyle.transition || '';\n\n      // Disable transitions\n      this.dragSource.style.transition = 'none';\n\n      // Calculate clone offset\n      const rect = this.dragSource.getBoundingClientRect();\n      this.cloneOffset.x = x - rect.left;\n      this.cloneOffset.y = y - rect.top;\n\n      // Set higher z-index to bring it on top\n      this.dragSource.style.zIndex = '9999';\n      // this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n      this.dragSource.focus();\n    }\n\n    e.preventDefault();\n  }\n\n  private handleTouchMove(e) {\n    if (this.isDraggable && this.dragSource) {\n      const { x, y } = this.getEventCoordinates(e);\n      const currentTouch = { clientX: x, clientY: y };\n\n      if (this.calculateDragDistance(currentTouch) >= this.MIN_DRAG_DISTANCE) {\n        this.dragSource.style.pointerEvents = 'none'; // So it doesn't block events\n        this.isDragging = true;\n      }\n\n      this.createDragClone(e, currentTouch);\n      e.preventDefault();\n    }\n  }\n\n  private createDragClone(e, currentTouch: { clientX: number; clientY: number }) {\n    if (!this.isDragging) return;\n\n    if (this.useDragClone) {\n      // Existing code for creating and handling the drag clone\n      if (!this.dragClone) {\n        this.dragSource.style.opacity = this.DRAG_CLONE_OPACITY.toString();\n        this.dragClone = this.dragSource.cloneNode(true) as HTMLElement;\n\n        if (this.copyStylesForDragClone) {\n          const computedStyles = window.getComputedStyle(this.dragSource);\n          for (const style of computedStyles) {\n            this.dragClone.style[style] = computedStyles.getPropertyValue(style);\n          }\n        }\n\n        // Move the drag clone to the root node\n        if (this.rootNode instanceof ShadowRoot) {\n          // Append to the host of the shadow root\n          this.rootNode.host.appendChild(this.dragClone);\n        } else if (this.rootNode instanceof Document) {\n          document.body.appendChild(this.dragClone);\n        }\n\n        this.calculateClonePosition(currentTouch);\n        this.setDragCloneStyles(currentTouch);\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      }\n\n      this.updateDragClonePosition(currentTouch);\n    } else {\n      // Handle dragging the original element using CSS transforms\n      if (this.touchStartPoint) {\n        const deltaX = currentTouch.clientX - this.touchStartPoint.x;\n        const deltaY = currentTouch.clientY - this.touchStartPoint.y;\n\n        // Apply boundaries\n        // const { boundedDeltaX, boundedDeltaY } = this.applyTransformBoundaries(deltaX, deltaY);\n        // this.dragSource.style.transform = `${this.initialTransform} translate(${boundedDeltaX}px, ${boundedDeltaY}px)`;\n\n        this.dragSource.style.transform = `${this.initialTransform} translate(${deltaX}px, ${deltaY}px)`;\n\n        if (!this.hasDispatchedDragStart) {\n          this.dispatchCustomEvent(this.dragSource, 'dragstart');\n          this.hasDispatchedDragStart = true;\n        }\n      }\n    }\n\n    const dropTarget = this.findDropTarget(e);\n\n    if (dropTarget !== this.lastTarget) {\n      this.dispatchCustomEvent(dropTarget, 'dragenter');\n      this.dispatchCustomEvent(this.lastTarget, 'dragleave');\n      this.lastTarget = dropTarget;\n    }\n\n    this.currentDropTarget = dropTarget;\n    if (this.currentDropTarget) this.dispatchCustomEvent(dropTarget, 'dragover');\n  }\n\n  private handleTouchEnd(e) {\n    this.touchEndTriggered = true;\n    this.isDraggable = false;\n    let dropFound = false;\n\n    // console.log('dropFound', dropFound);\n\n    if (this.currentDropTarget) {\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      dropFound = true;\n    } else if (this.isDragging) {\n      const dragEndEvent = new CustomEvent('dragend', { bubbles: true, cancelable: true });\n      dragEndEvent['dataTransfer'] = { dropEffect: 'none' };\n      this.dragSource?.dispatchEvent(dragEndEvent);\n    }\n\n    this.resetDragState(dropFound);\n  }\n\n  private handleTouchCancel(e) {\n    this.resetDragState();\n  }\n\n  private findDropTarget(event) {\n    const { x, y } = this.getEventCoordinates(event);\n    return this.getDropTargetAtPoint(document, x, y);\n  }\n\n  private getDropTargetAtPoint(root: DocumentOrShadowRoot, x: number, y: number, depth: number = 0): Element | null {\n    // Limit the recursion depth\n    const MAX_DEPTH = 2;\n    if (depth > MAX_DEPTH) {\n      return null;\n    }\n\n    const element = root.elementFromPoint(x, y) as HTMLElement;\n\n    if (!element) {\n      return null;\n    }\n\n    if (element.hasAttribute('dropzone')) {\n      return element;\n    }\n\n    // Traverse up the DOM tree to find an ancestor with 'dropzone' attribute\n    let currentElement = element.parentElement;\n    while (currentElement) {\n      if (currentElement.hasAttribute('dropzone')) {\n        return currentElement;\n      }\n      currentElement = currentElement.parentElement;\n    }\n\n    // If the element has a Shadow DOM and depth limit not reached, traverse it\n    if (element.shadowRoot && depth < MAX_DEPTH) {\n      const shadowElement = this.getDropTargetAtPoint(element.shadowRoot, x, y, depth + 1);\n      if (shadowElement) {\n        return shadowElement;\n      }\n    }\n\n    // No element with 'dropzone' found\n    return null;\n  }\n\n  private handleKeyDown(e: KeyboardEvent) {\n    if (this.focusedElement) {\n      if (e.key === ' ' && !this.isDragging) {\n        // Spacebar pressed to start dragging\n        e.preventDefault();\n        this.isDraggable = true;\n        this.dragSource = this.focusedElement;\n        this.isDragging = true;\n\n        // Store the drop zones for navigation\n        this.collectDropZones();\n\n        // Trigger dragstart event\n        this.dispatchCustomEvent(this.dragSource, 'dragstart');\n      } else if (e.key === 'Tab' && this.isDragging) {\n        // Tab key to navigate through drop zones\n        e.preventDefault();\n        this.moveToNextDropZone();\n      }\n    }\n  }\n\n  private handleKeyUp(e: KeyboardEvent) {\n    if (e.key === ' ' && this.isDragging && this.currentDropTarget) {\n      // Spacebar pressed again to drop the element\n      e.preventDefault();\n      this.dispatchCustomEvent(this.currentDropTarget, 'drop');\n      this.dispatchCustomEvent(this.dragSource, 'dragend');\n      this.resetDragState(true);\n    }\n  }\n\n  private collectDropZones() {\n    // Collect all elements with dropzone attribute\n    this.focusableDropZones = Array.from(document.querySelectorAll('[dropzone]')) as HTMLElement[]; // Array.from(this.droppables);\n    this.currentDropZoneIndex = -1; // Reset navigation index\n  }\n\n  private moveToNextDropZone() {\n    if (this.focusableDropZones.length === 0) return;\n\n    // Update index for the next drop zone\n    this.currentDropZoneIndex = (this.currentDropZoneIndex + 1) % this.focusableDropZones.length;\n\n    // Focus the next drop zone\n    const nextDropZone = this.focusableDropZones[this.currentDropZoneIndex];\n    nextDropZone.focus();\n\n    // Update current drop target\n    this.currentDropTarget = nextDropZone;\n\n    // Dispatch dragenter event\n    this.dispatchCustomEvent(nextDropZone, 'dragenter');\n  }\n\n  private getEventCoordinates(event, page = false) {\n    const touch = event.touches ? event.touches[0] : event;\n    return {\n      x: page ? touch.pageX : touch.clientX,\n      y: page ? touch.pageY : touch.clientY\n    };\n  }\n\n  private calculateClonePosition(touch) {\n    const rect = this.dragSource.getBoundingClientRect();\n    this.cloneOffset.x = touch.clientX - rect.left;\n    this.cloneOffset.y = touch.clientY - rect.top;\n  }\n\n  private setDragCloneStyles(touch) {\n    this.dragClone.style.position = 'fixed';\n    this.dragClone.style.top = `${touch.clientY - this.cloneOffset.y}px`;\n    this.dragClone.style.left = `${touch.clientX - this.cloneOffset.x}px`;\n    this.dragClone.style.pointerEvents = 'none';\n    this.dragClone.style.zIndex = '999999';\n  }\n\n  private updateDragClonePosition(touch) {\n    requestAnimationFrame(() => {\n      if (this.touchEndTriggered || !this.dragClone) return;\n\n      const newLeft = touch.clientX - this.cloneOffset.x;\n      const newTop = touch.clientY - this.cloneOffset.y;\n\n      // Apply boundaries\n      const { newLeft: boundedLeft, newTop: boundedTop } = this.applyBoundaries(newLeft, newTop, this.dragClone);\n\n      this.dragClone.style.left = `${boundedLeft}px`;\n      this.dragClone.style.top = `${boundedTop}px`;\n    });\n  }\n\n  private applyTransformBoundaries(deltaX: number, deltaY: number) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions and position of the element\n    const elementRect = this.dragSource.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Calculate potential new position\n    const newLeft = elementRect.left + deltaX;\n    const newTop = elementRect.top + deltaY;\n\n    // Limit the new position within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    // Calculate the bounded delta values\n    const boundedDeltaX = boundedLeft - elementRect.left;\n    const boundedDeltaY = boundedTop - elementRect.top;\n\n    return { boundedDeltaX, boundedDeltaY };\n  }\n\n  private applyBoundaries(newLeft: number, newTop: number, element: HTMLElement) {\n    // Get the boundaries of the root node\n    let boundaryRect: DOMRect;\n    if (this.rootNode instanceof ShadowRoot) {\n      boundaryRect = this.rootNode.host.getBoundingClientRect();\n    } else if (this.rootNode instanceof Document) {\n      boundaryRect = document.documentElement.getBoundingClientRect();\n    } else {\n      // Default to viewport\n      boundaryRect = new DOMRect(0, 0, window.innerWidth, window.innerHeight);\n    }\n\n    // Get the dimensions of the element\n    const elementRect = element.getBoundingClientRect();\n    const elementWidth = elementRect.width;\n    const elementHeight = elementRect.height;\n\n    // Limit the newLeft and newTop within the boundaries\n    const boundedLeft = Math.max(boundaryRect.left, Math.min(newLeft, boundaryRect.right - elementWidth));\n    const boundedTop = Math.max(boundaryRect.top, Math.min(newTop, boundaryRect.bottom - elementHeight));\n\n    return { newLeft: boundedLeft, newTop: boundedTop };\n  }\n\n  private calculateDragDistance(touch): number {\n    const xDist = Math.abs(touch.clientX - this.touchStartPoint.x);\n    const yDist = Math.abs(touch.clientY - this.touchStartPoint.y);\n    return xDist + yDist;\n  }\n\n  private dispatchCustomEvent(element, eventType, bubble = true) {\n    if (!element) return;\n    const event = new CustomEvent(eventType, { bubbles: bubble, cancelable: true });\n    event['dataTransfer'] = this.dataTransfer;\n    element.dispatchEvent(event);\n  }\n\n  private resetDragState(dropFound: boolean = false) {\n    if (this.isDragging) {\n      if (this.useDragClone) {\n        this.dragSource.style.opacity = '1.0';\n        this.dragClone?.parentElement.removeChild(this.dragClone);\n      } else {\n        // Restore original styles\n        if (!dropFound) this.dragSource.style.transform = 'translate(0, 0)';\n        this.dragSource.style.zIndex = '';\n        this.dragSource.style.pointerEvents = '';\n        // Restore the original transition style\n        this.dragSource.style.transition = this.initialTransition;\n\n        // Reset the original transition property\n        this.initialTransition = '';\n      }\n    }\n\n    this.isDragging = false;\n    this.dragSource = null;\n    this.dragClone = null;\n    this.isDraggable = false;\n    this.touchStartTime = 0;\n    this.touchStartPoint = null;\n    this.touchEndTriggered = false;\n    this.dataTransfer = {\n      data: {},\n      setData(type, val) {\n        this.data[type] = val;\n      },\n      getData(type) {\n        return this.data[type];\n      },\n      effectAllowed: 'move'\n    };\n    this.cloneOffset = { x: 0, y: 0 };\n    this.lastTarget = null;\n    this.currentDropTarget = null;\n    this.allowClick = true;\n    this.initialTransform = '';\n    this.hasDispatchedDragStart = false;\n\n    this.rootNode = null;\n  }\n}\n", "import { LitElement } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ndeclare class DroppablesInterface {}\n\nexport const DroppablesMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  useShadowRoot: boolean,\n  droppablesSelector: string\n) => {\n  abstract class DroppablesElement extends superClass {\n    private observer: MutationObserver;\n\n    @property({ type: Boolean, reflect: true }) disabled = false;\n\n    override firstUpdated(changedProps): void {\n      if (this.isMatchTabular()) return;\n      super.firstUpdated(changedProps);\n\n      const droppables = this.getDroppableElements();\n      this.initializeEventHandlers();\n      droppables.forEach(droppable => {\n        this.prepareDroppable(droppable);\n        this.observeDroppableAttributes(droppable);\n      });\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private getDroppableElements(): Element[] {\n      return Array.from(\n        useShadowRoot ? this.shadowRoot.querySelectorAll(droppablesSelector) : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private initializeEventHandlers(): void {\n      this.dragoverHandler = this.dragoverHandler.bind(this);\n      this.dragleaveHandler = this.dragleaveHandler.bind(this);\n      this.dragenterHandler = this.dragenterHandler.bind(this);\n      this.dropHandler = this.dropHandler.bind(this);\n    }\n\n    private prepareDroppable(droppable: Element): void {\n      droppable.setAttribute('dropzone', 'move');\n      droppable.addEventListener('dragleave', this.dragleaveHandler);\n      this.attachEventListeners(droppable);\n    }\n\n    private observeDroppableAttributes(droppable: Element): void {\n      this.observer = new MutationObserver(mutations => {\n        mutations.forEach(({ attributeName }) => {\n          if (attributeName === 'disabled') {\n            this.toggleDroppableHandlers(droppable);\n          }\n        });\n      });\n      this.observer.observe(droppable, { attributes: true });\n    }\n\n    private toggleDroppableHandlers(droppable: Element): void {\n      const disabled = droppable.hasAttribute('disabled');\n      if (disabled) {\n        this.removeEventListeners(droppable);\n      } else {\n        this.attachEventListeners(droppable);\n      }\n    }\n\n    private attachEventListeners(droppable: Element): void {\n      droppable.addEventListener('dragover', this.dragoverHandler);\n      droppable.addEventListener('dragenter', this.dragenterHandler);\n      droppable.addEventListener('drop', this.dropHandler);\n    }\n\n    private removeEventListeners(droppable: Element): void {\n      droppable.removeEventListener('dragover', this.dragoverHandler);\n      droppable.removeEventListener('dragenter', this.dragenterHandler);\n      droppable.removeEventListener('drop', this.dropHandler);\n    }\n\n    override disconnectedCallback(): void {\n      if (this.isMatchTabular()) return;\n      super.disconnectedCallback();\n      this.observer?.disconnect();\n    }\n\n    private dragenterHandler(ev: DragEvent): void {\n      ev.preventDefault();\n    }\n\n    private dragoverHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.activateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'move';\n      return false;\n    }\n\n    private activateDroppable(droppable: HTMLElement): void {\n      droppable.setAttribute('active', '');\n    }\n\n    private async dropHandler(ev: DragEvent): Promise<boolean> {\n      ev.preventDefault();\n      const droppable = ev.currentTarget as HTMLElement;\n      const identifier = ev.dataTransfer.getData('text');\n      const draggable = this.findDraggable(identifier);\n      // console.log(this.isValidDrop(droppable, draggable));\n\n      if (!draggable) return false;\n      if (draggable && !this.isValidDrop(droppable, draggable)) {\n        draggable.style.transform = 'translate(0, 0)';\n        return false;\n      }\n\n      await this.moveDraggableToDroppable(draggable, droppable);\n      this.deactivateDroppable(droppable);\n      return false;\n    }\n\n    private findDraggable(identifier: string): HTMLElement | null {\n      if (!identifier) return null;\n      return (\n        this.querySelector(`[identifier=${identifier}]`) || this.shadowRoot.querySelector(`[identifier=${identifier}]`)\n      );\n    }\n\n    private isValidDrop(droppable: HTMLElement, draggable: HTMLElement): boolean {\n      return draggable.parentElement.getAttribute('identifier') !== droppable.getAttribute('identifier');\n    }\n\n    private async moveDraggableToDroppable(draggable: HTMLElement, droppable: HTMLElement): Promise<void> {\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n\n        // checkMaxAssociations and saveResponse are defined/overridden in a mixin\n        this['checkMaxAssociations']();\n        this['saveResponse'](null); //\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n        return;\n      }\n\n      const transition = document.startViewTransition(moveElement);\n      await transition.finished;\n\n      // this['checkMaxAssociations']();\n    }\n\n    private deactivateDroppable(droppable: HTMLElement): void {\n      droppable.removeAttribute('active');\n    }\n\n    private dragleaveHandler(ev: DragEvent): boolean {\n      ev.preventDefault();\n      this.deactivateDroppable(ev.currentTarget as HTMLElement);\n      ev.dataTransfer.dropEffect = 'none';\n      return false;\n    }\n  }\n  return DroppablesElement as Constructor<DroppablesInterface> & T;\n};\n", "// THIS IS A MIXIN, THIS IS A MIXIN\n// USE LIKE THIS\n// ```class DropList extends Flippables(LitElement) {```\n// mixin which animates children with FLIP\n// a combination between this directive:\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\n// and a tutorial how to make a mixin\n// https://lit.dev/docs/composition/mixins/\n\nimport { LitElement } from 'lit';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\nexport declare class FlippablesInterface {\n  connectedCallback(): void;\n  disconnectedCallback(): void;\n}\n\n// just a conversion of a angular FLIP directive, made as a Mixin\n// https://ng-run.com/edit/9MGr5dYWA20AiJtpy5az?open=app%2Fapp.component.html\nexport const FlippablesMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  droppablesSel: string,\n  draggablesSel: string\n) => {\n  abstract class FlippablesElement extends superClass {\n    // private state = new Map<Element, any>();\n    // private observer: MutationObserver;\n    // flippablesSelector: string;\n    // override async firstUpdated(changedProps) {\n    //   await this.updateComplete; // pk: this is the key to calculate correct proportions\n    //   const draggables = Array.from(this.querySelectorAll(draggablesSel));\n    //   draggables.forEach((elem) => {\n    //     const { left, top, width, height } = elem.getBoundingClientRect();\n    //     this.state.set(elem, { left, top, width, height });\n    //   });\n    //   this.observer = new MutationObserver(this.animateMe);\n    //   const droppables = Array.from(this.querySelectorAll(droppablesSel));\n    //   droppables.forEach((draggable) => {\n    //     this.observer.observe(draggable, { childList: true });\n    //   });\n    //   this.observer.observe(this, { childList: true });\n    //   super.firstUpdated(changedProps);\n    // }\n    // private animateMe = () => {\n    //   this.state.forEach((value, elem) => {\n    //     const { left, top, width, height } = elem.getBoundingClientRect();\n    //     if (this.state.get(elem) == null) {\n    //       this.state.set(elem, { left, top, width, height });\n    //     }\n    //     const cache = this.state.get(elem);\n    //     const deltaX = cache.left - left;\n    //     const deltaY = cache.top - top;\n    //     const deltaW = cache.width / width;\n    //     const deltaH = cache.height / height;\n    //     this.state.set(elem, { left, top, width, height });\n    //     const { duration, easing } = { duration: 350, easing: 'cubic-bezier(0.26, 0.86, 0.44, 0.985)' };\n    //     elem.animate(\n    //       [\n    //         {\n    //           transformOrigin: 'top left',\n    //           transform: `\n    // translate(${deltaX}px, ${deltaY}px)\n    // scale(${deltaW}, ${deltaH})\n    // `,\n    //           // width: cache.width,\n    //           // height: cache.height+ 'px',\n    //           // opacity: cache.opacity,\n    //         },\n    //         {\n    //           transformOrigin: 'top left',\n    //           transform: 'none',\n    //         },\n    //       ],\n    //       {\n    //         duration,\n    //         easing,\n    //       }\n    //     );\n    //   });\n    // };\n    // override disconnectedCallback(): void {\n    //   super.disconnectedCallback();\n    //   this.observer.disconnect();\n    // }\n  }\n  return FlippablesElement as Constructor<FlippablesInterface> & T;\n};\n", "import { LitElement } from 'lit';\nimport { IInteraction } from '../interaction/interaction.interface';\nimport { DroppablesMixin } from './droppables-mixin';\nimport { FlippablesMixin } from './flippables-mixin';\n\nimport { property } from 'lit/decorators.js';\nimport { liveQuery } from '../../../../decorators/live-query';\nimport { TouchDragAndDrop } from './drag-drop-api';\nimport { Interaction } from '../interaction/interaction';\n\ntype Constructor<T = {}> = abstract new (...args: any[]) => T;\n\ninterface InteractionConfiguration {\n  copyStylesDragClone: boolean;\n  dragCanBePlacedBack: boolean;\n  dragOnClick: boolean;\n}\n\nexport const DragDropInteractionMixin = <T extends Constructor<Interaction>>(\n  superClass: T,\n  draggablesSelector: string,\n  useShadowRootForDroppables: boolean,\n  droppablesSelector: string\n) => {\n  abstract class DragDropInteractionElement extends FlippablesMixin(\n    DroppablesMixin(superClass, useShadowRootForDroppables, droppablesSelector),\n    droppablesSelector,\n    draggablesSelector\n  ) {\n    protected draggables = new Map<HTMLElement, { parent: HTMLElement; index: number }>();\n    protected droppables: HTMLElement[] = [];\n    dragDropApi: TouchDragAndDrop;\n\n    @property({ attribute: false, type: Object }) configuration: InteractionConfiguration = {\n      copyStylesDragClone: true,\n      dragCanBePlacedBack: true,\n      dragOnClick: false\n    };\n    @property({ type: Number, reflect: true, attribute: 'min-associations' }) minAssociations = 1;\n    @property({ type: Number, reflect: true, attribute: 'max-associations' }) maxAssociations = 1;\n\n    @liveQuery(draggablesSelector)\n    handleDraggablesChange(dragsAdded: HTMLElement[], dragsRemoved: Element[]) {\n      if (this.isMatchTabular()) return;\n      const newDraggables = this.filterExistingDraggables(dragsAdded);\n\n      if (newDraggables.length > 0) {\n        this.addNewDraggables(newDraggables);\n      }\n    }\n\n    override firstUpdated(changedProps): void {\n      super.firstUpdated(changedProps);\n      this.initializeDroppables();\n    }\n\n    override connectedCallback() {\n      super.connectedCallback();\n      this.initializeDragDropApi();\n    }\n\n    private initializeDragDropApi() {\n      this.dragDropApi = new TouchDragAndDrop();\n      this.dispatchEvent(\n        new CustomEvent<DragDropInteractionElement>('qti-register-interaction', {\n          bubbles: true,\n          composed: true,\n          detail: this\n        })\n      );\n    }\n\n    private isMatchTabular(): boolean {\n      return this.classList.contains('qti-match-tabular');\n    }\n\n    private filterExistingDraggables(draggables: HTMLElement[]): HTMLElement[] {\n      return draggables.filter(d => !this.draggables.has(d));\n    }\n\n    private addNewDraggables(draggables: HTMLElement[]): void {\n      this.dragDropApi.addDraggableElements(draggables);\n      draggables.forEach(draggable => this.storeDraggable(draggable));\n    }\n\n    private storeDraggable(draggable: HTMLElement): void {\n      const index = Array.from(draggable.parentNode.children).indexOf(draggable);\n      this.draggables.set(draggable, {\n        parent: draggable.parentElement,\n        index\n      });\n      draggable.style.viewTransitionName = `drag-${index}-${this.getAttribute('identifier') || crypto.randomUUID()}`;\n      draggable.setAttribute('qti-draggable', 'true');\n      draggable.addEventListener('dragstart', this.handleDragStart);\n      draggable.addEventListener('dragend', this.handleDragEnd);\n    }\n\n    private initializeDroppables(): void {\n      this.droppables = Array.from(\n        useShadowRootForDroppables\n          ? this.shadowRoot.querySelectorAll(droppablesSelector)\n          : this.querySelectorAll(droppablesSelector)\n      );\n    }\n\n    private handleDragStart = (ev: DragEvent) => {\n      const target = ev.currentTarget as HTMLElement;\n      ev.dataTransfer.setData('text', target.getAttribute('identifier'));\n      target.setAttribute('dragging', '');\n      this.activateDroppables();\n    };\n\n    private handleDragEnd = async (ev: DragEvent) => {\n      ev.preventDefault();\n      this.deactivateDroppables();\n      const draggable = ev.currentTarget as HTMLElement;\n      draggable.removeAttribute('dragging');\n      const wasDropped = await this.wasDropped(ev);\n      if (!wasDropped) {\n        if (this.configuration.dragCanBePlacedBack) {\n          this.restoreInitialDraggablePosition(draggable);\n        }\n      }\n    };\n\n    private activateDroppables(): void {\n      this.droppables.forEach(d => d.setAttribute('enabled', ''));\n    }\n\n    private deactivateDroppables(): void {\n      this.droppables.forEach(d => d.removeAttribute('enabled'));\n    }\n\n    // MH: This method is just to make sure this can be tested.\n    // because I can't get the dropEffect to be 'move' in the test\n    private checkForMoveTestItem = (ev: DragEvent): Promise<boolean> => {\n      if (!ev.dataTransfer.items) {\n        return Promise.resolve(false);\n      }\n      return new Promise(resolve => {\n        let hasMoveTestItem = false;\n\n        // Iterate over all dataTransfer items\n        const items = Array.from(ev.dataTransfer.items);\n        const pending = items.length;\n\n        // If there are no items, resolve immediately\n        if (pending === 0) {\n          resolve(false);\n          return;\n        }\n\n        items.forEach(item => {\n          if (item.kind === 'string' && item.type === 'text') {\n            item.getAsString(data => {\n              if (data === 'move-test') {\n                hasMoveTestItem = true;\n              }\n\n              // Resolve the promise after processing all items\n              if (pending === 0) {\n                resolve(hasMoveTestItem);\n              }\n            });\n          } else {\n            // If the item is not 'string', still count down pending\n            if (pending === 0) {\n              resolve(hasMoveTestItem);\n            }\n          }\n        });\n      });\n    };\n\n    private async wasDropped(ev: DragEvent): Promise<boolean> {\n      const hasMoveTestItem = await this.checkForMoveTestItem(ev);\n      return ev.dataTransfer.dropEffect !== 'none' || hasMoveTestItem;\n    }\n\n    private wasMoved(ev: DragEvent): boolean {\n      return ev.dataTransfer.dropEffect === 'move';\n    }\n\n    private async restoreInitialDraggablePosition(draggable: HTMLElement): Promise<void> {\n      const { parent, index } = this.draggables.get(draggable);\n      const targetIndex = Math.min(index, parent.children.length);\n\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n        draggable.style.transform = 'translate(0, 0)';\n        this.checkMaxAssociations();\n      };\n\n      // Fallback if view transitions are not supported\n      if (!document.startViewTransition) {\n        moveDraggable(draggable, parent, index);\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        draggable.style.transform = '';\n        moveDraggable(draggable, parent, index);\n      });\n      // transition.finished.then(() => {\n      //   draggable.style.transition = '';\n      // });\n    }\n\n    protected checkMaxAssociations(): void {\n      this.droppables.forEach((d, index) => {\n        const maxMatch = +(d.getAttribute('match-max') || 1);\n        const currentAssociations = d.querySelectorAll('[qti-draggable=\"true\"]').length;\n        const disableDroppable = currentAssociations >= maxMatch;\n        if (disableDroppable) {\n          this.disableDroppable(d);\n        } else {\n          this.enableDroppable(d);\n        }\n      });\n    }\n\n    private disableDroppable(droppable: Element): void {\n      droppable.setAttribute('disabled', '');\n      droppable.removeAttribute('dropzone');\n    }\n\n    private enableDroppable(droppable: Element): void {\n      droppable.removeAttribute('disabled');\n      droppable.setAttribute('dropzone', 'move');\n    }\n\n    get value(): string[] {\n      return this.collectResponseData();\n    }\n\n    set value(value: string[]) {\n      if (this.isMatchTabular()) return;\n\n      this.resetDroppables();\n      value?.forEach(entry => this.placeResponse(entry));\n    }\n\n    private placeResponse(response: string): void {\n      const [dropId, ...dragIds] = response.split(' ').reverse();\n      const droppable = this.findDroppableById(dropId);\n      dragIds.forEach(dragId => this.placeDraggableInDroppable(dragId, droppable));\n    }\n\n    private findDroppableById(identifier: string): Element | undefined {\n      return this.droppables.find(drop => drop.getAttribute('identifier') === identifier);\n    }\n\n    private async placeDraggableInDroppable(dragId: string, droppable: Element): Promise<void> {\n      const draggable = this.querySelector<HTMLElement>(`[identifier=${dragId}]`);\n      if (!droppable || !draggable) {\n        console.error(`Cannot find draggable or droppable with the given identifier: ${dragId}`);\n        return;\n      }\n      const moveElement = (): void => {\n        draggable.style.transform = 'translate(0, 0)';\n        droppable.appendChild(draggable);\n        this.checkMaxAssociations();\n      };\n\n      if (!document.startViewTransition) {\n        moveElement();\n      } else {\n        const transition = document.startViewTransition(moveElement);\n        await transition.finished;\n      }\n    }\n\n    validate(): boolean {\n      const validAssociations = this.getValidAssociations();\n      return this.minAssociations <= 0 || this.minAssociations <= validAssociations;\n    }\n\n    private getValidAssociations(): number {\n      return this.droppables.filter(d => d.childElementCount > 0).length;\n    }\n\n    public saveResponse(): void {\n      const response = this.collectResponseData();\n      this.dispatchEvent(\n        new CustomEvent('qti-interaction-response', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            responseIdentifier: this.responseIdentifier,\n            response\n          }\n        })\n      );\n    }\n\n    private collectResponseData(): string[] {\n      const response = this.droppables\n        .map(droppable => {\n          const draggablesInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n          const identifiers = Array.from(draggablesInDroppable).map(d => d.getAttribute('identifier'));\n          const droppableIdentifier = droppable.getAttribute('identifier');\n          return identifiers.map(id => `${id} ${droppableIdentifier}`);\n        })\n        .flat();\n      return response;\n    }\n\n    reset(save = true): void {\n      this.resetDroppables();\n      if (save) this.saveResponse();\n    }\n\n    private async resetDroppables(): Promise<void> {\n      const moveDraggable = (draggable: HTMLElement, parent: HTMLElement, index: number) => {\n        draggable.style.transform = 'translate(0, 0)';\n        const targetIndex = Math.min(index, parent.children.length);\n        parent.insertBefore(draggable, parent.children[targetIndex]);\n      };\n\n      if (!document.startViewTransition) {\n        // Fallback if view transitions are not supported\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n        return;\n      }\n\n      // Use view transitions if supported\n      const transition = document.startViewTransition(() => {\n        this.draggables.forEach(({ parent, index }, draggable) => {\n          moveDraggable(draggable, parent, index);\n        });\n      });\n\n      await transition.finished;\n    }\n  }\n\n  return DragDropInteractionElement as Constructor<IInteraction> & T;\n};\n", "// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n//  @watch('propName')\n//  handlePropChange(oldValue, newValue) {\n//    ...\n//  }\n\nimport type { LitElement } from 'lit';\n\ntype UpdateHandler = (prev?: unknown, next?: unknown) => void;\n\ntype NonUndefined<A> = A extends undefined ? never : A;\n\ntype UpdateHandlerFunctionKeys<T extends object> = {\n  [K in keyof T]-?: NonUndefined<T[K]> extends UpdateHandler ? K : never;\n}[keyof T];\n\ninterface LiveQueryOptions {\n  /**\n   * If true, will only start watching after the initial update/render\n   */\n}\n\nexport function liveQuery(querySelector: string, options?: LiveQueryOptions) {\n  let observer: MutationObserver;\n  const resolvedOptions: Required<LiveQueryOptions> = {\n    ...options\n  };\n  return <ElemClass extends LitElement>(\n    proto: ElemClass,\n    decoratedFnName: UpdateHandlerFunctionKeys<ElemClass>\n  ): void => {\n    const { connectedCallback, disconnectedCallback } = proto;\n\n    proto.connectedCallback = function (this: ElemClass) {\n      connectedCallback.call(this);\n      const callback = (mutationList: MutationRecord[]) => {\n        const elementsToWatch = Array.from(this.querySelectorAll(querySelector));\n        for (const mutation of mutationList) {\n          const addedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          const removedNodes = Array.from(mutation.addedNodes).map(e => e as Element);\n          if (mutation.type === 'childList' && addedNodes.find(n => elementsToWatch.includes(n))) {\n            (this[decoratedFnName] as unknown as UpdateHandler)(addedNodes, removedNodes);\n          }\n        }\n      };\n      observer = new MutationObserver(callback);\n      observer.observe(this, { childList: true, subtree: true });\n\n      const elementsAdded = this.querySelectorAll(querySelector) ?? [];\n      (this[decoratedFnName] as unknown as UpdateHandler)(Array.from(elementsAdded), []);\n    };\n\n    proto.disconnectedCallback = function (this: ElemClass) {\n      disconnectedCallback.call(this);\n      observer.disconnect();\n    };\n  };\n}\n", "import { css } from 'lit';\n\nexport default css`\n  :host {\n    display: block; /* necessary to calculate scaling position */\n  }\n  slot[name='qti-simple-associable-choice'] {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 0.5rem;\n  }\n\n  :host::part(associables-container) {\n    display: flex;\n    justify-content: space-between;\n    background: linear-gradient(\n      180deg,\n      rgb(0 0 0 / 0%) calc(50% - 1px),\n      var(--qti-border-color-gray) calc(50%),\n      rgb(0 0 0 / 0%) calc(50% + 1px)\n    );\n  }\n`;\n", "import { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { removeDoubleSlashes } from '../../internal/utils';\n\n@customElement('qti-custom-interaction')\nexport class QtiCustomInteraction extends Interaction {\n  // This custom-interaction support the CES API which is use in FACET\n  //\n  // It works like this:\n  // 1. The CI manifest is fetched\n  // 2. An iframe is created and the first style and first script from the manifest are loaded\n  // 3. The first script is bootstrap.js which also creates an iframe and loads the first media from the manifest\n  // 4. Communication is done via the CES API but because the iframe is not allowed to access the global CES object we need to use window.postMessage\n\n  // To achieve this we change the package by replacing the bootstrap.js with our own and inject a proxy CES API that communicates via postMessage\n  // Because we also want to run this in storybook, we cannot use window.top because to send messages there, because in case of storybook that is not the top window.\n  // So we send messages to all parent windows\n  private rawResponse: string;\n\n  constructor() {\n    super();\n    this.handlePostMessage = this.handlePostMessage.bind(this);\n  }\n\n  @property({ type: String, attribute: '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  get value(): string | string[] {\n    return this.rawResponse;\n  }\n\n  set value(val: string | string[]) {\n    if (typeof val === 'string') {\n      this.rawResponse = val;\n      this.saveResponse(val);\n    } else {\n      throw new Error('Value must be a string');\n    }\n  }\n\n  override disconnectedCallback(): void {\n    window.removeEventListener('message', this.handlePostMessage);\n    super.disconnectedCallback();\n  }\n\n  override render() {\n    return html`<iframe\n        width=${this.getAttribute('width')}\n        height=${this.getAttribute('height')}\n        frameborder=\"0\"\n        title=\"pciContainer\"\n        id=\"pciContainer\"\n      >\n      </iframe>\n      ${this._errorMessage &&\n      html`<div style=\"color:red\">\n        <h1>Error</h1>\n        ${this._errorMessage}\n      </div>`}`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-custom-interaction': QtiCustomInteraction;\n  }\n}\n", "import { html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\n@customElement('qti-end-attempt-interaction')\nexport class QtiEndAttemptInteraction extends Interaction {\n  @property({ type: String, attribute: 'count-attempt' })\n  public countAttempt: string = 'true';\n\n  @property({ type: String })\n  public title: 'end attempt';\n\n  validate(): boolean {\n    // not implemented by design\n    return true;\n  }\n\n  get value(): string | string[] {\n    // throw new Error('Method not implemented.');\n    return '';\n  }\n\n  set value(val: string | string[]) {\n    // not implemented by design\n  }\n\n  override render() {\n    return html`<button ?disabled=${this.disabled} part=\"button\" @click=${this.endAttempt}>${this.title}</button>`;\n  }\n  public endAttempt(e: Event) {\n    this.dispatchEvent(\n      new CustomEvent('end-attempt', {\n        bubbles: true,\n        composed: true,\n        detail: { responseIdentifier: this.responseIdentifier, countAttempt: this.countAttempt === 'true' }\n      })\n    );\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-end-attempt-interaction': QtiEndAttemptInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-gap-match-interaction')\nexport class QtiGapMatchInteraction extends DragDropInteractionMixin(Interaction, 'qti-gap-text', false, 'qti-gap') {\n  static override styles = [\n    css`\n      :host {\n        display: flex;\n        align-items: flex-start;\n        flex-direction: column;\n        gap: 0.5rem;\n      }\n\n      :host(.qti-choices-top) {\n        flex-direction: column;\n      }\n      :host(.qti-choices-bottom) {\n        flex-direction: column-reverse;\n      }\n      :host(.qti-choices-left) {\n        flex-direction: row;\n      }\n      :host(.qti-choices-right) {\n        flex-direction: row-reverse;\n      }\n      /* [part='drops'] , */\n      [part='drags'] {\n        display: flex;\n        align-items: flex-start;\n        flex: 1;\n        gap: 0.5rem;\n      }\n    `\n  ];\n\n  override render() {\n    return html`<slot name=\"prompt\"> </slot><slot part=\"drags\" name=\"qti-gap-text\"></slot> <slot part=\"drops\"></slot>`;\n  }\n\n  set correctResponse(value: string | string[]) {\n    let matches: { text: string; gap: string }[] = [];\n    const response = Array.isArray(value) ? value : [value];\n\n    if (response) {\n      matches = response.map(x => {\n        const split = x.split(' ');\n        return { text: split[0], gap: split[1] };\n      });\n    }\n\n    const gaps = this.querySelectorAll('qti-gap');\n    gaps.forEach((gap, index) => {\n      const identifier = gap.getAttribute('identifier');\n      const textIdentifier = matches.find(x => x.gap === identifier)?.text;\n      const text = this.querySelector(`qti-gap-text[identifier=\"${textIdentifier}\"]`)?.textContent.trim();\n      if (textIdentifier && text) {\n        if (!gap.nextElementSibling?.classList.contains('correct-option')) {\n          const textSpan = document.createElement('span');\n          textSpan.classList.add('correct-option');\n          textSpan.textContent = text;\n          gap.insertAdjacentElement('afterend', textSpan);\n        }\n      } else if (gap.nextElementSibling?.classList.contains('correct-option')) {\n        gap.nextElementSibling.remove();\n      }\n    });\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-match-interaction': QtiGapMatchInteraction;\n  }\n}\n", "import { css, html, svg } from 'lit';\nimport { customElement, query, queryAssignedElements, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { Interaction } from '../internal/interaction/interaction';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\n@customElement('qti-graphic-associate-interaction')\nexport class QtiGraphicAssociateInteraction extends Interaction {\n  choiceOrdering: boolean;\n  hotspots;\n  startPoint = null;\n  endPoint = null;\n  @state() _lines = [];\n  @state() startCoord: { x: any; y: any };\n  @state() mouseCoord: { x: number; y: number };\n  @query('svg') svgContainer;\n  @queryAssignedElements({ selector: 'img' }) grImage;\n\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        // position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n      }\n      ::slotted(qti-associable-hotspot) {\n        transform: translate(-50%, -50%);\n      }\n      line-container {\n        display: block;\n        position: relative;\n      }\n      svg {\n        position: absolute;\n        top: 0px;\n        left: 0px;\n      }\n    `\n  ];\n  svg: SVGSVGElement;\n\n  constructor() {\n    super();\n    this.addEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n\n  reset(): void {\n    this._lines = [];\n  }\n  validate(): boolean {\n    return this._lines.length > 0;\n  }\n  set value(val: string | string[]) {\n    if (Array.isArray(val)) {\n      this._lines = val;\n    }\n  }\n  get value(): string | string[] {\n    return this._lines;\n  }\n\n  override render() {\n    return html`<slot name=\"prompt\"></slot>\n      <line-container>\n        <svg\n          width=${ifDefined(this.grImage[0]?.width)}\n          height=${ifDefined(this.grImage[0]?.height)}\n          viewbox=\"0 0 ${this.grImage[0]?.width} ${this.grImage[0]?.height}\"\n        >\n          ${repeat(\n            this._lines,\n            line => line,\n            (line, index) => svg`\n              <line\n                part=\"line\"\n                x1=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[0] + ']').style.left)}\n                y1=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[0] + ']').style.top)}\n                x2=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[1] + ']').style.left)}\n                y2=${parseInt(this.querySelector<SVGLineElement>('[identifier=' + line.split(' ')[1] + ']').style.top)}\n                stroke=\"red\"\n                stroke-width=\"3\"\n                @click=${(e: Event) => {\n                  e.stopPropagation();\n                  this._lines = this._lines.filter((_, i) => i !== index);\n                  this.saveResponse(this._lines);\n                }}\n              />\n            `\n          )}\n          ${this.startPoint &&\n          svg`<line\n            part=\"point\"\n            x1=${this.startCoord.x}\n            y1=${this.startCoord.y}\n            x2=${this.mouseCoord.x}\n            y2=${this.mouseCoord.y}\n            stroke=\"red\"\n            stroke-width=\"3\"\n          />`}\n        </svg>\n        <slot></slot>\n      </line-container>`;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override firstUpdated(e): void {\n    super.firstUpdated(e);\n\n    this.hotspots = this.querySelectorAll('qti-associable-hotspot');\n\n    document.addEventListener('mousemove', event => {\n      this.mouseCoord = {\n        x: event.clientX - this.grImage[0].getBoundingClientRect().left,\n        y: event.clientY - this.grImage[0].getBoundingClientRect().top\n      };\n    });\n\n    this.hotspots.forEach(hotspot => {\n      hotspot.style.left = hotspot.getAttribute('coords').split(',')[0] + 'px';\n      hotspot.style.top = hotspot.getAttribute('coords').split(',')[1] + 'px';\n\n      hotspot.addEventListener('click', event => {\n        if (!this.startPoint) {\n          this.startPoint = event.target;\n\n          this.startCoord = {\n            x: this.startPoint.getAttribute('coords').split(',')[0],\n            y: this.startPoint.getAttribute('coords').split(',')[1]\n          };\n        } else if (!this.endPoint) {\n          this.endPoint = event.target;\n\n          this._lines = [\n            ...this._lines,\n            this.startPoint.getAttribute('identifier') + ' ' + this.endPoint.getAttribute('identifier')\n          ];\n          this.saveResponse(this._lines);\n          this.startPoint = null;\n          this.endPoint = null;\n        }\n      });\n    });\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-associate-interaction': QtiGraphicAssociateInteraction;\n  }\n}\n", "import { QtiHotspotChoice } from '../../qti-hotspot-choice';\n\nexport function positionHotspots(\n  shape: string,\n  coordsNumber: number[],\n  img: HTMLImageElement,\n  hotspot: QtiHotspotChoice\n) {\n  switch (shape) {\n    case 'circle':\n      {\n        const [centerX, centerY, radius] = coordsNumber;\n        const centerXPer = (centerX / img.width) * 100;\n        const centerYPer = (centerY / img.height) * 100;\n        const radiusPer = (radius / img.width) * 100;\n        hotspot.style.left = centerXPer - radiusPer + '%';\n        hotspot.style.top = centerYPer - radiusPer + '%';\n        hotspot.style.width = hotspot.style.height = 4 * radiusPer + 'px';\n        hotspot.style.borderRadius = `9999px`;\n      }\n      break;\n\n    case 'rect':\n      {\n        const [leftX, topY, rightX, bottomY] = coordsNumber;\n        const leftXPer = (leftX / img.width) * 100;\n        const topYPer = (topY / img.height) * 100;\n        const rightXPer = (rightX / img.width) * 100;\n        const bottomYPer = (bottomY / img.height) * 100;\n        hotspot.style.left = leftXPer + '%';\n        hotspot.style.top = topYPer + '%';\n        hotspot.style.width = rightXPer - leftXPer + '%';\n        hotspot.style.height = bottomYPer - topYPer + '%';\n      }\n      break;\n\n    case 'poly':\n      {\n        // from a,b,c,d,e,f => [{x:a, y:b},{x:c, y:d},{x:e, y:f}]\n        const polycoords = coordsNumber.reduce((acc, currentValue, currentIndex, polyC) => {\n          if (currentIndex % 2 === 1) {\n            const lastVal = acc.pop();\n            acc[acc.length] = { x: lastVal, y: polyC[currentIndex] };\n          } else {\n            acc.push(currentValue);\n          }\n          return acc;\n        }, []);\n\n        // calculate bounding box by finding the max ax min coordinates of x and y\n        const leftX = Math.min(...polycoords.map(point => point.x));\n        const rightX = Math.max(...polycoords.map(point => point.x));\n        const topY = Math.min(...polycoords.map(point => point.y));\n        const bottomY = Math.max(...polycoords.map(point => point.y));\n\n        // calculate the relative distance cause we want to use percentages\n        const leftXPer = (leftX / img.width) * 100;\n        const topYPer = (topY / img.height) * 100;\n        const rightXPer = (rightX / img.width) * 100;\n        const bottomYPer = (bottomY / img.height) * 100;\n\n        // set the hotspot on x,y and set the width and height in percentages\n        hotspot.style.left = (leftX / img.width) * 100 + '%';\n        hotspot.style.top = (topY / img.height) * 100 + '%';\n        hotspot.style.width = rightXPer - leftXPer + '%';\n        hotspot.style.height = bottomYPer - topYPer + '%';\n\n        // all the polygon points should be corrected caused they are from\n        // image 0,0 point, and should be from the hotspot point which already\n        // has been offsetted from the image in the previous few lines of code\n        // also the points have a relative distance to the image, but now have\n        // to have a relative distance from the width of the hotspot\n        const polygonData = polycoords.map(point => ({\n          x: ((point.x - leftX) / (rightX - leftX)) * 100,\n          y: ((point.y - topY) / (bottomY - topY)) * 100\n        }));\n\n        // create clip path coordinate style in percentages\n        const polyD = polygonData.map(p => Math.round(p.x) + '% ' + Math.round(p.y) + '%').join(',');\n\n        // 50% 0%, 100% 50%, 50% 100%, 0% 50%\n        hotspot.style.clipPath = `polygon(${polyD})`;\n      }\n      break;\n\n    default:\n      break;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-graphic-gap-match-interaction')\nexport class QtiGraphicGapMatchInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-gap-img',\n  false,\n  'qti-associable-hotspot'\n) {\n  static override styles = css`\n    :host {\n      display: inline-block;\n      position: relative;\n    }\n    slot[name='qti-gap-img'] {\n      display: flex;\n      gap: 1rem;\n    }\n  `;\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot></slot>\n      <slot name=\"qti-gap-img\"></slot>`;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<null>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    // positionHotspots(shape, coordsNumber, img, hotspot);\n    switch (shape) {\n      case 'circle':\n        {\n          const [centerX, centerY, radius] = coordsNumber;\n          hotspot.style.left = centerX - radius + 'px';\n          hotspot.style.top = centerY - radius + 'px';\n          hotspot.style.width = hotspot.style.height = 2 * radius + 'px';\n        }\n        break;\n\n      case 'rect':\n        {\n          const [leftX, topY, rightX, bottomY] = coordsNumber;\n          hotspot.style.left = leftX + 'px';\n          hotspot.style.top = topY + 'px';\n          hotspot.style.width = rightX - leftX + 'px';\n          hotspot.style.height = bottomY - topY + 'px';\n        }\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('qti-register-hotspot', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-gap-match-interaction': QtiGraphicGapMatchInteraction;\n  }\n}\n", "import { css, html } from 'lit';\nimport { Choice, ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\n\nimport { customElement } from 'lit/decorators.js';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { Interaction } from '../internal/interaction/interaction';\n\ntype HotspotChoice = Choice & { order: number };\n\n@customElement('qti-graphic-order-interaction')\nexport class QtiGraphicOrderInteraction extends ChoicesMixin(Interaction, 'qti-hotspot-choice') {\n  choiceOrdering: boolean;\n\n  // do not select ( highlight blue, the image)\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n      }\n    `\n  ];\n\n  override render() {\n    return html`\n      <slot name=\"prompt\"></slot>\n      <!-- slot for the prompt -->\n      <slot></slot>\n      <!-- slot for the image and hotspots -->\n    `;\n  }\n\n  private setHotspotOrder(e: CustomEvent<{ identifier: string; checked: boolean }>): void {\n    const { identifier } = e.detail;\n\n    const hotspot = this._choiceElements.find(el => el.getAttribute('identifier') === identifier) as HotspotChoice;\n\n    const maxSelection = this._choiceElements.length;\n    if (!this.choiceOrdering) {\n      this.choiceOrdering = true;\n      if (hotspot.order == null) {\n        if ((this._choiceElements as HotspotChoice[]).filter(i => i.order > 0).length >= maxSelection) {\n          this.choiceOrdering = false;\n          return; // don't do anything if user already selected 5 images.\n        }\n        hotspot.order = (this._choiceElements as HotspotChoice[]).filter(i => !!i.order).length + 1;\n        this.choiceOrdering = false;\n        return;\n      } else {\n        (this._choiceElements as HotspotChoice[]).forEach(hotspot => {\n          if (hotspot.order > hotspot.order) {\n            hotspot.order--;\n          }\n          return hotspot;\n        });\n        hotspot.order = null;\n      }\n      this.choiceOrdering = false;\n    }\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.addEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    this.removeEventListener('activate-qti-hotspot-choice', this.setHotspotOrder);\n    this.removeEventListener('register-qti-hotspot-choice', this.positionHotspotOnRegister);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-graphic-order-interaction': QtiGraphicOrderInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ChoicesMixin } from '../internal/choices/choices.mixin';\nimport { positionHotspots } from '../internal/hotspots/hotspot';\nimport { QtiHotspotChoice } from '../qti-hotspot-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-hotspot-interaction')\nexport class QtiHotspotInteraction extends ChoicesMixin(Interaction, 'qti-hotspot-choice') {\n  // do not select ( highlight blue, the image)\n  // target the main slot make it relative and fit with the conten\n  static override styles = [\n    css`\n      slot:not([name='prompt']) {\n        position: relative; /* qti-hotspot-choice relative to the slot */\n        display: block;\n        width: fit-content; /* hotspots not stretching further if image is at max size */\n      }\n      ::slotted(img) {\n        /* image not selectable anymore */\n        pointer-events: none;\n        user-select: none;\n        /* width:100%; */\n      }\n    `\n  ];\n  override render() {\n    return html`\n      <slot name=\"prompt\"></slot>\n      <!-- slot for the prompt -->\n      <slot></slot>\n      <!-- slot for the image and hotspots -->\n    `;\n  }\n\n  private positionHotspotOnRegister(e: CustomEvent<QtiHotspotChoice>): void {\n    const img = this.querySelector('img') as HTMLImageElement;\n    const hotspot = e.target as QtiHotspotChoice;\n    const coords = hotspot.getAttribute('coords');\n    const shape = hotspot.getAttribute('shape');\n    const coordsNumber = coords.split(',').map(s => parseInt(s));\n\n    positionHotspots(shape, coordsNumber, img, hotspot);\n  }\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.addEventListener('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 { CSSResultGroup, html, LitElement } from 'lit';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { ResponseInteraction } from '../../internal/expression-result';\n// import { TouchDragAndDrop } from '../internal/drag-drop';\nimport '../qti-simple-associable-choice';\nimport { QtiSimpleAssociableChoice } from '../qti-simple-associable-choice';\nimport styles from './qti-match-interaction.styles';\nimport { Interaction } from '../internal/interaction/interaction';\n\ninterface Column {\n  id: number;\n  name: string;\n}\n\ninterface Row {\n  id: number;\n  name: string;\n  isChecked: boolean;\n}\n\n@customElement('qti-match-interaction')\nexport class QtiMatchInteraction extends DragDropInteractionMixin(\n  Interaction,\n  'qti-simple-match-set:first-of-type qti-simple-associable-choice',\n  false,\n  'qti-simple-match-set:last-of-type qti-simple-associable-choice'\n) {\n  static styles: CSSResultGroup = styles;\n\n  rows: QtiSimpleAssociableChoice[];\n  cols: QtiSimpleAssociableChoice[];\n  lastCheckedRadio: HTMLInputElement | null = null;\n\n  @state() _response: string | string[] = [];\n  // dragDropApi: TouchDragAndDrop;\n  get value(): string[] {\n    if (!this.classList.contains('qti-match-tabular')) return super.value as string[];\n    else return this._response as string[];\n  }\n  set value(val: string[]) {\n    if (!this.classList.contains('qti-match-tabular')) super.value = val;\n    else this._response = val;\n  }\n  @state() correctOptions: string[] = [];\n  @property({ type: String, attribute: 'response-identifier' }) responseIdentifier: string = '';\n\n  async connectedCallback(): Promise<void> {\n    super.connectedCallback();\n    // await this.updateComplete;\n    // this.dragDropApi = new TouchDragAndDrop();\n    // this.dragDropApi.addDraggableElements(\n    //   this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    // );\n    // this.dragDropApi.addDroppableElements(\n    //   this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    // );\n    this.rows = Array.from<QtiSimpleAssociableChoice>(\n      this.querySelectorAll('qti-simple-match-set:first-of-type qti-simple-associable-choice')\n    );\n    this.cols = Array.from<QtiSimpleAssociableChoice>(\n      this.querySelectorAll('qti-simple-match-set:last-of-type qti-simple-associable-choice')\n    );\n\n    this.value = [];\n  }\n\n  handleRadioClick = e => {\n    const radio = e.target as HTMLInputElement;\n    if (this.lastCheckedRadio === radio) {\n      radio.checked = false;\n      this.lastCheckedRadio = null;\n      this.handleRadioChange(e);\n    } else {\n      this.lastCheckedRadio = radio;\n    }\n  };\n\n  handleRadioChange = e => {\n    const checkbox = e.target as HTMLInputElement;\n    const value = checkbox.value;\n    const name = checkbox.name;\n    const type = checkbox.type;\n\n    if (checkbox.checked) {\n      if (!this.value) {\n        this.value = [value];\n      } else if (this.value.indexOf(value) === -1) {\n        if (type === 'radio') {\n          this.value = this.value.filter(v => v.indexOf(name) === -1);\n        }\n        this.value = [...this.value, value];\n      }\n      this.lastCheckedRadio = checkbox;\n    } else {\n      this.value = this.value.filter(v => v !== value);\n      this.lastCheckedRadio = null;\n    }\n\n    this.requestUpdate();\n    this.dispatchEvent(\n      new CustomEvent<ResponseInteraction>('qti-interaction-response', {\n        bubbles: true,\n        composed: true,\n        detail: {\n          responseIdentifier: this.responseIdentifier,\n          response: Array.isArray(this.value) ? [...this.value] : this.value\n        }\n      })\n    );\n  };\n\n  set correctResponse(responseValue: string | string[]) {\n    if (responseValue === '') {\n      this.correctOptions = [];\n      return;\n    } else if (Array.isArray(responseValue)) {\n      this.correctOptions = responseValue;\n    }\n  }\n\n  override render() {\n    if (!this.classList.contains('qti-match-tabular')) {\n      return html`<slot name=\"prompt\"></slot> <slot></slot>`;\n    }\n    return html`\n      <slot name=\"prompt\"></slot>\n      <table>\n        <tr>\n          <td></td>\n          ${this.cols.map((col, i) => html`<th part=\"r-header\">${unsafeHTML(col.innerHTML)}</th>`)}\n        </tr>\n\n        ${this.rows.map(\n          (row, rIndex) =>\n            html`<tr>\n              <td part=\"c-header\">${unsafeHTML(row.innerHTML)}</td>\n              ${this.cols.map((col, cIndex) => {\n                const rowId = row.getAttribute('identifier');\n                const colId = col.getAttribute('identifier');\n                const value = `${rowId} ${colId}`;\n                const selectedInRowCount = this.value.filter(v => v.split(' ')[0] === rowId).length || 0;\n                const checked = this.value.includes(value);\n                const part = `rb ${checked ? 'rb-checked' : ''} ${this.correctOptions.includes(value) ? 'rb-correct' : ''}`;\n                // disable if match max is greater than 1 and max is reached\n                const disable =\n                  this.correctOptions.length > 0\n                    ? true\n                    : row.matchMax === 1\n                      ? false\n                      : selectedInRowCount >= row.matchMax && !checked;\n                return html`<td>\n                  <input\n                    type=${row.matchMax === 1 ? 'radio' : `checkbox`}\n                    part=${part}\n                    name=${rowId}\n                    value=${value}\n                    .disabled=${disable}\n                    @change=${e => this.handleRadioChange(e)}\n                    @click=${e => (row.matchMax === 1 ? this.handleRadioClick(e) : null)}\n                  />\n                </td>`;\n              })}\n            </tr>`\n        )}\n      </table>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-match-interaction': QtiMatchInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/* \nqti-match-interaction\nqti-associate-interaction\n*/\n@customElement('qti-simple-associable-choice')\n// tslint:disable: indent\nexport class QtiSimpleAssociableChoice extends ActiveElementMixin(LitElement, 'qti-simple-associable-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: block;\n    }\n    slot[name='qti-simple-associable-choice'] {\n      width: 100%;\n    }\n  `;\n\n  /** the minimal number of selections a candidate must make */\n  @property({\n    type: Number,\n    attribute: 'match-min'\n  })\n  public matchMin: number = 0;\n\n  /** the maximum number of selections a candidate must make, the other options will be disabled when max options is checked */\n  @property({\n    type: Number,\n    attribute: 'match-max'\n  })\n  public matchMax: number = 1;\n\n  @property({\n    type: Boolean,\n    attribute: 'fixed'\n  })\n  public fixed = false;\n\n  // pk: This needs some explanation\n  // in the associate interaction there is a special slot for these qti-simple-associable-choices\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-simple-associable-choice');\n    this.setAttribute('part', 'qti-simple-associable-choice');\n  }\n\n  // pk: This needs some explanation\n  // in qti-match-interaction, qti-simple-associable-choice is used to denote the\n  // draggable, but also the droppable. WEIRD.. but lets deal with it.\n  // So we have a slot for whenever another qti-simple-associable-choice is dropped in here.\n  // And we have slot for content like in this associate interaction\n  override render() {\n    return html`\n      <slot part=\"slot\"></slot>\n      <slot part=\"dropslot\" name=\"qti-simple-associable-choice\"></slot>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-associable-choice': QtiSimpleAssociableChoice;\n  }\n}\n", "import { css } from 'lit';\n// import componentStyles from '../../utilities/styles/component.styles';\n\n/* ${componentStyles} */\nexport default css`\n  slot {\n    /* slot where the */\n    display: flex;\n    flex-direction: column;\n    gap: 0.5rem;\n    align-items: flex-start; /* prevents the drag and drop container slots having the same height */\n  }\n  :host(.qti-choices-top) slot {\n    flex-direction: column;\n  }\n  :host(.qti-choices-bottom) slot {\n    flex-direction: column-reverse;\n  }\n  :host(.qti-choices-left) slot {\n    flex-direction: row;\n  }\n  :host(.qti-choices-right) slot {\n    flex-direction: row-reverse;\n  }\n  slot[name='prompt'] {\n    display: block;\n  }\n  ::slotted(qti-simple-match-set) {\n    /* Make sure the drag and drop container slots have the same width */\n    flex: 1;\n  }\n`;\n", "import { css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-media-interaction')\nexport class QtiMediaInteraction extends Interaction {\n  private _value = 0;\n  reset() {\n    // throw new Error('Method not implemented.');\n  }\n  validate(): boolean {\n    return true;\n    // maybe check if the media has been played?\n  }\n\n  get value(): string | string[] {\n    return this._value.toString();\n  }\n\n  set value(val: string | string[]) {\n    const isNumber = !isNaN(parseInt(val.toString()));\n    if (isNumber) {\n      this._value = parseInt(val.toString());\n    } else {\n      throw new Error('Value must be a number');\n    }\n  }\n\n  static override get properties() {\n    return {\n      ...Interaction.properties,\n      ...{\n        step: {\n          type: Number,\n          attribute: 'step',\n          default: 10\n        }\n      }\n    };\n  }\n\n  static override styles = [css``];\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <slot></slot>`;\n  }\n\n  constructor() {\n    super();\n  }\n\n  override connectedCallback() {\n    super.connectedCallback();\n    // get audio, video of object tag.\n    const mediaObject = this.querySelector('audio') || this.querySelector('video') || this.querySelector('object');\n    if (mediaObject) {\n      // listen to ended event\n      mediaObject.addEventListener('ended', () => {\n        // set value to 0\n        // check if this.value is a number\n        this._value++;\n        this.saveResponse(this.value);\n      });\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-media-interaction': QtiMediaInteraction;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { DragDropInteractionMixin } from '../internal/drag-drop/drag-drop-interaction-mixin';\nimport { ShuffleMixin } from '../internal/shuffle/shuffle-mixin'; // Import the mixin\nimport { QtiSimpleChoice } from '../qti-simple-choice';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-order-interaction')\nexport class QtiOrderInteraction extends ShuffleMixin(\n  DragDropInteractionMixin(Interaction, `qti-simple-choice`, true, 'drop-list'),\n  'qti-simple-choice'\n) {\n  childrenMap: Element[];\n\n  @state() nrChoices: number = 0;\n  @state() correctResponses: string[] = [];\n  @state() showCorrectResponses: boolean = false;\n\n  /** orientation of choices */\n  @property({ type: String })\n  public orientation: 'horizontal' | 'vertical';\n\n  static override styles = [\n    css`\n      [part='drags'] {\n        display: flex;\n        align-items: flex-start;\n        flex: 1;\n      }\n\n      [part='drops'] {\n        flex: 1;\n        display: grid;\n        grid-auto-flow: column;\n        grid-auto-columns: 1fr;\n      }\n\n      :host([orientation='horizontal']) [part='drags'] {\n        flex-direction: row;\n      }\n      :host([orientation='horizontal']) [part='drops'] {\n        grid-auto-flow: column;\n      }\n      :host([orientation='vertical']) [part='drags'] {\n        flex-direction: column;\n      }\n      :host([orientation='vertical']) [part='drops'] {\n        grid-auto-flow: row;\n      }\n\n      [part='drop-list'] {\n        display: block;\n        flex: 1;\n      }\n\n      [part='container'] {\n        display: flex;\n        gap: 0.5rem;\n      }\n      :host(.qti-choices-top) [part='container'] {\n        flex-direction: column;\n      }\n      :host(.qti-choices-bottom) [part='container'] {\n        flex-direction: column-reverse;\n      }\n      :host(.qti-choices-left) [part='container'] {\n        flex-direction: row;\n      }\n      :host(.qti-choices-right) [part='container'] {\n        flex-direction: row-reverse;\n      }\n    `\n  ];\n\n  override render() {\n    const choices = Array.from(this.querySelectorAll('qti-simple-choice'));\n    if (this.nrChoices < choices.length) {\n      this.nrChoices = choices.length;\n    }\n\n    return html` <slot name=\"prompt\"> </slot>\n      <div part=\"container\">\n        <slot part=\"drags\"> </slot>\n        <div part=\"drops\">\n          ${Array.from(Array(this.nrChoices)).map(\n            (_, i) =>\n              html`<drop-list part=\"drop-list\" identifier=\"droplist${i}\"></drop-list>${this.showCorrectResponses &&\n                this.correctResponses.length > i\n                  ? unsafeHTML(`<span part='correct-response'>${this.correctResponses[i]}</span>`)\n                  : ''}`\n          )}\n        </div>\n      </div>`;\n  }\n\n  set correctResponse(value: string | string[]) {\n    if (value === '') {\n      this.showCorrectResponses = false;\n      return;\n    }\n\n    if (this.correctResponses.length === 0) {\n      const responses = Array.isArray(value) ? value : [value];\n\n      responses.forEach((response, index) => {\n        let simpleChoice = this.querySelector(`qti-simple-choice[identifier=\"${response}\"]`);\n        if (!simpleChoice) {\n          simpleChoice = this.shadowRoot.querySelector(`qti-simple-choice[identifier=\"${response}\"]`);\n        }\n\n        const text = simpleChoice?.textContent.trim();\n        this.correctResponses = [...this.correctResponses, text];\n      });\n    }\n\n    this.showCorrectResponses = true;\n  }\n\n  // some interactions have a different way of getting the response\n  // this is called from the drag and drop mixin class\n  // you have to implement your own getResponse method in the superclass\n  // cause they are different for some interactions.\n  // MH: is this function called? Shouldn't we use getValue?\n  protected getResponse(): string[] {\n    const droppables = Array.from<QtiSimpleChoice>(this.shadowRoot.querySelectorAll('drop-list'));\n\n    const response = droppables.map(droppable => {\n      const dragsInDroppable = droppable.querySelectorAll('[qti-draggable=\"true\"]');\n      const identifiers = Array.from(dragsInDroppable).map(d => d.getAttribute('identifier'));\n      return [...identifiers].join(' ');\n    });\n    return response;\n  }\n\n  override async firstUpdated(changedProps) {\n    super.firstUpdated(changedProps);\n    this.childrenMap = Array.from(this.querySelectorAll('qti-simple-choice'));\n    this.childrenMap.forEach(el => el.setAttribute('part', 'qti-simple-choice'));\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-order-interaction': QtiOrderInteraction;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\n\nexport class QtiSPositionObjectInteraction extends LitElement {\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  static override styles = [\n    css`\n      :host {\n        display: block;\n      }\n      ::slotted(img) {\n        position: absolute;\n        cursor: move;\n        user-select: none;\n        left: 50%;\n        transform: translateX(-50%);\n      }\n    `\n  ];\n}\n\ncustomElements.define('qti-position-object-interaction', QtiSPositionObjectInteraction);\n", "import { LitElement, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-position-object-stage')\nexport class QtiPositionObjectStage extends LitElement {\n  choiceOrdering: boolean;\n  startX: any;\n  startY: any;\n  dragElement: any;\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n\n  static override styles = [\n    css`\n      :host {\n        display: inline-block;\n        position: relative;\n      }\n    `\n  ];\n\n  constructor() {\n    super();\n    this.removeMoveListener = this.removeMoveListener.bind(this);\n    this.dragElementHandler = this.dragElementHandler.bind(this);\n  }\n\n  // Define a function to handle the mousemove event on the draggable element\n  dragElementHandler(event) {\n    event.preventDefault();\n\n    // Calculate the distance the mouse has moved since the last event\n    const deltaX = event.clientX - this.startX;\n    const deltaY = event.clientY - this.startY;\n\n    // Update the position of the draggable element\n    this.dragElement.style.left = this.dragElement.offsetLeft + deltaX + 'px';\n    this.dragElement.style.top = this.dragElement.offsetTop + deltaY + 'px';\n\n    // Update the starting position of the mouse\n    this.startX = event.clientX;\n    this.startY = event.clientY;\n  }\n\n  override firstUpdated(a): void {\n    super.firstUpdated(a);\n\n    // Get the draggable and drop zone elements\n    this.dragElement = this.querySelector('qti-position-object-interaction>img');\n    // const canvasElement = document.getElementById('canvas');\n\n    // Initialize variables for the starting position of the draggable element\n    this.startX = 0;\n    this.startY = 0;\n\n    // Add a mousedown event listener to the draggable element\n    this.dragElement.addEventListener('mousedown', (event: MouseEvent) => {\n      // Save the starting position of the mouse\n      this.startX = event.clientX;\n      this.startY = event.clientY;\n\n      // Add a mousemove event listener to the document\n      document.addEventListener('mousemove', this.dragElementHandler, true);\n    });\n    document.addEventListener('mouseup', this.removeMoveListener);\n  }\n\n  removeMoveListener(event) {\n    document.removeEventListener('mousemove', this.dragElementHandler, true);\n  }\n\n  override disconnectedCallback() {\n    super.disconnectedCallback();\n    document.removeEventListener('mousemove', this.dragElementHandler);\n    document.removeEventListener('mouseup', this.removeMoveListener);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-position-object-stage': QtiPositionObjectStage;\n  }\n}\n", "import { css, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { styleMap } from 'lit/directives/style-map.js';\nimport { Interaction } from '../internal/interaction/interaction';\n\n@customElement('qti-select-point-interaction')\nexport class QtiSelectPointInteraction extends Interaction {\n  static override styles = [\n    css`\n      :host {\n        display: block;\n      }\n      point-container {\n        display: block;\n        position: relative;\n      }\n    `\n  ];\n\n  @property({\n    type: Number,\n    attribute: 'max-choices'\n  })\n  public maxChoices: number = Infinity;\n\n  @property({\n    type: Number,\n    attribute: 'min-choices'\n  })\n  public minChoices: number = 0;\n\n  @state()\n  private _points: string[] = [];\n\n  // Reference to the image element\n  private _imgElement: HTMLImageElement | null = null;\n\n  // Extracted click handler method\n  private _onImageClick = (event: MouseEvent) => {\n    if (this._points.length < this.maxChoices) {\n      const x = event.offsetX;\n      const y = event.offsetY;\n\n      this._points = [...this._points, `${x} ${y}`];\n      this.saveResponse(this._points);\n    }\n  };\n\n  override render() {\n    return html` <slot name=\"prompt\"></slot>\n      <point-container>\n        ${repeat(\n          this._points,\n          point => point,\n          (point, index) => html`\n            <button\n              part=\"point\"\n              style=${styleMap({\n                position: 'absolute',\n                transform: 'translate(-50%, -50%)',\n                left: `${point.split(' ')[0]}px`,\n                top: `${point.split(' ')[1]}px`\n              })}\n              aria-label=\"Remove point at ${point}\"\n              @click=${(e: Event) => {\n                e.stopPropagation();\n                this._points = this._points.filter((_, i) => i !== index);\n                this.saveResponse(this._points);\n              }}\n            ></button>\n          `\n        )}\n        <slot></slot>\n      </point-container>`;\n  }\n\n  reset(): void {\n    this._points = [];\n  }\n\n  validate(): boolean {\n    return this._points.length >= this.minChoices && this._points.length <= this.maxChoices;\n  }\n\n  set value(val: string | string[]) {\n    this._points = Array.isArray(val) ? val : [val];\n  }\n  get value(): string | string[] {\n    return this._points;\n  }\n\n  override firstUpdated(): void {\n    this._imgElement = this.querySelector('img');\n\n    if (this._imgElement) {\n      // Attach the click event listener to the image element\n      this._imgElement.addEventListener('click', this._onImageClick);\n    } else {\n      console.warn('No <img> element found in <qti-select-point-interaction>');\n    }\n  }\n\n  override disconnectedCallback(): void {\n    super.disconnectedCallback();\n\n    if (this._imgElement) {\n      // Remove the click event listener from the image element\n      this._imgElement.removeEventListener('click', this._onImageClick);\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-select-point-interaction': QtiSelectPointInteraction;\n  }\n}\n", "import { css, html, nothing } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\n\nimport { watch } from '../../../decorators/watch';\nimport { Interaction } from '../internal/interaction/interaction';\n\n/**\n * @summary The SliderInteraction.Type (qti-slider-interaction) presents the candidate with a control for selecting a numerical value between a lower and upper bound.\n * @documentation https://www.imsglobal.org/spec/qti/v3p0/impl#h.s61xcrj4qcyj\n * @status stable\n * @since 6.0\n *\n * @event qti-register-interaction - emitted when the interaction wants to register itself\n * @event qti-interaction-response - emitted when the interaction changes\n *\n * @cssprop --show-value - shows the current value while sliding\n * @cssprop --show-ticks - shows the ticks according to steps\n * @cssprop --show-bounds - shows value for lower and upper boundary\n *\n * @csspart slider -- slider inluding, bounds and ticks and value, use it for paddings and margins\n * @csspart bounds -- div for bounds, containing two divs for with min, and max bounds value\n * @csspart ticks -- div for ticks, use lineair gradient and exposed css variables for styling\n * @csspart rail -- div for rail, style according to needs\n * @csspart knob -- div, should be relative or absolute\n * @csspart value -- div, containing value\n *\n * @slot - The default slot where <qti-simple-choice> must be placed.\n * @slot prompt - slot where the prompt is placed.\n */\n\n@customElement('qti-slider-interaction')\nexport class QtiSliderInteraction extends Interaction {\n  private _value = 0;\n  csLive: CSSStyleDeclaration;\n\n  @query('#knob')\n  private _knob: HTMLElement;\n\n  @query('#rail')\n  private _rail: HTMLElement;\n\n  @property({ type: Boolean, attribute: 'step-label' }) stepLabel = false;\n\n  @property({ type: Boolean }) reverse = false;\n\n  private _min: number;\n  @property({ type: Number, attribute: 'lower-bound' }) set min(value: number) {\n    this._min = value;\n    this._value = value;\n    this.style.setProperty('--min', `${this._min}`);\n  }\n  get min(): number {\n    return this._min;\n  }\n\n  private _max: number;\n  @property({ type: Number, attribute: 'upper-bound' }) set max(value: number) {\n    this._max = value;\n    this.style.setProperty('--max', `${this._max}`);\n  }\n  get max(): number {\n    return this._max;\n  }\n\n  private _step: number;\n  @property({ type: Number, attribute: 'step' }) set step(value: number) {\n    this._step = value;\n    this.style.setProperty('--step', `${this._step}`);\n  }\n  get step(): number {\n    return this._step;\n  }\n\n  @watch('disabled', { waitUntilFirstUpdate: true })\n  _handleDisabledChange = (old, disabled) => {};\n\n  @watch('readonly', { waitUntilFirstUpdate: true })\n  _handleReadonlyChange = (old, readonly) => {};\n\n  reset() {\n    // throw new Error('Method not implemented.');\n  }\n  validate(): boolean {\n    return true;\n  }\n\n  get value(): string | string[] {\n    return this._value.toString();\n  }\n\n  set value(val: string | string[]) {\n    const isNumber = !isNaN(parseInt(val.toString()));\n    if (isNumber) {\n      this._value = parseInt(val.toString());\n    } else {\n      throw new Error('Value must be a number');\n    }\n  }\n\n  // static shadowRootOptions: ShadowRootInit = { ...LitElement.shadowRootOptions, delegatesFocus: true, mode: 'open' };\n\n  constructor() {\n    super();\n    /* the computed style is a live property, we use this to get css variables\n    see render template */\n    this.csLive = getComputedStyle(this);\n  }\n\n  set response(myResponse: string | string[]) {\n    if (Array.isArray(myResponse)) {\n      console.error('QtiSliderInteraction: response is an array, but should be a single value');\n      return;\n    }\n    const value = parseInt(myResponse);\n    if (Number.isNaN(value)) {\n      console.error('QtiSliderInteraction: response is not a number');\n      return;\n    }\n    this._value = value;\n  }\n\n  static override styles = [css``];\n\n  override render() {\n    // convert the value, which is the real slider value to a percentage for the dom.\n    if (this._value < this.min) {\n      this._value = this.min;\n    }\n    if (this._value > this.max) {\n      this._value = this.max;\n    }\n    const valuePercentage = ((this._value - this.min) / (this.max - this.min)) * 100;\n    this.style.setProperty('--value-percentage', `${valuePercentage}%`);\n    this.setAttribute('aria-valuenow', this.value.toString());\n\n    return html`<slot name=\"prompt\"></slot>\n      <div id=\"slider\" part=\"slider\">\n        ${this.csLive.getPropertyValue('--show-bounds') == 'true'\n          ? html`<div id=\"bounds\" part=\"bounds\">\n              <div>${this._min}</div>\n              <div>${this._max}</div>\n            </div>`\n          : nothing}\n        ${this.csLive.getPropertyValue('--show-ticks') == 'true' ? html`<div id=\"ticks\" part=\"ticks\"></div>` : nothing}\n        <div id=\"rail\" part=\"rail\" @mousedown=${this._onMouseDown} @touchstart=${this._onTouchMove}>\n          <div id=\"knob\" part=\"knob\">\n            ${this.csLive.getPropertyValue('--show-value') == 'true'\n              ? html`<div id=\"value\" part=\"value\">${this.value}</div>`\n              : nothing}\n          </div>\n        </div>\n      </div>`;\n  }\n\n  override connectedCallback() {\n    super.connectedCallback();\n    this.step = 1;\n    this.setAttribute('tabindex', '0');\n    this.setAttribute('role', 'slider');\n  }\n\n  private _onTouchMove(event) {\n    const handleTouchMove = event => {\n      const { x } = this.getPositionFromEvent(event);\n      const diffX = x - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n      this.calculateValue(diffX);\n      event.stopPropagation();\n    };\n\n    const handleTouchEnd = () => {\n      document.removeEventListener('touchmove', handleTouchMove);\n      document.removeEventListener('touchend', handleTouchEnd);\n\n      this.saveResponse(this.value.toString());\n    };\n\n    document.addEventListener('touchmove', handleTouchMove);\n    document.addEventListener('touchend', handleTouchEnd);\n\n    const { x } = this.getPositionFromEvent(event);\n    const diffX = x - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n    this.calculateValue(diffX);\n    event.stopPropagation();\n  }\n\n  private _onMouseDown(event) {\n    const handleMouseMove = (event: MouseEvent) => {\n      // if the qti-slider-interaction has an absolute left position and body is scrolled a bit, take account for that\n      const diffX = event.pageX - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n\n      this.calculateValue(diffX);\n      event.preventDefault();\n      event.stopPropagation();\n    };\n\n    const handleMouseUp = () => {\n      document.removeEventListener('mousemove', handleMouseMove);\n      document.removeEventListener('mouseup', handleMouseUp);\n\n      this.saveResponse(this.value.toString());\n    };\n\n    document.addEventListener('mousemove', handleMouseMove);\n    document.addEventListener('mouseup', handleMouseUp);\n\n    // if the qti-slider-interaction has an absolute left position and body is scrolled a bit, take account for that\n    const diffX = event.pageX - this._rail.getBoundingClientRect().left - document.documentElement.scrollLeft;\n\n    this.calculateValue(diffX);\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  /** calculateValue gets x position and compares this with the total width in pixels */\n  private calculateValue(diffX: number) {\n    const valueNow = this.min + ((this.max - this.min) * diffX) / this._rail.getBoundingClientRect().width;\n    const roundedStepValue = this.min + Math.round((valueNow - this.min) / this._step) * this._step;\n    this._value = roundedStepValue;\n  }\n\n  private getPositionFromEvent(e: any): {\n    x: number;\n    y: number;\n  } {\n    let _touchMove;\n    if (e.type == 'touchstart' || e.type == 'touchmove' || e.type == 'touchend' || e.type == 'touchcancel') {\n      const evt = typeof e.originalEvent === 'undefined' ? e : e.originalEvent;\n      const touch = evt.touches[0] || evt.changedTouches[0];\n      _touchMove = {\n        x: touch.pageX,\n        y: touch.pageY\n      };\n    } else if (\n      e.type == 'mousedown' ||\n      e.type == 'mouseup' ||\n      e.type == 'mousemove' ||\n      e.type == 'mouseover' ||\n      e.type == 'mouseout' ||\n      e.type == 'mouseenter' ||\n      e.type == 'mouseleave'\n    ) {\n      _touchMove = {\n        x: e.clientX,\n        y: e.clientY\n      };\n    }\n    return _touchMove;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-slider-interaction': QtiSliderInteraction;\n  }\n}\n", "import { consume } from '@lit/context';\nimport { LitElement, html } from 'lit';\nimport { customElement, state } from 'lit/decorators.js';\nimport { Calculate } from '../internal/expression-result';\nimport { ResponseVariable } from '../internal/variables';\nimport { ItemContext, itemContext } from '../qti-assessment-item/qti-assessment-item.context';\n\n/**\n * https://www.imsglobal.org/spec/qti/v3p0/impl#h.fi29q8dubjgw\n * <qti-custom-operator class=\"js.org\">\n        <qti-base-value base-type=\"string\"><![CDATA[\n          console.log(context.variables);\n          return 'B'\n          document.querySelector('qti-end-attempt-interaction').disabled = true;\n          ]]></qti-base-value>\n      </qti-custom-operator>\n    </qti-set-outcome-value>\n */\n@customElement('qti-custom-operator')\nexport class QtiCustomOperator extends LitElement implements Calculate {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n  private operatorFunction: Function;\n\n  @consume({ context: itemContext, subscribe: true })\n  @state()\n  private _context?: ItemContext;\n\n  render() {\n    return html`<slot @slotchange=${this.handleSlotChange}></slot>`;\n  }\n\n  handleSlotChange(event: Event) {\n    // expecting <[!CDATA[ ... ]]> is converted into <!-- ... --> with qti-transform: cDataToComment\n    const commentNode = Array.from(this.firstElementChild?.childNodes ?? []).find(\n      node => node.nodeType === Node.COMMENT_NODE\n    );\n    try {\n      this.operatorFunction = new Function('context', 'fn', 'item', commentNode.textContent ?? '');\n    } catch (e) {\n      console.error('custom-operator contains invalid javascript code', e);\n    }\n  }\n\n  public calculate() {\n    const fn = {\n      variable: (responseIdentifier: string) =>\n        this._context?.variables.find(v => v.identifier === responseIdentifier)?.value ?? '',\n      correct: (responseIdentifier: string) =>\n        (this._context?.variables.find(v => v.identifier === responseIdentifier) as ResponseVariable)\n          ?.correctResponse ?? ''\n    };\n    const item = {\n      getVariable: (variableIdentifier: string) =>\n        this._context?.variables.find(v => v.identifier === variableIdentifier),\n      updateOutcomeVariable: (outcomeIdentifier: string, value: string | string[]) => {\n        this.dispatchEvent(\n          new CustomEvent<{ outcomeIdentifier: string; value: string | string[] }>('qti-set-outcome-value', {\n            bubbles: true,\n            composed: true,\n            detail: {\n              outcomeIdentifier,\n              value\n            }\n          })\n        );\n      },\n      updateResponseVariable: (responseIdentifier: string, response: string | string[]) => {\n        this.dispatchEvent(\n          new CustomEvent<{ responseIdentifier: string; response: string | string[] }>('qti-interaction-response', {\n            bubbles: true,\n            composed: true,\n            detail: {\n              responseIdentifier,\n              response\n            }\n          })\n        );\n      }\n    };\n\n    return this.operatorFunction(this._context, fn, item);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-custom-operator': QtiCustomOperator;\n  }\n}\n", "import { LitElement, css, html } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\n@customElement('qti-associable-hotspot')\nexport class QtiAssociableHotspot extends LitElement {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n      position: absolute;\n    }\n  `;\n\n  override connectedCallback() {\n    super.connectedCallback();\n    this.dispatchEvent(\n      new CustomEvent('qti-register-hotspot', {\n        bubbles: true,\n        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';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-gap-text')\nexport class QtiGapText extends ActiveElementMixin(LitElement, 'qti-gap-text') {\n  static styles = css`\n    :host {\n      display: inline-flex;\n      user-select: none;\n    }\n  `;\n\n  @property({ type: Number, reflect: true }) tabindex: number | undefined = 0;\n\n  override connectedCallback(): void {\n    super.connectedCallback();\n    this.setAttribute('slot', 'qti-gap-text');\n  }\n\n  override render() {\n    return html`<slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-gap-text': QtiGapText;\n  }\n}\n", "import { css, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n// type shape = { shape: 'rect' | 'circle' | 'poly'; coords: number[] };\n\n@customElement('qti-hotspot-choice')\nexport class QtiHotspotChoice extends ActiveElementMixin(LitElement, 'qti-hotspot-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n      position: absolute;\n    }\n  `;\n  @property({ attribute: 'aria-ordervalue', type: Number, reflect: true }) order: number;\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hotspot-choice': QtiHotspotChoice;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n@customElement('qti-hottext')\nexport class QtiHottext extends ActiveElementMixin(LitElement, 'qti-hottext') {\n  static styles = css`\n    :host {\n      display: flex;\n      user-select: none;\n    }\n  `;\n\n  override render() {\n    return html`<div part=\"ch\"><div part=\"cha\"></div></div>\n      <slot></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-hottext': QtiHottext;\n  }\n}\n", "import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('qti-inline-choice')\nexport class QtiInlineChoice extends LitElement {\n  static override get styles() {\n    return [\n      css`\n        :host {\n          display: block;\n          cursor: pointer;\n        }\n      `\n    ];\n  }\n\n  @property({ type: String })\n  identifier: string;\n\n  override connectedCallback() {\n    super.connectedCallback();\n\n    this.addEventListener('click', this._onSelectInlineChoice);\n\n    this.dispatchEvent(\n      new CustomEvent('qti-inline-choice-register', {\n        bubbles: true,\n        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, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ActiveElementMixin } from './internal/active-element/active-element.mixin';\n\n/**\n * qti-order-interaction\n * qti-choice-interaction\n */\n@customElement('qti-simple-choice')\nexport class QtiSimpleChoice extends ActiveElementMixin(LitElement, 'qti-simple-choice') {\n  static styles = css`\n    :host {\n      display: flex;\n      align-items: center;\n      user-select: none;\n    }\n    slot {\n      width: 100%;\n      display: flex;\n      align-items: center;\n    }\n    [part='ch'] {\n      display: flex;\n      flex-shrink: 0;\n      align-items: center;\n      justify-content: center;\n    }\n  `;\n\n  // property label\n  @property({ type: String, attribute: false })\n  public marker: string;\n\n\n  get checked() {\n    return this['internals'].states.has('--checked');\n  }\n\n  override render() {\n    return html`<div part=\"ch\">\n        <div part=\"cha\"></div>\n      </div>\n      ${this.marker ? html`<div id=\"label\">${this.marker}</div>` : nothing}\n      <slot part=\"slot\"></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    'qti-simple-choice': QtiSimpleChoice;\n  }\n}\n", "/* only exported to override or extend for specific purposes */\nexport * from './internal/event-types';\nexport * from './internal/events';\nexport * from './internal/expression-result';\nexport * from './internal/variables';\n/* only exported to override or extend for specific purposes */\nexport * from './qti-assessment-item/qti-assessment-item';\nexport * from './qti-assessment-stimulus-ref/qti-assessment-stimulus-ref';\nexport * from './qti-interaction/internal/active-element/active-element.mixin';\nexport * from './qti-item-body/qti-item-body';\nexport * from './qti-prompt/qti-prompt';\nexport * from './qti-stylesheet/qti-stylesheet';\n/* start response and outcome */\nexport * from './qti-variable-declaration/qti-outcome-declaration/qti-outcome-declaration';\nexport * from './qti-variable-declaration/qti-response-declaration/qti-response-declaration';\n/* end response and outcome */\nexport * from './qti-companion-materials-info/qti-companion-materials-info';\nexport * from './qti-rubric-block/qti-content-body';\nexport * from './qti-rubric-block/qti-rubric-block';\n/* start feedback */\nexport * from './qti-feedback/qti-feedback-block/qti-feedback-block';\nexport * from './qti-feedback/qti-feedback-inline/qti-feedback-inline';\nexport * from './qti-feedback/qti-modal-feedback/qti-modal-feedback';\n/* end feedback */\n/* start textentryinteraction */\nexport * from './qti-interaction/qti-extended-text-interaction/qti-extended-text-interaction';\nexport * from './qti-interaction/qti-text-entry-interaction/qti-text-entry-interaction';\n/* end textentryinteraction */\n/* start hottext */\nexport * from './qti-interaction/qti-hottext-interaction/qti-hottext-interaction';\n/* end hottext */\n/* start inlinechoice */\nexport * from './qti-interaction/qti-inline-choice-interaction/qti-inline-choice-interaction';\n/* end inlinechoice */\n/* start choiceinteraction */\nexport * from './qti-interaction/qti-choice-interaction/qti-choice-interaction';\n/* end choiceinteraction */\nexport * from './qti-outcome-processing/qti-outcome-processing';\nexport * from './qti-response-processing';\n/* start custom interactions */\nexport * from './qti-interaction/qti-portable-custom-interaction/qti-portable-custom-interaction';\n/* end custom interactions */\n/* start only preview items */\nexport * from './qti-interaction/qti-associate-interaction/qti-associate-interaction';\nexport * from './qti-interaction/qti-custom-interaction/qti-custom-interaction';\nexport * from './qti-interaction/qti-end-attempt-interaction/qti-end-attempt-interaction';\nexport * from './qti-interaction/qti-gap-match-interaction/qti-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-associate-interaction/qti-graphic-associate-interaction';\nexport * from './qti-interaction/qti-graphic-gap-match-interaction/qti-graphic-gap-match-interaction';\nexport * from './qti-interaction/qti-graphic-order-interaction/qti-graphic-order-interaction';\nexport * from './qti-interaction/qti-hotspot-interaction/qti-hotspot-interaction';\nexport * from './qti-interaction/qti-match-interaction/qti-match-interaction';\nexport * from './qti-interaction/qti-media-interaction/qti-media-interaction';\nexport * from './qti-interaction/qti-order-interaction/qti-order-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-interaction';\nexport * from './qti-interaction/qti-position-object-interaction/qti-position-object-stage';\nexport * from './qti-interaction/qti-select-point-interaction/qti-select-point-interaction';\nexport * from './qti-interaction/qti-slider-interaction/qti-slider-interaction';\n/* end only preview items */\nexport * from './qti-assessment-item/qti-assessment-item.context';\nexport * from './qti-custom-operator/qti-custom-operator';\nexport * from './qti-interaction/internal/interaction/interaction';\nexport * from './qti-interaction/qti-associable-hotspot';\nexport * from './qti-interaction/qti-gap';\nexport * from './qti-interaction/qti-gap-img';\nexport * from './qti-interaction/qti-gap-text';\nexport * from './qti-interaction/qti-hotspot-choice';\nexport * from './qti-interaction/qti-hottext';\nexport * from './qti-interaction/qti-inline-choice';\nexport * from './qti-interaction/qti-simple-associable-choice';\nexport * from './qti-interaction/qti-simple-choice';\n\nconsole.log(\n  '%cC\u00BFTO%cLab%c: qti-components loaded',\n  'font-weight:bold; color:green',\n  'font-family: \"PT Sans\", font-weight:bold; color:green; font-size: smaller;vertical-align: sub',\n  'font-weight:unset'\n);\n\n// css for font pt-sans and subscript and green\n"],
  "mappings": "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",
  "names": ["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", "path", "stimulus", "qtiTransformItem", "api", "elements", "__decorateClass", "property", "customElement", "html", "property", "ariaBooleanConverter", "value", "ActiveElementMixin", "Base", "type", "QtiChoice", "args", "_oldValue", "disabled", "event", "html", "__decorateClass", "property", "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", "link", "response", "cssContent", "minifiedCss", "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", "state", "LitElement", "Interaction", "LitElement", "value", "__decorateClass", "property", "state", "customElement", "property", "state", "QtiExtendedTextInteraction", "Interaction", "old", "classes", "classNames", "rowsSet", "className", "nrRows", "estimatedRows", "val", "formData", "textarea", "patternSource", "pattern", "isValid", "css", "html", "event", "ifDefined", "input", "text", "__decorateClass", "state", "property", "watch", "customElement", "html", "customElement", "property", "state", "ifDefined", "createRef", "css", "qti_text_entry_interaction_styles_default", "QtiTextEntryInteraction", "Interaction", "createRef", "val", "formData", "input", "isValid", "html", "event", "ifDefined", "text", "qti_text_entry_interaction_styles_default", "__decorateClass", "property", "state", "customElement", "html", "customElement", "property", "query", "ChoicesMixin", "superClass", "selector", "ChoicesMixinElement", "_", "disabled", "ch", "readonly", "choice", "_oldValue", "_newValue", "val", "formData", "response", "value", "responseArray", "selectedChoices", "selectedCount", "isValid", "validityMessage", "event", "choiceElement", "checked", "_a", "selectedIdentifiers", "isSelected", "__decorateClass", "query", "property", "watch", "QtiHottextInteraction", "ChoicesMixin", "Interaction", "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", "customElement", "property", "property", "ShuffleMixin", "superClass", "selector", "ShuffleElement", "value", "oldValue", "choices", "fixedElements", "nonFixedElements", "choice", "index", "isShuffled", "maxAttempts", "attempt", "originalOrder", "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", "Interaction", "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", "val", "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", "val", "QtiOrdered", "QtiExpression", "variables", "variable", "consume", "LitElement", "html", "property", "state", "QtiPrintedVariable", "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", "html", "customElement", "state", "TouchDragAndDrop", "_TouchDragAndDrop", "type", "val", "draggables", "el", "e", "x", "y", "computedStyle", "rect", "currentTouch", "computedStyles", "style", "deltaX", "deltaY", "dropTarget", "_a", "dropFound", "dragEndEvent", "event", "root", "depth", "element", "currentElement", "shadowElement", "nextDropZone", "page", "touch", "newLeft", "newTop", "boundedLeft", "boundedTop", "boundaryRect", "elementRect", "elementWidth", "elementHeight", "boundedDeltaX", "boundedDeltaY", "xDist", "yDist", "eventType", "bubble", "property", "DroppablesMixin", "superClass", "useShadowRoot", "droppablesSelector", "DroppablesElement", "changedProps", "droppables", "droppable", "mutations", "attributeName", "_a", "ev", "identifier", "draggable", "moveElement", "__decorateClass", "property", "FlippablesMixin", "superClass", "droppablesSel", "draggablesSel", "FlippablesElement", "property", "liveQuery", "querySelector", "options", "observer", "resolvedOptions", "__spreadValues", "proto", "decoratedFnName", "connectedCallback", "disconnectedCallback", "_a", "callback", "mutationList", "elementsToWatch", "mutation", "addedNodes", "e", "removedNodes", "n", "elementsAdded", "DragDropInteractionMixin", "superClass", "draggablesSelector", "useShadowRootForDroppables", "droppablesSelector", "DragDropInteractionElement", "FlippablesMixin", "DroppablesMixin", "ev", "target", "draggable", "resolve", "hasMoveTestItem", "items", "pending", "item", "data", "dragsAdded", "dragsRemoved", "newDraggables", "changedProps", "TouchDragAndDrop", "draggables", "d", "index", "parent", "targetIndex", "moveDraggable", "transition", "maxMatch", "droppable", "value", "entry", "response", "dropId", "dragIds", "dragId", "identifier", "drop", "moveElement", "validAssociations", "draggablesInDroppable", "identifiers", "droppableIdentifier", "id", "save", "__decorateClass", "property", "liveQuery", "css", "qti_associate_interaction_styles_default", "QtiAssociateInteraction", "DragDropInteractionMixin", "Interaction", "event", "choice", "html", "_", "index", "qti_associate_interaction_styles_default", "__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", "customElement", "QtiGapMatchInteraction", "DragDropInteractionMixin", "Interaction", "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", "customElement", "QtiGraphicGapMatchInteraction", "DragDropInteractionMixin", "Interaction", "html", "e", "img", "hotspot", "coords", "shape", "coordsNumber", "s", "centerX", "centerY", "radius", "leftX", "topY", "rightX", "bottomY", "css", "__decorateClass", "customElement", "css", "html", "customElement", "QtiGraphicOrderInteraction", "ChoicesMixin", "Interaction", "html", "e", "identifier", "hotspot", "el", "maxSelection", "i", "img", "coords", "shape", "coordsNumber", "s", "positionHotspots", "css", "__decorateClass", "customElement", "css", "html", "customElement", "QtiHotspotInteraction", "ChoicesMixin", "Interaction", "html", "e", "img", "hotspot", "coords", "shape", "coordsNumber", "s", "positionHotspots", "css", "__decorateClass", "customElement", "html", "customElement", "property", "state", "unsafeHTML", "css", "html", "LitElement", "customElement", "property", "QtiSimpleAssociableChoice", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "qti_match_interaction_styles_default", "QtiMatchInteraction", "DragDropInteractionMixin", "Interaction", "radio", "checkbox", "value", "name", "type", "v", "val", "responseValue", "html", "col", "i", "unsafeHTML", "row", "rIndex", "cIndex", "rowId", "colId", "selectedInRowCount", "checked", "part", "disable", "e", "qti_match_interaction_styles_default", "__decorateClass", "state", "property", "customElement", "css", "html", "customElement", "QtiMediaInteraction", "Interaction", "val", "__spreadProps", "__spreadValues", "html", "mediaObject", "css", "__decorateClass", "customElement", "css", "html", "customElement", "property", "state", "unsafeHTML", "QtiOrderInteraction", "ShuffleMixin", "DragDropInteractionMixin", "Interaction", "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", "val", "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", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "property", "customElement", "css", "LitElement", "customElement", "property", "QtiHotspotChoice", "ActiveElementMixin", "LitElement", "css", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "customElement", "QtiHottext", "ActiveElementMixin", "LitElement", "html", "css", "__decorateClass", "customElement", "css", "html", "LitElement", "customElement", "property", "QtiInlineChoice", "LitElement", "css", "html", "__decorateClass", "property", "customElement", "css", "html", "LitElement", "nothing", "customElement", "property", "QtiSimpleChoice", "ActiveElementMixin", "LitElement", "html", "nothing", "css", "__decorateClass", "property", "customElement"]
}
