@citolab/qti-components 6.7.1-17 → 6.7.1-18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/custom-elements.json +153 -153
- package/dist/index.js +2 -15
- package/dist/qti-transformers/index.d.ts +3 -0
- package/dist/qti-transformers/index.js +3 -16
- package/package.json +1 -1
|
@@ -2,159 +2,6 @@
|
|
|
2
2
|
"schemaVersion": "1.0.0",
|
|
3
3
|
"readme": "",
|
|
4
4
|
"modules": [
|
|
5
|
-
{
|
|
6
|
-
"kind": "javascript-module",
|
|
7
|
-
"path": "src/lib/decorators/index.ts",
|
|
8
|
-
"declarations": [],
|
|
9
|
-
"exports": [
|
|
10
|
-
{
|
|
11
|
-
"kind": "js",
|
|
12
|
-
"name": "*",
|
|
13
|
-
"declaration": {
|
|
14
|
-
"name": "*",
|
|
15
|
-
"package": "./live-query"
|
|
16
|
-
}
|
|
17
|
-
},
|
|
18
|
-
{
|
|
19
|
-
"kind": "js",
|
|
20
|
-
"name": "*",
|
|
21
|
-
"declaration": {
|
|
22
|
-
"name": "*",
|
|
23
|
-
"package": "./watch"
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
]
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
"kind": "javascript-module",
|
|
30
|
-
"path": "src/lib/decorators/live-query.ts",
|
|
31
|
-
"declarations": [
|
|
32
|
-
{
|
|
33
|
-
"kind": "function",
|
|
34
|
-
"name": "liveQuery",
|
|
35
|
-
"parameters": [
|
|
36
|
-
{
|
|
37
|
-
"name": "querySelector",
|
|
38
|
-
"type": {
|
|
39
|
-
"text": "string"
|
|
40
|
-
}
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
"name": "options",
|
|
44
|
-
"optional": true,
|
|
45
|
-
"type": {
|
|
46
|
-
"text": "LiveQueryOptions"
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
]
|
|
50
|
-
}
|
|
51
|
-
],
|
|
52
|
-
"exports": [
|
|
53
|
-
{
|
|
54
|
-
"kind": "js",
|
|
55
|
-
"name": "liveQuery",
|
|
56
|
-
"declaration": {
|
|
57
|
-
"name": "liveQuery",
|
|
58
|
-
"module": "src/lib/decorators/live-query.ts"
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
]
|
|
62
|
-
},
|
|
63
|
-
{
|
|
64
|
-
"kind": "javascript-module",
|
|
65
|
-
"path": "src/lib/decorators/watch.ts",
|
|
66
|
-
"declarations": [
|
|
67
|
-
{
|
|
68
|
-
"kind": "function",
|
|
69
|
-
"name": "watch",
|
|
70
|
-
"parameters": [
|
|
71
|
-
{
|
|
72
|
-
"name": "propertyName",
|
|
73
|
-
"type": {
|
|
74
|
-
"text": "string | string[]"
|
|
75
|
-
}
|
|
76
|
-
},
|
|
77
|
-
{
|
|
78
|
-
"name": "options",
|
|
79
|
-
"optional": true,
|
|
80
|
-
"type": {
|
|
81
|
-
"text": "WatchOptions"
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
],
|
|
85
|
-
"description": "Runs when observed properties change, e.g. @property or @state, but before the component updates. To wait for an\nupdate to complete after a change occurs, use `await this.updateComplete` in the handler. To start watching after the\ninitial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n\nUsage:"
|
|
86
|
-
}
|
|
87
|
-
],
|
|
88
|
-
"exports": [
|
|
89
|
-
{
|
|
90
|
-
"kind": "js",
|
|
91
|
-
"name": "watch",
|
|
92
|
-
"declaration": {
|
|
93
|
-
"name": "watch",
|
|
94
|
-
"module": "src/lib/decorators/watch.ts"
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
]
|
|
98
|
-
},
|
|
99
|
-
{
|
|
100
|
-
"kind": "javascript-module",
|
|
101
|
-
"path": "src/lib/qti-transformers/index.ts",
|
|
102
|
-
"declarations": [],
|
|
103
|
-
"exports": [
|
|
104
|
-
{
|
|
105
|
-
"kind": "js",
|
|
106
|
-
"name": "*",
|
|
107
|
-
"declaration": {
|
|
108
|
-
"name": "*",
|
|
109
|
-
"package": "./qti-transformers"
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
]
|
|
113
|
-
},
|
|
114
|
-
{
|
|
115
|
-
"kind": "javascript-module",
|
|
116
|
-
"path": "src/lib/qti-transformers/qti-transformers.ts",
|
|
117
|
-
"declarations": [
|
|
118
|
-
{
|
|
119
|
-
"kind": "function",
|
|
120
|
-
"name": "qtiTransformItem",
|
|
121
|
-
"return": {
|
|
122
|
-
"type": {
|
|
123
|
-
"text": ""
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
"description": "Browser based QTI-XML to HTML transformer.\nReturns an object with methods to load, parse, transform and serialize QTI XML items."
|
|
127
|
-
},
|
|
128
|
-
{
|
|
129
|
-
"kind": "function",
|
|
130
|
-
"name": "qtiTransformTest",
|
|
131
|
-
"return": {
|
|
132
|
-
"type": {
|
|
133
|
-
"text": ""
|
|
134
|
-
}
|
|
135
|
-
},
|
|
136
|
-
"description": "Returns an object with methods to load, parse and transform QTI tests."
|
|
137
|
-
}
|
|
138
|
-
],
|
|
139
|
-
"exports": [
|
|
140
|
-
{
|
|
141
|
-
"kind": "js",
|
|
142
|
-
"name": "qtiTransformItem",
|
|
143
|
-
"declaration": {
|
|
144
|
-
"name": "qtiTransformItem",
|
|
145
|
-
"module": "src/lib/qti-transformers/qti-transformers.ts"
|
|
146
|
-
}
|
|
147
|
-
},
|
|
148
|
-
{
|
|
149
|
-
"kind": "js",
|
|
150
|
-
"name": "qtiTransformTest",
|
|
151
|
-
"declaration": {
|
|
152
|
-
"name": "qtiTransformTest",
|
|
153
|
-
"module": "src/lib/qti-transformers/qti-transformers.ts"
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
]
|
|
157
|
-
},
|
|
158
5
|
{
|
|
159
6
|
"kind": "javascript-module",
|
|
160
7
|
"path": "src/lib/qti-components/index.ts",
|
|
@@ -570,6 +417,159 @@
|
|
|
570
417
|
}
|
|
571
418
|
]
|
|
572
419
|
},
|
|
420
|
+
{
|
|
421
|
+
"kind": "javascript-module",
|
|
422
|
+
"path": "src/lib/decorators/index.ts",
|
|
423
|
+
"declarations": [],
|
|
424
|
+
"exports": [
|
|
425
|
+
{
|
|
426
|
+
"kind": "js",
|
|
427
|
+
"name": "*",
|
|
428
|
+
"declaration": {
|
|
429
|
+
"name": "*",
|
|
430
|
+
"package": "./live-query"
|
|
431
|
+
}
|
|
432
|
+
},
|
|
433
|
+
{
|
|
434
|
+
"kind": "js",
|
|
435
|
+
"name": "*",
|
|
436
|
+
"declaration": {
|
|
437
|
+
"name": "*",
|
|
438
|
+
"package": "./watch"
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
]
|
|
442
|
+
},
|
|
443
|
+
{
|
|
444
|
+
"kind": "javascript-module",
|
|
445
|
+
"path": "src/lib/decorators/live-query.ts",
|
|
446
|
+
"declarations": [
|
|
447
|
+
{
|
|
448
|
+
"kind": "function",
|
|
449
|
+
"name": "liveQuery",
|
|
450
|
+
"parameters": [
|
|
451
|
+
{
|
|
452
|
+
"name": "querySelector",
|
|
453
|
+
"type": {
|
|
454
|
+
"text": "string"
|
|
455
|
+
}
|
|
456
|
+
},
|
|
457
|
+
{
|
|
458
|
+
"name": "options",
|
|
459
|
+
"optional": true,
|
|
460
|
+
"type": {
|
|
461
|
+
"text": "LiveQueryOptions"
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
]
|
|
465
|
+
}
|
|
466
|
+
],
|
|
467
|
+
"exports": [
|
|
468
|
+
{
|
|
469
|
+
"kind": "js",
|
|
470
|
+
"name": "liveQuery",
|
|
471
|
+
"declaration": {
|
|
472
|
+
"name": "liveQuery",
|
|
473
|
+
"module": "src/lib/decorators/live-query.ts"
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
]
|
|
477
|
+
},
|
|
478
|
+
{
|
|
479
|
+
"kind": "javascript-module",
|
|
480
|
+
"path": "src/lib/decorators/watch.ts",
|
|
481
|
+
"declarations": [
|
|
482
|
+
{
|
|
483
|
+
"kind": "function",
|
|
484
|
+
"name": "watch",
|
|
485
|
+
"parameters": [
|
|
486
|
+
{
|
|
487
|
+
"name": "propertyName",
|
|
488
|
+
"type": {
|
|
489
|
+
"text": "string | string[]"
|
|
490
|
+
}
|
|
491
|
+
},
|
|
492
|
+
{
|
|
493
|
+
"name": "options",
|
|
494
|
+
"optional": true,
|
|
495
|
+
"type": {
|
|
496
|
+
"text": "WatchOptions"
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
],
|
|
500
|
+
"description": "Runs when observed properties change, e.g. @property or @state, but before the component updates. To wait for an\nupdate to complete after a change occurs, use `await this.updateComplete` in the handler. To start watching after the\ninitial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n\nUsage:"
|
|
501
|
+
}
|
|
502
|
+
],
|
|
503
|
+
"exports": [
|
|
504
|
+
{
|
|
505
|
+
"kind": "js",
|
|
506
|
+
"name": "watch",
|
|
507
|
+
"declaration": {
|
|
508
|
+
"name": "watch",
|
|
509
|
+
"module": "src/lib/decorators/watch.ts"
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
]
|
|
513
|
+
},
|
|
514
|
+
{
|
|
515
|
+
"kind": "javascript-module",
|
|
516
|
+
"path": "src/lib/qti-transformers/index.ts",
|
|
517
|
+
"declarations": [],
|
|
518
|
+
"exports": [
|
|
519
|
+
{
|
|
520
|
+
"kind": "js",
|
|
521
|
+
"name": "*",
|
|
522
|
+
"declaration": {
|
|
523
|
+
"name": "*",
|
|
524
|
+
"package": "./qti-transformers"
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
]
|
|
528
|
+
},
|
|
529
|
+
{
|
|
530
|
+
"kind": "javascript-module",
|
|
531
|
+
"path": "src/lib/qti-transformers/qti-transformers.ts",
|
|
532
|
+
"declarations": [
|
|
533
|
+
{
|
|
534
|
+
"kind": "function",
|
|
535
|
+
"name": "qtiTransformItem",
|
|
536
|
+
"return": {
|
|
537
|
+
"type": {
|
|
538
|
+
"text": ""
|
|
539
|
+
}
|
|
540
|
+
},
|
|
541
|
+
"description": "Browser based QTI-XML to HTML transformer.\nReturns an object with methods to load, parse, transform and serialize QTI XML items."
|
|
542
|
+
},
|
|
543
|
+
{
|
|
544
|
+
"kind": "function",
|
|
545
|
+
"name": "qtiTransformTest",
|
|
546
|
+
"return": {
|
|
547
|
+
"type": {
|
|
548
|
+
"text": ""
|
|
549
|
+
}
|
|
550
|
+
},
|
|
551
|
+
"description": "Returns an object with methods to load, parse and transform QTI tests."
|
|
552
|
+
}
|
|
553
|
+
],
|
|
554
|
+
"exports": [
|
|
555
|
+
{
|
|
556
|
+
"kind": "js",
|
|
557
|
+
"name": "qtiTransformItem",
|
|
558
|
+
"declaration": {
|
|
559
|
+
"name": "qtiTransformItem",
|
|
560
|
+
"module": "src/lib/qti-transformers/qti-transformers.ts"
|
|
561
|
+
}
|
|
562
|
+
},
|
|
563
|
+
{
|
|
564
|
+
"kind": "js",
|
|
565
|
+
"name": "qtiTransformTest",
|
|
566
|
+
"declaration": {
|
|
567
|
+
"name": "qtiTransformTest",
|
|
568
|
+
"module": "src/lib/qti-transformers/qti-transformers.ts"
|
|
569
|
+
}
|
|
570
|
+
}
|
|
571
|
+
]
|
|
572
|
+
},
|
|
573
573
|
{
|
|
574
574
|
"kind": "javascript-module",
|
|
575
575
|
"path": "src/lib/qti-components/internal/event-types.ts",
|
package/dist/index.js
CHANGED
|
@@ -453,8 +453,7 @@ var Tr=Object.defineProperty,As=Object.defineProperties,qs=Object.getOwnProperty
|
|
|
453
453
|
width: 100%;
|
|
454
454
|
display: block;
|
|
455
455
|
}
|
|
456
|
-
`,nt=a([m("qti-simple-choice")],nt);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");var
|
|
457
|
-
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
456
|
+
`,nt=a([m("qti-simple-choice")],nt);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");var Qs=String.raw,Rf=()=>{let i,t={async load(e){return new Promise((r,s)=>{_s(e).then(o=>(i=o,r(t)))})},parse(e){return i=ri(e),t},path:e=>(si(i,e),t),pciHooks(e){let r=["hook","module"],s=e.substring(0,e.lastIndexOf("/"));for(let o of r)i.querySelectorAll("["+o+"]").forEach(l=>{let c=l.getAttribute(o);!c.startsWith("data:")&&!c.startsWith("http")&&(l.setAttribute("base-url",e),l.setAttribute("module",s+"/"+encodeURIComponent(c+(c.endsWith(".js")?"":".js"))))});return t},convertCDATAtoComment(){return ii(i),t},html(){return new XMLSerializer().serializeToString(It(i))},xml(){return new XMLSerializer().serializeToString(i)},htmldoc(){return It(i)},xmldoc(){return i}};return t},kf=()=>{let i,t={async load(e){return new Promise((r,s)=>{_s(e).then(o=>(i=o,r(t)))})},items(){return ti(i)},html(){return new XMLSerializer().serializeToString(It(i))},xml(){return new XMLSerializer().serializeToString(i)},htmldoc(){return It(i)},xmldoc(){return i}};return t},ei=Qs`<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
458
457
|
<xsl:output method="html" version="5.0" encoding="UTF-8" indent="yes" />
|
|
459
458
|
<xsl:template match="@*|node()">
|
|
460
459
|
<xsl:copy>
|
|
@@ -462,18 +461,6 @@ var Tr=Object.defineProperty,As=Object.defineProperties,qs=Object.getOwnProperty
|
|
|
462
461
|
</xsl:copy>
|
|
463
462
|
</xsl:template>
|
|
464
463
|
|
|
465
|
-
<!-- convert CDATA to comments -->
|
|
466
|
-
<xsl:template match="text()[contains(., 'CDATA')]">
|
|
467
|
-
<strong>
|
|
468
|
-
<xsl:comment>
|
|
469
|
-
<xsl:value-of select="."/>
|
|
470
|
-
</xsl:comment>
|
|
471
|
-
<strong>
|
|
472
|
-
</xsl:template>
|
|
473
|
-
|
|
474
|
-
<!-- remove xml comments -->
|
|
475
|
-
<xsl:template match="comment()" />
|
|
476
|
-
|
|
477
464
|
<!-- remove existing namespaces -->
|
|
478
465
|
<xsl:template match="*">
|
|
479
466
|
<!-- remove element prefix -->
|
|
@@ -488,7 +475,7 @@ var Tr=Object.defineProperty,As=Object.defineProperties,qs=Object.getOwnProperty
|
|
|
488
475
|
<xsl:apply-templates/>
|
|
489
476
|
</xsl:element>
|
|
490
477
|
</xsl:template>
|
|
491
|
-
</xsl:stylesheet>`;function
|
|
478
|
+
</xsl:stylesheet>`;function ti(i){let t=[];return i.querySelectorAll("qti-assessment-item-ref").forEach(e=>{let r=e.getAttribute("identifier"),s=e.getAttribute("href"),o=e.getAttribute("category");t.push({identifier:r,href:s,category:o})}),t}function _s(i){return new Promise((t,e)=>{let r=new XMLHttpRequest;r.open("GET",i,!0),r.responseType="document",r.onload=()=>r.status>=200&&r.status<300?t(r.responseXML):(e(r.statusText),null),r.onerror=function(){e(r.statusText)},r.send()})}function ri(i){return new DOMParser().parseFromString(i,"text/xml")}function It(i){let t=new XSLTProcessor,e=new DOMParser().parseFromString(ei,"text/xml");return t.importStylesheet(e),t.transformToFragment(i,document)}function si(i,t){t.endsWith("/")||(t+="/"),i.querySelectorAll("[src],[href]").forEach(e=>{var o;let r="";e.getAttribute("src")&&(r="src"),e.getAttribute("href")&&(r="href");let s=(o=e.getAttribute(r))==null?void 0:o.trim();if(!s.startsWith("data:")&&!s.startsWith("http")){let n=t+encodeURI(s);e.setAttribute(r,n)}})}function ii(i){i.querySelectorAll('qti-custom-operator[class="js.org"] > qti-base-value').forEach(e=>{let r=document.createComment(e.textContent);e.replaceChild(r,e.firstChild)})}export{T as Interaction,Ye as QtPrintedVariable,$t as QtiAnd,N as QtiAssessmentItem,rt as QtiAssociableHotspot,qe as QtiAssociateInteraction,St as QtiBaseValue,M as QtiChoice,Ce as QtiChoiceInteraction,xt as QtiCompanionMaterialsInfo,V as QtiConditionExpression,nr as QtiContains,Et as QtiContentBody,ar as QtiCorrect,tt as QtiCustomOperator,Te as QtiEndAttemptInteraction,kt as QtiEqual,Rt as QtiEqualRounded,y as QtiExpression,z as QtiExtendedTextInteraction,Ue as QtiFeedbackBlock,Ie as QtiFeedbackInline,st as QtiGap,it as QtiGapImg,Ke as QtiGapMatchInteraction,ot as QtiGapText,W as QtiGraphicAssociateInteraction,Je as QtiGraphicGapMatchInteraction,Ze as QtiGraphicOrderInteraction,lr as QtiGt,cr as QtiGte,$e as QtiHotspotChoice,Ge as QtiHotspotInteraction,Ot as QtiHottext,Tt as QtiHottextInteraction,Ut as QtiInlineChoice,oe as QtiInlineChoiceInteraction,pr as QtiIsNull,wt as QtiLookupOutcomeValue,dr as QtiLt,ur as QtiLte,Mt as QtiMapResponse,Ae as QtiMapping,mr as QtiMatch,me as QtiMatchInteraction,Qe as QtiMediaInteraction,hr as QtiMember,Fe as QtiModalFeedback,fr as QtiMultiple,gr as QtiNot,br as QtiOr,he as QtiOrderInteraction,vr as QtiOrdered,F as QtiOutcomeDeclaration,We as QtiOutcomeProcessing,Cr as QtiOutcomeProcessingProcessor,Nt as QtiPortableCustomInteraction,et as QtiPositionObjectStage,yr as QtiProduct,vt as QtiPrompt,rr as QtiResponseCondition,G as QtiResponseDeclaration,ze as QtiResponseElse,or as QtiResponseElseIf,je as QtiResponseIf,ue as QtiResponseProcessing,B as QtiRubricBlock,j as QtiRule,Dt as QtiSPositionObjectInteraction,ne as QtiSelectPointInteraction,sr as QtiSetOutcomeValue,ir as QtiSetOutcomeValueRule,Vt as QtiSimpleAssociableChoice,nt as QtiSimpleChoice,k as QtiSliderInteraction,Lt as QtiStringMatch,yt as QtiStylesheet,xr as QtiSum,Er as QtiSumExpression,P as QtiTextEntryInteraction,_r as QtiVariable,I as itemContext,is as itemContextVariables,Zs as qtiAndMixin,Rf as qtiTransformItem,kf as qtiTransformTest};
|
|
492
479
|
/*! Bundled license information:
|
|
493
480
|
|
|
494
481
|
@lit/context/lib/context-request-event.js:
|
|
@@ -19,6 +19,7 @@ declare const qtiTransformItem: () => {
|
|
|
19
19
|
parse(xmlString: string): any;
|
|
20
20
|
path: (location: string) => any;
|
|
21
21
|
pciHooks(uri: string): any;
|
|
22
|
+
convertCDATAtoComment(): any;
|
|
22
23
|
html(): string;
|
|
23
24
|
xml(): string;
|
|
24
25
|
htmldoc(): DocumentFragment;
|
|
@@ -29,6 +30,7 @@ declare const qtiTransformItem: () => {
|
|
|
29
30
|
parse(xmlString: string): any;
|
|
30
31
|
path: (location: string) => any;
|
|
31
32
|
pciHooks(uri: string): any;
|
|
33
|
+
convertCDATAtoComment(): any;
|
|
32
34
|
html(): string;
|
|
33
35
|
xml(): string;
|
|
34
36
|
htmldoc(): DocumentFragment;
|
|
@@ -39,6 +41,7 @@ declare const qtiTransformItem: () => {
|
|
|
39
41
|
parse(xmlString: string): any;
|
|
40
42
|
path: (location: string) => any;
|
|
41
43
|
pciHooks(uri: string): any;
|
|
44
|
+
convertCDATAtoComment(): any;
|
|
42
45
|
html(): string;
|
|
43
46
|
xml(): string;
|
|
44
47
|
htmldoc(): DocumentFragment;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import"../chunk-JILF7TI5.js";var
|
|
2
|
-
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
1
|
+
import"../chunk-JILF7TI5.js";var u=String.raw,d=()=>{let e,n={async load(t){return new Promise((r,o)=>{c(t).then(s=>(e=s,r(n)))})},parse(t){return e=x(t),n},path:t=>(f(e,t),n),pciHooks(t){let r=["hook","module"],o=t.substring(0,t.lastIndexOf("/"));for(let s of r)e.querySelectorAll("["+s+"]").forEach(m=>{let i=m.getAttribute(s);!i.startsWith("data:")&&!i.startsWith("http")&&(m.setAttribute("base-url",t),m.setAttribute("module",o+"/"+encodeURIComponent(i+(i.endsWith(".js")?"":".js"))))});return n},convertCDATAtoComment(){return h(e),n},html(){return new XMLSerializer().serializeToString(a(e))},xml(){return new XMLSerializer().serializeToString(e)},htmldoc(){return a(e)},xmldoc(){return e}};return n},y=()=>{let e,n={async load(t){return new Promise((r,o)=>{c(t).then(s=>(e=s,r(n)))})},items(){return p(e)},html(){return new XMLSerializer().serializeToString(a(e))},xml(){return new XMLSerializer().serializeToString(e)},htmldoc(){return a(e)},xmldoc(){return e}};return n},g=u`<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
3
2
|
<xsl:output method="html" version="5.0" encoding="UTF-8" indent="yes" />
|
|
4
3
|
<xsl:template match="@*|node()">
|
|
5
4
|
<xsl:copy>
|
|
@@ -7,18 +6,6 @@ import"../chunk-JILF7TI5.js";var f=()=>{let e,n={async load(t){return new Promis
|
|
|
7
6
|
</xsl:copy>
|
|
8
7
|
</xsl:template>
|
|
9
8
|
|
|
10
|
-
<!-- convert CDATA to comments -->
|
|
11
|
-
<xsl:template match="text()[contains(., 'CDATA')]">
|
|
12
|
-
<strong>
|
|
13
|
-
<xsl:comment>
|
|
14
|
-
<xsl:value-of select="."/>
|
|
15
|
-
</xsl:comment>
|
|
16
|
-
<strong>
|
|
17
|
-
</xsl:template>
|
|
18
|
-
|
|
19
|
-
<!-- remove xml comments -->
|
|
20
|
-
<xsl:template match="comment()" />
|
|
21
|
-
|
|
22
9
|
<!-- remove existing namespaces -->
|
|
23
10
|
<xsl:template match="*">
|
|
24
11
|
<!-- remove element prefix -->
|
|
@@ -33,5 +20,5 @@ import"../chunk-JILF7TI5.js";var f=()=>{let e,n={async load(t){return new Promis
|
|
|
33
20
|
<xsl:apply-templates/>
|
|
34
21
|
</xsl:element>
|
|
35
22
|
</xsl:template>
|
|
36
|
-
</xsl:stylesheet>`;function p(e){let n=[];return e.querySelectorAll("qti-assessment-item-ref").forEach(t=>{let r=t.getAttribute("identifier"),o=t.getAttribute("href"),s=t.getAttribute("category");n.push({identifier:r,href:o,category:s})}),n}function c(e){return new Promise((n,t)=>{let r=new XMLHttpRequest;r.open("GET",e,!0),r.responseType="document",r.onload=()=>r.status>=200&&r.status<300?n(r.responseXML):(t(r.statusText),null),r.onerror=function(){t(r.statusText)},r.send()})}function
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/lib/qti-transformers/qti-transformers.ts"],
  "sourcesContent": ["/**\n * Browser based QTI-XML to HTML transformer.\n * Returns an object with methods to load, parse, transform and serialize QTI XML items.\n * @returns An object with methods to load, parse, transform and serialize QTI XML items.\n * @example\n * const qtiTransformer = qtiTransformItem();\n * await qtiTransformer.load('path/to/xml/file.xml');\n * qtiTransformer.path('/assessmentItem/itemBody');\n * const html = qtiTransformer.html();\n * const xml = qtiTransformer.xml();\n * const htmldoc = qtiTransformer.htmldoc();\n * const xmldoc = qtiTransformer.xmldoc();\n *\n * qtiTransformItem().parse(storyXML).html()\n */\n\nexport const qtiTransformItem = (): {\n  load: (uri: string) => Promise<typeof api>;\n  parse: (xmlString: string) => typeof api;\n  path: (location: string) => typeof api;\n  html: () => string;\n  xml: () => string;\n  htmldoc: () => DocumentFragment;\n  xmldoc: () => XMLDocument;\n} => {\n  let xmlFragment: XMLDocument;\n\n  const api = {\n    async load(uri: string) {\n      return new Promise<typeof api>((resolve, reject) => {\n        loadXML(uri).then(xml => {\n          xmlFragment = xml;\n          return resolve(api);\n        });\n      });\n    },\n    parse(xmlString: string) {\n      xmlFragment = parseXML(xmlString);\n      return api;\n    },\n    path: (location: string) => {\n      setLocation(xmlFragment, location);\n      return api;\n    },\n    pciHooks(uri: string) {\n      const attributes = ['hook', 'module'];\n      const documentPath = uri.substring(0, uri.lastIndexOf('/'));\n      for (const attribute of attributes) {\n        const srcAttributes = xmlFragment.querySelectorAll('[' + attribute + ']');\n        srcAttributes.forEach(node => {\n          const srcValue = node.getAttribute(attribute)!;\n          if (!srcValue.startsWith('data:') && !srcValue.startsWith('http')) {\n            // Just paste the relative path of the src location after the documentrootPath\n            // old pcis can have a .js, new pci's don't\n            node.setAttribute('base-url', uri);\n            node.setAttribute(\n              'module',\n              documentPath + '/' + encodeURIComponent(srcValue + (srcValue.endsWith('.js') ? '' : '.js'))\n            );\n          }\n        });\n      }\n      return api;\n    },\n    html() {\n      return new XMLSerializer().serializeToString(toHTML(xmlFragment));\n    },\n    xml(): string {\n      return new XMLSerializer().serializeToString(xmlFragment);\n    },\n    htmldoc() {\n      return toHTML(xmlFragment);\n    },\n    xmldoc(): XMLDocument {\n      return xmlFragment; // new XMLSerializer().serializeToString(xmlFragment);\n    }\n  };\n  return api;\n};\n\n/**\n * Returns an object with methods to load, parse and transform QTI tests.\n * @returns An object with methods to load, parse and transform QTI tests.\n * @example\n * const qtiTransformer = qtiTransformTest();\n * await qtiTransformer.load('https://example.com/test.xml');\n * const items = qtiTransformer.items();\n * const html = qtiTransformer.html();\n * const xml = qtiTransformer.xml();\n */\nexport const qtiTransformTest = (): {\n  load: (uri: string) => Promise<typeof api>;\n  items: () => { identifier: string; href: string; category: string }[];\n  html: () => string;\n  xml: () => string;\n  htmldoc: () => DocumentFragment;\n  xmldoc: () => XMLDocument;\n} => {\n  let xmlFragment: XMLDocument;\n\n  const api = {\n    async load(uri) {\n      return new Promise<typeof api>((resolve, reject) => {\n        loadXML(uri).then(xml => {\n          xmlFragment = xml;\n          return resolve(api);\n        });\n      });\n    },\n    items() {\n      return itemsFromTest(xmlFragment);\n    },\n    html() {\n      return new XMLSerializer().serializeToString(toHTML(xmlFragment));\n    },\n    xml(): string {\n      return new XMLSerializer().serializeToString(xmlFragment);\n    },\n    htmldoc() {\n      return toHTML(xmlFragment);\n    },\n    xmldoc(): XMLDocument {\n      return xmlFragment;\n    }\n  };\n  return api;\n};\n\nconst xmlToHTML = `\n<xsl:stylesheet version=\"1.0\" xmlns:xsl=\"http://www.w3.org/1999/XSL/Transform\">\n<xsl:output method=\"html\" version=\"5.0\" encoding=\"UTF-8\" indent=\"yes\" />\n  <xsl:template match=\"@*|node()\">\n    <xsl:copy>\n      <xsl:apply-templates select=\"@*|node()\"/>\n    </xsl:copy>\n  </xsl:template>\n\n  <!-- convert CDATA to comments -->\n  <xsl:template match=\"text()[contains(., 'CDATA')]\">\n    <strong>\n      <xsl:comment>\n        <xsl:value-of select=\".\"/>\n      </xsl:comment>\n    <strong>\n  </xsl:template>\n\n  <!-- remove xml comments -->\n  <xsl:template match=\"comment()\" />\n\n  <!-- remove existing namespaces -->\n  <xsl:template match=\"*\">\n    <!-- remove element prefix -->\n    <xsl:element name=\"{local-name()}\">\n      <!-- process attributes -->\n      <xsl:for-each select=\"@*\">\n        <!-- remove attribute prefix -->\n        <xsl:attribute name=\"{local-name()}\">\n          <xsl:value-of select=\".\"/>\n        </xsl:attribute>\n      </xsl:for-each>\n    <xsl:apply-templates/>\n  </xsl:element>\n</xsl:template>\n</xsl:stylesheet>`;\n\nfunction itemsFromTest(xmlFragment: DocumentFragment) {\n  const items: { identifier: string; href: string; category: string }[] = [];\n  xmlFragment.querySelectorAll('qti-assessment-item-ref').forEach(el => {\n    const identifier = el.getAttribute('identifier');\n    const href = el.getAttribute('href');\n    const category = el.getAttribute('category');\n    items.push({ identifier, href, category });\n  });\n  return items;\n}\n\nfunction loadXML(url) {\n  return new Promise<XMLDocument | null>((resolve, reject) => {\n    const xhr = new XMLHttpRequest();\n    xhr.open('GET', url, true);\n    xhr.responseType = 'document';\n\n    xhr.onload = () => {\n      if (xhr.status >= 200 && xhr.status < 300) {\n        return resolve(xhr.responseXML);\n      } else {\n        reject(xhr.statusText);\n        return null;\n      }\n    };\n\n    xhr.onerror = function () {\n      reject(xhr.statusText);\n    };\n\n    xhr.send();\n  });\n}\n\nfunction parseXML(xmlDocument: string) {\n  const parser = new DOMParser();\n  const xmlFragment = parser.parseFromString(xmlDocument, 'text/xml');\n  return xmlFragment;\n}\n\nfunction toHTML(xmlFragment: Document): DocumentFragment {\n  const processor = new XSLTProcessor();\n  const xsltDocument = new DOMParser().parseFromString(xmlToHTML, 'text/xml');\n  processor.importStylesheet(xsltDocument);\n  const itemHTMLFragment = processor.transformToFragment(xmlFragment, document);\n  return itemHTMLFragment;\n}\n\nfunction setLocation(xmlFragment: DocumentFragment, location: string) {\n  if (!location.endsWith('/')) {\n    location += '/';\n  }\n\n  xmlFragment.querySelectorAll('[src],[href]').forEach(elWithSrc => {\n    let attr: 'src' | 'href' | '' = '';\n\n    if (elWithSrc.getAttribute('src')) {\n      attr = 'src';\n    }\n    if (elWithSrc.getAttribute('href')) {\n      attr = 'href';\n    }\n    const attrValue = elWithSrc.getAttribute(attr)?.trim();\n\n    if (!attrValue.startsWith('data:') && !attrValue.startsWith('http')) {\n      const newSrcValue = location + encodeURI(attrValue);\n      elWithSrc.setAttribute(attr, newSrcValue);\n    }\n  });\n}\n"],
  "mappings": "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",
  "names": ["qtiTransformItem", "xmlFragment", "api", "uri", "resolve", "reject", "loadXML", "xml", "xmlString", "parseXML", "location", "setLocation", "attributes", "documentPath", "attribute", "node", "srcValue", "toHTML", "qtiTransformTest", "itemsFromTest", "xmlToHTML", "items", "el", "identifier", "href", "category", "url", "xhr", "xmlDocument", "processor", "xsltDocument", "elWithSrc", "_a", "attr", "attrValue", "newSrcValue"]
}

|
|
23
|
+
</xsl:stylesheet>`;function p(e){let n=[];return e.querySelectorAll("qti-assessment-item-ref").forEach(t=>{let r=t.getAttribute("identifier"),o=t.getAttribute("href"),s=t.getAttribute("category");n.push({identifier:r,href:o,category:s})}),n}function c(e){return new Promise((n,t)=>{let r=new XMLHttpRequest;r.open("GET",e,!0),r.responseType="document",r.onload=()=>r.status>=200&&r.status<300?n(r.responseXML):(t(r.statusText),null),r.onerror=function(){t(r.statusText)},r.send()})}function x(e){return new DOMParser().parseFromString(e,"text/xml")}function a(e){let n=new XSLTProcessor,t=new DOMParser().parseFromString(g,"text/xml");return n.importStylesheet(t),n.transformToFragment(e,document)}function f(e,n){n.endsWith("/")||(n+="/"),e.querySelectorAll("[src],[href]").forEach(t=>{var s;let r="";t.getAttribute("src")&&(r="src"),t.getAttribute("href")&&(r="href");let o=(s=t.getAttribute(r))==null?void 0:s.trim();if(!o.startsWith("data:")&&!o.startsWith("http")){let l=n+encodeURI(o);t.setAttribute(r,l)}})}function h(e){e.querySelectorAll('qti-custom-operator[class="js.org"] > qti-base-value').forEach(t=>{let r=document.createComment(t.textContent);t.replaceChild(r,t.firstChild)})}export{d as qtiTransformItem,y as qtiTransformTest};
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/lib/qti-transformers/qti-transformers.ts"],
  "sourcesContent": ["const xml = String.raw;\n\n/**\n * Browser based QTI-XML to HTML transformer.\n * Returns an object with methods to load, parse, transform and serialize QTI XML items.\n * @returns An object with methods to load, parse, transform and serialize QTI XML items.\n * @example\n * const qtiTransformer = qtiTransformItem();\n * await qtiTransformer.load('path/to/xml/file.xml');\n * qtiTransformer.path('/assessmentItem/itemBody');\n * const html = qtiTransformer.html();\n * const xml = qtiTransformer.xml();\n * const htmldoc = qtiTransformer.htmldoc();\n * const xmldoc = qtiTransformer.xmldoc();\n *\n * qtiTransformItem().parse(storyXML).html()\n */\n\nexport const qtiTransformItem = (): {\n  load: (uri: string) => Promise<typeof api>;\n  parse: (xmlString: string) => typeof api;\n  path: (location: string) => typeof api;\n  html: () => string;\n  xml: () => string;\n  htmldoc: () => DocumentFragment;\n  xmldoc: () => XMLDocument;\n} => {\n  let xmlFragment: XMLDocument;\n\n  const api = {\n    async load(uri: string) {\n      return new Promise<typeof api>((resolve, reject) => {\n        loadXML(uri).then(xml => {\n          xmlFragment = xml;\n          return resolve(api);\n        });\n      });\n    },\n    parse(xmlString: string) {\n      xmlFragment = parseXML(xmlString);\n      return api;\n    },\n    path: (location: string) => {\n      setLocation(xmlFragment, location);\n      return api;\n    },\n    pciHooks(uri: string) {\n      const attributes = ['hook', 'module'];\n      const documentPath = uri.substring(0, uri.lastIndexOf('/'));\n      for (const attribute of attributes) {\n        const srcAttributes = xmlFragment.querySelectorAll('[' + attribute + ']');\n        srcAttributes.forEach(node => {\n          const srcValue = node.getAttribute(attribute)!;\n          if (!srcValue.startsWith('data:') && !srcValue.startsWith('http')) {\n            // Just paste the relative path of the src location after the documentrootPath\n            // old pcis can have a .js, new pci's don't\n            node.setAttribute('base-url', uri);\n            node.setAttribute(\n              'module',\n              documentPath + '/' + encodeURIComponent(srcValue + (srcValue.endsWith('.js') ? '' : '.js'))\n            );\n          }\n        });\n      }\n      return api;\n    },\n    convertCDATAtoComment() {\n      convertCDATAtoComment(xmlFragment);\n      return api;\n    },\n\n    html() {\n      return new XMLSerializer().serializeToString(toHTML(xmlFragment));\n    },\n    xml(): string {\n      return new XMLSerializer().serializeToString(xmlFragment);\n    },\n    htmldoc() {\n      return toHTML(xmlFragment);\n    },\n    xmldoc(): XMLDocument {\n      return xmlFragment; // new XMLSerializer().serializeToString(xmlFragment);\n    }\n  };\n  return api;\n};\n\n/**\n * Returns an object with methods to load, parse and transform QTI tests.\n * @returns An object with methods to load, parse and transform QTI tests.\n * @example\n * const qtiTransformer = qtiTransformTest();\n * await qtiTransformer.load('https://example.com/test.xml');\n * const items = qtiTransformer.items();\n * const html = qtiTransformer.html();\n * const xml = qtiTransformer.xml();\n */\nexport const qtiTransformTest = (): {\n  load: (uri: string) => Promise<typeof api>;\n  items: () => { identifier: string; href: string; category: string }[];\n  html: () => string;\n  xml: () => string;\n  htmldoc: () => DocumentFragment;\n  xmldoc: () => XMLDocument;\n} => {\n  let xmlFragment: XMLDocument;\n\n  const api = {\n    async load(uri) {\n      return new Promise<typeof api>((resolve, reject) => {\n        loadXML(uri).then(xml => {\n          xmlFragment = xml;\n          return resolve(api);\n        });\n      });\n    },\n    items() {\n      return itemsFromTest(xmlFragment);\n    },\n    html() {\n      return new XMLSerializer().serializeToString(toHTML(xmlFragment));\n    },\n    xml(): string {\n      return new XMLSerializer().serializeToString(xmlFragment);\n    },\n    htmldoc() {\n      return toHTML(xmlFragment);\n    },\n    xmldoc(): XMLDocument {\n      return xmlFragment;\n    }\n  };\n  return api;\n};\n\n/*   <!-- convert CDATA to comments -->\n  <xsl:template match=\"text()[contains(., 'CDATA')]\">\n  <xsl:comment>\n    <xsl:value-of select=\".\"/>\n  </xsl:comment>\n</xsl:template>\n*/\n\n/*\n  <!-- remove xml comments -->\n  <xsl:template match=\"comment()\" />\n  */\n\nconst xmlToHTML = xml`<xsl:stylesheet version=\"1.0\" xmlns:xsl=\"http://www.w3.org/1999/XSL/Transform\">\n<xsl:output method=\"html\" version=\"5.0\" encoding=\"UTF-8\" indent=\"yes\" />\n  <xsl:template match=\"@*|node()\">\n    <xsl:copy>\n      <xsl:apply-templates select=\"@*|node()\"/>\n    </xsl:copy>\n  </xsl:template>\n\n  <!-- remove existing namespaces -->\n  <xsl:template match=\"*\">\n    <!-- remove element prefix -->\n    <xsl:element name=\"{local-name()}\">\n      <!-- process attributes -->\n      <xsl:for-each select=\"@*\">\n        <!-- remove attribute prefix -->\n        <xsl:attribute name=\"{local-name()}\">\n          <xsl:value-of select=\".\"/>\n        </xsl:attribute>\n      </xsl:for-each>\n    <xsl:apply-templates/>\n  </xsl:element>\n</xsl:template>\n</xsl:stylesheet>`;\n\nfunction itemsFromTest(xmlFragment: DocumentFragment) {\n  const items: { identifier: string; href: string; category: string }[] = [];\n  xmlFragment.querySelectorAll('qti-assessment-item-ref').forEach(el => {\n    const identifier = el.getAttribute('identifier');\n    const href = el.getAttribute('href');\n    const category = el.getAttribute('category');\n    items.push({ identifier, href, category });\n  });\n  return items;\n}\n\nfunction loadXML(url) {\n  return new Promise<XMLDocument | null>((resolve, reject) => {\n    const xhr = new XMLHttpRequest();\n    xhr.open('GET', url, true);\n    xhr.responseType = 'document';\n\n    xhr.onload = () => {\n      if (xhr.status >= 200 && xhr.status < 300) {\n        return resolve(xhr.responseXML);\n      } else {\n        reject(xhr.statusText);\n        return null;\n      }\n    };\n\n    xhr.onerror = function () {\n      reject(xhr.statusText);\n    };\n\n    xhr.send();\n  });\n}\n\nfunction parseXML(xmlDocument: string) {\n  const parser = new DOMParser();\n  const xmlFragment = parser.parseFromString(xmlDocument, 'text/xml');\n  return xmlFragment;\n}\n\nfunction toHTML(xmlFragment: Document): DocumentFragment {\n  const processor = new XSLTProcessor();\n  const xsltDocument = new DOMParser().parseFromString(xmlToHTML, 'text/xml');\n  processor.importStylesheet(xsltDocument);\n  const itemHTMLFragment = processor.transformToFragment(xmlFragment, document);\n  return itemHTMLFragment;\n}\n\nfunction setLocation(xmlFragment: DocumentFragment, location: string) {\n  if (!location.endsWith('/')) {\n    location += '/';\n  }\n\n  xmlFragment.querySelectorAll('[src],[href]').forEach(elWithSrc => {\n    let attr: 'src' | 'href' | '' = '';\n\n    if (elWithSrc.getAttribute('src')) {\n      attr = 'src';\n    }\n    if (elWithSrc.getAttribute('href')) {\n      attr = 'href';\n    }\n    const attrValue = elWithSrc.getAttribute(attr)?.trim();\n\n    if (!attrValue.startsWith('data:') && !attrValue.startsWith('http')) {\n      const newSrcValue = location + encodeURI(attrValue);\n      elWithSrc.setAttribute(attr, newSrcValue);\n    }\n  });\n}\n\nfunction convertCDATAtoComment(xmlFragment: DocumentFragment) {\n  const cdataElements = xmlFragment.querySelectorAll('qti-custom-operator[class=\"js.org\"] > qti-base-value');\n  cdataElements.forEach(element => {\n    const commentText = document.createComment(element.textContent);\n    element.replaceChild(commentText, element.firstChild);\n  });\n}\n"],
  "mappings": "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",
  "names": ["xml", "qtiTransformItem", "xmlFragment", "api", "uri", "resolve", "reject", "loadXML", "xmlString", "parseXML", "location", "setLocation", "attributes", "documentPath", "attribute", "node", "srcValue", "convertCDATAtoComment", "toHTML", "qtiTransformTest", "itemsFromTest", "xmlToHTML", "items", "el", "identifier", "href", "category", "url", "xhr", "xmlDocument", "processor", "xsltDocument", "elWithSrc", "_a", "attr", "attrValue", "newSrcValue", "element", "commentText"]
}

|