@pie-element/extended-text-entry 15.1.2-next.2 → 15.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. package/CHANGELOG.json +1282 -0
  2. package/CHANGELOG.md +2270 -0
  3. package/LICENSE.md +5 -0
  4. package/README.md +1 -0
  5. package/configure/CHANGELOG.json +922 -0
  6. package/configure/CHANGELOG.md +1959 -0
  7. package/configure/lib/defaults.js +224 -0
  8. package/configure/lib/defaults.js.map +1 -0
  9. package/configure/lib/index.js +125 -0
  10. package/configure/lib/index.js.map +1 -0
  11. package/configure/lib/main.js +247 -0
  12. package/configure/lib/main.js.map +1 -0
  13. package/configure/package.json +23 -0
  14. package/controller/CHANGELOG.json +362 -0
  15. package/controller/CHANGELOG.md +1183 -0
  16. package/controller/lib/defaults.js +91 -0
  17. package/controller/lib/defaults.js.map +1 -0
  18. package/controller/lib/index.js +101 -0
  19. package/controller/lib/index.js.map +1 -0
  20. package/controller/package.json +16 -0
  21. package/docs/config-schema.json +1782 -0
  22. package/docs/config-schema.json.md +1333 -0
  23. package/docs/demo/config.js +7 -0
  24. package/docs/demo/generate.js +14 -0
  25. package/docs/demo/index.html +3 -0
  26. package/docs/demo/session.js +7 -0
  27. package/docs/pie-schema.json +954 -0
  28. package/docs/pie-schema.json.md +717 -0
  29. package/lib/annotation/annotation-editor.js +636 -0
  30. package/lib/annotation/annotation-editor.js.map +1 -0
  31. package/lib/annotation/annotation-menu.js +147 -0
  32. package/lib/annotation/annotation-menu.js.map +1 -0
  33. package/lib/annotation/annotation-utils.js +205 -0
  34. package/lib/annotation/annotation-utils.js.map +1 -0
  35. package/lib/annotation/freeform-editor.js +241 -0
  36. package/lib/annotation/freeform-editor.js.map +1 -0
  37. package/lib/index.js +108 -0
  38. package/lib/index.js.map +1 -0
  39. package/lib/main.js +205 -0
  40. package/lib/main.js.map +1 -0
  41. package/lib/print.js +86 -0
  42. package/lib/print.js.map +1 -0
  43. package/module/configure.js +1 -0
  44. package/module/controller.js +139 -0
  45. package/module/demo.js +38 -0
  46. package/module/element.js +1 -0
  47. package/module/index.html +21 -0
  48. package/module/manifest.json +22 -0
  49. package/module/print-demo.js +76 -0
  50. package/module/print.html +18 -0
  51. package/module/print.js +1 -0
  52. package/package.json +22 -87
  53. package/configure.js +0 -2
  54. package/controller.js +0 -1
  55. package/dist/author/defaults.d.ts +0 -166
  56. package/dist/author/defaults.js +0 -209
  57. package/dist/author/index.d.ts +0 -52
  58. package/dist/author/index.js +0 -74
  59. package/dist/author/main.d.ts +0 -26
  60. package/dist/author/main.js +0 -166
  61. package/dist/browser/author/index.js +0 -495
  62. package/dist/browser/author/index.js.map +0 -1
  63. package/dist/browser/browser-kkT1XVKw.js +0 -219
  64. package/dist/browser/browser-kkT1XVKw.js.map +0 -1
  65. package/dist/browser/controller/index.js +0 -184
  66. package/dist/browser/controller/index.js.map +0 -1
  67. package/dist/browser/delivery/index.js +0 -98
  68. package/dist/browser/delivery/index.js.map +0 -1
  69. package/dist/browser/dist-BCJzhghM.js +0 -47879
  70. package/dist/browser/dist-BCJzhghM.js.map +0 -1
  71. package/dist/browser/extended-text-entry.css +0 -2
  72. package/dist/browser/main-VcQEFn-b.js +0 -714
  73. package/dist/browser/main-VcQEFn-b.js.map +0 -1
  74. package/dist/browser/print/index.js +0 -48
  75. package/dist/browser/print/index.js.map +0 -1
  76. package/dist/controller/defaults.d.ts +0 -33
  77. package/dist/controller/defaults.js +0 -104
  78. package/dist/controller/index.d.ts +0 -59
  79. package/dist/controller/index.js +0 -72
  80. package/dist/delivery/annotation/annotation-editor.d.ts +0 -47
  81. package/dist/delivery/annotation/annotation-editor.js +0 -296
  82. package/dist/delivery/annotation/annotation-menu.d.ts +0 -25
  83. package/dist/delivery/annotation/annotation-menu.js +0 -113
  84. package/dist/delivery/annotation/annotation-utils.d.ts +0 -20
  85. package/dist/delivery/annotation/annotation-utils.js +0 -65
  86. package/dist/delivery/annotation/freeform-editor.d.ts +0 -30
  87. package/dist/delivery/annotation/freeform-editor.js +0 -143
  88. package/dist/delivery/index.d.ts +0 -23
  89. package/dist/delivery/index.js +0 -68
  90. package/dist/delivery/main.d.ts +0 -27
  91. package/dist/delivery/main.js +0 -134
  92. package/dist/extended-text-entry.css +0 -2
  93. package/dist/index.d.ts +0 -1
  94. package/dist/index.iife.d.ts +0 -8
  95. package/dist/index.iife.js +0 -403
  96. package/dist/index.js +0 -2
  97. package/dist/print/index.d.ts +0 -15
  98. package/dist/print/index.js +0 -48
  99. package/dist/runtime-support.d.ts +0 -12
  100. package/dist/runtime-support.js +0 -12
package/lib/print.js ADDED
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _client = require("react-dom/client");
10
+ var _lodashEs = require("lodash-es");
11
+ var _main = _interopRequireDefault(require("./main"));
12
+ var _mathRendering = require("@pie-lib/math-rendering");
13
+ var _debug = _interopRequireDefault(require("debug"));
14
+ const log = (0, _debug.default)('pie-element:extended-text-entry:print');
15
+ const preparePrintModel = (model, opts) => {
16
+ const instr = opts.role === 'instructor';
17
+ const printModel = (0, _lodashEs.cloneDeep)(model);
18
+ printModel.prompt = printModel.promptEnabled !== false ? printModel.prompt : undefined;
19
+ printModel.teacherInstructions = instr && printModel.teacherInstructionsEnabled !== false ? printModel.teacherInstructions : undefined;
20
+ printModel.showTeacherInstructions = instr;
21
+ printModel.mode = instr ? 'evaluate' : printModel.mode;
22
+ const defaultDimensions = {
23
+ height: 100,
24
+ width: 500
25
+ };
26
+ printModel.dimensions = {
27
+ ...defaultDimensions,
28
+ ...printModel.dimensions
29
+ };
30
+ printModel.disabled = true;
31
+ printModel.feedback = undefined;
32
+ printModel.animationsDisabled = true;
33
+ return printModel;
34
+ };
35
+ class ExtendedTextEntryPrint extends HTMLElement {
36
+ constructor() {
37
+ super();
38
+ this._options = null;
39
+ this._model = null;
40
+ this._session = [];
41
+ this._root = null;
42
+ this._rerender = (0, _lodashEs.debounce)(() => {
43
+ if (this._model && this._session && this._options) {
44
+ const printModel = preparePrintModel(this._model, this._options);
45
+ const element = /*#__PURE__*/_react.default.createElement(_main.default, {
46
+ model: printModel,
47
+ session: {},
48
+ onChange: () => {},
49
+ onValueChange: () => {},
50
+ onAnnotationsChange: () => {},
51
+ onCommentChange: () => {}
52
+ });
53
+ if (!this._root) {
54
+ this._root = (0, _client.createRoot)(this);
55
+ }
56
+ this._root.render(element);
57
+ queueMicrotask(() => {
58
+ log('render complete - render math');
59
+ (0, _mathRendering.renderMath)(this);
60
+ });
61
+ } else {
62
+ log('skip');
63
+ }
64
+ }, 50, {
65
+ leading: false,
66
+ trailing: true
67
+ });
68
+ }
69
+ set options(o) {
70
+ this._options = o;
71
+ // re-render so role changes (student/instructor) propagate
72
+ this._rerender();
73
+ }
74
+ set model(s) {
75
+ this._model = s;
76
+ this._rerender();
77
+ }
78
+ connectedCallback() {}
79
+ disconnectedCallback() {
80
+ if (this._root) {
81
+ this._root.unmount();
82
+ }
83
+ }
84
+ }
85
+ exports.default = ExtendedTextEntryPrint;
86
+ //# sourceMappingURL=print.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"print.js","names":["_react","_interopRequireDefault","require","_client","_lodashEs","_main","_mathRendering","_debug","log","debug","preparePrintModel","model","opts","instr","role","printModel","cloneDeep","prompt","promptEnabled","undefined","teacherInstructions","teacherInstructionsEnabled","showTeacherInstructions","mode","defaultDimensions","height","width","dimensions","disabled","feedback","animationsDisabled","ExtendedTextEntryPrint","HTMLElement","constructor","_options","_model","_session","_root","_rerender","debounce","element","React","createElement","Main","session","onChange","onValueChange","onAnnotationsChange","onCommentChange","createRoot","render","queueMicrotask","renderMath","leading","trailing","options","o","s","connectedCallback","disconnectedCallback","unmount","exports","default"],"sources":["../src/print.js"],"sourcesContent":["import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport { cloneDeep, debounce } from 'lodash-es';\nimport Main from './main';\nimport { renderMath } from '@pie-lib/math-rendering';\n\nimport debug from 'debug';\n\nconst log = debug('pie-element:extended-text-entry:print');\n\nconst preparePrintModel = (model, opts) => {\n const instr = opts.role === 'instructor';\n const printModel = cloneDeep(model);\n\n printModel.prompt = printModel.promptEnabled !== false ? printModel.prompt : undefined;\n printModel.teacherInstructions =\n instr && printModel.teacherInstructionsEnabled !== false ? printModel.teacherInstructions : undefined;\n printModel.showTeacherInstructions = instr;\n printModel.mode = instr ? 'evaluate' : printModel.mode;\n\n const defaultDimensions = { height: 100, width: 500 };\n\n printModel.dimensions = {\n ...defaultDimensions,\n ...printModel.dimensions,\n };\n\n printModel.disabled = true;\n printModel.feedback = undefined;\n printModel.animationsDisabled = true;\n\n return printModel;\n};\n\nexport default class ExtendedTextEntryPrint extends HTMLElement {\n constructor() {\n super();\n this._options = null;\n this._model = null;\n this._session = [];\n this._root = null;\n this._rerender = debounce(\n () => {\n if (this._model && this._session && this._options) {\n const printModel = preparePrintModel(this._model, this._options);\n\n const element = React.createElement(Main, {\n model: printModel,\n session: {},\n onChange: () => {},\n onValueChange: () => {},\n onAnnotationsChange: () => {},\n onCommentChange: () => {},\n });\n\n if (!this._root) {\n this._root = createRoot(this);\n }\n this._root.render(element);\n queueMicrotask(() => {\n log('render complete - render math');\n renderMath(this);\n });\n } else {\n log('skip');\n }\n },\n 50,\n { leading: false, trailing: true },\n );\n }\n set options(o) {\n this._options = o;\n // re-render so role changes (student/instructor) propagate\n this._rerender();\n }\n\n set model(s) {\n this._model = s;\n this._rerender();\n }\n\n connectedCallback() {}\n\n disconnectedCallback() {\n if (this._root) {\n this._root.unmount();\n }\n }\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,cAAA,GAAAJ,OAAA;AAEA,IAAAK,MAAA,GAAAN,sBAAA,CAAAC,OAAA;AAEA,MAAMM,GAAG,GAAG,IAAAC,cAAK,EAAC,uCAAuC,CAAC;AAE1D,MAAMC,iBAAiB,GAAGA,CAACC,KAAK,EAAEC,IAAI,KAAK;EACzC,MAAMC,KAAK,GAAGD,IAAI,CAACE,IAAI,KAAK,YAAY;EACxC,MAAMC,UAAU,GAAG,IAAAC,mBAAS,EAACL,KAAK,CAAC;EAEnCI,UAAU,CAACE,MAAM,GAAGF,UAAU,CAACG,aAAa,KAAK,KAAK,GAAGH,UAAU,CAACE,MAAM,GAAGE,SAAS;EACtFJ,UAAU,CAACK,mBAAmB,GAC5BP,KAAK,IAAIE,UAAU,CAACM,0BAA0B,KAAK,KAAK,GAAGN,UAAU,CAACK,mBAAmB,GAAGD,SAAS;EACvGJ,UAAU,CAACO,uBAAuB,GAAGT,KAAK;EAC1CE,UAAU,CAACQ,IAAI,GAAGV,KAAK,GAAG,UAAU,GAAGE,UAAU,CAACQ,IAAI;EAEtD,MAAMC,iBAAiB,GAAG;IAAEC,MAAM,EAAE,GAAG;IAAEC,KAAK,EAAE;EAAI,CAAC;EAErDX,UAAU,CAACY,UAAU,GAAG;IACtB,GAAGH,iBAAiB;IACpB,GAAGT,UAAU,CAACY;EAChB,CAAC;EAEDZ,UAAU,CAACa,QAAQ,GAAG,IAAI;EAC1Bb,UAAU,CAACc,QAAQ,GAAGV,SAAS;EAC/BJ,UAAU,CAACe,kBAAkB,GAAG,IAAI;EAEpC,OAAOf,UAAU;AACnB,CAAC;AAEc,MAAMgB,sBAAsB,SAASC,WAAW,CAAC;EAC9DC,WAAWA,CAAA,EAAG;IACZ,KAAK,CAAC,CAAC;IACP,IAAI,CAACC,QAAQ,GAAG,IAAI;IACpB,IAAI,CAACC,MAAM,GAAG,IAAI;IAClB,IAAI,CAACC,QAAQ,GAAG,EAAE;IAClB,IAAI,CAACC,KAAK,GAAG,IAAI;IACjB,IAAI,CAACC,SAAS,GAAG,IAAAC,kBAAQ,EACvB,MAAM;MACJ,IAAI,IAAI,CAACJ,MAAM,IAAI,IAAI,CAACC,QAAQ,IAAI,IAAI,CAACF,QAAQ,EAAE;QACjD,MAAMnB,UAAU,GAAGL,iBAAiB,CAAC,IAAI,CAACyB,MAAM,EAAE,IAAI,CAACD,QAAQ,CAAC;QAEhE,MAAMM,OAAO,gBAAGC,cAAK,CAACC,aAAa,CAACC,aAAI,EAAE;UACxChC,KAAK,EAAEI,UAAU;UACjB6B,OAAO,EAAE,CAAC,CAAC;UACXC,QAAQ,EAAEA,CAAA,KAAM,CAAC,CAAC;UAClBC,aAAa,EAAEA,CAAA,KAAM,CAAC,CAAC;UACvBC,mBAAmB,EAAEA,CAAA,KAAM,CAAC,CAAC;UAC7BC,eAAe,EAAEA,CAAA,KAAM,CAAC;QAC1B,CAAC,CAAC;QAEF,IAAI,CAAC,IAAI,CAACX,KAAK,EAAE;UACf,IAAI,CAACA,KAAK,GAAG,IAAAY,kBAAU,EAAC,IAAI,CAAC;QAC/B;QACA,IAAI,CAACZ,KAAK,CAACa,MAAM,CAACV,OAAO,CAAC;QAC1BW,cAAc,CAAC,MAAM;UACnB3C,GAAG,CAAC,+BAA+B,CAAC;UACpC,IAAA4C,yBAAU,EAAC,IAAI,CAAC;QAClB,CAAC,CAAC;MACJ,CAAC,MAAM;QACL5C,GAAG,CAAC,MAAM,CAAC;MACb;IACF,CAAC,EACD,EAAE,EACF;MAAE6C,OAAO,EAAE,KAAK;MAAEC,QAAQ,EAAE;IAAK,CACnC,CAAC;EACH;EACA,IAAIC,OAAOA,CAACC,CAAC,EAAE;IACb,IAAI,CAACtB,QAAQ,GAAGsB,CAAC;IACjB;IACA,IAAI,CAAClB,SAAS,CAAC,CAAC;EAClB;EAEA,IAAI3B,KAAKA,CAAC8C,CAAC,EAAE;IACX,IAAI,CAACtB,MAAM,GAAGsB,CAAC;IACf,IAAI,CAACnB,SAAS,CAAC,CAAC;EAClB;EAEAoB,iBAAiBA,CAAA,EAAG,CAAC;EAErBC,oBAAoBA,CAAA,EAAG;IACrB,IAAI,IAAI,CAACtB,KAAK,EAAE;MACd,IAAI,CAACA,KAAK,CAACuB,OAAO,CAAC,CAAC;IACtB;EACF;AACF;AAACC,OAAA,CAAAC,OAAA,GAAA/B,sBAAA","ignoreList":[]}
@@ -0,0 +1 @@
1
+ import{_dll_react as e,_dll_prop_types as t,_dll_mui__material as n,_dll_mui__material_styles as i,_dll_react_dom_client as a}from"../../../@pie-lib/shared-module@^5.2.4/module/index.js";import{_dll_pie_lib__config_ui as s}from"../../../@pie-lib/config-module@^4.0.9/module/index.js";import{_dll_pie_lib__editable_html_tip_tap as o}from"../../../@pie-lib/editable-html-module@^7.1.6/module/index.js";var l={};Object.defineProperty(l,"__esModule",{value:!0});class r extends CustomEvent{constructor(e,t=!1){super(r.TYPE,{bubbles:!0,detail:{update:e,reset:t}}),this.update=e,this.reset=t}}r.TYPE="model.updated";var d=l.ModelUpdatedEvent=r;class c extends CustomEvent{constructor(e,t){super(c.TYPE,{bubbles:!0,detail:{src:e,done:t}}),this.src=e,this.done=t}}c.TYPE="delete.image";var p=l.DeleteImageEvent=c;class u extends CustomEvent{constructor(e){super(u.TYPE,{bubbles:!0,detail:e}),this.handler=e}}u.TYPE="insert.image";var h=l.InsertImageEvent=u;class g extends CustomEvent{constructor(e,t){super(g.TYPE,{bubbles:!0,detail:{src:e,done:t}}),this.src=e,this.done=t}}g.TYPE="delete.sound";var b=l.DeleteSoundEvent=g;class m extends CustomEvent{constructor(e){super(m.TYPE,{bubbles:!0,detail:e}),this.handler=e}}m.TYPE="insert.sound";var _=l.InsertSoundEvent=m;const E=e,f=t,{Typography:C}=n,{styled:I}=i,{FeedbackSelector:v}=s,{InputContainer:S}=s,{settings:x}=s,{layout:y}=s,k=o,{ALL_PLUGINS:P}=o;function w(e){let t,n=e[0],i=1;for(;i<e.length;){const a=e[i],s=e[i+1];if(i+=2,("optionalAccess"===a||"optionalCall"===a)&&null==n)return;"access"===a||"optionalAccess"===a?(t=n,n=s(n)):"call"!==a&&"optionalCall"!==a||(n=s((...e)=>n.call(t,...e)),t=void 0)}return n}const{Panel:M,toggle:T,numberFields:A,dropdown:D}=x,R={type:"default",default:"Your answer has been submitted"},q=I(C)(({theme:e})=>({paddingBottom:e.spacing(1)})),Y=I(S)(({theme:e})=>({paddingTop:e.spacing(1),marginTop:e.spacing(2),marginBottom:e.spacing(2),width:"100%"})),O=I("div")(({theme:e})=>({fontSize:e.typography.fontSize-2,color:e.palette.error.main,paddingTop:e.spacing(1)}));class j extends E.Component{static __initStatic(){this.propTypes={onModelChanged:f.func.isRequired,onConfigurationChanged:f.func,model:f.object.isRequired,configuration:f.object.isRequired,imageSupport:f.object.isRequired,uploadSoundSupport:f.object.isRequired}}constructor(e){super(e),j.prototype.__init.call(this),j.prototype.__init2.call(this),j.prototype.__init3.call(this),this.state={setDimensions:!0}}__init(){this.onPromptChange=e=>{const{onModelChanged:t,model:n}=this.props;t({...n,prompt:e})}}__init2(){this.changeFeedback=e=>{const{model:t,onModelChanged:n}=this.props;n({...t,feedback:e})}}__init3(){this.changeTeacherInstructions=e=>{const{model:t,onModelChanged:n}=this.props;n({...t,teacherInstructions:e})}}render(){const{model:e,configuration:t,imageSupport:n,onConfigurationChanged:i,onModelChanged:a,uploadSoundSupport:s}=this.props,{annotations:o={},contentDimensions:l={},dimensions:r={},equationEditor:d={},feedback:c={},playerSpellCheck:p={},prompt:u={},settingsPanelDisabled:h,spanishInput:g={},specialInput:b={},spellCheck:m={},studentInstructions:_={},teacherInstructions:f={},mathInput:C={},maxImageWidth:I={},maxImageHeight:S={},multiple:x={},withRubric:j={},mathMlOptions:H={},baseInputConfiguration:F={}}=t||{},{errors:G={},extraCSSRules:W,feedbackEnabled:L,promptEnabled:z,spellCheckEnabled:N,teacherInstructionsEnabled:B,toolbarEditorPosition:U}=e||{},{prompt:J,teacherInstructions:K}=G,Q=I&&I.prompt,V=S&&S.prompt,X={position:"top"===U?"top":"bottom"},Z={mathInput:C.settings&&T(C.label),equationEditor:d.enabled&&e.mathInput&&D(d.label,["non-negative-integers","integers","decimals","fractions","Grade 1 - 2","Grade 3 - 5","Grade 6 - 7","Grade 8 - HS","geometry","advanced-algebra","statistics","item-authoring"]),spanishInput:g.settings&&T(g.label),specialInput:b.settings&&T(b.label),dimensions:r.settings&&A(r.label,{width:{label:"Width (px)",suffix:"px",min:100,max:1200},height:{label:"Height (px)",suffix:"px",min:100,max:500}}),"multiple.enabled":x.settings&&T(x.label,!0),promptEnabled:u.settings&&T(u.label),feedbackEnabled:c.settings&&T(c.label),annotationsEnabled:o.settings&&T(o.label),spellCheckEnabled:m.settings&&T(m.label),playerSpellCheckDisabled:p.settings&&T(p.label)},$={teacherInstructionsEnabled:f.settings&&T(f.label),studentInstructionsEnabled:_.settings&&T(_.label),rubricEnabled:w([j,"optionalAccess",e=>e.settings])&&T(w([j,"optionalAccess",e=>e.label]))},ee=e=>Object.assign({...F},e||{});return E.createElement(y.ConfigLayout,{extraCSSRules:W,dimensions:l,hideSettings:h,settings:E.createElement(M,{model:e,configuration:t,onChangeModel:e=>a(e),onChangeConfiguration:e=>i(e),groups:{Settings:Z,Properties:$}})},B&&E.createElement(Y,{label:f.label},E.createElement(k,{className:"prompt",markup:e.teacherInstructions||"",onChange:this.changeTeacherInstructions,imageSupport:n,nonEmpty:!1,error:K,toolbarOpts:X,spellCheck:N,maxImageWidth:I&&I.teacherInstructions||Q,maxImageHeight:S&&S.teacherInstructions||V,uploadSoundSupport:s,languageCharactersProps:[{language:"spanish"},{language:"special"}],mathMlOptions:H,pluginProps:ee(w([f,"optionalAccess",e=>e.inputConfiguration]))}),K&&E.createElement(O,null,K)),z&&E.createElement(Y,{label:u.label},E.createElement(k,{activePlugins:P,className:"prompt",markup:e.prompt||"",onChange:this.onPromptChange,imageSupport:n,nonEmpty:!1,error:J,toolbarOpts:X,spellCheck:N,maxImageWidth:Q,maxImageHeight:V,uploadSoundSupport:s,languageCharactersProps:[{language:"spanish"},{language:"special"}],mathMlOptions:H,pluginProps:ee(w([u,"optionalAccess",e=>e.inputConfiguration]))}),J&&E.createElement(O,null,J)),L&&E.createElement(E.Fragment,null,E.createElement(q,{variant:"h6"},"Feedback"),E.createElement(v,{label:"When submitted, show",feedback:e.feedback||R,onChange:this.changeFeedback,toolbarOpts:X})))}}j.__initStatic();var H={annotationsEnabled:!1,dimensions:{height:100,width:500},equationEditor:"Grade 8 - HS",feedbackEnabled:!1,mathInput:!1,playerSpellCheckDisabled:!0,predefinedAnnotations:[{label:"good",text:"good",type:"positive"},{label:"★",text:"★",type:"positive"},{label:":-)",text:":-)",type:"positive"},{label:"creative",text:"creative",type:"positive"},{label:"run-on",text:"run-on",type:"negative"},{label:"frag",text:"fragment",type:"negative"},{label:"tran",text:"transition",type:"negative"},{label:"supp",text:"support needed",type:"negative"},{label:"punc",text:"punctuation",type:"negative"},{label:"agr",text:"agreement wrong",type:"negative"},{label:"unclear",text:"unclear",type:"negative"},{label:"cut",text:"cut",type:"negative"},{label:"sp",text:"spelling",type:"negative"},{label:"cap",text:"capitalization",type:"negative"},{label:"inf",text:"informal",type:"negative"},{label:"awk",text:"awkward",type:"negative"}],prompt:"",promptEnabled:!0,rationale:"",rationaleEnabled:!0,spanishInput:!1,specialInput:!1,spellCheckEnabled:!0,studentInstructionsEnabled:!0,teacherInstructions:"",teacherInstructionsEnabled:!0,toolbarEditorPosition:"bottom"},F={annotations:{settings:!1,label:"Annotations"},baseInputConfiguration:{audio:{disabled:!1},video:{disabled:!1},image:{disabled:!1},h3:{disabled:!0},blockquote:{disabled:!0},textAlign:{disabled:!0},showParagraphs:{disabled:!1},separateParagraphs:{disabled:!0}},dimensions:{settings:!0,label:"Text-Entry Display Size"},spellCheck:{label:"Spellcheck",settings:!1,enabled:!0},playerSpellCheck:{label:"Disable Student Spellcheck",settings:!0,enabled:!0},equationEditor:{settings:!1,label:"Equation Editor",enabled:!0},feedback:{settings:!0,label:"Feedback"},mathInput:{settings:!0,label:"Student response can include math notation",enabled:!1},settingsPanelDisabled:!1,spanishInput:{settings:!0,label:"Students can insert Spanish",enabled:!1},specialInput:{settings:!0,label:"Students can insert Special Characters",enabled:!1},multiple:{settings:!1,label:"Multiple Parts",enabled:!1},studentInstructions:{settings:!1,label:"Student Instructions"},prompt:{settings:!0,label:"Prompt",inputConfiguration:{audio:{disabled:!1},video:{disabled:!1},image:{disabled:!1}},required:!1},teacherInstructions:{settings:!0,label:"Teacher Instructions",inputConfiguration:{audio:{disabled:!1},video:{disabled:!1},image:{disabled:!1}},required:!1},maxImageWidth:{teacherInstructions:300,prompt:300},maxImageHeight:{teacherInstructions:300,prompt:300},withRubric:{settings:!1,label:"Add Rubric"},mathMlOptions:{mmlOutput:!1,mmlEditing:!1}};const G=e,{createRoot:W}=a;function L(e){let t,n=e[0],i=1;for(;i<e.length;){const a=e[i],s=e[i+1];if(i+=2,("optionalAccess"===a||"optionalCall"===a)&&null==n)return;"access"===a||"optionalAccess"===a?(t=n,n=s(n)):"call"!==a&&"optionalCall"!==a||(n=s((...e)=>n.call(t,...e)),t=void 0)}return n}class z extends HTMLElement{static __initStatic(){this.createDefaultModel=(e={},t)=>{const n={...H,...e};return L([t,"optionalAccess",e=>e.withRubric,"optionalAccess",e=>e.forceEnabled])&&!n.rubricEnabled&&(n.rubricEnabled=!0),n}}constructor(){super(),this._root=null,this._configuration=F,L([this,"access",e=>e._configuration,"access",e=>e.withRubric,"optionalAccess",e=>e.forceEnabled])&&(this._configuration.withRubric.settings=!1),this._model=z.createDefaultModel({},this._configuration)}set model(e){this._model=z.createDefaultModel(e,this._configuration),this.render()}set configuration(e){this._configuration={...F,...e};const{withRubric:t={}}=e||{};L([t,"optionalAccess",e=>e.forceEnabled])&&(this._configuration.withRubric.settings=!1,this._model.rubricEnabled||(this._model.rubricEnabled=!0)),this.render()}onModelChanged(e){this._model=e,this.render(),this.dispatchEvent(new d(this._model,!1))}onConfigurationChanged(e){this._configuration={...F,...e},this._model&&this.onModelChanged(this._model),this.render()}insertImage(e){this.dispatchEvent(new h(e))}onDeleteImage(e,t){this.dispatchEvent(new p(e,t))}insertSound(e){this.dispatchEvent(new _(e))}onDeleteSound(e,t){this.dispatchEvent(new b(e,t))}render(){if(this._model){const e=G.createElement(j,{model:this._model,configuration:this._configuration,onModelChanged:this.onModelChanged.bind(this),onConfigurationChanged:this.onConfigurationChanged.bind(this),imageSupport:{add:this.insertImage.bind(this),delete:this.onDeleteImage.bind(this)},uploadSoundSupport:{add:this.insertSound.bind(this),delete:this.onDeleteSound.bind(this)}});this._root||(this._root=W(this)),this._root.render(e)}}disconnectedCallback(){this._root&&this._root.unmount()}}z.__initStatic();export{z as default};
@@ -0,0 +1,139 @@
1
+ /**
2
+ * Get the feedback from a {FeedbackConfig}
3
+ *
4
+ * @param {FeedbackConfig} feedback
5
+ * @param {string} fallback
6
+ */
7
+ const getFeedback = (feedback, fallback) =>
8
+ new Promise((resolve) => {
9
+ if (!feedback || feedback.type === 'none') {
10
+ resolve(undefined);
11
+ return;
12
+ }
13
+ feedback = feedback || {};
14
+ const out = feedback[feedback.type] || fallback;
15
+ resolve(out);
16
+ });
17
+
18
+ var defaults = {
19
+ annotationsEnabled: false,
20
+ dimensions: { height: 100, width: 500 },
21
+ equationEditor: 'Grade 8 - HS',
22
+ feedbackEnabled: false,
23
+ mathInput: false,
24
+ playerSpellCheckDisabled: true,
25
+ predefinedAnnotations: [
26
+ { label: 'good', text: 'good', type: 'positive' },
27
+ { label: '★', text: '★', type: 'positive' },
28
+ { label: ':-)', text: ':-)', type: 'positive' },
29
+ { label: 'creative', text: 'creative', type: 'positive' },
30
+ { label: 'run-on', text: 'run-on', type: 'negative' },
31
+ { label: 'frag', text: 'fragment', type: 'negative' },
32
+ { label: 'tran', text: 'transition', type: 'negative' },
33
+ { label: 'supp', text: 'support needed', type: 'negative' },
34
+ { label: 'punc', text: 'punctuation', type: 'negative' },
35
+ { label: 'agr', text: 'agreement wrong', type: 'negative' },
36
+ { label: 'unclear', text: 'unclear', type: 'negative' },
37
+ { label: 'cut', text: 'cut', type: 'negative' },
38
+ { label: 'sp', text: 'spelling', type: 'negative' },
39
+ { label: 'cap', text: 'capitalization', type: 'negative' },
40
+ { label: 'inf', text: 'informal', type: 'negative' },
41
+ { label: 'awk', text: 'awkward', type: 'negative' },
42
+ ],
43
+ prompt: '',
44
+ promptEnabled: true,
45
+ rationale: '',
46
+ rationaleEnabled: true,
47
+ studentInstructionsEnabled: true,
48
+ teacherInstructions: '',
49
+ teacherInstructionsEnabled: true,
50
+ toolbarEditorPosition: 'bottom',
51
+ };
52
+
53
+ async function createDefaultModel(model = {}) {
54
+
55
+ return { ...defaults, ...model };
56
+ }
57
+
58
+ const normalize = (question) => ({ ...defaults, ...question });
59
+
60
+ async function model(question, session, env) {
61
+ const normalizedQuestion = normalize(question);
62
+
63
+ const fb =
64
+ env.mode === 'evaluate' && normalizedQuestion.feedbackEnabled
65
+ ? getFeedback(normalizedQuestion.feedback, 'Your answer has been submitted')
66
+ : Promise.resolve(undefined);
67
+
68
+ let teacherInstructions = null;
69
+ if (env.role === 'instructor' && (env.mode === 'view' || env.mode === 'evaluate')) {
70
+ teacherInstructions = normalizedQuestion.teacherInstructionsEnabled ? normalizedQuestion.teacherInstructions : null;
71
+ } else {
72
+ teacherInstructions = null;
73
+ }
74
+
75
+ let equationEditor = normalizedQuestion.equationEditor || 'miscellaneous';
76
+
77
+ switch (normalizedQuestion.equationEditor) {
78
+ case 'Grade 1 - 2':
79
+ equationEditor = 1;
80
+ break;
81
+ case 'Grade 3 - 5':
82
+ equationEditor = 3;
83
+ break;
84
+ case 'Grade 6 - 7':
85
+ equationEditor = 6;
86
+ break;
87
+ case 'Grade 8 - HS':
88
+ equationEditor = 8;
89
+ break;
90
+ }
91
+
92
+ const annotatorMode = normalizedQuestion.annotationsEnabled && (env.role === 'instructor' || env.mode === 'evaluate');
93
+
94
+ return fb.then((feedback) => ({
95
+ prompt: normalizedQuestion.promptEnabled ? normalizedQuestion.prompt : null,
96
+ dimensions: normalizedQuestion.dimensions,
97
+ customKeys: normalizedQuestion.customKeys || [],
98
+ id: normalizedQuestion.id,
99
+ disabled: env.mode !== 'gather',
100
+ feedback,
101
+ teacherInstructions,
102
+ language: normalizedQuestion.language,
103
+ mathInput: normalizedQuestion.mathInput,
104
+ spanishInput: normalizedQuestion.spanishInput,
105
+ specialInput: normalizedQuestion.specialInput,
106
+ equationEditor,
107
+ spellCheckEnabled: !normalizedQuestion.playerSpellCheckDisabled,
108
+ playersToolbarPosition: normalizedQuestion.playersToolbarPosition || 'bottom',
109
+ annotatorMode,
110
+ disabledAnnotator: normalizedQuestion.annotationsEnabled ? env.role !== 'instructor' : true,
111
+ predefinedAnnotations: normalizedQuestion.annotationsEnabled ? normalizedQuestion.predefinedAnnotations : [],
112
+ extraCSSRules: normalizedQuestion.extraCSSRules,
113
+ }));
114
+ }
115
+
116
+ async function outcome(/*question, session, env*/) {
117
+ return {
118
+ score: 0,
119
+ completed: 'n/a',
120
+ note: 'Requires manual scoring',
121
+ };
122
+ }
123
+
124
+ // remove all html tags except img, iframe and source tag for audio
125
+ const getContent = (html) => (html || '').replace(/(<(?!img|iframe|source)([^>]+)>)/gi, '');
126
+
127
+ const validate = (model = {}, config = {}) => {
128
+ const errors = {};
129
+
130
+ ['teacherInstructions', 'prompt'].forEach((field) => {
131
+ if (config[field]?.required && !getContent(model[field])) {
132
+ errors[field] = 'This field is required.';
133
+ }
134
+ });
135
+
136
+ return errors;
137
+ };
138
+
139
+ export { createDefaultModel, model, normalize, outcome, validate };
package/module/demo.js ADDED
@@ -0,0 +1,38 @@
1
+ import Configure from './configure.js';
2
+ import Element from './element.js';
3
+ import * as controller from './controller.js';
4
+
5
+ var generate = {};
6
+
7
+ generate.model = (id, element) => ({
8
+ id,
9
+ element,
10
+ customKeys: ['\\square'],
11
+ feedback: { type: 'default', default: 'this is default feedback' },
12
+ prompt: 'This is the question prompt',
13
+ promptEnabled: true,
14
+ mathInput: true,
15
+ playersToolbarPosition: 'bottom',
16
+ toolbarEditorPosition: 'bottom',
17
+ spellCheckEnabled: true,
18
+ rubricEnabled: false,
19
+ annotationsEnabled: false,
20
+ });
21
+
22
+ const { model } = generate;
23
+ var config = {
24
+ elements: {
25
+ 'extended-text-entry': '../..',
26
+ },
27
+ models: [model('1', 'extended-text-entry')],
28
+ };
29
+
30
+ //Note: demo-el is a custom element loaded in the markup.
31
+ customElements.whenDefined("demo-el").then(() => {
32
+ config.models.forEach((m) => {
33
+ const de = document.createElement("demo-el");
34
+ document.body.appendChild(de);
35
+ de.def = { tagName: m.element, Element, Configure, controller };
36
+ de.model = m;
37
+ });
38
+ });
@@ -0,0 +1 @@
1
+ import{_dll_react as e,_dll_prop_types as t,_dll_mui__material as n,_dll_mui__material_styles as o,_dll_debug as i,_dll_pie_lib__render_ui as s,_dll_react_dom_client as a}from"../../../@pie-lib/shared-module@^5.2.4/module/index.js";import{_dll_pie_lib__math_rendering as r}from"../../../@pie-lib/math-rendering-module@^5.0.9/module/index.js";import{_dll_pie_lib__editable_html_tip_tap as l}from"../../../@pie-lib/editable-html-module@^7.1.6/module/index.js";import{_dll_pie_lib__config_ui as d}from"../../../@pie-lib/config-module@^4.0.9/module/index.js";var c="object"==typeof global&&global&&global.Object===Object&&global,p="object"==typeof self&&self&&self.Object===Object&&self,h=c||p||Function("return this")(),u=h.Symbol,m=Object.prototype,g=m.hasOwnProperty,f=m.toString,b=u?u.toStringTag:void 0;var y=Object.prototype.toString;var v=u?u.toStringTag:void 0;function C(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":v&&v in Object(e)?function(e){var t=g.call(e,b),n=e[b];try{e[b]=void 0;var o=!0}catch(e){}var i=f.call(e);return o&&(t?e[b]=n:delete e[b]),i}(e):function(e){return y.call(e)}(e)}var x=/\s/;var _=/^\s+/;function E(e){return e?e.slice(0,function(e){for(var t=e.length;t--&&x.test(e.charAt(t)););return t}(e)+1).replace(_,""):e}function w(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}var S=/^[-+]0x[0-9a-f]+$/i,A=/^0b[01]+$/i,k=/^0o[0-7]+$/i,T=parseInt;function R(e){if("number"==typeof e)return e;if(function(e){return"symbol"==typeof e||function(e){return null!=e&&"object"==typeof e}(e)&&"[object Symbol]"==C(e)}(e))return NaN;if(w(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=w(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=E(e);var n=A.test(e);return n||k.test(e)?T(e.slice(2),n?2:8):S.test(e)?NaN:+e}var M=function(){return h.Date.now()},L=Math.max,P=Math.min;function N(e,t,n){var o,i,s,a,r,l,d=0,c=!1,p=!1,h=!0;if("function"!=typeof e)throw new TypeError("Expected a function");function u(t){var n=o,s=i;return o=i=void 0,d=t,a=e.apply(s,n)}function m(e){var n=e-l;return void 0===l||n>=t||n<0||p&&e-d>=s}function g(){var e=M();if(m(e))return f(e);r=setTimeout(g,function(e){var n=t-(e-l);return p?P(n,s-(e-d)):n}(e))}function f(e){return r=void 0,h&&o?u(e):(o=i=void 0,a)}function b(){var e=M(),n=m(e);if(o=arguments,i=this,l=e,n){if(void 0===r)return function(e){return d=e,r=setTimeout(g,t),c?u(e):a}(l);if(p)return clearTimeout(r),r=setTimeout(g,t),u(l)}return void 0===r&&(r=setTimeout(g,t)),a}return t=R(t)||0,w(n)&&(c=!!n.leading,s=(p="maxWait"in n)?L(R(n.maxWait)||0,t):s,h="trailing"in n?!!n.trailing:h),b.cancel=function(){void 0!==r&&clearTimeout(r),d=0,o=l=i=r=void 0},b.flush=function(){return void 0===r?a:f(M())},b}const I=(e,t,n)=>{const o=n||[],i=o.reduce((e,t)=>e+t.textContent.length,0);let s=!0;if(i>t)return!1;for(e&&(3===e.nodeType&&e.parentNode&&!e.parentNode.hasAttribute("data-ann-id")&&o.push(e),e=e.firstChild);e&&s;)s=I(e,t,o),e=e.nextSibling;return o},D=e=>{const{commonAncestorContainer:t,startContainer:n,endContainer:o,startOffset:i,endOffset:s}=e,a=[];let r=!1,l=!1,d="";const c=e=>{const{nodeValue:t,childNodes:p}=e;e===n&&e===o?(t&&(d+=t.substring(i,s)),r=l=!0):e===n?(t&&(d+=t.substring(i)),r=!0):e===o?(t&&(d+=t.substring(0,s)),l=!0):e&&3===e.nodeType&&e.parentNode&&!e.parentNode.hasAttribute("data-ann-id")&&t&&r&&!l&&(d+=t,a.push(e)),p.forEach(e=>{l||c(e)})};return c(t),[a,d]},j=e=>{const t=document.createElement("SPAN");return e.surroundContents(t),t},O=e=>{if(e.startContainer===e.endContainer)return[j(e)];const[t]=D(e),n=document.createRange();n.selectNodeContents(e.startContainer),n.setStart(e.startContainer,e.startOffset);const o=j(n),i=document.createRange();i.selectNode(e.endContainer),i.setEnd(e.endContainer,e.endOffset);const s=j(i);return[o,...t.map(e=>{const t=document.createElement("SPAN");return e.parentNode.insertBefore(t,e),t.appendChild(e),t}),s]},W=(e,t)=>{(e||[]).forEach(e=>{const t=e.parentNode,n=e.childNodes,o=n.length;if(o>0)for(let i=0;i<o;i++)t.insertBefore(n[0],e);else t.insertBefore(document.createTextNode(e.textContent),e);t.removeChild(e)}),t.normalize()},$=()=>{document.getSelection?(document.getSelection().removeAllRanges(),document.getSelection().addRange(document.createRange())):window.getSelection?window.getSelection().removeAllRanges?(window.getSelection().removeAllRanges(),window.getSelection().addRange(document.createRange())):window.getSelection().empty&&window.getSelection().empty():document.selection&&document.selection.empty()},H=e=>e.length>=20||-1!==e.search(/\n|\r|\r\n/),z=e=>Array.from(document.querySelectorAll(`[data-id='${e}']`)),q=e=>document.querySelector(`[data-ann-id='${e}']`),B=e,F=t,{Popover:K}=n,{TextField:U}=n,{styled:V}=o,Y=V(K)(({theme:e,annotationType:t})=>({"& .MuiPaper-root":{overflowX:"unset",overflowY:"unset",marginLeft:"16px","&::before":{position:"absolute",right:"100%",top:"13px",border:"solid transparent",content:'""',height:0,width:0,pointerEvents:"none",borderWidth:"7px",borderRightColor:e.palette.grey[100]},..."negative"===t&&{"&::before":{borderRightColor:"rgb(255, 204, 238) !important"}},..."positive"===t&&{"&::before":{borderRightColor:"rgb(153, 255, 153) !important"}}}})),G=V("div")(({theme:e,annotationType:t})=>({width:"200px",overflow:"hidden",borderRadius:"4px",backgroundColor:"#ffffff",border:`4px solid ${e.palette.grey[100]}`,..."negative"===t&&{borderColor:"rgb(255, 204, 238) !important"},..."positive"===t&&{borderColor:"rgb(153, 255, 153) !important"}})),X=V("div")(({theme:e})=>({display:"flex",flexWrap:"wrap",borderTop:`2px solid ${e.palette.grey[100]}`})),Q=V("div")(({theme:e,variant:t,annotationType:n})=>({flexGrow:1,width:"28%",textAlign:"center",padding:"4px",cursor:"pointer","&:not(:nth-child(3n))":{borderRight:`1px solid ${e.palette.grey[100]}`},"&:hover":{backgroundColor:e.palette.grey[100]},..."positive"===t&&{backgroundColor:"rgb(153, 255, 153) !important","&:hover":{filter:"brightness(85%)"}},..."negative"===t&&{backgroundColor:"rgb(255, 204, 238) !important","&:hover":{filter:"brightness(85%)"}},..."typeChange"===t&&"negative"===n&&{"&:hover":{backgroundColor:"rgb(153, 255, 153) !important"}},..."typeChange"===t&&"positive"===n&&{"&:hover":{backgroundColor:"rgb(255, 204, 238) !important"}}}));class J extends B.Component{static __initStatic(){this.propTypes={anchorEl:F.object,open:F.bool,offset:F.number,value:F.string,type:F.string,onClose:F.func,onDelete:F.func,onSave:F.func,onTypeChange:F.func}}constructor(e){super(e),J.prototype.__init.call(this),J.prototype.__init2.call(this),J.prototype.__init3.call(this),this.state={value:e.value}}UNSAFE_componentWillReceiveProps(e){const{value:t}=e,{value:n}=this.props;t!==n&&this.setState({value:t})}__init(){this.onValueChange=e=>this.setState({value:e.target.value})}__init2(){this.handleSave=()=>{const{value:e,onSave:t,onClose:n,onDelete:o}=this.props,{value:i}=this.state;""===i&&o(),e!==i&&t(e,i),this.setState({value:""}),n()}}__init3(){this.handleTypeChange=()=>{const{onTypeChange:e,onDelete:t}=this.props,{value:n}=this.state;""===n?t():e(n),this.setState({value:""})}}render(){const{anchorEl:e,offset:t,onDelete:n,open:o,type:i}=this.props,{value:s}=this.state;return B.createElement(Y,{anchorEl:e,elevation:2,open:o,onClose:this.handleSave,annotationType:i,style:{marginTop:`${t}px`,transition:"margin-top 2s ease-out"},transitionDuration:{enter:225,exit:195},anchorOrigin:{vertical:"top",horizontal:"right"},transformOrigin:{vertical:"top",horizontal:"left"}},B.createElement(G,{annotationType:i},B.createElement(U,{id:"annotation-editor",style:{padding:"2px 5px",width:"95%"},autoFocus:!0,multiline:!0,rows:1,maxRows:4,value:s,onChange:this.onValueChange,InputProps:{disableUnderline:!0}}),B.createElement(X,null,B.createElement(Q,{onClick:n},"Delete"),B.createElement(Q,{variant:"typeChange",annotationType:i,onClick:this.handleTypeChange},"negative"===i?"Green":"Pink"),B.createElement(Q,{onClick:this.handleSave},"Save"))))}}J.__initStatic();const Z=e,ee=t,{styled:te}=o,{Popover:ne}=n,oe=te(ne)({"& .MuiPaper-root":{overflowX:"unset",overflowY:"unset",marginTop:"-16px","&::after":{position:"absolute",left:"calc(50% - 7px)",border:"solid transparent",content:'""',height:0,width:0,pointerEvents:"none",borderWidth:"7px",borderTopColor:"black"}}}),ie=te("div")(({theme:e})=>({width:"300px",overflow:"hidden",borderRadius:"4px",backgroundColor:e.palette.common.white,border:`2px solid ${e.palette.grey[100]}`})),se=te("div")({display:"flex",flexWrap:"wrap"}),ae=te("div")(({theme:e})=>({display:"flex",flexWrap:"wrap",borderTop:`2px solid ${e.palette.grey[100]}`})),re=te("div")(({theme:e,variant:t})=>({width:"22%",textAlign:"center",padding:"4px",cursor:"pointer",borderBottom:`1px solid ${e.palette.grey[100]}`,"&:not(:nth-child(4n))":{borderRight:`1px solid ${e.palette.grey[100]}`},"&:nth-child(4n)":{flexGrow:1},"&:hover":{backgroundColor:e.palette.grey[100]},..."positive"===t&&{backgroundColor:"rgb(153, 255, 153) !important","&:hover":{filter:"brightness(85%)"}},..."negative"===t&&{backgroundColor:"rgb(255, 204, 238) !important","&:hover":{filter:"brightness(85%)"}}}));class le extends Z.Component{static __initStatic(){this.propTypes={anchorEl:ee.object,open:ee.bool,annotations:ee.array,isNewAnnotation:ee.bool,onClose:ee.func,onDelete:ee.func,onEdit:ee.func,onWrite:ee.func,onAnnotate:ee.func}}render(){const{anchorEl:e,annotations:t,isNewAnnotation:n,onAnnotate:o,onClose:i,onEdit:s,onDelete:a,onWrite:r,open:l}=this.props;return Z.createElement(oe,{anchorEl:e,open:l,onClose:i,elevation:5,transitionDuration:{enter:225,exit:195},anchorOrigin:{vertical:"top",horizontal:"center"},transformOrigin:{vertical:"bottom",horizontal:"center"}},Z.createElement(ie,null,Z.createElement(se,null,t.map((e,t)=>Z.createElement(re,{key:`annotation-${t}`,variant:e.type,onClick:()=>o(e)},e.label))),Z.createElement(ae,null,Z.createElement(re,{onClick:i},"Cancel"),Z.createElement(re,{style:{pointerEvents:"none"}}),n?Z.createElement(Z.Fragment,null,Z.createElement(re,{variant:"positive",onClick:()=>r("positive")},"Write"),Z.createElement(re,{variant:"negative",onClick:()=>r("negative")},"Write")):Z.createElement(Z.Fragment,null,Z.createElement(re,{onClick:a},"Delete"),Z.createElement(re,{onClick:s},"Edit")))))}}le.__initStatic();const de=e,{styled:ce}=o,pe=t,he=l,{InputContainer:ue}=d,me=ce("div")({padding:"10px 120px 10px 16px",backgroundColor:"rgba(0, 0, 0, 0.06)",border:"1px solid #ccc",borderRadius:"4px",overflowY:"scroll",lineHeight:"36px",whiteSpace:"pre-wrap",overflowWrap:"break-word","& p":{margin:0},"& span[data-latex]":{userSelect:"none","-webkit-user-select":"none","-moz-user-select":"none","-ms-user-select":"none"}}),ge=ce("div")({width:"230px"}),fe=ce("div")({position:"relative",overflowX:"hidden",display:"flex"}),be=ce(ue)(({theme:e})=>({paddingTop:e.spacing(2),marginBottom:e.spacing(2),marginTop:e.spacing(2),width:"100%"}));if(!document.getElementById("annotation-editor-styles")){const e=document.createElement("style");e.id="annotation-editor-styles",e.textContent='\n .sideAnnotation:before {\n position: absolute;\n right: var(--before-right, 100%);\n top: var(--before-top, 5px);\n border: solid transparent;\n content: "";\n height: 0;\n width: 0;\n pointer-events: none;\n border-width: var(--before-border-width, 7px);\n border-right-color: var(--before-border-color, rgb(153, 255, 153));\n }\n',document.head.appendChild(e)}class ye extends de.Component{static __initStatic(){this.propTypes={text:pe.string,comment:pe.string,annotations:pe.array,predefinedAnnotations:pe.array,onChange:pe.func.isRequired,onCommentChange:pe.func.isRequired,width:pe.number,height:pe.number,maxHeight:pe.string,disabled:pe.bool,disabledMath:pe.bool,customKeys:pe.array,keypadMode:pe.string}}constructor(e){super(e),ye.prototype.__init.call(this),ye.prototype.__init2.call(this),ye.prototype.__init3.call(this),ye.prototype.__init4.call(this),ye.prototype.__init5.call(this),ye.prototype.__init6.call(this),ye.prototype.__init7.call(this),ye.prototype.__init8.call(this),ye.prototype.__init9.call(this),ye.prototype.__init10.call(this),ye.prototype.__init11.call(this),ye.prototype.__init12.call(this),ye.prototype.__init13.call(this),ye.prototype.__init14.call(this),ye.prototype.__init15.call(this),this.state={anchorEl:null,openedMenu:!1,openedEditor:!1,selectedElems:[],labelElem:null,selectionDetails:null,annotation:null,annotationIndex:null}}componentDidMount(){const{annotations:e,text:t}=this.props;t&&e.forEach(e=>{const[t,n]=((e,t,n)=>{const o=I(n,t),i=[];let s=0;return o.forEach(n=>{const o=s+n.textContent.length;[e,t].forEach(e=>{s<=e&&e<o&&i.push({node:n,offset:e-s})}),s=o}),i})(e.start,e.end,this.textRef);if(t&&n){const o=document.createRange();o.setStart(t.node,t.offset),o.setEnd(n.node,n.offset);const i=O(o);this.createDOMAnnotation(i,e)}}),this.textRef&&(this.adjustAnnotationsPosition(),this.textRef.addEventListener("scroll",this.adjustAnnotationsPosition))}__init(){this.adjustAnnotationsPosition=()=>{if(this.textRef&&this.labelsRef){const e=this.textRef.offsetLeft+this.textRef.offsetWidth+8;Array.from(this.labelsRef.children).forEach(t=>{const n=z(t.dataset.annId),o=(n[0].offsetTop?n[0].offsetTop:n[0].offsetParent.offsetTop)-this.textRef.scrollTop-6;t.style.top=`${o}px`,t.style.left=`${e}px`})}}}__init2(){this.handleClick=e=>{const{annotations:t}=this.props,{selectionDetails:n}=this.state;if(n)return;const{id:o,annId:i}=e.target.dataset,s=o||i,a=z(s),r=q(s),l=t.findIndex(e=>e.id===s),d=r.hasAttribute("data-freeform");d&&(r.style.zIndex="10"),this.setState({anchorEl:a[0],openedMenu:!!o||!!i&&!d,openedEditor:!!i&&d,selectedElems:a,labelElem:r,annotationIndex:l,annotation:t[l],selectionDetails:null})}}__init3(){this.handleHover=e=>{const{id:t,annId:n}=e.target.dataset,o=t||n,i=z(o),s=q(o),a=s.hasAttribute("data-freeform");i.forEach(e=>{e.style.zIndex="20",e.classList.contains("positive")?e.style.backgroundColor="rgb(51, 255, 51, 0.7)":e.classList.contains("negative")&&(e.style.backgroundColor="rgba(255, 102, 204, 0.55)")}),a?(s.style.zIndex="20",s.classList.contains("positive")?(s.style.backgroundColor="rgb(128, 255, 128)",s.style.setProperty("--before-border-color","rgb(153, 255, 153)")):s.classList.contains("negative")&&(s.style.backgroundColor="rgb(255, 179, 230)",s.style.setProperty("--before-border-color","rgb(255, 179, 230)"))):(s.style.zIndex="20",s.classList.contains("positive")?s.style.color="rgb(0, 77, 0)":s.classList.contains("negative")&&(s.style.color="rgb(153, 0, 102)"))}}__init4(){this.handleCancelHover=e=>{const{id:t,annId:n}=e.target.dataset,o=t||n,i=z(o),s=q(o),a=s.hasAttribute("data-freeform");i.forEach(e=>{e.style.zIndex="",e.classList.contains("positive")?e.style.backgroundColor="rgb(51, 255, 51, 0.5)":e.classList.contains("negative")&&(e.style.backgroundColor="rgba(255, 102, 204, 0.4)")}),a?(s.style.zIndex="",s.classList.contains("positive")?(s.style.backgroundColor="rgb(153, 255, 153)",s.style.removeProperty("--before-border-color")):s.classList.contains("negative")&&(s.style.backgroundColor="rgb(255, 204, 238)",s.style.removeProperty("--before-border-color"))):(s.style.zIndex="",s.classList.contains("positive")?s.style.color="rgb(0, 128, 0)":s.classList.contains("negative")&&(s.style.color="rgb(204, 0, 136)"))}}__init5(){this.handleClose=e=>{const{selectedElems:t,labelElem:n}=this.state;t.length&&!t[0].hasAttribute("data-id")&&W(t,this.textRef),n&&(n.style.zIndex=""),this.setState({anchorEl:null,openedMenu:!1,openedEditor:!1,selectedElems:[],labelElem:null,selectionDetails:null,annotationIndex:null,annotation:null}),$()}}__init6(){this.handleSelection=e=>{const t=window.getSelection();if(e.detail>2)$();else if(t&&t.rangeCount>0){const e=t.getRangeAt(0),n=e.toString(),o=this.textRef.contains(e.commonAncestorContainer);if(!t.isCollapsed&&""!==n&&o){const t=((e,t)=>{const n=document.createRange();n.setStart(t,0),n.setEnd(e.startContainer,e.startOffset);const[,o]=D(n),[,i]=D(e),s=o.length;return{quote:i,start:s,end:s+i.length}})(e,this.textRef),n=O(e);this.setState({anchorEl:n[0],openedMenu:!0,selectedElems:n,selectionDetails:t})}}}}__init7(){this.deleteAnnotation=()=>{const{annotations:e,onChange:t}=this.props,{selectedElems:n,labelElem:o,annotationIndex:i,annotation:s}=this.state;(H(s.label)?this.labelsRef:n[0]).removeChild(o),W(n,this.textRef),e.splice(i,1),t(e),this.handleClose()}}__init8(){this.createDOMAnnotation=(e,t)=>{const{disabled:n}=this.props,{id:o,label:i,type:s}=t;(e||[]).forEach(e=>{e.dataset.id=o,e.className=`annotation ${s}`,e.style.position="relative",e.style.cursor="pointer","positive"===s?e.style.backgroundColor="rgb(51, 255, 51, 0.5)":"negative"===s&&(e.style.backgroundColor="rgba(255, 102, 204, 0.4)"),e.onclick=!n&&this.handleClick,e.onmouseover=this.handleHover,e.onmouseout=this.handleCancelHover});const a=e&&e[0]||{},r=document.createElement("SPAN");if(r.dataset.annId=o,r.innerHTML=i,r.onclick=!n&&this.handleClick,r.onmouseover=this.handleHover,r.onmouseout=this.handleCancelHover,H(i)){const e=(a.offsetTop?a.offsetTop:a.offsetParent.offsetTop)-this.textRef.scrollTop,t=this.textRef.offsetLeft+this.textRef.offsetWidth+8;r.dataset.freeform=!0,r.className=`sideAnnotation ${s}`,r.style.position="absolute",r.style.padding="4px",r.style.borderRadius="4px",r.style.marginLeft="8px",r.style.width="180px",r.style.whiteSpace="pre-wrap",r.style.wordBreak="break-word",r.style.border="2px solid #ffffff",r.style.fontSize="14px",r.style.fontStyle="normal",r.style.fontWeight="normal",r.style.top=`${e}px`,r.style.left=`${t}px`,"negative"===s?r.style.backgroundColor="rgb(255, 204, 238)":"positive"===s&&(r.style.backgroundColor="rgb(153, 255, 153)"),r.style.setProperty("--before-border-width","7px"),r.style.setProperty("--before-top","5px"),r.style.setProperty("--before-right","100%"),"negative"===s?r.style.setProperty("--before-border-color","rgb(255, 204, 238)"):"positive"===s&&r.style.setProperty("--before-border-color","rgb(153, 255, 153)"),this.labelsRef.appendChild(r)}else r.className=`annotationLabel ${s}`,r.style.backgroundColor="rgb(242, 242, 242)",r.style.padding="2px",r.style.position="absolute",r.style.userSelect="none",r.style.whiteSpace="nowrap",r.style.top="-10px",r.style.left="-2px",r.style.fontSize="12px",r.style.fontStyle="normal",r.style.fontWeight="normal",r.style.lineHeight="6px",r.style.webkitUserSelect="none",r.style.mozUserSelect="none",r.style.msUserSelect="none","positive"===s?r.style.color="rgb(0, 128, 0)":"negative"===s&&(r.style.color="rgb(204, 0, 136)"),a.appendChild(r)}}__init9(){this.createNewAnnotation=(e,t)=>{const{selectedElems:n,selectionDetails:o}=this.state,i={id:[o.start,o.end,(new Date).getTime()].join("-"),label:e,type:t,...o};return this.createDOMAnnotation(n,i),i}}__init10(){this.handleMenuClick=e=>{const{annotations:t,onChange:n}=this.props,{annotation:o,annotationIndex:i}=this.state,{type:s,text:a}=e;if(o){const e={...o,label:a,type:s},{type:n,label:r}=o;this.updateLabel(r,e,s!==n&&n),t.splice(i,1,e)}else{const e=this.createNewAnnotation(a,s);t.push(e)}n(t),this.handleClose()}}__init11(){this.editAnnotation=()=>{this.setState({openedMenu:!1,openedEditor:!0})}}__init12(){this.addAnnotation=e=>{const{annotations:t,onChange:n}=this.props,o=this.createNewAnnotation("",e),i=q(o.id);t.push(o),this.setState({openedMenu:!1,openedEditor:!0,annotationIndex:t.length-1,annotation:o,labelElem:i}),n(t)}}__init13(){this.updateLabel=(e,t,n)=>{const{selectedElems:o,labelElem:i}=this.state,{label:s,type:a}=t;H(s)&&H(e)||!H(s)&&!H(e)?(i.innerHTML=s,n&&(i.classList.remove(n),i.classList.add(a),o.forEach(e=>{e.classList.remove(n),e.classList.add(a)}))):H(s)&&!H(e)?(o[0].removeChild(i),this.createDOMAnnotation(o,t)):!H(s)&&H(e)&&(this.labelsRef.removeChild(i),this.createDOMAnnotation(o,t))}}__init14(){this.changeAnnotationType=e=>{const{annotations:t,onChange:n}=this.props,{annotationIndex:o,selectedElems:i}=this.state,{type:s,label:a}=t[o],r="positive"===s?"negative":"positive",l={...t[o],type:r,label:e};i.forEach(e=>{e.classList.remove(s),e.classList.add(r)}),this.updateLabel(a,l,s),t.splice(o,1,l),n(t),this.handleClose()}}__init15(){this.updateAnnotation=(e,t)=>{const{annotations:n,onChange:o}=this.props,{annotationIndex:i}=this.state,s={...n[i],label:t};this.updateLabel(e,s),n.splice(i,1,s),o(n)}}componentWillUnmount(){this.textRef.removeEventListener("scroll",this.adjustAnnotationsPosition)}render(){const{comment:e,customKeys:t,disabled:n,disabledMath:o,keypadMode:i,height:s,width:a,maxHeight:r,onCommentChange:l,predefinedAnnotations:d,text:c}=this.props,{anchorEl:p,annotation:h,openedMenu:u,openedEditor:m,selectionDetails:g}=this.state,f=p&&(p.offsetTop?p.offsetTop:p.offsetParent.offsetTop),b=this.textRef&&f?f-this.textRef.scrollTop-8:0;return de.createElement("div",null,de.createElement(fe,null,de.createElement(me,{style:{width:a-34,minHeight:s,maxHeight:r},ref:e=>this.textRef=e,onMouseDown:n?()=>{}:$,onMouseUp:n?()=>{}:this.handleSelection,dangerouslySetInnerHTML:{__html:c}}),de.createElement(ge,{ref:e=>this.labelsRef=e})),de.createElement(be,{label:"Comment"},de.createElement(he,{className:"prompt",markup:e||"",onChange:l,width:a&&(a+104).toString(),disabled:n,pluginProps:{math:{disabled:o,customKeys:t,keypadMode:i,controlledKeypadMode:!1},video:{disabled:!0},audio:{disabled:!0},textAlign:{disabled:!0},h3:{disabled:!0}}})),de.createElement(le,{anchorEl:p,open:u&&!n,annotations:d,isNewAnnotation:!!g,onClose:this.handleClose,onDelete:this.deleteAnnotation,onEdit:this.editAnnotation,onWrite:this.addAnnotation,onAnnotate:this.handleMenuClick}),de.createElement(J,{anchorEl:this.textRef,open:m&&!n,offset:b,value:h&&h.label||"",type:h&&h.type,onClose:this.handleClose,onDelete:this.deleteAnnotation,onSave:this.updateAnnotation,onTypeChange:this.changeAnnotationType}))}}ye.__initStatic();const ve=e,Ce=t,xe=i,{Typography:_e}=n,{styled:Ee}=o,{color:we}=s,{Feedback:Se}=s,{Collapsible:Ae}=s,{PreviewPrompt:ke}=s,{UiLayout:Te}=s,Re=l,Me=xe("@pie-ui:extended-text-entry"),Le=Ee(Te)({backgroundColor:we.background(),color:we.text()}),Pe=Ee(_e)(({theme:e})=>({width:"100%",color:we.text(),marginBottom:e.spacing(2),fontSize:"inherit"})),Ne=Ee("div")(({theme:e})=>({marginBottom:e.spacing(2)})),Ie=Ee(Re)(({theme:e})=>({marginBottom:e.spacing(2),borderRadius:"4px"})),De=Ee("h2")({position:"absolute",left:"-10000px",top:"auto",width:"1px",height:"1px",overflow:"hidden"});class je extends ve.Component{constructor(...e){super(...e),je.prototype.__init.call(this),je.prototype.__init2.call(this)}static __initStatic(){this.propTypes={onValueChange:Ce.func.isRequired,onAnnotationsChange:Ce.func.isRequired,onCommentChange:Ce.func.isRequired,model:Ce.object,session:Ce.shape({value:Ce.string,annotations:Ce.array,comment:Ce.string}).isRequired}}__init(){this.changeSessionValue=N(this.props.onValueChange,1500)}__init2(){this.changeSessionComment=N(this.props.onCommentChange,1500)}render(){const{model:e,session:t,onAnnotationsChange:n}=this.props,{animationsDisabled:o,annotatorMode:i,customKeys:s,dimensions:a,disabled:r,disabledAnnotator:l,equationEditor:d,extraCSSRules:c,feedback:p,mathInput:h,playersToolbarPosition:u,predefinedAnnotations:m,prompt:g,spanishInput:f,specialInput:b,spellCheckEnabled:y,teacherInstructions:v}=e,{annotations:C,comment:x,value:_}=t,{width:E,height:w}=a||{},S="40vh",A={position:"top"===u?"top":"bottom"};Me("[render] disabled? ",r);const k=ve.createElement(ke,{defaultClassName:"teacher-instructions",prompt:v}),T=[];return f&&T.push({language:"spanish"}),b&&T.push({language:"special"}),ve.createElement(Le,{extraCSSRules:c,ref:e=>{this.containerRef=e}},ve.createElement(De,null,"Constructed Response Question"),v&&ve.createElement(Ne,null,o?k:ve.createElement(Ae,{labels:{hidden:"Show Teacher Instructions",visible:"Hide Teacher Instructions"}},k)),g&&ve.createElement(Pe,{component:"span"},ve.createElement(ke,{defaultClassName:"prompt",prompt:e.prompt})),i?ve.createElement(ye,{text:_||"",annotations:C||[],comment:x||"",predefinedAnnotations:m||[],onChange:n,onCommentChange:this.changeSessionComment,width:E,height:w,maxHeight:S,disabled:l,disabledMath:!h,customKeys:s,keypadMode:d}):ve.createElement(Ie,{className:"response-area-editor",onChange:this.changeSessionValue,markup:_||"",maxWidth:E&&E.toString(),minWidth:"100px",minHeight:w&&w.toString(),maxHeight:S,disabled:r,highlightShape:!0,toolbarOpts:A,spellCheck:y,charactersLimit:5e4,autoWidthToolbar:!0,pluginProps:{math:{disabled:!h,customKeys:this.props.model.customKeys,keypadMode:this.props.model.equationEditor,controlledKeypadMode:!1},video:{disabled:!0},audio:{disabled:!0},table:{disabled:!0},textAlign:{disabled:!0},h3:{disabled:!0},separateParagraphs:{disabled:!1},ul_list:{disabled:!0},ol_list:{disabled:!0}},languageCharactersProps:T}),p&&ve.createElement(Se,{correctness:"correct",feedback:p}))}}je.__initStatic();var Oe={};Object.defineProperty(Oe,"__esModule",{value:!0});class We extends CustomEvent{constructor(e,t,n){super(We.TYPE,{bubbles:!0,composed:!0,detail:{complete:t,component:e,hasModel:n}}),this.component=e,this.complete=t}}We.TYPE="model-set";var $e=Oe.ModelSetEvent=We;class He extends CustomEvent{constructor(e,t){super(He.TYPE,{bubbles:!0,composed:!0,detail:{complete:t,component:e}}),this.component=e,this.complete=t}}He.TYPE="session-changed";var ze=Oe.SessionChangedEvent=He;const qe=e,{createRoot:Be}=a,Fe=i,{renderMath:Ke}=r,Ue=Fe("@pie-elements:extended-text-entry"),Ve=void 0!==typeof window?new DOMParser:{parseFromString:e=>e};function Ye(e){if("string"==typeof e)try{const t=Ve.parseFromString(e,"text/html");return t.body.textContent}catch(t){return Ue("tried to parse as dom and failed",e),e}}function Ge(e){const t=Ye(e);return void 0!==t&&t.length>0}class Xe extends HTMLElement{constructor(){super(),this._model=null,this._session=null,this._root=null}setLangAttribute(){const e=this._model&&(this._model.language,1)?this._model.language:"",t=e?e.slice(0,2):"en";this.setAttribute("lang",t)}set model(e){this._model=e,this.dispatchEvent(new $e(this.tagName.toLowerCase(),!1,!!this._model)),this.render()}set session(e){this._session=e,this.render()}get session(){return this._session}valueChange(e){this._session.value=e,this.dispatchEvent(new ze(this.tagName.toLowerCase(),Ge(e))),this.render()}annotationsChange(e){this._session.annotations=e,this.dispatchEvent(new ze(this.tagName.toLowerCase(),!0)),this.render()}commentChange(e){this._session.comment=e,this.dispatchEvent(new ze(this.tagName.toLowerCase(),Ge(e))),this.render()}connectedCallback(){this.setAttribute("aria-label","Written Response Question"),this.setAttribute("role","region"),this.render()}render(){if(this._model&&this._session){let e=qe.createElement(je,{model:this._model,session:this._session,onValueChange:this.valueChange.bind(this),onAnnotationsChange:this.annotationsChange.bind(this),onCommentChange:this.commentChange.bind(this)});this.setLangAttribute(),this._root||(this._root=Be(this)),this._root.render(e),queueMicrotask(()=>{Ke(this)})}}disconnectedCallback(){this._root&&this._root.unmount()}}export{Xe as default,Ge as isComplete,Ye as textContent};
@@ -0,0 +1,21 @@
1
+
2
+ <!doctype html>
3
+ <html>
4
+ <head>
5
+ <title>@pie-element/extended-text-entry@15.1.1</title>
6
+ <script
7
+ type="module"
8
+ src="https://cdn.jsdelivr.net/npm/@pslb/demo-el@^1.0.0/dist/demo-el/demo-el.esm.js"></script>
9
+
10
+ <link
11
+ href="https://fonts.googleapis.com/css?family=Roboto&display=swap"
12
+ rel="stylesheet"
13
+ />
14
+ <style>
15
+ html, body {
16
+ font-family: 'Roboto', sans-serif;
17
+ }
18
+ </style>
19
+ <script type="module" src="./demo.js"></script>
20
+ </head>
21
+ </html>
@@ -0,0 +1,22 @@
1
+ {
2
+ "name": "@pie-element/extended-text-entry",
3
+ "version": "15.1.1",
4
+ "modules": [
5
+ {
6
+ "name": "@pie-lib/shared-module",
7
+ "version": "^5.2.4"
8
+ },
9
+ {
10
+ "name": "@pie-lib/math-rendering-module",
11
+ "version": "^5.0.9"
12
+ },
13
+ {
14
+ "name": "@pie-lib/editable-html-module",
15
+ "version": "^7.1.6"
16
+ },
17
+ {
18
+ "name": "@pie-lib/config-module",
19
+ "version": "^4.0.9"
20
+ }
21
+ ]
22
+ }
@@ -0,0 +1,76 @@
1
+ import PrintElement from './print.js';
2
+
3
+ var generate = {};
4
+
5
+ generate.model = (id, element) => ({
6
+ id,
7
+ element,
8
+ customKeys: ['\\square'],
9
+ feedback: { type: 'default', default: 'this is default feedback' },
10
+ prompt: 'This is the question prompt',
11
+ promptEnabled: true,
12
+ mathInput: true,
13
+ playersToolbarPosition: 'bottom',
14
+ toolbarEditorPosition: 'bottom',
15
+ spellCheckEnabled: true,
16
+ rubricEnabled: false,
17
+ annotationsEnabled: false,
18
+ });
19
+
20
+ const { model } = generate;
21
+ var config = {
22
+ elements: {
23
+ 'extended-text-entry': '../..',
24
+ },
25
+ models: [model('1', 'extended-text-entry')],
26
+ };
27
+
28
+ // new init - just shows off print!
29
+
30
+ const init = async () => {
31
+ console.log('define the element...');
32
+ await Promise.all(
33
+ config.models.map(async (m) => {
34
+ try {
35
+ const printTag = `${m.element}-print`;
36
+ if (customElements.get(printTag)) {
37
+ return true;
38
+ } else {
39
+ customElements.define(printTag, PrintElement);
40
+ await customElements.whenDefined(printTag);
41
+ return true;
42
+ }
43
+ } catch (e) {
44
+ return false;
45
+ }
46
+ })
47
+ );
48
+
49
+ console.log('now apply the model...');
50
+ config.models.forEach((m) => {
51
+ const printTag = `${m.element}-print`;
52
+ const h3s = document.createElement('h3');
53
+ h3s.textContent = 'student mode';
54
+ document.body.appendChild(h3s);
55
+ const de = document.createElement(printTag);
56
+ document.body.appendChild(de);
57
+ de.options = {};
58
+ de.model = m;
59
+
60
+ const h3 = document.createElement('h3');
61
+ h3.textContent = 'instructor mode';
62
+ document.body.appendChild(h3);
63
+ const instr = document.createElement(printTag);
64
+ document.body.appendChild(instr);
65
+ instr.options = { mode: 'instructor' };
66
+ instr.model = JSON.parse(JSON.stringify(m));
67
+ });
68
+ };
69
+
70
+ init()
71
+ .then(() => {
72
+ console.log('ready');
73
+ })
74
+ .catch((e) => {
75
+ console.error(e);
76
+ });
@@ -0,0 +1,18 @@
1
+
2
+ <!doctype html>
3
+ <html>
4
+ <head>
5
+ <title>@pie-element/extended-text-entry@15.1.1</title>
6
+ <link
7
+ href="https://fonts.googleapis.com/css?family=Roboto&display=swap"
8
+ rel="stylesheet"
9
+ />
10
+ <style>
11
+ html, body {
12
+ font-family: 'Roboto', sans-serif;
13
+ }
14
+ </style>
15
+ <script type="module" src="./print-demo.js"></script>
16
+ </head>
17
+ <body></body>
18
+ </html>
@@ -0,0 +1 @@
1
+ import{_dll_react as t,_dll_prop_types as e,_dll_mui__material as n,_dll_mui__material_styles as o,_dll_debug as r,_dll_pie_lib__render_ui as i,_dll_react_dom_client as a}from"../../../@pie-lib/shared-module@^5.2.4/module/index.js";import{_dll_pie_lib__math_rendering as s}from"../../../@pie-lib/math-rendering-module@^5.0.9/module/index.js";import{_dll_pie_lib__editable_html_tip_tap as l}from"../../../@pie-lib/editable-html-module@^7.1.6/module/index.js";import{_dll_pie_lib__config_ui as c}from"../../../@pie-lib/config-module@^4.0.9/module/index.js";var d="object"==typeof global&&global&&global.Object===Object&&global,p="object"==typeof self&&self&&self.Object===Object&&self,u=d||p||Function("return this")(),h=u.Symbol,f=Object.prototype,b=f.hasOwnProperty,y=f.toString,m=h?h.toStringTag:void 0;var g=Object.prototype.toString;var v=h?h.toStringTag:void 0;function _(t){return null==t?void 0===t?"[object Undefined]":"[object Null]":v&&v in Object(t)?function(t){var e=b.call(t,m),n=t[m];try{t[m]=void 0;var o=!0}catch(t){}var r=y.call(t);return o&&(e?t[m]=n:delete t[m]),r}(t):function(t){return g.call(t)}(t)}function x(t){return null!=t&&"object"==typeof t}var C=Array.isArray,j=/\s/;var w=/^\s+/;function E(t){return t?t.slice(0,function(t){for(var e=t.length;e--&&j.test(t.charAt(e)););return e}(t)+1).replace(w,""):t}function A(t){var e=typeof t;return null!=t&&("object"==e||"function"==e)}var S=/^[-+]0x[0-9a-f]+$/i,k=/^0b[01]+$/i,O=/^0o[0-7]+$/i,T=parseInt;function R(t){if("number"==typeof t)return t;if(function(t){return"symbol"==typeof t||x(t)&&"[object Symbol]"==_(t)}(t))return NaN;if(A(t)){var e="function"==typeof t.valueOf?t.valueOf():t;t=A(e)?e+"":e}if("string"!=typeof t)return 0===t?t:+t;t=E(t);var n=k.test(t);return n||O.test(t)?T(t.slice(2),n?2:8):S.test(t)?NaN:+t}function P(t){if(!A(t))return!1;var e=_(t);return"[object Function]"==e||"[object GeneratorFunction]"==e||"[object AsyncFunction]"==e||"[object Proxy]"==e}var I,M=u["__core-js_shared__"],z=(I=/[^.]+$/.exec(M&&M.keys&&M.keys.IE_PROTO||""))?"Symbol(src)_1."+I:"";var D=Function.prototype.toString;function L(t){if(null!=t){try{return D.call(t)}catch(t){}try{return t+""}catch(t){}}return""}var N=/^\[object .+?Constructor\]$/,$=Function.prototype,W=Object.prototype,U=$.toString,F=W.hasOwnProperty,B=RegExp("^"+U.call(F).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function H(t){return!(!A(t)||(e=t,z&&z in e))&&(P(t)?B:N).test(L(t));var e}function q(t,e){var n=function(t,e){return null==t?void 0:t[e]}(t,e);return H(n)?n:void 0}var V=q(u,"WeakMap"),K=Object.create,G=function(){function t(){}return function(e){if(!A(e))return{};if(K)return K(e);t.prototype=e;var n=new t;return t.prototype=void 0,n}}();var X=function(){try{var t=q(Object,"defineProperty");return t({},"",{}),t}catch(t){}}();var Y=/^(?:0|[1-9]\d*)$/;function Q(t,e){var n=typeof t;return!!(e=null==e?9007199254740991:e)&&("number"==n||"symbol"!=n&&Y.test(t))&&t>-1&&t%1==0&&t<e}function J(t,e,n){"__proto__"==e&&X?X(t,e,{configurable:!0,enumerable:!0,value:n,writable:!0}):t[e]=n}function Z(t,e){return t===e||t!=t&&e!=e}var tt=Object.prototype.hasOwnProperty;function et(t,e,n){var o=t[e];tt.call(t,e)&&Z(o,n)&&(void 0!==n||e in t)||J(t,e,n)}function nt(t,e,n,o){var r=!n;n||(n={});for(var i=-1,a=e.length;++i<a;){var s=e[i],l=o?o(n[s],t[s],s,n,t):void 0;void 0===l&&(l=t[s]),r?J(n,s,l):et(n,s,l)}return n}function ot(t){return"number"==typeof t&&t>-1&&t%1==0&&t<=9007199254740991}function rt(t){return null!=t&&ot(t.length)&&!P(t)}var it=Object.prototype;function at(t){var e=t&&t.constructor;return t===("function"==typeof e&&e.prototype||it)}function st(t){return x(t)&&"[object Arguments]"==_(t)}var lt=Object.prototype,ct=lt.hasOwnProperty,dt=lt.propertyIsEnumerable,pt=st(function(){return arguments}())?st:function(t){return x(t)&&ct.call(t,"callee")&&!dt.call(t,"callee")};var ut="object"==typeof exports&&exports&&!exports.nodeType&&exports,ht=ut&&"object"==typeof module&&module&&!module.nodeType&&module,ft=ht&&ht.exports===ut?u.Buffer:void 0,bt=(ft?ft.isBuffer:void 0)||function(){return!1},yt={};function mt(t){return function(e){return t(e)}}yt["[object Float32Array]"]=yt["[object Float64Array]"]=yt["[object Int8Array]"]=yt["[object Int16Array]"]=yt["[object Int32Array]"]=yt["[object Uint8Array]"]=yt["[object Uint8ClampedArray]"]=yt["[object Uint16Array]"]=yt["[object Uint32Array]"]=!0,yt["[object Arguments]"]=yt["[object Array]"]=yt["[object ArrayBuffer]"]=yt["[object Boolean]"]=yt["[object DataView]"]=yt["[object Date]"]=yt["[object Error]"]=yt["[object Function]"]=yt["[object Map]"]=yt["[object Number]"]=yt["[object Object]"]=yt["[object RegExp]"]=yt["[object Set]"]=yt["[object String]"]=yt["[object WeakMap]"]=!1;var gt="object"==typeof exports&&exports&&!exports.nodeType&&exports,vt=gt&&"object"==typeof module&&module&&!module.nodeType&&module,_t=vt&&vt.exports===gt&&d.process,xt=function(){try{var t=vt&&vt.require&&vt.require("util").types;return t||_t&&_t.binding&&_t.binding("util")}catch(t){}}(),Ct=xt&&xt.isTypedArray,jt=Ct?mt(Ct):function(t){return x(t)&&ot(t.length)&&!!yt[_(t)]},wt=Object.prototype.hasOwnProperty;function Et(t,e){var n=C(t),o=!n&&pt(t),r=!n&&!o&&bt(t),i=!n&&!o&&!r&&jt(t),a=n||o||r||i,s=a?function(t,e){for(var n=-1,o=Array(t);++n<t;)o[n]=e(n);return o}(t.length,String):[],l=s.length;for(var c in t)!e&&!wt.call(t,c)||a&&("length"==c||r&&("offset"==c||"parent"==c)||i&&("buffer"==c||"byteLength"==c||"byteOffset"==c)||Q(c,l))||s.push(c);return s}function At(t,e){return function(n){return t(e(n))}}var St=At(Object.keys,Object),kt=Object.prototype.hasOwnProperty;function Ot(t){return rt(t)?Et(t):function(t){if(!at(t))return St(t);var e=[];for(var n in Object(t))kt.call(t,n)&&"constructor"!=n&&e.push(n);return e}(t)}var Tt=Object.prototype.hasOwnProperty;function Rt(t){if(!A(t))return function(t){var e=[];if(null!=t)for(var n in Object(t))e.push(n);return e}(t);var e=at(t),n=[];for(var o in t)("constructor"!=o||!e&&Tt.call(t,o))&&n.push(o);return n}function Pt(t){return rt(t)?Et(t,!0):Rt(t)}var It=q(Object,"create");var Mt=Object.prototype.hasOwnProperty;var zt=Object.prototype.hasOwnProperty;function Dt(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var o=t[e];this.set(o[0],o[1])}}function Lt(t,e){for(var n=t.length;n--;)if(Z(t[n][0],e))return n;return-1}Dt.prototype.clear=function(){this.__data__=It?It(null):{},this.size=0},Dt.prototype.delete=function(t){var e=this.has(t)&&delete this.__data__[t];return this.size-=e?1:0,e},Dt.prototype.get=function(t){var e=this.__data__;if(It){var n=e[t];return"__lodash_hash_undefined__"===n?void 0:n}return Mt.call(e,t)?e[t]:void 0},Dt.prototype.has=function(t){var e=this.__data__;return It?void 0!==e[t]:zt.call(e,t)},Dt.prototype.set=function(t,e){var n=this.__data__;return this.size+=this.has(t)?0:1,n[t]=It&&void 0===e?"__lodash_hash_undefined__":e,this};var Nt=Array.prototype.splice;function $t(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var o=t[e];this.set(o[0],o[1])}}$t.prototype.clear=function(){this.__data__=[],this.size=0},$t.prototype.delete=function(t){var e=this.__data__,n=Lt(e,t);return!(n<0)&&(n==e.length-1?e.pop():Nt.call(e,n,1),--this.size,!0)},$t.prototype.get=function(t){var e=this.__data__,n=Lt(e,t);return n<0?void 0:e[n][1]},$t.prototype.has=function(t){return Lt(this.__data__,t)>-1},$t.prototype.set=function(t,e){var n=this.__data__,o=Lt(n,t);return o<0?(++this.size,n.push([t,e])):n[o][1]=e,this};var Wt=q(u,"Map");function Ut(t,e){var n,o,r=t.__data__;return("string"==(o=typeof(n=e))||"number"==o||"symbol"==o||"boolean"==o?"__proto__"!==n:null===n)?r["string"==typeof e?"string":"hash"]:r.map}function Ft(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var o=t[e];this.set(o[0],o[1])}}function Bt(t,e){for(var n=-1,o=e.length,r=t.length;++n<o;)t[r+n]=e[n];return t}Ft.prototype.clear=function(){this.size=0,this.__data__={hash:new Dt,map:new(Wt||$t),string:new Dt}},Ft.prototype.delete=function(t){var e=Ut(this,t).delete(t);return this.size-=e?1:0,e},Ft.prototype.get=function(t){return Ut(this,t).get(t)},Ft.prototype.has=function(t){return Ut(this,t).has(t)},Ft.prototype.set=function(t,e){var n=Ut(this,t),o=n.size;return n.set(t,e),this.size+=n.size==o?0:1,this};var Ht=At(Object.getPrototypeOf,Object);function qt(t){var e=this.__data__=new $t(t);this.size=e.size}qt.prototype.clear=function(){this.__data__=new $t,this.size=0},qt.prototype.delete=function(t){var e=this.__data__,n=e.delete(t);return this.size=e.size,n},qt.prototype.get=function(t){return this.__data__.get(t)},qt.prototype.has=function(t){return this.__data__.has(t)},qt.prototype.set=function(t,e){var n=this.__data__;if(n instanceof $t){var o=n.__data__;if(!Wt||o.length<199)return o.push([t,e]),this.size=++n.size,this;n=this.__data__=new Ft(o)}return n.set(t,e),this.size=n.size,this};var Vt="object"==typeof exports&&exports&&!exports.nodeType&&exports,Kt=Vt&&"object"==typeof module&&module&&!module.nodeType&&module,Gt=Kt&&Kt.exports===Vt?u.Buffer:void 0,Xt=Gt?Gt.allocUnsafe:void 0;function Yt(){return[]}var Qt=Object.prototype.propertyIsEnumerable,Jt=Object.getOwnPropertySymbols,Zt=Jt?function(t){return null==t?[]:(t=Object(t),function(t,e){for(var n=-1,o=null==t?0:t.length,r=0,i=[];++n<o;){var a=t[n];e(a,n,t)&&(i[r++]=a)}return i}(Jt(t),function(e){return Qt.call(t,e)}))}:Yt;var te=Object.getOwnPropertySymbols?function(t){for(var e=[];t;)Bt(e,Zt(t)),t=Ht(t);return e}:Yt;function ee(t,e,n){var o=e(t);return C(t)?o:Bt(o,n(t))}function ne(t){return ee(t,Ot,Zt)}function oe(t){return ee(t,Pt,te)}var re=q(u,"DataView"),ie=q(u,"Promise"),ae=q(u,"Set"),se="[object Map]",le="[object Promise]",ce="[object Set]",de="[object WeakMap]",pe="[object DataView]",ue=L(re),he=L(Wt),fe=L(ie),be=L(ae),ye=L(V),me=_;(re&&me(new re(new ArrayBuffer(1)))!=pe||Wt&&me(new Wt)!=se||ie&&me(ie.resolve())!=le||ae&&me(new ae)!=ce||V&&me(new V)!=de)&&(me=function(t){var e=_(t),n="[object Object]"==e?t.constructor:void 0,o=n?L(n):"";if(o)switch(o){case ue:return pe;case he:return se;case fe:return le;case be:return ce;case ye:return de}return e});var ge=me,ve=Object.prototype.hasOwnProperty;var _e=u.Uint8Array;function xe(t){var e=new t.constructor(t.byteLength);return new _e(e).set(new _e(t)),e}var Ce=/\w*$/;var je=h?h.prototype:void 0,we=je?je.valueOf:void 0;function Ee(t,e,n){var o,r,i,a=t.constructor;switch(e){case"[object ArrayBuffer]":return xe(t);case"[object Boolean]":case"[object Date]":return new a(+t);case"[object DataView]":return function(t,e){var n=e?xe(t.buffer):t.buffer;return new t.constructor(n,t.byteOffset,t.byteLength)}(t,n);case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return function(t,e){var n=e?xe(t.buffer):t.buffer;return new t.constructor(n,t.byteOffset,t.length)}(t,n);case"[object Map]":case"[object Set]":return new a;case"[object Number]":case"[object String]":return new a(t);case"[object RegExp]":return(i=new(r=t).constructor(r.source,Ce.exec(r))).lastIndex=r.lastIndex,i;case"[object Symbol]":return o=t,we?Object(we.call(o)):{}}}var Ae=xt&&xt.isMap,Se=Ae?mt(Ae):function(t){return x(t)&&"[object Map]"==ge(t)};var ke=xt&&xt.isSet,Oe=ke?mt(ke):function(t){return x(t)&&"[object Set]"==ge(t)},Te="[object Arguments]",Re="[object Function]",Pe="[object Object]",Ie={};function Me(t,e,n,o,r,i){var a,s=1&e,l=2&e,c=4&e;if(n&&(a=r?n(t,o,r,i):n(t)),void 0!==a)return a;if(!A(t))return t;var d=C(t);if(d){if(a=function(t){var e=t.length,n=new t.constructor(e);return e&&"string"==typeof t[0]&&ve.call(t,"index")&&(n.index=t.index,n.input=t.input),n}(t),!s)return function(t,e){var n=-1,o=t.length;for(e||(e=Array(o));++n<o;)e[n]=t[n];return e}(t,a)}else{var p=ge(t),u=p==Re||"[object GeneratorFunction]"==p;if(bt(t))return function(t,e){if(e)return t.slice();var n=t.length,o=Xt?Xt(n):new t.constructor(n);return t.copy(o),o}(t,s);if(p==Pe||p==Te||u&&!r){if(a=l||u?{}:function(t){return"function"!=typeof t.constructor||at(t)?{}:G(Ht(t))}(t),!s)return l?function(t,e){return nt(t,te(t),e)}(t,function(t,e){return t&&nt(e,Pt(e),t)}(a,t)):function(t,e){return nt(t,Zt(t),e)}(t,function(t,e){return t&&nt(e,Ot(e),t)}(a,t))}else{if(!Ie[p])return r?t:{};a=Ee(t,p,s)}}i||(i=new qt);var h=i.get(t);if(h)return h;i.set(t,a),Oe(t)?t.forEach(function(o){a.add(Me(o,e,n,o,t,i))}):Se(t)&&t.forEach(function(o,r){a.set(r,Me(o,e,n,r,t,i))});var f=d?void 0:(c?l?oe:ne:l?Pt:Ot)(t);return function(t,e){for(var n=-1,o=null==t?0:t.length;++n<o&&!1!==e(t[n],n,t););}(f||t,function(o,r){f&&(o=t[r=o]),et(a,r,Me(o,e,n,r,t,i))}),a}Ie[Te]=Ie["[object Array]"]=Ie["[object ArrayBuffer]"]=Ie["[object DataView]"]=Ie["[object Boolean]"]=Ie["[object Date]"]=Ie["[object Float32Array]"]=Ie["[object Float64Array]"]=Ie["[object Int8Array]"]=Ie["[object Int16Array]"]=Ie["[object Int32Array]"]=Ie["[object Map]"]=Ie["[object Number]"]=Ie[Pe]=Ie["[object RegExp]"]=Ie["[object Set]"]=Ie["[object String]"]=Ie["[object Symbol]"]=Ie["[object Uint8Array]"]=Ie["[object Uint8ClampedArray]"]=Ie["[object Uint16Array]"]=Ie["[object Uint32Array]"]=!0,Ie["[object Error]"]=Ie[Re]=Ie["[object WeakMap]"]=!1;var ze=function(){return u.Date.now()},De=Math.max,Le=Math.min;function Ne(t,e,n){var o,r,i,a,s,l,c=0,d=!1,p=!1,u=!0;if("function"!=typeof t)throw new TypeError("Expected a function");function h(e){var n=o,i=r;return o=r=void 0,c=e,a=t.apply(i,n)}function f(t){var n=t-l;return void 0===l||n>=e||n<0||p&&t-c>=i}function b(){var t=ze();if(f(t))return y(t);s=setTimeout(b,function(t){var n=e-(t-l);return p?Le(n,i-(t-c)):n}(t))}function y(t){return s=void 0,u&&o?h(t):(o=r=void 0,a)}function m(){var t=ze(),n=f(t);if(o=arguments,r=this,l=t,n){if(void 0===s)return function(t){return c=t,s=setTimeout(b,e),d?h(t):a}(l);if(p)return clearTimeout(s),s=setTimeout(b,e),h(l)}return void 0===s&&(s=setTimeout(b,e)),a}return e=R(e)||0,A(n)&&(d=!!n.leading,i=(p="maxWait"in n)?De(R(n.maxWait)||0,e):i,u="trailing"in n?!!n.trailing:u),m.cancel=function(){void 0!==s&&clearTimeout(s),c=0,o=l=r=s=void 0},m.flush=function(){return void 0===s?a:y(ze())},m}const $e=(t,e,n)=>{const o=n||[],r=o.reduce((t,e)=>t+e.textContent.length,0);let i=!0;if(r>e)return!1;for(t&&(3===t.nodeType&&t.parentNode&&!t.parentNode.hasAttribute("data-ann-id")&&o.push(t),t=t.firstChild);t&&i;)i=$e(t,e,o),t=t.nextSibling;return o},We=t=>{const{commonAncestorContainer:e,startContainer:n,endContainer:o,startOffset:r,endOffset:i}=t,a=[];let s=!1,l=!1,c="";const d=t=>{const{nodeValue:e,childNodes:p}=t;t===n&&t===o?(e&&(c+=e.substring(r,i)),s=l=!0):t===n?(e&&(c+=e.substring(r)),s=!0):t===o?(e&&(c+=e.substring(0,i)),l=!0):t&&3===t.nodeType&&t.parentNode&&!t.parentNode.hasAttribute("data-ann-id")&&e&&s&&!l&&(c+=e,a.push(t)),p.forEach(t=>{l||d(t)})};return d(e),[a,c]},Ue=t=>{const e=document.createElement("SPAN");return t.surroundContents(e),e},Fe=t=>{if(t.startContainer===t.endContainer)return[Ue(t)];const[e]=We(t),n=document.createRange();n.selectNodeContents(t.startContainer),n.setStart(t.startContainer,t.startOffset);const o=Ue(n),r=document.createRange();r.selectNode(t.endContainer),r.setEnd(t.endContainer,t.endOffset);const i=Ue(r);return[o,...e.map(t=>{const e=document.createElement("SPAN");return t.parentNode.insertBefore(e,t),e.appendChild(t),e}),i]},Be=(t,e)=>{(t||[]).forEach(t=>{const e=t.parentNode,n=t.childNodes,o=n.length;if(o>0)for(let r=0;r<o;r++)e.insertBefore(n[0],t);else e.insertBefore(document.createTextNode(t.textContent),t);e.removeChild(t)}),e.normalize()},He=()=>{document.getSelection?(document.getSelection().removeAllRanges(),document.getSelection().addRange(document.createRange())):window.getSelection?window.getSelection().removeAllRanges?(window.getSelection().removeAllRanges(),window.getSelection().addRange(document.createRange())):window.getSelection().empty&&window.getSelection().empty():document.selection&&document.selection.empty()},qe=t=>t.length>=20||-1!==t.search(/\n|\r|\r\n/),Ve=t=>Array.from(document.querySelectorAll(`[data-id='${t}']`)),Ke=t=>document.querySelector(`[data-ann-id='${t}']`),Ge=t,Xe=e,{Popover:Ye}=n,{TextField:Qe}=n,{styled:Je}=o,Ze=Je(Ye)(({theme:t,annotationType:e})=>({"& .MuiPaper-root":{overflowX:"unset",overflowY:"unset",marginLeft:"16px","&::before":{position:"absolute",right:"100%",top:"13px",border:"solid transparent",content:'""',height:0,width:0,pointerEvents:"none",borderWidth:"7px",borderRightColor:t.palette.grey[100]},..."negative"===e&&{"&::before":{borderRightColor:"rgb(255, 204, 238) !important"}},..."positive"===e&&{"&::before":{borderRightColor:"rgb(153, 255, 153) !important"}}}})),tn=Je("div")(({theme:t,annotationType:e})=>({width:"200px",overflow:"hidden",borderRadius:"4px",backgroundColor:"#ffffff",border:`4px solid ${t.palette.grey[100]}`,..."negative"===e&&{borderColor:"rgb(255, 204, 238) !important"},..."positive"===e&&{borderColor:"rgb(153, 255, 153) !important"}})),en=Je("div")(({theme:t})=>({display:"flex",flexWrap:"wrap",borderTop:`2px solid ${t.palette.grey[100]}`})),nn=Je("div")(({theme:t,variant:e,annotationType:n})=>({flexGrow:1,width:"28%",textAlign:"center",padding:"4px",cursor:"pointer","&:not(:nth-child(3n))":{borderRight:`1px solid ${t.palette.grey[100]}`},"&:hover":{backgroundColor:t.palette.grey[100]},..."positive"===e&&{backgroundColor:"rgb(153, 255, 153) !important","&:hover":{filter:"brightness(85%)"}},..."negative"===e&&{backgroundColor:"rgb(255, 204, 238) !important","&:hover":{filter:"brightness(85%)"}},..."typeChange"===e&&"negative"===n&&{"&:hover":{backgroundColor:"rgb(153, 255, 153) !important"}},..."typeChange"===e&&"positive"===n&&{"&:hover":{backgroundColor:"rgb(255, 204, 238) !important"}}}));class on extends Ge.Component{static __initStatic(){this.propTypes={anchorEl:Xe.object,open:Xe.bool,offset:Xe.number,value:Xe.string,type:Xe.string,onClose:Xe.func,onDelete:Xe.func,onSave:Xe.func,onTypeChange:Xe.func}}constructor(t){super(t),on.prototype.__init.call(this),on.prototype.__init2.call(this),on.prototype.__init3.call(this),this.state={value:t.value}}UNSAFE_componentWillReceiveProps(t){const{value:e}=t,{value:n}=this.props;e!==n&&this.setState({value:e})}__init(){this.onValueChange=t=>this.setState({value:t.target.value})}__init2(){this.handleSave=()=>{const{value:t,onSave:e,onClose:n,onDelete:o}=this.props,{value:r}=this.state;""===r&&o(),t!==r&&e(t,r),this.setState({value:""}),n()}}__init3(){this.handleTypeChange=()=>{const{onTypeChange:t,onDelete:e}=this.props,{value:n}=this.state;""===n?e():t(n),this.setState({value:""})}}render(){const{anchorEl:t,offset:e,onDelete:n,open:o,type:r}=this.props,{value:i}=this.state;return Ge.createElement(Ze,{anchorEl:t,elevation:2,open:o,onClose:this.handleSave,annotationType:r,style:{marginTop:`${e}px`,transition:"margin-top 2s ease-out"},transitionDuration:{enter:225,exit:195},anchorOrigin:{vertical:"top",horizontal:"right"},transformOrigin:{vertical:"top",horizontal:"left"}},Ge.createElement(tn,{annotationType:r},Ge.createElement(Qe,{id:"annotation-editor",style:{padding:"2px 5px",width:"95%"},autoFocus:!0,multiline:!0,rows:1,maxRows:4,value:i,onChange:this.onValueChange,InputProps:{disableUnderline:!0}}),Ge.createElement(en,null,Ge.createElement(nn,{onClick:n},"Delete"),Ge.createElement(nn,{variant:"typeChange",annotationType:r,onClick:this.handleTypeChange},"negative"===r?"Green":"Pink"),Ge.createElement(nn,{onClick:this.handleSave},"Save"))))}}on.__initStatic();const rn=t,an=e,{styled:sn}=o,{Popover:ln}=n,cn=sn(ln)({"& .MuiPaper-root":{overflowX:"unset",overflowY:"unset",marginTop:"-16px","&::after":{position:"absolute",left:"calc(50% - 7px)",border:"solid transparent",content:'""',height:0,width:0,pointerEvents:"none",borderWidth:"7px",borderTopColor:"black"}}}),dn=sn("div")(({theme:t})=>({width:"300px",overflow:"hidden",borderRadius:"4px",backgroundColor:t.palette.common.white,border:`2px solid ${t.palette.grey[100]}`})),pn=sn("div")({display:"flex",flexWrap:"wrap"}),un=sn("div")(({theme:t})=>({display:"flex",flexWrap:"wrap",borderTop:`2px solid ${t.palette.grey[100]}`})),hn=sn("div")(({theme:t,variant:e})=>({width:"22%",textAlign:"center",padding:"4px",cursor:"pointer",borderBottom:`1px solid ${t.palette.grey[100]}`,"&:not(:nth-child(4n))":{borderRight:`1px solid ${t.palette.grey[100]}`},"&:nth-child(4n)":{flexGrow:1},"&:hover":{backgroundColor:t.palette.grey[100]},..."positive"===e&&{backgroundColor:"rgb(153, 255, 153) !important","&:hover":{filter:"brightness(85%)"}},..."negative"===e&&{backgroundColor:"rgb(255, 204, 238) !important","&:hover":{filter:"brightness(85%)"}}}));class fn extends rn.Component{static __initStatic(){this.propTypes={anchorEl:an.object,open:an.bool,annotations:an.array,isNewAnnotation:an.bool,onClose:an.func,onDelete:an.func,onEdit:an.func,onWrite:an.func,onAnnotate:an.func}}render(){const{anchorEl:t,annotations:e,isNewAnnotation:n,onAnnotate:o,onClose:r,onEdit:i,onDelete:a,onWrite:s,open:l}=this.props;return rn.createElement(cn,{anchorEl:t,open:l,onClose:r,elevation:5,transitionDuration:{enter:225,exit:195},anchorOrigin:{vertical:"top",horizontal:"center"},transformOrigin:{vertical:"bottom",horizontal:"center"}},rn.createElement(dn,null,rn.createElement(pn,null,e.map((t,e)=>rn.createElement(hn,{key:`annotation-${e}`,variant:t.type,onClick:()=>o(t)},t.label))),rn.createElement(un,null,rn.createElement(hn,{onClick:r},"Cancel"),rn.createElement(hn,{style:{pointerEvents:"none"}}),n?rn.createElement(rn.Fragment,null,rn.createElement(hn,{variant:"positive",onClick:()=>s("positive")},"Write"),rn.createElement(hn,{variant:"negative",onClick:()=>s("negative")},"Write")):rn.createElement(rn.Fragment,null,rn.createElement(hn,{onClick:a},"Delete"),rn.createElement(hn,{onClick:i},"Edit")))))}}fn.__initStatic();const bn=t,{styled:yn}=o,mn=e,gn=l,{InputContainer:vn}=c,_n=yn("div")({padding:"10px 120px 10px 16px",backgroundColor:"rgba(0, 0, 0, 0.06)",border:"1px solid #ccc",borderRadius:"4px",overflowY:"scroll",lineHeight:"36px",whiteSpace:"pre-wrap",overflowWrap:"break-word","& p":{margin:0},"& span[data-latex]":{userSelect:"none","-webkit-user-select":"none","-moz-user-select":"none","-ms-user-select":"none"}}),xn=yn("div")({width:"230px"}),Cn=yn("div")({position:"relative",overflowX:"hidden",display:"flex"}),jn=yn(vn)(({theme:t})=>({paddingTop:t.spacing(2),marginBottom:t.spacing(2),marginTop:t.spacing(2),width:"100%"}));if(!document.getElementById("annotation-editor-styles")){const t=document.createElement("style");t.id="annotation-editor-styles",t.textContent='\n .sideAnnotation:before {\n position: absolute;\n right: var(--before-right, 100%);\n top: var(--before-top, 5px);\n border: solid transparent;\n content: "";\n height: 0;\n width: 0;\n pointer-events: none;\n border-width: var(--before-border-width, 7px);\n border-right-color: var(--before-border-color, rgb(153, 255, 153));\n }\n',document.head.appendChild(t)}class wn extends bn.Component{static __initStatic(){this.propTypes={text:mn.string,comment:mn.string,annotations:mn.array,predefinedAnnotations:mn.array,onChange:mn.func.isRequired,onCommentChange:mn.func.isRequired,width:mn.number,height:mn.number,maxHeight:mn.string,disabled:mn.bool,disabledMath:mn.bool,customKeys:mn.array,keypadMode:mn.string}}constructor(t){super(t),wn.prototype.__init.call(this),wn.prototype.__init2.call(this),wn.prototype.__init3.call(this),wn.prototype.__init4.call(this),wn.prototype.__init5.call(this),wn.prototype.__init6.call(this),wn.prototype.__init7.call(this),wn.prototype.__init8.call(this),wn.prototype.__init9.call(this),wn.prototype.__init10.call(this),wn.prototype.__init11.call(this),wn.prototype.__init12.call(this),wn.prototype.__init13.call(this),wn.prototype.__init14.call(this),wn.prototype.__init15.call(this),this.state={anchorEl:null,openedMenu:!1,openedEditor:!1,selectedElems:[],labelElem:null,selectionDetails:null,annotation:null,annotationIndex:null}}componentDidMount(){const{annotations:t,text:e}=this.props;e&&t.forEach(t=>{const[e,n]=((t,e,n)=>{const o=$e(n,e),r=[];let i=0;return o.forEach(n=>{const o=i+n.textContent.length;[t,e].forEach(t=>{i<=t&&t<o&&r.push({node:n,offset:t-i})}),i=o}),r})(t.start,t.end,this.textRef);if(e&&n){const o=document.createRange();o.setStart(e.node,e.offset),o.setEnd(n.node,n.offset);const r=Fe(o);this.createDOMAnnotation(r,t)}}),this.textRef&&(this.adjustAnnotationsPosition(),this.textRef.addEventListener("scroll",this.adjustAnnotationsPosition))}__init(){this.adjustAnnotationsPosition=()=>{if(this.textRef&&this.labelsRef){const t=this.textRef.offsetLeft+this.textRef.offsetWidth+8;Array.from(this.labelsRef.children).forEach(e=>{const n=Ve(e.dataset.annId),o=(n[0].offsetTop?n[0].offsetTop:n[0].offsetParent.offsetTop)-this.textRef.scrollTop-6;e.style.top=`${o}px`,e.style.left=`${t}px`})}}}__init2(){this.handleClick=t=>{const{annotations:e}=this.props,{selectionDetails:n}=this.state;if(n)return;const{id:o,annId:r}=t.target.dataset,i=o||r,a=Ve(i),s=Ke(i),l=e.findIndex(t=>t.id===i),c=s.hasAttribute("data-freeform");c&&(s.style.zIndex="10"),this.setState({anchorEl:a[0],openedMenu:!!o||!!r&&!c,openedEditor:!!r&&c,selectedElems:a,labelElem:s,annotationIndex:l,annotation:e[l],selectionDetails:null})}}__init3(){this.handleHover=t=>{const{id:e,annId:n}=t.target.dataset,o=e||n,r=Ve(o),i=Ke(o),a=i.hasAttribute("data-freeform");r.forEach(t=>{t.style.zIndex="20",t.classList.contains("positive")?t.style.backgroundColor="rgb(51, 255, 51, 0.7)":t.classList.contains("negative")&&(t.style.backgroundColor="rgba(255, 102, 204, 0.55)")}),a?(i.style.zIndex="20",i.classList.contains("positive")?(i.style.backgroundColor="rgb(128, 255, 128)",i.style.setProperty("--before-border-color","rgb(153, 255, 153)")):i.classList.contains("negative")&&(i.style.backgroundColor="rgb(255, 179, 230)",i.style.setProperty("--before-border-color","rgb(255, 179, 230)"))):(i.style.zIndex="20",i.classList.contains("positive")?i.style.color="rgb(0, 77, 0)":i.classList.contains("negative")&&(i.style.color="rgb(153, 0, 102)"))}}__init4(){this.handleCancelHover=t=>{const{id:e,annId:n}=t.target.dataset,o=e||n,r=Ve(o),i=Ke(o),a=i.hasAttribute("data-freeform");r.forEach(t=>{t.style.zIndex="",t.classList.contains("positive")?t.style.backgroundColor="rgb(51, 255, 51, 0.5)":t.classList.contains("negative")&&(t.style.backgroundColor="rgba(255, 102, 204, 0.4)")}),a?(i.style.zIndex="",i.classList.contains("positive")?(i.style.backgroundColor="rgb(153, 255, 153)",i.style.removeProperty("--before-border-color")):i.classList.contains("negative")&&(i.style.backgroundColor="rgb(255, 204, 238)",i.style.removeProperty("--before-border-color"))):(i.style.zIndex="",i.classList.contains("positive")?i.style.color="rgb(0, 128, 0)":i.classList.contains("negative")&&(i.style.color="rgb(204, 0, 136)"))}}__init5(){this.handleClose=t=>{const{selectedElems:e,labelElem:n}=this.state;e.length&&!e[0].hasAttribute("data-id")&&Be(e,this.textRef),n&&(n.style.zIndex=""),this.setState({anchorEl:null,openedMenu:!1,openedEditor:!1,selectedElems:[],labelElem:null,selectionDetails:null,annotationIndex:null,annotation:null}),He()}}__init6(){this.handleSelection=t=>{const e=window.getSelection();if(t.detail>2)He();else if(e&&e.rangeCount>0){const t=e.getRangeAt(0),n=t.toString(),o=this.textRef.contains(t.commonAncestorContainer);if(!e.isCollapsed&&""!==n&&o){const e=((t,e)=>{const n=document.createRange();n.setStart(e,0),n.setEnd(t.startContainer,t.startOffset);const[,o]=We(n),[,r]=We(t),i=o.length;return{quote:r,start:i,end:i+r.length}})(t,this.textRef),n=Fe(t);this.setState({anchorEl:n[0],openedMenu:!0,selectedElems:n,selectionDetails:e})}}}}__init7(){this.deleteAnnotation=()=>{const{annotations:t,onChange:e}=this.props,{selectedElems:n,labelElem:o,annotationIndex:r,annotation:i}=this.state;(qe(i.label)?this.labelsRef:n[0]).removeChild(o),Be(n,this.textRef),t.splice(r,1),e(t),this.handleClose()}}__init8(){this.createDOMAnnotation=(t,e)=>{const{disabled:n}=this.props,{id:o,label:r,type:i}=e;(t||[]).forEach(t=>{t.dataset.id=o,t.className=`annotation ${i}`,t.style.position="relative",t.style.cursor="pointer","positive"===i?t.style.backgroundColor="rgb(51, 255, 51, 0.5)":"negative"===i&&(t.style.backgroundColor="rgba(255, 102, 204, 0.4)"),t.onclick=!n&&this.handleClick,t.onmouseover=this.handleHover,t.onmouseout=this.handleCancelHover});const a=t&&t[0]||{},s=document.createElement("SPAN");if(s.dataset.annId=o,s.innerHTML=r,s.onclick=!n&&this.handleClick,s.onmouseover=this.handleHover,s.onmouseout=this.handleCancelHover,qe(r)){const t=(a.offsetTop?a.offsetTop:a.offsetParent.offsetTop)-this.textRef.scrollTop,e=this.textRef.offsetLeft+this.textRef.offsetWidth+8;s.dataset.freeform=!0,s.className=`sideAnnotation ${i}`,s.style.position="absolute",s.style.padding="4px",s.style.borderRadius="4px",s.style.marginLeft="8px",s.style.width="180px",s.style.whiteSpace="pre-wrap",s.style.wordBreak="break-word",s.style.border="2px solid #ffffff",s.style.fontSize="14px",s.style.fontStyle="normal",s.style.fontWeight="normal",s.style.top=`${t}px`,s.style.left=`${e}px`,"negative"===i?s.style.backgroundColor="rgb(255, 204, 238)":"positive"===i&&(s.style.backgroundColor="rgb(153, 255, 153)"),s.style.setProperty("--before-border-width","7px"),s.style.setProperty("--before-top","5px"),s.style.setProperty("--before-right","100%"),"negative"===i?s.style.setProperty("--before-border-color","rgb(255, 204, 238)"):"positive"===i&&s.style.setProperty("--before-border-color","rgb(153, 255, 153)"),this.labelsRef.appendChild(s)}else s.className=`annotationLabel ${i}`,s.style.backgroundColor="rgb(242, 242, 242)",s.style.padding="2px",s.style.position="absolute",s.style.userSelect="none",s.style.whiteSpace="nowrap",s.style.top="-10px",s.style.left="-2px",s.style.fontSize="12px",s.style.fontStyle="normal",s.style.fontWeight="normal",s.style.lineHeight="6px",s.style.webkitUserSelect="none",s.style.mozUserSelect="none",s.style.msUserSelect="none","positive"===i?s.style.color="rgb(0, 128, 0)":"negative"===i&&(s.style.color="rgb(204, 0, 136)"),a.appendChild(s)}}__init9(){this.createNewAnnotation=(t,e)=>{const{selectedElems:n,selectionDetails:o}=this.state,r={id:[o.start,o.end,(new Date).getTime()].join("-"),label:t,type:e,...o};return this.createDOMAnnotation(n,r),r}}__init10(){this.handleMenuClick=t=>{const{annotations:e,onChange:n}=this.props,{annotation:o,annotationIndex:r}=this.state,{type:i,text:a}=t;if(o){const t={...o,label:a,type:i},{type:n,label:s}=o;this.updateLabel(s,t,i!==n&&n),e.splice(r,1,t)}else{const t=this.createNewAnnotation(a,i);e.push(t)}n(e),this.handleClose()}}__init11(){this.editAnnotation=()=>{this.setState({openedMenu:!1,openedEditor:!0})}}__init12(){this.addAnnotation=t=>{const{annotations:e,onChange:n}=this.props,o=this.createNewAnnotation("",t),r=Ke(o.id);e.push(o),this.setState({openedMenu:!1,openedEditor:!0,annotationIndex:e.length-1,annotation:o,labelElem:r}),n(e)}}__init13(){this.updateLabel=(t,e,n)=>{const{selectedElems:o,labelElem:r}=this.state,{label:i,type:a}=e;qe(i)&&qe(t)||!qe(i)&&!qe(t)?(r.innerHTML=i,n&&(r.classList.remove(n),r.classList.add(a),o.forEach(t=>{t.classList.remove(n),t.classList.add(a)}))):qe(i)&&!qe(t)?(o[0].removeChild(r),this.createDOMAnnotation(o,e)):!qe(i)&&qe(t)&&(this.labelsRef.removeChild(r),this.createDOMAnnotation(o,e))}}__init14(){this.changeAnnotationType=t=>{const{annotations:e,onChange:n}=this.props,{annotationIndex:o,selectedElems:r}=this.state,{type:i,label:a}=e[o],s="positive"===i?"negative":"positive",l={...e[o],type:s,label:t};r.forEach(t=>{t.classList.remove(i),t.classList.add(s)}),this.updateLabel(a,l,i),e.splice(o,1,l),n(e),this.handleClose()}}__init15(){this.updateAnnotation=(t,e)=>{const{annotations:n,onChange:o}=this.props,{annotationIndex:r}=this.state,i={...n[r],label:e};this.updateLabel(t,i),n.splice(r,1,i),o(n)}}componentWillUnmount(){this.textRef.removeEventListener("scroll",this.adjustAnnotationsPosition)}render(){const{comment:t,customKeys:e,disabled:n,disabledMath:o,keypadMode:r,height:i,width:a,maxHeight:s,onCommentChange:l,predefinedAnnotations:c,text:d}=this.props,{anchorEl:p,annotation:u,openedMenu:h,openedEditor:f,selectionDetails:b}=this.state,y=p&&(p.offsetTop?p.offsetTop:p.offsetParent.offsetTop),m=this.textRef&&y?y-this.textRef.scrollTop-8:0;return bn.createElement("div",null,bn.createElement(Cn,null,bn.createElement(_n,{style:{width:a-34,minHeight:i,maxHeight:s},ref:t=>this.textRef=t,onMouseDown:n?()=>{}:He,onMouseUp:n?()=>{}:this.handleSelection,dangerouslySetInnerHTML:{__html:d}}),bn.createElement(xn,{ref:t=>this.labelsRef=t})),bn.createElement(jn,{label:"Comment"},bn.createElement(gn,{className:"prompt",markup:t||"",onChange:l,width:a&&(a+104).toString(),disabled:n,pluginProps:{math:{disabled:o,customKeys:e,keypadMode:r,controlledKeypadMode:!1},video:{disabled:!0},audio:{disabled:!0},textAlign:{disabled:!0},h3:{disabled:!0}}})),bn.createElement(fn,{anchorEl:p,open:h&&!n,annotations:c,isNewAnnotation:!!b,onClose:this.handleClose,onDelete:this.deleteAnnotation,onEdit:this.editAnnotation,onWrite:this.addAnnotation,onAnnotate:this.handleMenuClick}),bn.createElement(on,{anchorEl:this.textRef,open:f&&!n,offset:m,value:u&&u.label||"",type:u&&u.type,onClose:this.handleClose,onDelete:this.deleteAnnotation,onSave:this.updateAnnotation,onTypeChange:this.changeAnnotationType}))}}wn.__initStatic();const En=t,An=e,Sn=r,{Typography:kn}=n,{styled:On}=o,{color:Tn}=i,{Feedback:Rn}=i,{Collapsible:Pn}=i,{PreviewPrompt:In}=i,{UiLayout:Mn}=i,zn=l,Dn=Sn("@pie-ui:extended-text-entry"),Ln=On(Mn)({backgroundColor:Tn.background(),color:Tn.text()}),Nn=On(kn)(({theme:t})=>({width:"100%",color:Tn.text(),marginBottom:t.spacing(2),fontSize:"inherit"})),$n=On("div")(({theme:t})=>({marginBottom:t.spacing(2)})),Wn=On(zn)(({theme:t})=>({marginBottom:t.spacing(2),borderRadius:"4px"})),Un=On("h2")({position:"absolute",left:"-10000px",top:"auto",width:"1px",height:"1px",overflow:"hidden"});class Fn extends En.Component{constructor(...t){super(...t),Fn.prototype.__init.call(this),Fn.prototype.__init2.call(this)}static __initStatic(){this.propTypes={onValueChange:An.func.isRequired,onAnnotationsChange:An.func.isRequired,onCommentChange:An.func.isRequired,model:An.object,session:An.shape({value:An.string,annotations:An.array,comment:An.string}).isRequired}}__init(){this.changeSessionValue=Ne(this.props.onValueChange,1500)}__init2(){this.changeSessionComment=Ne(this.props.onCommentChange,1500)}render(){const{model:t,session:e,onAnnotationsChange:n}=this.props,{animationsDisabled:o,annotatorMode:r,customKeys:i,dimensions:a,disabled:s,disabledAnnotator:l,equationEditor:c,extraCSSRules:d,feedback:p,mathInput:u,playersToolbarPosition:h,predefinedAnnotations:f,prompt:b,spanishInput:y,specialInput:m,spellCheckEnabled:g,teacherInstructions:v}=t,{annotations:_,comment:x,value:C}=e,{width:j,height:w}=a||{},E="40vh",A={position:"top"===h?"top":"bottom"};Dn("[render] disabled? ",s);const S=En.createElement(In,{defaultClassName:"teacher-instructions",prompt:v}),k=[];return y&&k.push({language:"spanish"}),m&&k.push({language:"special"}),En.createElement(Ln,{extraCSSRules:d,ref:t=>{this.containerRef=t}},En.createElement(Un,null,"Constructed Response Question"),v&&En.createElement($n,null,o?S:En.createElement(Pn,{labels:{hidden:"Show Teacher Instructions",visible:"Hide Teacher Instructions"}},S)),b&&En.createElement(Nn,{component:"span"},En.createElement(In,{defaultClassName:"prompt",prompt:t.prompt})),r?En.createElement(wn,{text:C||"",annotations:_||[],comment:x||"",predefinedAnnotations:f||[],onChange:n,onCommentChange:this.changeSessionComment,width:j,height:w,maxHeight:E,disabled:l,disabledMath:!u,customKeys:i,keypadMode:c}):En.createElement(Wn,{className:"response-area-editor",onChange:this.changeSessionValue,markup:C||"",maxWidth:j&&j.toString(),minWidth:"100px",minHeight:w&&w.toString(),maxHeight:E,disabled:s,highlightShape:!0,toolbarOpts:A,spellCheck:g,charactersLimit:5e4,autoWidthToolbar:!0,pluginProps:{math:{disabled:!u,customKeys:this.props.model.customKeys,keypadMode:this.props.model.equationEditor,controlledKeypadMode:!1},video:{disabled:!0},audio:{disabled:!0},table:{disabled:!0},textAlign:{disabled:!0},h3:{disabled:!0},separateParagraphs:{disabled:!1},ul_list:{disabled:!0},ol_list:{disabled:!0}},languageCharactersProps:k}),p&&En.createElement(Rn,{correctness:"correct",feedback:p}))}}Fn.__initStatic();const Bn=t,{createRoot:Hn}=a,qn=r,{renderMath:Vn}=s,Kn=qn("pie-element:extended-text-entry:print"),Gn=(t,e)=>{const n="instructor"===e.role,o=Me(t,5);o.prompt=!1!==o.promptEnabled?o.prompt:void 0,o.teacherInstructions=n&&!1!==o.teacherInstructionsEnabled?o.teacherInstructions:void 0,o.showTeacherInstructions=n,o.mode=n?"evaluate":o.mode;return o.dimensions={height:100,width:500,...o.dimensions},o.disabled=!0,o.feedback=void 0,o.animationsDisabled=!0,o};class Xn extends HTMLElement{constructor(){super(),this._options=null,this._model=null,this._session=[],this._root=null,this._rerender=Ne(()=>{if(this._model&&this._session&&this._options){const t=Gn(this._model,this._options),e=Bn.createElement(Fn,{model:t,session:{},onChange:()=>{},onValueChange:()=>{},onAnnotationsChange:()=>{},onCommentChange:()=>{}});this._root||(this._root=Hn(this)),this._root.render(e),queueMicrotask(()=>{Kn("render complete - render math"),Vn(this)})}else Kn("skip")},50,{leading:!1,trailing:!0})}set options(t){this._options=t,this._rerender()}set model(t){this._model=t,this._rerender()}connectedCallback(){}disconnectedCallback(){this._root&&this._root.unmount()}}export{Xn as default};