@pie-element/multiple-choice 11.2.0-mui-update.1 → 11.2.0-mui-update.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.
package/lib/index.js CHANGED
@@ -289,4 +289,4 @@ class MultipleChoice extends HTMLElement {
289
289
  }
290
290
  }
291
291
  exports.default = MultipleChoice;
292
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_main","_interopRequireDefault","require","_react","_client","_debounce","_debug","_piePlayerEvents","_mathRendering","_renderUi","_sessionUpdater","log","debug","isComplete","session","model","audioComplete","elementContext","autoplayAudioEnabled","completeAudioEnabled","audio","querySelector","isInsidePrompt","closest","value","choiceMode","minSelections","maxSelections","selections","length","exports","MultipleChoice","HTMLElement","constructor","_model","_session","_boundHandleKeyDown","handleKeyDown","bind","_keyboardEventsEnabled","_audioInitialized","_root","_rerender","debounce","element","React","createElement","Main","onChoiceChanged","_onChange","onShowCorrectToggle","setAttribute","setLangAttribute","createRoot","render","queueMicrotask","renderMath","keyboardEventsEnabled","enableKeyboardEvents","leading","trailing","_dispatchResponseChanged","dispatchEvent","SessionChangedEvent","tagName","toLowerCase","_dispatchModelSet","ModelSetEvent","undefined","language","lang","slice","s","data","updateSessionValue","_createAudioInfoToast","info","document","id","Object","assign","style","position","top","width","height","display","justifyContent","alignItems","background","zIndex","cursor","img","src","EnableAudioAutoplayImage","alt","appendChild","connectedCallback","observer","MutationObserver","mutationsList","forEach","mutation","type","container","enableAudio","play","removeChild","removeEventListener","setTimeout","paused","addEventListener","handlePlaying","updateSessionMetadata","audioStartTime","Date","getTime","handleEnded","audioEndTime","_audio","_handlePlaying","_handleEnded","_enableAudio","disconnect","observe","childList","subtree","window","disconnectedCallback","unmount","event","mode","keyToIndex","key","numOffset","letterOffset","test","charCodeAt","choiceIndex","choices","currentValue","choiceId","newValue","selected","includes","selector","default"],"sources":["../src/index.js"],"sourcesContent":["import Main from './main';\nimport React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport debounce from 'lodash/debounce';\nimport debug from 'debug';\nimport { ModelSetEvent, SessionChangedEvent } from '@pie-framework/pie-player-events';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { EnableAudioAutoplayImage } from '@pie-lib/render-ui';\nimport { updateSessionValue, updateSessionMetadata } from './session-updater';\n\nconst log = debug('pie-ui:multiple-choice');\n\nexport const isComplete = (session, model, audioComplete, elementContext) => {\n  const { autoplayAudioEnabled, completeAudioEnabled } = model || {};\n\n  // check audio completion if audio settings are enabled and audio actually exists\n  if (autoplayAudioEnabled && completeAudioEnabled && !audioComplete) {\n    if (elementContext) {\n      const audio = elementContext.querySelector('audio');\n      const isInsidePrompt = audio && audio.closest('#preview-prompt');\n\n      // only require audio completion if audio exists and is inside the prompt\n      if (audio && isInsidePrompt) {\n        return false;\n      }\n    }\n  }\n\n  if (!session || !session.value) {\n    return false;\n  }\n\n  const { choiceMode, minSelections = 1, maxSelections } = model || {};\n  const selections = session.value.length || 0;\n\n  if (choiceMode === 'radio') {\n    return !!selections;\n  }\n\n  if (selections < minSelections || selections > maxSelections) {\n    return false;\n  }\n\n  return true;\n};\n\nexport default class MultipleChoice extends HTMLElement {\n  constructor() {\n    super();\n    this._model = null;\n    this._session = null;\n    this.audioComplete = false;\n    this._boundHandleKeyDown = this.handleKeyDown.bind(this);\n    this._keyboardEventsEnabled = false;\n    this._audioInitialized = false;\n    this._root = null;\n\n    this._rerender = debounce(\n      () => {\n        if (this._model && this._session) {\n          var element = React.createElement(Main, {\n            model: this._model,\n            session: this._session,\n            onChoiceChanged: this._onChange.bind(this),\n            onShowCorrectToggle: this.onShowCorrectToggle.bind(this),\n          });\n\n          //TODO: aria-label is set in the _rerender because we need to change it when the model.choiceMode is updated. Consider revisiting the placement of the aria-label setting in the _rerender\n          this.setAttribute(\n            'aria-label',\n            this._model.choiceMode === 'radio' ? 'Multiple Choice Question' : 'Multiple Correct Answer Question',\n          );\n          this.setAttribute('role', 'region');\n          this.setLangAttribute();\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\n          if (this._model.keyboardEventsEnabled === true && !this._keyboardEventsEnabled) {\n            this.enableKeyboardEvents();\n          }\n        } else {\n          log('skip');\n        }\n      },\n      50,\n      { leading: false, trailing: true },\n    );\n\n    this._dispatchResponseChanged = debounce(() => {\n      this.dispatchEvent(\n        new SessionChangedEvent(\n          this.tagName.toLowerCase(),\n          isComplete(this._session, this._model, this.audioComplete, this),\n        ),\n      );\n    });\n\n    this._dispatchModelSet = debounce(\n      () => {\n        this.dispatchEvent(\n          new ModelSetEvent(\n            this.tagName.toLowerCase(),\n            isComplete(this._session, this._model, this.audioComplete, this),\n            this._model !== undefined,\n          ),\n        );\n      },\n      50,\n      { leading: false, trailing: true },\n    );\n  }\n\n  onShowCorrectToggle() {\n    renderMath(this);\n  }\n\n  setLangAttribute() {\n    const language = this._model && typeof this._model.language ? this._model.language : '';\n    const lang = language ? language.slice(0, 2) : 'en';\n    this.setAttribute('lang', lang);\n  }\n\n  set model(s) {\n    this._model = s;\n    this._rerender();\n    // reset the audioInitialized to false since the model changed, and we might need to reinitialize the audio\n    this._audioInitialized = false;\n    this._dispatchModelSet();\n  }\n\n  get session() {\n    return this._session;\n  }\n\n  set session(s) {\n    this._session = s;\n    this._rerender();\n    //TODO: remove this session-changed should only be emit on user change\n    this._dispatchResponseChanged();\n  }\n\n  _onChange(data) {\n    updateSessionValue(this._session, this._model.choiceMode, data);\n    this._dispatchResponseChanged();\n    this._rerender();\n  }\n\n  _createAudioInfoToast() {\n    const info = document.createElement('div');\n    info.id = 'play-audio-info';\n\n    Object.assign(info.style, {\n      position: 'absolute',\n      top: 0,\n      width: '100%',\n      height: '100%',\n      display: 'flex',\n      justifyContent: 'center',\n      alignItems: 'center',\n      background: 'white',\n      zIndex: '1000',\n      cursor: 'pointer',\n    });\n\n    const img = document.createElement('img');\n    img.src = EnableAudioAutoplayImage;\n    img.alt = 'Click anywhere to enable audio autoplay';\n    img.width = 500;\n    img.height = 300;\n\n    info.appendChild(img);\n    return info;\n  }\n\n  connectedCallback() {\n    this._rerender();\n\n    // Observation:  audio in Chrome will have the autoplay attribute,\n    // while other browsers will not have the autoplay attribute and will need a user interaction to play the audio\n    // This workaround fixes the issue of audio being cached and played on any user interaction in Safari and Firefox\n    const observer = new MutationObserver((mutationsList, observer) => {\n      mutationsList.forEach((mutation) => {\n        if (mutation.type === 'childList') {\n          if (this._audioInitialized) return;\n\n          const audio = this.querySelector('audio');\n          const isInsidePrompt = audio && audio.closest('#preview-prompt');\n\n          if (!this._model) return;\n          if (!this._model.autoplayAudioEnabled) return;\n          if (audio && !isInsidePrompt) return;\n          if (!audio) return;\n\n          const info = this._createAudioInfoToast();\n          const container = this.querySelector('#main-container');\n          const enableAudio = () => {\n            if (this.querySelector('#play-audio-info')) {\n              audio.play();\n              container.removeChild(info);\n            }\n\n            document.removeEventListener('click', enableAudio);\n          };\n\n          // if the audio is paused, it means the user has not interacted with the page yet and the audio will not play\n          // FIX FOR SAFARI: play with a slight delay to check if autoplay was blocked\n          setTimeout(() => {\n            if (audio.paused && !this.querySelector('#play-audio-info')) {\n              // add info message as a toast to enable audio playback\n              container.appendChild(info);\n              document.addEventListener('click', enableAudio);\n            } else {\n              document.removeEventListener('click', enableAudio);\n            }\n          }, 500);\n\n          // we need to listen for the playing event to remove the toast in case the audio plays because of re-rendering\n          const handlePlaying = () => {\n            updateSessionMetadata(this._session, { audioStartTime: new Date().getTime() });\n\n            const info = this.querySelector('#play-audio-info');\n            if (info) {\n              container.removeChild(info);\n            }\n\n            audio.removeEventListener('playing', handlePlaying);\n          };\n\n          audio.addEventListener('playing', handlePlaying);\n\n          // we need to listen for the ended event to update the isComplete state\n          const handleEnded = () => {\n            updateSessionMetadata(this._session, { audioEndTime: new Date().getTime() });\n            this.audioComplete = true;\n            this._dispatchResponseChanged();\n            audio.removeEventListener('ended', handleEnded);\n          };\n\n          audio.addEventListener('ended', handleEnded);\n\n          // store references to remove later\n          this._audio = audio;\n          this._handlePlaying = handlePlaying;\n          this._handleEnded = handleEnded;\n          this._enableAudio = enableAudio;\n          // set to true to prevent multiple initializations\n          this._audioInitialized = true;\n\n          observer.disconnect();\n        }\n      });\n    });\n\n    observer.observe(this, { childList: true, subtree: true });\n  }\n\n  enableKeyboardEvents() {\n    if (!this._keyboardEventsEnabled) {\n      window.addEventListener('keydown', this._boundHandleKeyDown);\n      this._keyboardEventsEnabled = true;\n    }\n  }\n\n  disconnectedCallback() {\n    if (this._keyboardEventsEnabled) {\n      window.removeEventListener('keydown', this._boundHandleKeyDown);\n      this._keyboardEventsEnabled = false;\n    }\n\n    document.removeEventListener('click', this._enableAudio);\n\n    if (this._audio) {\n      this._audio.removeEventListener('playing', this._handlePlaying);\n      this._audio.removeEventListener('ended', this._handleEnded);\n      this._audio = null;\n    }\n\n    if (this._root) {\n      this._root.unmount();\n    }\n  }\n\n  /**\n   * Handles global keyboard events for selecting or toggling multiple-choice answers.\n   * Maps keys (1-9, 0, a-j, A-J) to choices and updates the session state accordingly.\n   * Ensures valid key presses toggle or select the appropriate choice based on the model.\n   */\n  handleKeyDown(event) {\n    if (!this._model || !this._session) {\n      return;\n    }\n\n    const { mode } = this._model;\n    if (mode !== 'gather') {\n      return;\n    }\n\n    const keyToIndex = (key) => {\n      const numOffset = key >= '1' && key <= '9' ? key - '1' : key === '0' ? 9 : -1;\n      const letterOffset = /^[a-jA-J]$/.test(key) ? key.toLowerCase().charCodeAt(0) - 'a'.charCodeAt(0) : -1;\n      return numOffset >= 0 ? numOffset : letterOffset;\n    };\n\n    const choiceIndex = keyToIndex(event.key);\n\n    if (choiceIndex === undefined || choiceIndex <= -1 || choiceIndex >= this._model.choices?.length) {\n      return;\n    }\n\n    const currentValue = this._session.value || [];\n    const choiceId = this._model.choices[choiceIndex].value;\n\n    const newValue = {\n      value: choiceId,\n      selected: !currentValue.includes(choiceId),\n      selector: 'Keyboard',\n    };\n\n    this._onChange(newValue);\n  }\n}\n"],"mappings":"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","ignoreList":[]}
292
+ //# sourceMappingURL=index.js.map
package/lib/main.js CHANGED
@@ -51,4 +51,4 @@ class Main extends _react.default.Component {
51
51
  session: {}
52
52
  });
53
53
  var _default = exports.default = Main;
54
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9wcm9wVHlwZXMiLCJfcmVuZGVyVWkiLCJfbXVsdGlwbGVDaG9pY2UiLCJNYWluIiwiUmVhY3QiLCJDb21wb25lbnQiLCJyZW5kZXIiLCJtb2RlbCIsIm9uQ2hvaWNlQ2hhbmdlZCIsInNlc3Npb24iLCJvblNob3dDb3JyZWN0VG9nZ2xlIiwicHJvcHMiLCJleHRyYUNTU1J1bGVzIiwiZm9udFNpemVGYWN0b3IiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsIlByZXZpZXdMYXlvdXQiLCJjbGFzc2VzIiwiX2V4dGVuZHMyIiwiX2RlZmluZVByb3BlcnR5MiIsIlByb3BUeXBlcyIsIm9iamVjdCIsImZ1bmMiLCJzaGFwZSIsIm5hbWVzIiwiYXJyYXlPZiIsInN0cmluZyIsInJ1bGVzIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vc3JjL21haW4uanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgUHJldmlld0xheW91dCB9IGZyb20gJ0BwaWUtbGliL3JlbmRlci11aSc7XG5pbXBvcnQgTXVsdGlwbGVDaG9pY2UgZnJvbSAnLi9tdWx0aXBsZS1jaG9pY2UnO1xuXG5jbGFzcyBNYWluIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBtb2RlbDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBzZXNzaW9uOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIG9uQ2hvaWNlQ2hhbmdlZDogUHJvcFR5cGVzLmZ1bmMsXG4gICAgb25TaG93Q29ycmVjdFRvZ2dsZTogUHJvcFR5cGVzLmZ1bmMsXG4gICAgZXh0cmFDU1NSdWxlczogUHJvcFR5cGVzLnNoYXBlKHtcbiAgICAgIG5hbWVzOiBQcm9wVHlwZXMuYXJyYXlPZihQcm9wVHlwZXMuc3RyaW5nKSxcbiAgICAgIHJ1bGVzOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIH0pLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbW9kZWw6IHt9LFxuICAgIHNlc3Npb246IHt9LFxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IG1vZGVsLCBvbkNob2ljZUNoYW5nZWQsIHNlc3Npb24sIG9uU2hvd0NvcnJlY3RUb2dnbGUgfSA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgeyBleHRyYUNTU1J1bGVzLCBmb250U2l6ZUZhY3RvciB9ID0gbW9kZWw7XG5cbiAgICAvLyBtb2RlbC5wYXJ0TGFiZWwgaXMgYSBwcm9wZXJ0eSB1c2VkIGZvciBlYnNyXG4gICAgcmV0dXJuIChcbiAgICAgIDxQcmV2aWV3TGF5b3V0IGV4dHJhQ1NTUnVsZXM9e2V4dHJhQ1NTUnVsZXN9IGZvbnRTaXplRmFjdG9yPXtmb250U2l6ZUZhY3Rvcn0gY2xhc3Nlcz17e319PlxuICAgICAgICA8TXVsdGlwbGVDaG9pY2VcbiAgICAgICAgICB7Li4ubW9kZWx9XG4gICAgICAgICAgc2Vzc2lvbj17c2Vzc2lvbn1cbiAgICAgICAgICBvbkNob2ljZUNoYW5nZWQ9e29uQ2hvaWNlQ2hhbmdlZH1cbiAgICAgICAgICBvblNob3dDb3JyZWN0VG9nZ2xlPXtvblNob3dDb3JyZWN0VG9nZ2xlfVxuICAgICAgICAvPlxuICAgICAgPC9QcmV2aWV3TGF5b3V0PlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgTWFpbjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUUsU0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsZUFBQSxHQUFBSixzQkFBQSxDQUFBQyxPQUFBO0FBRUEsTUFBTUksSUFBSSxTQUFTQyxjQUFLLENBQUNDLFNBQVMsQ0FBQztFQWlCakNDLE1BQU1BLENBQUEsRUFBRztJQUNQLE1BQU07TUFBRUMsS0FBSztNQUFFQyxlQUFlO01BQUVDLE9BQU87TUFBRUM7SUFBb0IsQ0FBQyxHQUFHLElBQUksQ0FBQ0MsS0FBSztJQUMzRSxNQUFNO01BQUVDLGFBQWE7TUFBRUM7SUFBZSxDQUFDLEdBQUdOLEtBQUs7O0lBRS9DO0lBQ0Esb0JBQ0VWLE1BQUEsQ0FBQWlCLE9BQUEsQ0FBQUMsYUFBQSxDQUFDZCxTQUFBLENBQUFlLGFBQWE7TUFBQ0osYUFBYSxFQUFFQSxhQUFjO01BQUNDLGNBQWMsRUFBRUEsY0FBZTtNQUFDSSxPQUFPLEVBQUUsQ0FBQztJQUFFLGdCQUN2RnBCLE1BQUEsQ0FBQWlCLE9BQUEsQ0FBQUMsYUFBQSxDQUFDYixlQUFBLENBQUFZLE9BQWMsTUFBQUksU0FBQSxDQUFBSixPQUFBLE1BQ1RQLEtBQUs7TUFDVEUsT0FBTyxFQUFFQSxPQUFRO01BQ2pCRCxlQUFlLEVBQUVBLGVBQWdCO01BQ2pDRSxtQkFBbUIsRUFBRUE7SUFBb0IsRUFDMUMsQ0FDWSxDQUFDO0VBRXBCO0FBQ0Y7QUFBQyxJQUFBUyxnQkFBQSxDQUFBTCxPQUFBLEVBakNLWCxJQUFJLGVBQ1c7RUFDakJJLEtBQUssRUFBRWEsa0JBQVMsQ0FBQ0MsTUFBTTtFQUN2QlosT0FBTyxFQUFFVyxrQkFBUyxDQUFDQyxNQUFNO0VBQ3pCYixlQUFlLEVBQUVZLGtCQUFTLENBQUNFLElBQUk7RUFDL0JaLG1CQUFtQixFQUFFVSxrQkFBUyxDQUFDRSxJQUFJO0VBQ25DVixhQUFhLEVBQUVRLGtCQUFTLENBQUNHLEtBQUssQ0FBQztJQUM3QkMsS0FBSyxFQUFFSixrQkFBUyxDQUFDSyxPQUFPLENBQUNMLGtCQUFTLENBQUNNLE1BQU0sQ0FBQztJQUMxQ0MsS0FBSyxFQUFFUCxrQkFBUyxDQUFDTTtFQUNuQixDQUFDO0FBQ0gsQ0FBQztBQUFBLElBQUFQLGdCQUFBLENBQUFMLE9BQUEsRUFWR1gsSUFBSSxrQkFZYztFQUNwQkksS0FBSyxFQUFFLENBQUMsQ0FBQztFQUNURSxPQUFPLEVBQUUsQ0FBQztBQUNaLENBQUM7QUFBQSxJQUFBbUIsUUFBQSxHQUFBQyxPQUFBLENBQUFmLE9BQUEsR0FvQllYLElBQUkiLCJpZ25vcmVMaXN0IjpbXX0=
54
+ //# sourceMappingURL=main.js.map
@@ -383,4 +383,4 @@ MultipleChoice.defaultProps = {
383
383
  }
384
384
  };
385
385
  var _default = exports.default = MultipleChoice;
386
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_correctAnswerToggle","_classnames","_styles","_Box","_renderUi","_translator","_choice","translator","Translator","MainContainer","styled","Box","color","text","backgroundColor","background","position","border","PartLabel","theme","display","fontSize","margin","fontWeight","paddingBottom","spacing","TeacherInstructions","marginBottom","HorizontalLayout","flexDirection","flexWrap","GridLayout","StyledFieldset","padding","minWidth","outline","SrOnly","left","top","width","height","overflow","ErrorText","typography","palette","error","main","paddingTop","MultipleChoice","React","Component","constructor","props","_defineProperty2","default","event","value","checked","target","maxSelections","onChoiceChanged","session","length","setState","maxSelectionsErrorState","selected","selector","mode","showCorrect","state","onShowCorrectToggle","choice","isCorrect","correct","isChecked","isSelected","undefined","e","fieldset","currentTarget","activeEl","document","activeElement","contains","relatedTarget","compareDocumentPosition","Node","DOCUMENT_POSITION_PRECEDING","firstInputRef","current","focus","alwaysShowCorrect","onToggle","bind","createRef","sessionValue","indexOf","UNSAFE_componentWillReceiveProps","nextProps","correctResponse","indexToSymbol","index","keyMode","String","fromCharCode","toUpperCase","getChecked","isPrintMode","options","isEvaluateMode","renderHeading","choiceMode","createElement","render","disabled","className","choices","gridColumns","partLabel","prompt","responseCorrect","teacherInstructions","animationsDisabled","language","isSelectionButtonBelow","minSelections","autoplayAudioEnabled","customAudioButton","showCorrectAnswerToggle","columnsStyle","gridTemplateColumns","selections","teacherInstructionsDiv","PreviewPrompt","tagName","defaultClassName","getMultipleChoiceMinSelectionErrorMessage","t","lng","LayoutComponent","choicesLayout","id","classNames","Collapsible","labels","hidden","visible","tabIndex","onFocus","handleGroupFocus","role","show","toggled","style","map","autoFocusRef","selectedAnswerBackgroundColor","selectedAnswerStrokeColor","selectedAnswerStrokeWidth","hoverAnswerBackgroundColor","hoverAnswerStrokeColor","hoverAnswerStrokeWidth","key","choicesLength","handleChange","hideTick","correctness","getCorrectness","displayKey","exports","PropTypes","string","oneOf","array","object","bool","func","number","playImage","pauseImage","defaultProps","_default"],"sources":["../src/multiple-choice.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport CorrectAnswerToggle from '@pie-lib/correct-answer-toggle';\nimport classNames from 'classnames';\nimport { styled } from '@mui/material/styles';\nimport Box from '@mui/material/Box';\nimport { color, Collapsible, PreviewPrompt } from '@pie-lib/render-ui';\nimport Translator from '@pie-lib/translator';\n\nimport Choice from './choice';\n\n// MultipleChoice\n\nconst { translator } = Translator;\n\nconst MainContainer = styled(Box)({\n  color: color.text(),\n  backgroundColor: color.background(),\n  '& *': {\n    '-webkit-font-smoothing': 'antialiased',\n  },\n  position: 'relative',\n  // remove border from legend tags inside main to override the OT default styles\n  '& legend': {\n    border: 'none !important',\n  },\n});\n\nconst PartLabel = styled('h2')(({ theme }) => ({\n  display: 'block',\n  fontSize: 'inherit',\n  margin: '0',\n  fontWeight: 'normal',\n  paddingBottom: theme.spacing(2),\n}));\n\nconst TeacherInstructions = styled(Box)(({ theme }) => ({\n  marginBottom: theme.spacing(2),\n}));\n\nconst HorizontalLayout = styled(Box)({\n  display: 'flex',\n  flexDirection: 'row',\n  flexWrap: 'wrap',\n});\n\nconst GridLayout = styled(Box)({\n  display: 'grid',\n});\n\nconst StyledFieldset = styled('fieldset')({\n  border: '0px',\n  padding: '0.01em 0 0 0',\n  margin: '0px',\n  minWidth: '0px',\n  '&:focus': {\n    outline: 'none',\n  },\n});\n\nconst SrOnly = styled('h3')({\n  position: 'absolute',\n  left: '-10000px',\n  top: 'auto',\n  width: '1px',\n  height: '1px',\n  overflow: 'hidden',\n});\n\nconst ErrorText = styled('div')(({ theme }) => ({\n  fontSize: theme.typography.fontSize - 2,\n  color: theme.palette.error.main,\n  paddingTop: theme.spacing(1),\n}));\n\nexport class MultipleChoice extends React.Component {\n  static propTypes = {\n    className: PropTypes.string,\n    mode: PropTypes.oneOf(['gather', 'view', 'evaluate']),\n    choiceMode: PropTypes.oneOf(['radio', 'checkbox']),\n    keyMode: PropTypes.oneOf(['numbers', 'letters', 'none']),\n    choices: PropTypes.array,\n    partLabel: PropTypes.string,\n    prompt: PropTypes.string,\n    teacherInstructions: PropTypes.string,\n    session: PropTypes.object,\n    disabled: PropTypes.bool,\n    onChoiceChanged: PropTypes.func,\n    responseCorrect: PropTypes.bool,\n    correctResponse: PropTypes.array,\n    choicesLayout: PropTypes.oneOf(['vertical', 'grid', 'horizontal']),\n    gridColumns: PropTypes.string,\n    alwaysShowCorrect: PropTypes.bool,\n    animationsDisabled: PropTypes.bool,\n    language: PropTypes.string,\n    selectedAnswerBackgroundColor: PropTypes.string,\n    selectedAnswerStrokeColor: PropTypes.string,\n    selectedAnswerStrokeWidth: PropTypes.string,\n    hoverAnswerBackgroundColor: PropTypes.string,\n    hoverAnswerStrokeColor: PropTypes.string,\n    hoverAnswerStrokeWidth: PropTypes.string,\n    onShowCorrectToggle: PropTypes.func,\n    isSelectionButtonBelow: PropTypes.bool,\n    minSelections: PropTypes.number,\n    maxSelections: PropTypes.number,\n    autoplayAudioEnabled: PropTypes.bool,\n    customAudioButton: {\n      playImage: PropTypes.string,\n      pauseImage: PropTypes.string,\n    },\n    options: PropTypes.object,\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      showCorrect: this.props.alwaysShowCorrect || false,\n      maxSelectionsErrorState: false,\n    };\n\n    this.onToggle = this.onToggle.bind(this);\n    this.firstInputRef = React.createRef();\n  }\n\n  isSelected(value) {\n    const sessionValue = this.props.session && this.props.session.value;\n\n    return sessionValue && sessionValue.indexOf && sessionValue.indexOf(value) >= 0;\n  }\n\n  // handleChange was added for accessibility. Please see comments and videos from PD-2441.\n  handleChange = (event) => {\n    const { value, checked } = event.target;\n    const { maxSelections, onChoiceChanged, session } = this.props;\n\n    if (session.value && session.value.length >= maxSelections) {\n      // show/hide max selections error when user select/deselect an answer\n      this.setState({ maxSelectionsErrorState: checked });\n\n      if (checked) {\n        // prevent selecting more answers\n        return;\n      }\n    }\n\n    onChoiceChanged({ value, selected: checked, selector: 'Mouse' });\n  };\n\n  onToggle = () => {\n    if (this.props.mode === 'evaluate') {\n      this.setState({ showCorrect: !this.state.showCorrect }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n  };\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    if (!nextProps.correctResponse && this.state.showCorrect !== false) {\n      this.setState({ showCorrect: false }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n\n    if (nextProps.alwaysShowCorrect && this.state.showCorrect !== true) {\n      this.setState({ showCorrect: true }, () => {\n        if (this.props.onShowCorrectToggle) {\n          this.props.onShowCorrectToggle();\n        }\n      });\n    }\n  }\n\n  indexToSymbol(index) {\n    if (this.props.keyMode === 'numbers') {\n      return `${index + 1}`;\n    }\n\n    if (this.props.keyMode === 'letters') {\n      return String.fromCharCode(97 + index).toUpperCase();\n    }\n\n    return '';\n  }\n\n  getCorrectness = (choice = {}) => {\n    const isCorrect = choice.correct;\n    const isChecked = this.isSelected(choice.value);\n\n    if (this.state.showCorrect) {\n      return isCorrect ? 'correct' : undefined;\n    }\n\n    if (isCorrect) {\n      if (isChecked) {\n        // A correct answer is selected: marked with a green checkmark\n        return 'correct';\n      } else {\n        // A correct answer is NOT selected: marked with an orange X\n        return 'incorrect';\n      }\n    } else {\n      if (isChecked) {\n        // An incorrect answer is selected: marked with an orange X\n        return 'incorrect';\n      } else {\n        // An incorrect answer is NOT selected: not marked\n        return undefined;\n      }\n    }\n  };\n\n  getChecked(choice) {\n    // check for print context: options prop is passed from print.js and alwaysShowCorrect is true\n    const isPrintMode = this.props.options && this.props.alwaysShowCorrect;\n    \n    if (isPrintMode) {\n      return choice.correct || false;\n    }\n\n    // evaluate mode with show correct toggled\n    const isEvaluateMode = this.state.showCorrect && this.props.mode === 'evaluate';\n    \n    if (isEvaluateMode) {\n      return choice.correct || false;\n    }\n\n    // default behavior: show what the user has selected\n    return this.isSelected(choice.value);\n  }\n\n  // renderHeading function was added for accessibility.\n  renderHeading() {\n    const { mode, choiceMode } = this.props;\n\n    if (mode !== 'gather') {\n      return null;\n    }\n\n    return choiceMode === 'radio' ? (\n      <SrOnly>Multiple Choice Question</SrOnly>\n    ) : (\n      <SrOnly>Multiple Select Question</SrOnly>\n    );\n  }\n\n  handleGroupFocus = (e) => {\n    const fieldset = e.currentTarget;\n    const activeEl = document.activeElement;\n\n    if (fieldset.contains(activeEl) && activeEl !== fieldset) {\n      return;\n    }\n\n    // Only focus the first input if user is tabbing forward\n    if (!e.relatedTarget || fieldset.compareDocumentPosition(e.relatedTarget) & Node.DOCUMENT_POSITION_PRECEDING) {\n      if (this.firstInputRef?.current) {\n        this.firstInputRef.current.focus();\n      }\n    }\n  };\n\n  render() {\n    const {\n      mode,\n      disabled,\n      className,\n      choices = [],\n      choiceMode,\n      gridColumns,\n      partLabel,\n      prompt,\n      responseCorrect,\n      teacherInstructions,\n      alwaysShowCorrect,\n      animationsDisabled,\n      language,\n      isSelectionButtonBelow,\n      minSelections,\n      maxSelections,\n      autoplayAudioEnabled,\n      session,\n      customAudioButton,\n    } = this.props;\n    const { showCorrect, maxSelectionsErrorState } = this.state;\n    const isEvaluateMode = mode === 'evaluate';\n    const showCorrectAnswerToggle = isEvaluateMode && !responseCorrect;\n    const columnsStyle = gridColumns > 1 ? { gridTemplateColumns: `repeat(${gridColumns}, 1fr)` } : undefined;\n    const selections = (session.value && session.value.length) || 0;\n\n    const teacherInstructionsDiv = (\n      <PreviewPrompt\n        tagName=\"div\"\n        className=\"prompt\"\n        defaultClassName=\"teacher-instructions\"\n        prompt={teacherInstructions}\n      />\n    );\n\n    const getMultipleChoiceMinSelectionErrorMessage = () => {\n      if (minSelections && maxSelections) {\n        return minSelections === maxSelections\n          ? translator.t('translation:multipleChoice:minmaxSelections_equal', { lng: language, minSelections })\n          : translator.t('translation:multipleChoice:minmaxSelections_range', {\n              lng: language,\n              minSelections,\n              maxSelections,\n            });\n      }\n\n      if (minSelections) {\n        return translator.t('translation:multipleChoice:minSelections', { lng: language, minSelections });\n      }\n\n      return '';\n    };\n\n    const LayoutComponent = this.props.choicesLayout === 'grid' \n      ? GridLayout \n      : this.props.choicesLayout === 'horizontal' \n        ? HorizontalLayout \n        : Box;\n\n    return (\n      <MainContainer id={'main-container'} className={classNames(className, 'multiple-choice')}>\n        {partLabel && <PartLabel>{partLabel}</PartLabel>}\n\n        {this.renderHeading()}\n\n        {teacherInstructions && (\n          <TeacherInstructions>\n            {!animationsDisabled ? (\n              <Collapsible\n                labels={{\n                  hidden: 'Show Teacher Instructions',\n                  visible: 'Hide Teacher Instructions',\n                }}\n              >\n                {teacherInstructionsDiv}\n              </Collapsible>\n            ) : (\n              teacherInstructionsDiv\n            )}\n          </TeacherInstructions>\n        )}\n\n        <StyledFieldset\n          tabIndex={0}\n          onFocus={this.handleGroupFocus}\n          role={choiceMode === 'radio' ? 'radiogroup' : 'group'}\n        >\n          <PreviewPrompt\n            className=\"prompt\"\n            defaultClassName=\"prompt\"\n            prompt={prompt}\n            tagName={'legend'}\n            autoplayAudioEnabled={autoplayAudioEnabled}\n            customAudioButton={customAudioButton}\n          />\n\n          {!alwaysShowCorrect && (\n            <CorrectAnswerToggle\n              show={showCorrectAnswerToggle}\n              toggled={showCorrect}\n              onToggle={this.onToggle.bind(this)}\n              language={language}\n            />\n          )}\n\n          <LayoutComponent style={columnsStyle}>\n            {choices.map((choice, index) => (\n              <Choice\n                autoFocusRef={index === 0 ? this.firstInputRef : null}\n                choicesLayout={this.props.choicesLayout}\n                selectedAnswerBackgroundColor={this.props.selectedAnswerBackgroundColor}\n                selectedAnswerStrokeColor={this.props.selectedAnswerStrokeColor}\n                selectedAnswerStrokeWidth={this.props.selectedAnswerStrokeWidth}\n                hoverAnswerBackgroundColor={this.props.hoverAnswerBackgroundColor}\n                hoverAnswerStrokeColor={this.props.hoverAnswerStrokeColor}\n                hoverAnswerStrokeWidth={this.props.hoverAnswerStrokeWidth}\n                gridColumns={gridColumns}\n                key={`choice-${index}`}\n                choice={choice}\n                index={index}\n                choicesLength={choices.length}\n                showCorrect={showCorrect}\n                isEvaluateMode={isEvaluateMode}\n                choiceMode={choiceMode}\n                disabled={disabled}\n                tagName={partLabel ? `group-${partLabel}` : 'group'}\n                onChoiceChanged={this.handleChange}\n                hideTick={choice.hideTick}\n                checked={this.getChecked(choice)}\n                correctness={isEvaluateMode ? this.getCorrectness(choice) : undefined}\n                displayKey={this.indexToSymbol(index)}\n                isSelectionButtonBelow={isSelectionButtonBelow}\n              />\n            ))}\n          </LayoutComponent>\n        </StyledFieldset>\n\n        {choiceMode === 'checkbox' && selections < minSelections && (\n          <ErrorText>{getMultipleChoiceMinSelectionErrorMessage()}</ErrorText>\n        )}\n        {choiceMode === 'checkbox' && maxSelectionsErrorState && (\n          <ErrorText>\n            {translator.t(`translation:multipleChoice:maxSelections_${maxSelections === 1 ? 'one' : 'other'}`, {\n              lng: language,\n              maxSelections,\n            })}\n          </ErrorText>\n        )}\n      </MainContainer>\n    );\n  }\n}\n\nMultipleChoice.defaultProps = {\n  session: {\n    value: [],\n  },\n};\n\nexport default MultipleChoice;\n"],"mappings":"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","ignoreList":[]}
386
+ //# sourceMappingURL=multiple-choice.js.map
package/lib/print.js CHANGED
@@ -89,4 +89,4 @@ class MultipleChoicePrint extends HTMLElement {
89
89
  }
90
90
  }
91
91
  exports.default = MultipleChoicePrint;
92
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_client","_debounce","_cloneDeep","_main","_mathRendering","_debug","log","debug","preparePrintModel","model","opts","instr","role","prompt","promptEnabled","undefined","teacherInstructions","teacherInstructionsEnabled","showTeacherInstructions","alwaysShowCorrect","mode","disabled","animationsDisabled","lockChoiceOrder","choicesLayout","choices","cloneDeep","map","c","rationale","rationaleEnabled","hideTick","feedback","keyMode","choicePrefix","MultipleChoicePrint","HTMLElement","constructor","_options","_model","_session","_root","_rerender","debounce","printModel","element","React","createElement","Main","session","options","createRoot","render","queueMicrotask","renderMath","leading","trailing","o","s","connectedCallback","disconnectedCallback","unmount","exports","default"],"sources":["../src/print.js"],"sourcesContent":["import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport debounce from 'lodash/debounce';\nimport cloneDeep from 'lodash/cloneDeep';\nimport Main from './main';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport debug from 'debug';\n\nconst log = debug('pie-element:multiple-choice:print');\n\n/**\n * Live in same package as main element - so we can access some of the shared comps!\n *\n * - update pslb to build print if src/print.js is there\n * - update demo el\n * - get configure/controller building\n */\n\nconst preparePrintModel = (model, opts) => {\n  const instr = opts.role === 'instructor';\n\n  model.prompt = model.promptEnabled !== false ? model.prompt : undefined;\n  model.teacherInstructions =\n    instr && model.teacherInstructionsEnabled !== false ? model.teacherInstructions : undefined;\n  model.showTeacherInstructions = instr;\n  model.alwaysShowCorrect = instr;\n  model.mode = instr ? 'evaluate' : model.mode;\n\n  model.disabled = true;\n  model.animationsDisabled = true;\n  model.lockChoiceOrder = true;\n  model.choicesLayout = model.choicesLayout || 'vertical';\n\n  const choices = cloneDeep(model.choices);\n\n  model.choices = choices.map((c) => {\n    c.rationale = instr && model.rationaleEnabled !== false ? c.rationale : undefined;\n    c.hideTick = instr;\n    c.feedback = undefined;\n    return c;\n  });\n\n  model.keyMode = model.choicePrefix || 'letters';\n\n  return model;\n};\n\nexport default class MultipleChoicePrint 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) {\n          const printModel = preparePrintModel(this._model, this._options);\n\n          const element =\n            this._options &&\n            React.createElement(Main, {\n              model: printModel,\n              session: {},\n              options: this._options,\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  }\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,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,UAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,KAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,cAAA,GAAAL,OAAA;AACA,IAAAM,MAAA,GAAAP,sBAAA,CAAAC,OAAA;AAEA,MAAMO,GAAG,GAAG,IAAAC,cAAK,EAAC,mCAAmC,CAAC;;AAEtD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAMC,iBAAiB,GAAGA,CAACC,KAAK,EAAEC,IAAI,KAAK;EACzC,MAAMC,KAAK,GAAGD,IAAI,CAACE,IAAI,KAAK,YAAY;EAExCH,KAAK,CAACI,MAAM,GAAGJ,KAAK,CAACK,aAAa,KAAK,KAAK,GAAGL,KAAK,CAACI,MAAM,GAAGE,SAAS;EACvEN,KAAK,CAACO,mBAAmB,GACvBL,KAAK,IAAIF,KAAK,CAACQ,0BAA0B,KAAK,KAAK,GAAGR,KAAK,CAACO,mBAAmB,GAAGD,SAAS;EAC7FN,KAAK,CAACS,uBAAuB,GAAGP,KAAK;EACrCF,KAAK,CAACU,iBAAiB,GAAGR,KAAK;EAC/BF,KAAK,CAACW,IAAI,GAAGT,KAAK,GAAG,UAAU,GAAGF,KAAK,CAACW,IAAI;EAE5CX,KAAK,CAACY,QAAQ,GAAG,IAAI;EACrBZ,KAAK,CAACa,kBAAkB,GAAG,IAAI;EAC/Bb,KAAK,CAACc,eAAe,GAAG,IAAI;EAC5Bd,KAAK,CAACe,aAAa,GAAGf,KAAK,CAACe,aAAa,IAAI,UAAU;EAEvD,MAAMC,OAAO,GAAG,IAAAC,kBAAS,EAACjB,KAAK,CAACgB,OAAO,CAAC;EAExChB,KAAK,CAACgB,OAAO,GAAGA,OAAO,CAACE,GAAG,CAAEC,CAAC,IAAK;IACjCA,CAAC,CAACC,SAAS,GAAGlB,KAAK,IAAIF,KAAK,CAACqB,gBAAgB,KAAK,KAAK,GAAGF,CAAC,CAACC,SAAS,GAAGd,SAAS;IACjFa,CAAC,CAACG,QAAQ,GAAGpB,KAAK;IAClBiB,CAAC,CAACI,QAAQ,GAAGjB,SAAS;IACtB,OAAOa,CAAC;EACV,CAAC,CAAC;EAEFnB,KAAK,CAACwB,OAAO,GAAGxB,KAAK,CAACyB,YAAY,IAAI,SAAS;EAE/C,OAAOzB,KAAK;AACd,CAAC;AAEc,MAAM0B,mBAAmB,SAASC,WAAW,CAAC;EAC3DC,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,iBAAQ,EACvB,MAAM;MACJ,IAAI,IAAI,CAACJ,MAAM,IAAI,IAAI,CAACC,QAAQ,EAAE;QAChC,MAAMI,UAAU,GAAGpC,iBAAiB,CAAC,IAAI,CAAC+B,MAAM,EAAE,IAAI,CAACD,QAAQ,CAAC;QAEhE,MAAMO,OAAO,GACX,IAAI,CAACP,QAAQ,iBACbQ,cAAK,CAACC,aAAa,CAACC,aAAI,EAAE;UACxBvC,KAAK,EAAEmC,UAAU;UACjBK,OAAO,EAAE,CAAC,CAAC;UACXC,OAAO,EAAE,IAAI,CAACZ;QAChB,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,CAACG,KAAK,EAAE;UACf,IAAI,CAACA,KAAK,GAAG,IAAAU,kBAAU,EAAC,IAAI,CAAC;QAC/B;QACA,IAAI,CAACV,KAAK,CAACW,MAAM,CAACP,OAAO,CAAC;QAC1BQ,cAAc,CAAC,MAAM;UACnB/C,GAAG,CAAC,+BAA+B,CAAC;UACpC,IAAAgD,yBAAU,EAAC,IAAI,CAAC;QAClB,CAAC,CAAC;MACJ,CAAC,MAAM;QACLhD,GAAG,CAAC,MAAM,CAAC;MACb;IACF,CAAC,EACD,EAAE,EACF;MAAEiD,OAAO,EAAE,KAAK;MAAEC,QAAQ,EAAE;IAAK,CACnC,CAAC;EACH;EACA,IAAIN,OAAOA,CAACO,CAAC,EAAE;IACb,IAAI,CAACnB,QAAQ,GAAGmB,CAAC;EACnB;EAEA,IAAIhD,KAAKA,CAACiD,CAAC,EAAE;IACX,IAAI,CAACnB,MAAM,GAAGmB,CAAC;IACf,IAAI,CAAChB,SAAS,CAAC,CAAC;EAClB;EAEAiB,iBAAiBA,CAAA,EAAG,CAAC;EAErBC,oBAAoBA,CAAA,EAAG;IACrB,IAAI,IAAI,CAACnB,KAAK,EAAE;MACd,IAAI,CAACA,KAAK,CAACoB,OAAO,CAAC,CAAC;IACtB;EACF;AACF;AAACC,OAAA,CAAAC,OAAA,GAAA5B,mBAAA","ignoreList":[]}
92
+ //# sourceMappingURL=print.js.map
@@ -34,4 +34,4 @@ function updateSessionMetadata(session, metadata) {
34
34
  session.waitTime = session.audioEndTime - session.audioStartTime;
35
35
  }
36
36
  }
37
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1cGRhdGVTZXNzaW9uVmFsdWUiLCJzZXNzaW9uIiwiY2hvaWNlTW9kZSIsImRhdGEiLCJ2YWx1ZSIsInNlbGVjdGVkIiwiQXJyYXkiLCJmcm9tIiwiU2V0IiwiZmlsdGVyIiwidiIsInNlbGVjdG9yIiwidXBkYXRlU2Vzc2lvbk1ldGFkYXRhIiwibWV0YWRhdGEiLCJhdWRpb1N0YXJ0VGltZSIsImF1ZGlvRW5kVGltZSIsIndhaXRUaW1lIl0sInNvdXJjZXMiOlsiLi4vc3JjL3Nlc3Npb24tdXBkYXRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gdXBkYXRlU2Vzc2lvblZhbHVlKHNlc3Npb24sIGNob2ljZU1vZGUsIGRhdGEpIHtcbiAgc2Vzc2lvbi52YWx1ZSA9IHNlc3Npb24udmFsdWUgfHwgW107XG4gIGlmIChjaG9pY2VNb2RlID09PSAnY2hlY2tib3gnKSB7XG4gICAgaWYgKGRhdGEuc2VsZWN0ZWQpIHtcbiAgICAgIHNlc3Npb24udmFsdWUgPSBBcnJheS5mcm9tKG5ldyBTZXQoWy4uLnNlc3Npb24udmFsdWUsIGRhdGEudmFsdWVdKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHNlc3Npb24udmFsdWUgPSBzZXNzaW9uLnZhbHVlLmZpbHRlcih2ID0+IHYgIT09IGRhdGEudmFsdWUpO1xuICAgIH1cbiAgfVxuXG4gIGlmIChjaG9pY2VNb2RlID09PSAncmFkaW8nKSB7XG4gICAgaWYgKGRhdGEuc2VsZWN0ZWQpIHtcbiAgICAgIHNlc3Npb24udmFsdWUgPSBbZGF0YS52YWx1ZV07XG4gICAgfSBlbHNlIHtcbiAgICAgIHNlc3Npb24udmFsdWUgPSBbXTtcbiAgICB9XG4gIH1cbiAgXG4gIC8vdXBkYXRlIHNlc3Npb24gdmFsdWUgbWV0YWRhdGFcbiAgc2Vzc2lvbi5zZWxlY3RvciA9IGRhdGEuc2VsZWN0b3I7IC8vdGhlIGlucHV0IG1ldGhvZCB1c2VkIHRvIHNlbGVjdCB0aGUgY2hvaWNlIChlLmcuIG1vdXNlLCBrZXlib2FyZClcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVwZGF0ZVNlc3Npb25NZXRhZGF0YShzZXNzaW9uLCBtZXRhZGF0YSkge1xuICBzZXNzaW9uLmF1ZGlvU3RhcnRUaW1lID0gc2Vzc2lvbi5hdWRpb1N0YXJ0VGltZSB8fCBtZXRhZGF0YS5hdWRpb1N0YXJ0VGltZTsgLy90aW1lc3RhbXAgd2hlbiBhdXRvLXBsYXllZCBhdWRpbyBzdGFydGVkIHBsYXlpbmdcbiAgc2Vzc2lvbi5hdWRpb0VuZFRpbWUgPSBzZXNzaW9uLmF1ZGlvRW5kVGltZSB8fCBtZXRhZGF0YS5hdWRpb0VuZFRpbWU7IC8vdGltZXN0YW1wIHdoZW4gYXV0by1wbGF5ZWQgYXVkaW8gY29tcGxldGVkIHBsYXlpbmdcbiAgXG4gIGlmKCFzZXNzaW9uLndhaXRUaW1lICYmIHNlc3Npb24uYXVkaW9TdGFydFRpbWUgJiYgc2Vzc2lvbi5hdWRpb0VuZFRpbWUpIHtcbiAgICAvLyB3YWl0VGltZSBpcyBlbGFwc2VkIHRpbWUgdGhlIHVzZXIgd2FpdGVkIGZvciBhdXRvLXBsYXllZCBhdWRpbyB0byBmaW5pc2hcbiAgICBzZXNzaW9uLndhaXRUaW1lID0gKHNlc3Npb24uYXVkaW9FbmRUaW1lIC0gc2Vzc2lvbi5hdWRpb1N0YXJ0VGltZSk7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFPLFNBQVNBLGtCQUFrQkEsQ0FBQ0MsT0FBTyxFQUFFQyxVQUFVLEVBQUVDLElBQUksRUFBRTtFQUM1REYsT0FBTyxDQUFDRyxLQUFLLEdBQUdILE9BQU8sQ0FBQ0csS0FBSyxJQUFJLEVBQUU7RUFDbkMsSUFBSUYsVUFBVSxLQUFLLFVBQVUsRUFBRTtJQUM3QixJQUFJQyxJQUFJLENBQUNFLFFBQVEsRUFBRTtNQUNqQkosT0FBTyxDQUFDRyxLQUFLLEdBQUdFLEtBQUssQ0FBQ0MsSUFBSSxDQUFDLElBQUlDLEdBQUcsQ0FBQyxDQUFDLEdBQUdQLE9BQU8sQ0FBQ0csS0FBSyxFQUFFRCxJQUFJLENBQUNDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDckUsQ0FBQyxNQUFNO01BQ0xILE9BQU8sQ0FBQ0csS0FBSyxHQUFHSCxPQUFPLENBQUNHLEtBQUssQ0FBQ0ssTUFBTSxDQUFDQyxDQUFDLElBQUlBLENBQUMsS0FBS1AsSUFBSSxDQUFDQyxLQUFLLENBQUM7SUFDN0Q7RUFDRjtFQUVBLElBQUlGLFVBQVUsS0FBSyxPQUFPLEVBQUU7SUFDMUIsSUFBSUMsSUFBSSxDQUFDRSxRQUFRLEVBQUU7TUFDakJKLE9BQU8sQ0FBQ0csS0FBSyxHQUFHLENBQUNELElBQUksQ0FBQ0MsS0FBSyxDQUFDO0lBQzlCLENBQUMsTUFBTTtNQUNMSCxPQUFPLENBQUNHLEtBQUssR0FBRyxFQUFFO0lBQ3BCO0VBQ0Y7O0VBRUE7RUFDQUgsT0FBTyxDQUFDVSxRQUFRLEdBQUdSLElBQUksQ0FBQ1EsUUFBUSxDQUFDLENBQUM7QUFDcEM7QUFFTyxTQUFTQyxxQkFBcUJBLENBQUNYLE9BQU8sRUFBRVksUUFBUSxFQUFFO0VBQ3ZEWixPQUFPLENBQUNhLGNBQWMsR0FBR2IsT0FBTyxDQUFDYSxjQUFjLElBQUlELFFBQVEsQ0FBQ0MsY0FBYyxDQUFDLENBQUM7RUFDNUViLE9BQU8sQ0FBQ2MsWUFBWSxHQUFHZCxPQUFPLENBQUNjLFlBQVksSUFBSUYsUUFBUSxDQUFDRSxZQUFZLENBQUMsQ0FBQzs7RUFFdEUsSUFBRyxDQUFDZCxPQUFPLENBQUNlLFFBQVEsSUFBSWYsT0FBTyxDQUFDYSxjQUFjLElBQUliLE9BQU8sQ0FBQ2MsWUFBWSxFQUFFO0lBQ3RFO0lBQ0FkLE9BQU8sQ0FBQ2UsUUFBUSxHQUFJZixPQUFPLENBQUNjLFlBQVksR0FBR2QsT0FBTyxDQUFDYSxjQUFlO0VBQ3BFO0FBQ0YiLCJpZ25vcmVMaXN0IjpbXX0=
37
+ //# sourceMappingURL=session-updater.js.map
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@pie-element/multiple-choice",
3
3
  "repository": "pie-framework/pie-elements",
4
- "version": "11.2.0-mui-update.1",
4
+ "version": "11.2.0-mui-update.2",
5
5
  "publishConfig": {
6
6
  "access": "public"
7
7
  },
@@ -11,10 +11,10 @@
11
11
  "@mui/icons-material": "^7.3.4",
12
12
  "@mui/material": "^7.3.4",
13
13
  "@pie-framework/pie-player-events": "^0.1.0",
14
- "@pie-lib/correct-answer-toggle": "2.28.0-mui-update.0",
15
- "@pie-lib/math-rendering": "3.29.0-mui-update.0",
16
- "@pie-lib/render-ui": "4.38.0-mui-update.0",
17
- "@pie-lib/translator": "2.27.0-mui-update.0",
14
+ "@pie-lib/correct-answer-toggle": "2.29.0-mui-update.0",
15
+ "@pie-lib/math-rendering": "3.30.0-mui-update.0",
16
+ "@pie-lib/render-ui": "4.39.0-mui-update.0",
17
+ "@pie-lib/translator": "2.28.0-mui-update.0",
18
18
  "classnames": "^2.2.5",
19
19
  "debug": "^4.1.1",
20
20
  "enzyme-to-json": "^3.3.3",
@@ -1,248 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _enzyme = require("enzyme");
5
- var _react = _interopRequireDefault(require("react"));
6
- var _main = require("../main");
7
- var _defaults = _interopRequireDefault(require("../defaults"));
8
- var _configUi = require("@pie-lib/config-ui");
9
- var _index = _interopRequireDefault(require("../index"));
10
- jest.mock('@pie-lib/config-ui', () => ({
11
- choiceUtils: {
12
- firstAvailableIndex: jest.fn(),
13
- normalizeChoices: jest.fn(model => model)
14
- },
15
- settings: {
16
- Panel: props => /*#__PURE__*/_react.default.createElement("div", props),
17
- toggle: jest.fn(),
18
- radio: jest.fn()
19
- }
20
- }));
21
- const model = extras => ({
22
- ..._defaults.default.model,
23
- prompt: 'Which of these northern European countries are EU members?',
24
- choiceMode: 'checkbox',
25
- choices: [{
26
- correct: true,
27
- value: 'sweden',
28
- label: 'Sweden',
29
- feedback: {
30
- type: 'none',
31
- value: ''
32
- }
33
- }, {
34
- value: 'iceland',
35
- label: 'Iceland',
36
- feedback: {
37
- type: 'none',
38
- value: ''
39
- }
40
- }, {
41
- value: 'norway',
42
- label: 'Norway',
43
- feedback: {
44
- type: 'none',
45
- value: ''
46
- }
47
- }, {
48
- correct: true,
49
- value: 'finland',
50
- label: 'Finland',
51
- feedback: {
52
- type: 'none',
53
- value: ''
54
- }
55
- }],
56
- partialScoring: false,
57
- configure: {},
58
- ...extras
59
- });
60
- describe('Main', () => {
61
- let w;
62
- let onModelChanged = jest.fn();
63
- let onConfigurationChanged = jest.fn();
64
- let initialModel = model();
65
- const wrapper = extras => {
66
- const defaults = {
67
- onModelChanged,
68
- onConfigurationChanged,
69
- classes: {},
70
- model: model()
71
- };
72
- const props = {
73
- ...defaults,
74
- ...extras
75
- };
76
- return (0, _enzyme.shallow)(/*#__PURE__*/_react.default.createElement(_main.Main, props));
77
- };
78
- describe('snapshot', () => {
79
- it('renders with choicePrefix="numbers"', () => {
80
- w = wrapper({
81
- model: model({
82
- choicePrefix: 'numbers'
83
- })
84
- });
85
- expect(w).toMatchSnapshot();
86
- });
87
- it('renders with choicePrefix="letters" as default', () => {
88
- w = wrapper();
89
- expect(w).toMatchSnapshot();
90
- });
91
- });
92
- describe('logic', () => {
93
- beforeEach(() => {
94
- w = wrapper();
95
- });
96
- describe('onRemoveChoice', () => {
97
- it('removes choice', () => {
98
- w.instance().onRemoveChoice(0);
99
- expect(onModelChanged).toBeCalledWith({
100
- ...initialModel,
101
- choices: initialModel.choices.slice(1)
102
- });
103
- });
104
- });
105
- describe('createDefaultModel', () => {
106
- it('sets choicesLayout: horizontal if verticalMode: false', () => {
107
- const m = _index.default.createDefaultModel(model({
108
- verticalMode: false,
109
- choicesLayout: undefined
110
- }));
111
- expect(m.choicesLayout).toEqual('horizontal');
112
- });
113
- it('sets choicesLayout: vertical if verticalMode: true', () => {
114
- const m = _index.default.createDefaultModel(model({
115
- verticalMode: true,
116
- choicesLayout: undefined
117
- }));
118
- expect(m.choicesLayout).toEqual('vertical');
119
- });
120
- it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', () => {
121
- const m = _index.default.createDefaultModel(model({
122
- verticalMode: true,
123
- choicesLayout: 'grid'
124
- }));
125
- expect(m.choicesLayout).toEqual('grid');
126
- });
127
- it('sets choicesLayout: vertical', () => {
128
- const m = _index.default.createDefaultModel(model());
129
- expect(m.choicesLayout).toEqual('vertical');
130
- });
131
- });
132
- describe('onAddChoice', () => {
133
- it('adds a choice', () => {
134
- w.instance().onAddChoice();
135
- expect(onModelChanged).toBeCalledWith({
136
- ...initialModel,
137
- choices: [...initialModel.choices, {
138
- label: '',
139
- value: _configUi.choiceUtils.firstAvailableIndex(initialModel.choices.map(c => c.value), 0),
140
- feedback: {
141
- type: 'none'
142
- }
143
- }]
144
- });
145
- });
146
- });
147
- describe('onChoiceChanged', () => {
148
- describe('checkbox', () => {
149
- it('changes choice (there are 2 true values)', () => {
150
- const newChoices = [...model().choices];
151
- let choice = {
152
- correct: true,
153
- value: 'iceland',
154
- label: 'Iceland',
155
- feedback: {
156
- type: 'none',
157
- value: ''
158
- }
159
- };
160
- w.instance().onChoiceChanged(1, choice);
161
- newChoices[1].correct = true;
162
- expect(onModelChanged).toBeCalledWith({
163
- ...initialModel,
164
- choices: newChoices
165
- });
166
- });
167
- });
168
- describe('radio', () => {
169
- it('changes choice (there is only one true value)', () => {
170
- let choice = {
171
- correct: true,
172
- value: 'iceland',
173
- label: 'Iceland',
174
- feedback: {
175
- type: 'none',
176
- value: ''
177
- }
178
- };
179
- const newModel = {
180
- ...initialModel,
181
- choiceMode: 'radio',
182
- choices: initialModel.choices.slice(0, 2)
183
- };
184
- w = wrapper({
185
- model: newModel
186
- });
187
- w.instance().onChoiceChanged(1, choice);
188
- expect(onModelChanged).toBeCalledWith({
189
- ...newModel,
190
- choices: [{
191
- correct: false,
192
- value: 'sweden',
193
- label: 'Sweden',
194
- feedback: {
195
- type: 'none',
196
- value: ''
197
- }
198
- }, {
199
- correct: true,
200
- value: 'iceland',
201
- label: 'Iceland',
202
- feedback: {
203
- type: 'none',
204
- value: ''
205
- }
206
- }]
207
- });
208
- });
209
- });
210
- });
211
- describe('onPromptChanged', () => {
212
- it('changes prompt', () => {
213
- w.instance().onPromptChanged('New Prompt');
214
- expect(onModelChanged).toBeCalledWith({
215
- ...initialModel,
216
- prompt: 'New Prompt'
217
- });
218
- });
219
- });
220
- describe('onTeacherInstructionsChanged', () => {
221
- it('changes teacher instructions', () => {
222
- w.instance().onTeacherInstructionsChanged('New Teacher Instructions');
223
- expect(onModelChanged).toBeCalledWith({
224
- ...initialModel,
225
- teacherInstructions: 'New Teacher Instructions'
226
- });
227
- });
228
- });
229
- describe('onModelChanged', () => {
230
- it('changes choice and makes incorrect all other choices', () => {
231
- w.instance().onModelChanged({
232
- ...initialModel,
233
- choiceMode: 'radio'
234
- }, 'choiceMode');
235
- const expectedChoices = model().choices;
236
- expectedChoices.forEach((eC, index) => {
237
- eC.correct = index === 0;
238
- });
239
- expect(onModelChanged).toBeCalledWith({
240
- ...initialModel,
241
- choiceMode: 'radio',
242
- choices: expectedChoices
243
- }, true);
244
- });
245
- });
246
- });
247
- });
248
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_enzyme","require","_react","_interopRequireDefault","_main","_defaults","_configUi","_index","jest","mock","choiceUtils","firstAvailableIndex","fn","normalizeChoices","model","settings","Panel","props","default","createElement","toggle","radio","extras","defaults","prompt","choiceMode","choices","correct","value","label","feedback","type","partialScoring","configure","describe","w","onModelChanged","onConfigurationChanged","initialModel","wrapper","classes","shallow","Main","it","choicePrefix","expect","toMatchSnapshot","beforeEach","instance","onRemoveChoice","toBeCalledWith","slice","m","MultipleChoice","createDefaultModel","verticalMode","choicesLayout","undefined","toEqual","onAddChoice","utils","map","c","newChoices","choice","onChoiceChanged","newModel","onPromptChanged","onTeacherInstructionsChanged","teacherInstructions","expectedChoices","forEach","eC","index"],"sources":["../../src/__tests__/root.test.jsx"],"sourcesContent":["import { shallow } from 'enzyme';\nimport React from 'react';\n\nimport { Main } from '../main';\nimport defaults from '../defaults';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport MultipleChoice from '../index';\n\njest.mock('@pie-lib/config-ui', () => ({\n  choiceUtils: {\n    firstAvailableIndex: jest.fn(),\n    normalizeChoices: jest.fn((model) => model),\n  },\n  settings: {\n    Panel: (props) => <div {...props} />,\n    toggle: jest.fn(),\n    radio: jest.fn(),\n  },\n}));\n\nconst model = (extras) => ({\n  ...defaults.model,\n  prompt: 'Which of these northern European countries are EU members?',\n  choiceMode: 'checkbox',\n  choices: [\n    {\n      correct: true,\n      value: 'sweden',\n      label: 'Sweden',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'iceland',\n      label: 'Iceland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'norway',\n      label: 'Norway',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      correct: true,\n      value: 'finland',\n      label: 'Finland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n  ],\n  partialScoring: false,\n  configure: {},\n  ...extras,\n});\n\ndescribe('Main', () => {\n  let w;\n  let onModelChanged = jest.fn();\n  let onConfigurationChanged = jest.fn();\n  let initialModel = model();\n\n  const wrapper = (extras) => {\n    const defaults = {\n      onModelChanged,\n      onConfigurationChanged,\n      classes: {},\n      model: model(),\n    };\n    const props = { ...defaults, ...extras };\n\n    return shallow(<Main {...props} />);\n  };\n\n  describe('snapshot', () => {\n    it('renders with choicePrefix=\"numbers\"', () => {\n      w = wrapper({ model: model({ choicePrefix: 'numbers' }) });\n      expect(w).toMatchSnapshot();\n    });\n\n    it('renders with choicePrefix=\"letters\" as default', () => {\n      w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    beforeEach(() => {\n      w = wrapper();\n    });\n    describe('onRemoveChoice', () => {\n      it('removes choice', () => {\n        w.instance().onRemoveChoice(0);\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: initialModel.choices.slice(1),\n        });\n      });\n    });\n\n    describe('createDefaultModel', () => {\n      it('sets choicesLayout: horizontal if verticalMode: false', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: false, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('horizontal');\n      });\n\n      it('sets choicesLayout: vertical if verticalMode: true', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n\n      it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: 'grid' }));\n\n        expect(m.choicesLayout).toEqual('grid');\n      });\n\n      it('sets choicesLayout: vertical', () => {\n        const m = MultipleChoice.createDefaultModel(model());\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n    });\n\n    describe('onAddChoice', () => {\n      it('adds a choice', () => {\n        w.instance().onAddChoice();\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: [\n            ...initialModel.choices,\n            {\n              label: '',\n              value: utils.firstAvailableIndex(\n                initialModel.choices.map((c) => c.value),\n                0,\n              ),\n              feedback: {\n                type: 'none',\n              },\n            },\n          ],\n        });\n      });\n    });\n\n    describe('onChoiceChanged', () => {\n      describe('checkbox', () => {\n        it('changes choice (there are 2 true values)', () => {\n          const newChoices = [...model().choices];\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          w.instance().onChoiceChanged(1, choice);\n\n          newChoices[1].correct = true;\n\n          expect(onModelChanged).toBeCalledWith({\n            ...initialModel,\n            choices: newChoices,\n          });\n        });\n      });\n\n      describe('radio', () => {\n        it('changes choice (there is only one true value)', () => {\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          const newModel = { ...initialModel, choiceMode: 'radio', choices: initialModel.choices.slice(0, 2) };\n          w = wrapper({ model: newModel });\n\n          w.instance().onChoiceChanged(1, choice);\n\n          expect(onModelChanged).toBeCalledWith({\n            ...newModel,\n            choices: [\n              {\n                correct: false,\n                value: 'sweden',\n                label: 'Sweden',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n              {\n                correct: true,\n                value: 'iceland',\n                label: 'Iceland',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n            ],\n          });\n        });\n      });\n    });\n\n    describe('onPromptChanged', () => {\n      it('changes prompt', () => {\n        w.instance().onPromptChanged('New Prompt');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          prompt: 'New Prompt',\n        });\n      });\n    });\n\n    describe('onTeacherInstructionsChanged', () => {\n      it('changes teacher instructions', () => {\n        w.instance().onTeacherInstructionsChanged('New Teacher Instructions');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          teacherInstructions: 'New Teacher Instructions',\n        });\n      });\n    });\n\n    describe('onModelChanged', () => {\n      it('changes choice and makes incorrect all other choices', () => {\n        w.instance().onModelChanged(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n          },\n          'choiceMode',\n        );\n\n        const expectedChoices = model().choices;\n\n        expectedChoices.forEach((eC, index) => {\n          eC.correct = index === 0;\n        });\n\n        expect(onModelChanged).toBeCalledWith(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n            choices: expectedChoices,\n          },\n          true,\n        );\n      });\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}