@cuemath/leap 3.5.46 → 3.5.47-gg10

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 (182) hide show
  1. package/dist/assets/line-icons/icons/bulb.js +10 -10
  2. package/dist/assets/line-icons/icons/bulb.js.map +1 -1
  3. package/dist/assets/line-icons/icons/chevron-up.js +28 -0
  4. package/dist/assets/line-icons/icons/chevron-up.js.map +1 -0
  5. package/dist/assets/line-icons/icons/close.js +28 -0
  6. package/dist/assets/line-icons/icons/close.js.map +1 -0
  7. package/dist/assets/line-icons/icons/cursor2.js +24 -0
  8. package/dist/assets/line-icons/icons/cursor2.js.map +1 -0
  9. package/dist/assets/line-icons/icons/hand.js.map +1 -1
  10. package/dist/assets/line-icons/icons/hints.js +25 -0
  11. package/dist/assets/line-icons/icons/hints.js.map +1 -0
  12. package/dist/assets/line-icons/icons/question-feedback.js +30 -0
  13. package/dist/assets/line-icons/icons/question-feedback.js.map +1 -0
  14. package/dist/assets/line-icons/icons/scribble.js +13 -36
  15. package/dist/assets/line-icons/icons/scribble.js.map +1 -1
  16. package/dist/assets/line-icons/icons/sticker.js +9 -9
  17. package/dist/assets/line-icons/icons/sticker.js.map +1 -1
  18. package/dist/assets/line-icons/icons/teaching-tools.js +40 -0
  19. package/dist/assets/line-icons/icons/teaching-tools.js.map +1 -0
  20. package/dist/assets/line-icons/icons/tval-question.js +32 -0
  21. package/dist/assets/line-icons/icons/tval-question.js.map +1 -0
  22. package/dist/features/circle-games/hooks/use-circle-sounds/constants.js +4 -7
  23. package/dist/features/circle-games/hooks/use-circle-sounds/constants.js.map +1 -1
  24. package/dist/features/circle-games/hooks/use-circle-sounds/helper.js +19 -0
  25. package/dist/features/circle-games/hooks/use-circle-sounds/helper.js.map +1 -0
  26. package/dist/features/circle-games/hooks/use-circle-sounds/use-circle-sounds.js +110 -51
  27. package/dist/features/circle-games/hooks/use-circle-sounds/use-circle-sounds.js.map +1 -1
  28. package/dist/features/cue-canvas/sidebar/puzzles/api/get-puzzles.js.map +1 -1
  29. package/dist/features/hooks/use-audio-player.js +54 -0
  30. package/dist/features/hooks/use-audio-player.js.map +1 -0
  31. package/dist/features/journey/hooks/use-home-page-journey/home-page-homeworks-mock.js +6 -6
  32. package/dist/features/journey/hooks/use-home-page-journey/home-page-homeworks-mock.js.map +1 -1
  33. package/dist/features/journey/hooks/use-home-page-journey/recent-chapters-mock.js +2 -2
  34. package/dist/features/journey/hooks/use-home-page-journey/recent-chapters-mock.js.map +1 -1
  35. package/dist/features/journey/mocks/chapter-page-journey-mock-data.js +64 -29
  36. package/dist/features/journey/mocks/chapter-page-journey-mock-data.js.map +1 -1
  37. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/test-preview/test-preview.js +9 -9
  38. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/test-preview/test-preview.js.map +1 -1
  39. package/dist/features/puzzles/app/puzzle-app-view.js +40 -40
  40. package/dist/features/puzzles/app/puzzle-app-view.js.map +1 -1
  41. package/dist/features/ui/tabs/tabs.js +15 -15
  42. package/dist/features/ui/tabs/tabs.js.map +1 -1
  43. package/dist/features/worksheet/learnosity-preloader/learnosity-preloader.js +0 -1
  44. package/dist/features/worksheet/learnosity-preloader/learnosity-preloader.js.map +1 -1
  45. package/dist/features/worksheet/worksheet/constants.js +12 -13
  46. package/dist/features/worksheet/worksheet/constants.js.map +1 -1
  47. package/dist/features/worksheet/worksheet/hooks/use-create-imperative-handle.js +120 -101
  48. package/dist/features/worksheet/worksheet/hooks/use-create-imperative-handle.js.map +1 -1
  49. package/dist/features/worksheet/worksheet/hooks/use-worksheet-store.js +1 -1
  50. package/dist/features/worksheet/worksheet/hooks/use-worksheet-store.js.map +1 -1
  51. package/dist/features/worksheet/worksheet/worksheet-action-bar/worksheet-action-bar.js +40 -109
  52. package/dist/features/worksheet/worksheet/worksheet-action-bar/worksheet-action-bar.js.map +1 -1
  53. package/dist/features/worksheet/worksheet/worksheet-behavior-helper.js +49 -46
  54. package/dist/features/worksheet/worksheet/worksheet-behavior-helper.js.map +1 -1
  55. package/dist/features/worksheet/worksheet/worksheet-calculator/worksheet-calculator.js +4 -4
  56. package/dist/features/worksheet/worksheet/worksheet-calculator/worksheet-calculator.js.map +1 -1
  57. package/dist/features/worksheet/worksheet/worksheet-helpers.js +127 -274
  58. package/dist/features/worksheet/worksheet/worksheet-helpers.js.map +1 -1
  59. package/dist/features/worksheet/worksheet/worksheet-navigation/worksheet-navigation.js +25 -25
  60. package/dist/features/worksheet/worksheet/worksheet-navigation/worksheet-navigation.js.map +1 -1
  61. package/dist/features/worksheet/worksheet/worksheet-provider.js +1 -1
  62. package/dist/features/worksheet/worksheet/worksheet-provider.js.map +1 -1
  63. package/dist/features/worksheet/worksheet/worksheet-question/subjective-styled.js +17 -22
  64. package/dist/features/worksheet/worksheet/worksheet-question/subjective-styled.js.map +1 -1
  65. package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question-styled.js +25 -29
  66. package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question-styled.js.map +1 -1
  67. package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question.js +319 -259
  68. package/dist/features/worksheet/worksheet/worksheet-question/worksheet-question.js.map +1 -1
  69. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-allow-retry-button-click.js +15 -0
  70. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-allow-retry-button-click.js.map +1 -0
  71. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-back-button-click.js +18 -0
  72. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-back-button-click.js.map +1 -0
  73. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-check-button-click.js +21 -0
  74. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-check-button-click.js.map +1 -0
  75. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-next-button-click.js +19 -0
  76. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-next-button-click.js.map +1 -0
  77. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-ready-button-click.js +34 -0
  78. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-ready-button-click.js.map +1 -0
  79. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-response-change.js +38 -0
  80. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-response-change.js.map +1 -0
  81. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-retry-button-click.js +16 -0
  82. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-retry-button-click.js.map +1 -0
  83. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-skip-button-click.js +35 -0
  84. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-skip-button-click.js.map +1 -0
  85. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-skip-section-button-click.js +12 -0
  86. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-skip-section-button-click.js.map +1 -0
  87. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-start-button-click.js +44 -0
  88. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-start-button-click.js.map +1 -0
  89. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-submit-quiz.js +51 -0
  90. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-submit-quiz.js.map +1 -0
  91. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-validate-button-click.js +19 -0
  92. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-handle-validate-button-click.js.map +1 -0
  93. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-play-validation-audio.js +23 -0
  94. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-play-validation-audio.js.map +1 -0
  95. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-validate-question.js +36 -0
  96. package/dist/features/worksheet/worksheet/worksheet-questions-controller/hooks/use-validate-question.js.map +1 -0
  97. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller-lesson-v3.js +184 -0
  98. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller-lesson-v3.js.map +1 -0
  99. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller-lesson-v3_1.js +258 -0
  100. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller-lesson-v3_1.js.map +1 -0
  101. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller.js +180 -0
  102. package/dist/features/worksheet/worksheet/worksheet-questions-controller/student/controller.js.map +1 -0
  103. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller-lesson-v3.js +77 -0
  104. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller-lesson-v3.js.map +1 -0
  105. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller-lesson-v3_1.js +103 -0
  106. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller-lesson-v3_1.js.map +1 -0
  107. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller.js +21 -0
  108. package/dist/features/worksheet/worksheet/worksheet-questions-controller/teacher/controller.js.map +1 -0
  109. package/dist/features/worksheet/worksheet/worksheet-questions-controller/worksheet-questions-controller-view.js +22 -0
  110. package/dist/features/worksheet/worksheet/worksheet-questions-controller/worksheet-questions-controller-view.js.map +1 -0
  111. package/dist/features/worksheet/worksheet/worksheet-questions-controller/worksheet-questions-controller.js +20 -345
  112. package/dist/features/worksheet/worksheet/worksheet-questions-controller/worksheet-questions-controller.js.map +1 -1
  113. package/dist/features/worksheet/worksheet/worksheet-questions-tools/questions-toolbar/questions-toolbar-styled.js +49 -0
  114. package/dist/features/worksheet/worksheet/worksheet-questions-tools/questions-toolbar/questions-toolbar-styled.js.map +1 -0
  115. package/dist/features/worksheet/worksheet/worksheet-questions-tools/questions-toolbar/questions-toolbar.js +184 -0
  116. package/dist/features/worksheet/worksheet/worksheet-questions-tools/questions-toolbar/questions-toolbar.js.map +1 -0
  117. package/dist/features/worksheet/worksheet/worksheet-questions-tools/scribble-switch.js +65 -0
  118. package/dist/features/worksheet/worksheet/worksheet-questions-tools/scribble-switch.js.map +1 -0
  119. package/dist/features/worksheet/worksheet/worksheet-questions-tools/worksheet-questions-styled.js +9 -0
  120. package/dist/features/worksheet/worksheet/worksheet-questions-tools/worksheet-questions-styled.js.map +1 -0
  121. package/dist/features/worksheet/worksheet/worksheet-questions-tools/worksheet-questions-tools.js +38 -0
  122. package/dist/features/worksheet/worksheet/worksheet-questions-tools/worksheet-questions-tools.js.map +1 -0
  123. package/dist/features/worksheet/worksheet/worksheet-sidebar/navigator.js +33 -20
  124. package/dist/features/worksheet/worksheet/worksheet-sidebar/navigator.js.map +1 -1
  125. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-computed-properties.js +73 -0
  126. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-computed-properties.js.map +1 -0
  127. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-derived-blocker.js +20 -0
  128. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-derived-blocker.js.map +1 -0
  129. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-last-attemptable-question-index.js +69 -0
  130. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-last-attemptable-question-index.js.map +1 -0
  131. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-last-unlocked-question-index.js +18 -0
  132. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-last-unlocked-question-index.js.map +1 -0
  133. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-merged-response-state.js +19 -0
  134. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-merged-response-state.js.map +1 -0
  135. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-questions-from-items.js +138 -0
  136. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-questions-from-items.js.map +1 -0
  137. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-renderable-questions.js +9 -0
  138. package/dist/features/worksheet/worksheet/worksheet-store/helpers/get-renderable-questions.js.map +1 -0
  139. package/dist/features/worksheet/worksheet/worksheet-store/worksheet-store.js +230 -0
  140. package/dist/features/worksheet/worksheet/worksheet-store/worksheet-store.js.map +1 -0
  141. package/dist/features/worksheet/worksheet/worksheet-styled.js +29 -83
  142. package/dist/features/worksheet/worksheet/worksheet-styled.js.map +1 -1
  143. package/dist/features/worksheet/worksheet/worksheet-summary-controller/worksheet-summary-controller.js +45 -24
  144. package/dist/features/worksheet/worksheet/worksheet-summary-controller/worksheet-summary-controller.js.map +1 -1
  145. package/dist/features/worksheet/worksheet/worksheet-teaching-tools/worksheet-teaching-tools-styled.js +19 -0
  146. package/dist/features/worksheet/worksheet/worksheet-teaching-tools/worksheet-teaching-tools-styled.js.map +1 -0
  147. package/dist/features/worksheet/worksheet/worksheet-teaching-tools/worksheet-teaching-tools.js +66 -0
  148. package/dist/features/worksheet/worksheet/worksheet-teaching-tools/worksheet-teaching-tools.js.map +1 -0
  149. package/dist/features/worksheet/worksheet/worksheet-types.js +3 -2
  150. package/dist/features/worksheet/worksheet/worksheet-types.js.map +1 -1
  151. package/dist/features/worksheet/worksheet/worksheet-view.js +89 -100
  152. package/dist/features/worksheet/worksheet/worksheet-view.js.map +1 -1
  153. package/dist/features/worksheet/worksheet/worksheet.js +126 -117
  154. package/dist/features/worksheet/worksheet/worksheet.js.map +1 -1
  155. package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js +29 -29
  156. package/dist/features/worksheet/worksheet-preview/dynamic-worksheet-preview/dynamic-worksheet-preview.js.map +1 -1
  157. package/dist/features/worksheet/worksheet-preview/hooks/use-worksheet-layout.js +16 -16
  158. package/dist/features/worksheet/worksheet-preview/hooks/use-worksheet-layout.js.map +1 -1
  159. package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js +24 -24
  160. package/dist/features/worksheet/worksheet-preview/worksheet-preview-view.js.map +1 -1
  161. package/dist/index.d.ts +67 -28
  162. package/dist/index.js +760 -745
  163. package/dist/index.js.map +1 -1
  164. package/dist/types/models/worksheet.js +2 -1
  165. package/dist/types/models/worksheet.js.map +1 -1
  166. package/package.json +2 -2
  167. package/dist/features/hooks/use-audio-player/use-audio-player.js +0 -164
  168. package/dist/features/hooks/use-audio-player/use-audio-player.js.map +0 -1
  169. package/dist/features/worksheet/worksheet/question-tips.js +0 -100
  170. package/dist/features/worksheet/worksheet/question-tips.js.map +0 -1
  171. package/dist/features/worksheet/worksheet/worksheet-questions-controller/scribble-switch.js +0 -53
  172. package/dist/features/worksheet/worksheet/worksheet-questions-controller/scribble-switch.js.map +0 -1
  173. package/dist/features/worksheet/worksheet/worksheet-questions-controller/use-handler-callbacks.js +0 -195
  174. package/dist/features/worksheet/worksheet/worksheet-questions-controller/use-handler-callbacks.js.map +0 -1
  175. package/dist/features/worksheet/worksheet/worksheet-sidebar/question-guide.js +0 -112
  176. package/dist/features/worksheet/worksheet/worksheet-sidebar/question-guide.js.map +0 -1
  177. package/dist/features/worksheet/worksheet/worksheet-sidebar/sidebar.js +0 -61
  178. package/dist/features/worksheet/worksheet/worksheet-sidebar/sidebar.js.map +0 -1
  179. package/dist/features/worksheet/worksheet/worksheet-sidebar/worksheet-sidebar-styled.js +0 -91
  180. package/dist/features/worksheet/worksheet/worksheet-sidebar/worksheet-sidebar-styled.js.map +0 -1
  181. package/dist/features/worksheet/worksheet/worksheet-store.js +0 -289
  182. package/dist/features/worksheet/worksheet/worksheet-store.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"use-handler-callbacks.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-questions-controller/use-handler-callbacks.ts"],"sourcesContent":["import { useCallback, type Dispatch, type SetStateAction } from 'react';\nimport { useErrorBoundary } from 'react-error-boundary';\n\nimport { useAudioPlayer } from '../../../hooks/use-audio-player/use-audio-player';\nimport { useAutoPlayPermission } from '../../../hooks/use-auto-play-permission/use-auto-play-permission';\nimport EVENTS from '../../constants/events';\nimport { SYSTEM_VALIDATION_AUDIO_LIST } from '../constants';\nimport { useWorksheetStore } from '../hooks/use-worksheet-store';\nimport {\n checkIsClozeFormulaResponseInvalid,\n getQuestionMetadata,\n isOkayTypeQuestion,\n} from '../worksheet-helpers';\nimport type { IWorksheetResponse } from '../worksheet-types';\nimport type { IWorksheetQuestionsControllerProps } from './worksheet-questions-controller-types';\n\ninterface IUseHandlerCallbacks {\n (\n options: Pick<IWorksheetQuestionsControllerProps, 'question' | 'getTimeSpentOnQuestion'> & {\n setSkipped: Dispatch<SetStateAction<boolean>>;\n },\n ): {\n handleResponseChange: () => void;\n handleHelpButtonClick?: () => void;\n handleHintButtonClick: () => void;\n handleBackButtonClick?: () => void;\n handleNextButtonClick: () => void;\n handleRetryButtonClick: () => void;\n handleCheckButtonClick: () => void;\n handleValidateButtonClick: () => void;\n handleStartButtonClick: () => void;\n handleReadyButtonClick: () => void;\n handleSkipSectionButtonClick: () => void;\n handleSkipButtonClick: () => void;\n };\n}\n\nconst useHandlerCallbacks: IUseHandlerCallbacks = options => {\n const {\n behavior,\n layout,\n questions,\n setResponses,\n questionIndex,\n updateResponse,\n onResponseChange,\n showSummary,\n changeQuestion,\n setBlocker,\n onTeacherValidation,\n learnosity,\n loggerRef,\n onHelp,\n } = useWorksheetStore(store => ({\n behavior: store.behavior,\n layout: store.layout,\n questions: store.questions,\n questionIndex: store.activeQuestionIndex,\n setResponses: store.setResponses,\n updateResponse: store.updateResponse,\n onResponseChange: store.onResponseChange,\n showSummary: store.showSummary,\n changeQuestion: store.changeQuestion,\n setBlocker: store.setBlocker,\n onTeacherValidation: store.onTeacherValidation,\n learnosity: store.learnosity,\n loggerRef: store.loggerRef,\n onHelp: store.onHelp,\n }));\n const { question, getTimeSpentOnQuestion, setSkipped } = options;\n const { questionsScrollable } = layout;\n const { response_id, item_type, question_number, item_number, total_questions } = question;\n const isExitTicket = item_type === 'exit-ticket';\n const { validation, teacherValidationEnabled } = behavior;\n const { canAutoPlayAudio } = useAutoPlayPermission();\n\n // Convert array to object config for new useAudioPlayer\n const audioConfig = SYSTEM_VALIDATION_AUDIO_LIST.reduce(\n (acc, { name, url }) => {\n acc[name] = url;\n\n return acc;\n },\n {} as Record<string, string>,\n );\n\n const audioManager = useAudioPlayer(audioConfig, canAutoPlayAudio);\n const { showBoundary } = useErrorBoundary();\n\n const playAudio = useCallback(() => {\n const questionInstance = learnosity.question(response_id);\n\n if (questionInstance && validation && !isOkayTypeQuestion(questionInstance.getQuestion())) {\n questionInstance.getScore(sc => {\n const { max_score: maxScore, score: currentScore } = sc || {};\n\n if (maxScore) {\n if (maxScore === currentScore) {\n audioManager.play('CORRECT');\n } else {\n audioManager.play('INCORRECT');\n }\n }\n });\n }\n }, [learnosity, audioManager, response_id, validation]);\n\n const validateQuestion = useCallback(\n (questionId: string, rating?: number) => {\n setResponses(prevResponses => {\n const newResponse = {\n ...getQuestionMetadata(questions, questionId),\n ...prevResponses[questionId],\n validatedByTeacher: true,\n rating,\n };\n\n onResponseChange?.({\n responseId: questionId,\n response: newResponse,\n question: questions.find(q => q.response_id === questionId)!,\n isNewAttempt: false,\n });\n\n return {\n ...prevResponses,\n [questionId]: newResponse,\n };\n });\n },\n [onResponseChange, questions, setResponses],\n );\n\n const handleHelpButtonClick = useCallback(() => {\n if (onHelp && question) {\n onHelp({\n questionId: response_id,\n questionNumber: `${item_number + 1}${\n total_questions > 1 ? String.fromCharCode('a'.charCodeAt(0) + question_number) : ''\n }`,\n });\n }\n }, [item_number, onHelp, question, question_number, response_id, total_questions]);\n\n const handleHintButtonClick = useCallback(() => {\n loggerRef.current(EVENTS.WORKSHEET_V3_HINT_SEEN);\n setResponses(prevResponses => {\n const newResponse = {\n ...getQuestionMetadata(questions, response_id),\n ...prevResponses[response_id],\n hintsUsed: (prevResponses[response_id]?.hintsUsed ?? 0) + 1,\n };\n\n onResponseChange?.({\n responseId: response_id,\n response: newResponse,\n question: questions.find(q => q.response_id === response_id)!,\n isNewAttempt: false,\n });\n\n return {\n ...prevResponses,\n [response_id]: newResponse,\n };\n });\n }, [loggerRef, onResponseChange, questions, response_id, setResponses]);\n\n const handleBackButtonClick = useCallback(() => {\n const questionId = questions[questionIndex - 1]?.response_id;\n\n if (questionId) {\n changeQuestion(questionId);\n }\n }, [changeQuestion, questionIndex, questions]);\n\n const handleNextButtonClick = useCallback(() => {\n const questionId = questions[questionIndex + 1]?.response_id;\n\n if (questionId) {\n changeQuestion(questionId);\n } else {\n showSummary();\n }\n }, [changeQuestion, questionIndex, questions, showSummary]);\n\n const handleSkipButtonClick = useCallback(() => {\n setResponses(prevResponses => {\n const newResponse = {\n ...getQuestionMetadata(questions, response_id),\n ...prevResponses[response_id],\n skipped: true,\n };\n\n onResponseChange?.({\n responseId: response_id,\n response: newResponse,\n question: questions.find(q => q.response_id === response_id)!,\n isNewAttempt: false,\n });\n\n return {\n ...prevResponses,\n [response_id]: newResponse,\n };\n });\n setSkipped(true);\n }, [onResponseChange, questions, response_id, setResponses, setSkipped]);\n\n const handleResponseChange = useCallback(\n (answerChecked?: boolean) => {\n const questionInstance = learnosity.question(response_id);\n\n if (questionInstance) {\n const lquestion = questionInstance.getQuestion();\n const questionResponse = questionInstance.getResponse();\n const shouldCheckAbuse =\n lquestion.type === 'clozeformula' && questionResponse && questionResponse?.value;\n const isInputExceedingMaxLength = shouldCheckAbuse\n ? checkIsClozeFormulaResponseInvalid(questionResponse)\n : false;\n\n if (isInputExceedingMaxLength) {\n showBoundary(new Error('CLOZE_FORMULA_RESPONSE_EXCEEDS_MAX_LENGTH'));\n }\n\n questionInstance.getScore(score => {\n updateResponse({\n responseId: response_id,\n response: questionResponse,\n score:\n isOkayTypeQuestion(lquestion) || !score\n ? {\n max_score: 0,\n score: 0,\n unscored: !score, // score will be null for unscored questions\n }\n : { ...score, score: score.score ?? 0 },\n answerChecked,\n timeSpent: getTimeSpentOnQuestion(response_id),\n });\n });\n }\n },\n [getTimeSpentOnQuestion, learnosity, response_id, showBoundary, updateResponse],\n );\n\n const handleRetryButtonClick = useCallback(() => {\n const questionInstance = learnosity.question(response_id);\n\n if (questionInstance) {\n questionInstance.enable();\n questionInstance.resetValidationUI();\n handleResponseChange();\n }\n }, [handleResponseChange, learnosity, response_id]);\n\n const handleValidate = useCallback(() => {\n playAudio();\n handleResponseChange(true);\n }, [handleResponseChange, playAudio]);\n\n const handleCheckButtonClick = useCallback(() => {\n const questionInstance = learnosity.question(response_id);\n\n if (questionInstance) {\n questionInstance.disable();\n questionInstance.validate(\n {\n feedbackAttempts: true,\n },\n handleValidate,\n );\n }\n }, [handleValidate, learnosity, response_id]);\n\n const handleValidateButtonClick = useCallback(() => {\n if (isExitTicket) {\n setBlocker('exit-ticket-review');\n } else {\n onTeacherValidation?.(response_id);\n }\n }, [isExitTicket, onTeacherValidation, response_id, setBlocker]);\n\n const handleStartButtonClick = useCallback(() => {\n validateQuestion(response_id);\n }, [response_id, validateQuestion]);\n\n const handleReadyButtonClick = useCallback(() => {\n setResponses(prevResponses => {\n const newResponse: IWorksheetResponse = {\n ...getQuestionMetadata(questions, response_id),\n ...prevResponses[response_id],\n submittedByStudent: true,\n };\n\n onResponseChange?.({\n responseId: response_id,\n response: newResponse,\n question: questions.find(q => q.response_id === response_id)!,\n isNewAttempt: false,\n });\n\n return {\n ...prevResponses,\n [response_id]: newResponse,\n };\n });\n setBlocker('exit-ticket-student-submission');\n }, [onResponseChange, questions, response_id, setBlocker, setResponses]);\n\n const handleSkipSectionButtonClick = useCallback(() => {\n setBlocker('optional-items-skip');\n }, [setBlocker]);\n\n return {\n handleResponseChange,\n handleHelpButtonClick: onHelp ? handleHelpButtonClick : undefined,\n handleHintButtonClick,\n handleBackButtonClick:\n !questionsScrollable && !teacherValidationEnabled ? handleBackButtonClick : undefined,\n handleNextButtonClick,\n handleRetryButtonClick,\n handleCheckButtonClick,\n handleValidateButtonClick,\n handleStartButtonClick,\n handleReadyButtonClick,\n handleSkipSectionButtonClick,\n handleSkipButtonClick,\n };\n};\n\nexport default useHandlerCallbacks;\n"],"names":["useHandlerCallbacks","options","behavior","layout","questions","setResponses","questionIndex","updateResponse","onResponseChange","showSummary","changeQuestion","setBlocker","onTeacherValidation","learnosity","loggerRef","onHelp","useWorksheetStore","store","question","getTimeSpentOnQuestion","setSkipped","questionsScrollable","response_id","item_type","question_number","item_number","total_questions","isExitTicket","validation","teacherValidationEnabled","canAutoPlayAudio","useAutoPlayPermission","audioConfig","SYSTEM_VALIDATION_AUDIO_LIST","acc","name","url","audioManager","useAudioPlayer","showBoundary","useErrorBoundary","playAudio","useCallback","questionInstance","isOkayTypeQuestion","sc","maxScore","currentScore","validateQuestion","questionId","rating","prevResponses","newResponse","getQuestionMetadata","q","handleHelpButtonClick","handleHintButtonClick","EVENTS","_a","handleBackButtonClick","handleNextButtonClick","handleSkipButtonClick","handleResponseChange","answerChecked","lquestion","questionResponse","checkIsClozeFormulaResponseInvalid","score","handleRetryButtonClick","handleValidate","handleCheckButtonClick","handleValidateButtonClick","handleStartButtonClick","handleReadyButtonClick","handleSkipSectionButtonClick"],"mappings":"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"}
@@ -1,112 +0,0 @@
1
- import { jsxs as a, jsx as e } from "react/jsx-runtime";
2
- import { memo as w, useState as H, useCallback as u, useMemo as G, useRef as N, useEffect as y } from "react";
3
- import O from "../../../ui/arrow-tooltip/arrow-tooltip.js";
4
- import p from "../../../ui/buttons/clickable/clickable.js";
5
- import r from "../../../ui/layout/flex-view.js";
6
- import P from "../../../ui/separator/separator.js";
7
- import h from "../../../ui/text/text.js";
8
- import R from "../../constants/events.js";
9
- import { useWorksheetStore as V } from "../hooks/use-worksheet-store.js";
10
- import { GuideContainer as j, HintIcon as L, SolIcon as Q, Pointer as B, SectionContainer as M, Section as q, CloseIcon as K, Guide as U } from "./worksheet-sidebar-styled.js";
11
- const re = w(function({
12
- questionWidth: g,
13
- questions: k,
14
- learnosity: $,
15
- actionbarHeight: I
16
- }) {
17
- var C;
18
- const { activeQuestionIndex: _, loggerRef: l, plugins: m } = V((o) => ({
19
- activeQuestionIndex: o.activeQuestionIndex,
20
- loggerRef: o.loggerRef,
21
- plugins: o.plugins
22
- })), [t, c] = H(), [v, A] = H({
23
- top: 0,
24
- left: 0
25
- }), { top: S, left: b } = v, X = u(() => {
26
- c("HINT"), l.current(R.WORKSHEET_V3_HINT_SEEN);
27
- }, [l]), x = u(() => {
28
- c("SOL"), l.current(R.WORKSHEET_V3_SOLUTION_SEEN);
29
- }, [l]), W = u(() => {
30
- c(() => {
31
- });
32
- }, []), { hints: s, solution: d } = ((C = k[_]) == null ? void 0 : C.metadata) || {}, i = G(() => t === void 0 ? void 0 : t === "HINT" ? s : d, [t, s, d]), E = N(null), T = N(null), f = u((o) => {
33
- if (o.current) {
34
- const n = o.current.getBoundingClientRect();
35
- A({
36
- top: n.top + n.height / 2 - 8,
37
- left: n.right - 78
38
- // 52px (sidebar width) + 16px (gutter) + 10px
39
- });
40
- }
41
- }, []);
42
- return t && i && $ && $.renderMath("mathjax"), y(() => {
43
- t === "HINT" ? f(T) : t === "SOL" ? f(E) : i || c(void 0);
44
- }, [t, f, i]), /* @__PURE__ */ a(j, { $background: "WHITE", children: [
45
- (m == null ? void 0 : m.stickers) ?? null,
46
- /* @__PURE__ */ e(
47
- O,
48
- {
49
- renderAs: "primary",
50
- tooltipItem: /* @__PURE__ */ e(h, { $renderAs: "ab3", $color: "WHITE", children: "Hint" }),
51
- position: "left",
52
- tooltipXCoOrdinates: "40%",
53
- children: /* @__PURE__ */ e(p, { label: "hints", onClick: X, disabled: !s, children: /* @__PURE__ */ e(r, { $alignItems: "center", $justifyContent: "center", ref: T, children: /* @__PURE__ */ e(L, { width: 32, height: 32, $disabled: !s }) }) })
54
- }
55
- ),
56
- /* @__PURE__ */ e(r, { $gap: 8, $alignItems: "center", children: /* @__PURE__ */ e(P, { width: 24, height: 1, background: "GREY_2" }) }),
57
- /* @__PURE__ */ e(
58
- O,
59
- {
60
- renderAs: "primary",
61
- tooltipItem: /* @__PURE__ */ e(h, { $renderAs: "ab3", $color: "WHITE", children: "Solution" }),
62
- position: "left",
63
- tooltipXCoOrdinates: "25%",
64
- tooltipYCoOrdinates: "5%",
65
- children: /* @__PURE__ */ e(p, { label: "solution", onClick: x, disabled: !d, children: /* @__PURE__ */ e(r, { $alignItems: "center", $justifyContent: "center", ref: E, children: /* @__PURE__ */ e(Q, { width: 32, height: 32, $disabled: !d }) }) })
66
- }
67
- ),
68
- t && S && b && /* @__PURE__ */ e(B, { topValue: S, leftValue: b }),
69
- t && /* @__PURE__ */ e(
70
- M,
71
- {
72
- $background: "WHITE",
73
- $questionWidth: g,
74
- $actionbarHeight: I,
75
- $borderRadius: 10,
76
- children: /* @__PURE__ */ a(
77
- q,
78
- {
79
- $gutterX: 1,
80
- $gapX: 1,
81
- $questionWidth: g,
82
- $actionbarHeight: I,
83
- children: [
84
- /* @__PURE__ */ e(p, { label: "close", onClick: W, children: /* @__PURE__ */ e(K, {}) }),
85
- /* @__PURE__ */ e(r, { $gutterX: 0.5, children: /* @__PURE__ */ e(h, { $renderAs: "eyebrow2", $color: "ORANGE_5", $marginBottomX: 0.25, children: t === "HINT" ? "HINTS:" : "SOLUTION:" }) }),
86
- i && i.map((o, n) => /* @__PURE__ */ a(r, { $gutterX: 0.5, $gapX: 0.5, children: [
87
- i.length > 1 && /* @__PURE__ */ a(h, { $renderAs: "eyebrow2", $color: "ORANGE_5", $marginBottomX: 0.25, children: [
88
- t,
89
- " ",
90
- n + 1,
91
- ":"
92
- ] }),
93
- /* @__PURE__ */ e(
94
- U,
95
- {
96
- dangerouslySetInnerHTML: {
97
- __html: o
98
- }
99
- }
100
- )
101
- ] }, n.toString()))
102
- ]
103
- }
104
- )
105
- }
106
- )
107
- ] });
108
- });
109
- export {
110
- re as default
111
- };
112
- //# sourceMappingURL=question-guide.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"question-guide.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-sidebar/question-guide.tsx"],"sourcesContent":["import {\n type FC,\n memo,\n type RefObject,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\n\nimport ArrowTooltip from '../../../ui/arrow-tooltip/arrow-tooltip';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport EVENTS from '../../constants/events';\nimport { useWorksheetStore } from '../hooks/use-worksheet-store';\nimport type { ILearnosity, IWorksheetQuestion } from '../worksheet-types';\nimport {\n CloseIcon,\n Guide,\n GuideContainer,\n HintIcon,\n Pointer,\n Section,\n SectionContainer,\n SolIcon,\n} from './worksheet-sidebar-styled';\n\ntype TSections = 'HINT' | 'SOL';\n\ninterface IQuestionGuideProps {\n questionWidth: number;\n questions: IWorksheetQuestion[];\n learnosity: ILearnosity;\n actionbarHeight: number;\n}\n\nconst QuestionGuide: FC<IQuestionGuideProps> = memo(function QuestionGuide({\n questionWidth,\n questions,\n learnosity,\n actionbarHeight,\n}) {\n const { activeQuestionIndex, loggerRef, plugins } = useWorksheetStore(store => ({\n activeQuestionIndex: store.activeQuestionIndex,\n loggerRef: store.loggerRef,\n plugins: store.plugins,\n }));\n const [activeSection, setActiveSection] = useState<TSections | undefined>();\n const [pointerPosition, setPointerPosition] = useState({\n top: 0,\n left: 0,\n });\n const { top, left } = pointerPosition;\n\n const handleHintClick = useCallback(() => {\n setActiveSection('HINT');\n loggerRef.current(EVENTS.WORKSHEET_V3_HINT_SEEN);\n }, [loggerRef]);\n const handleSolClick = useCallback(() => {\n setActiveSection('SOL');\n loggerRef.current(EVENTS.WORKSHEET_V3_SOLUTION_SEEN);\n }, [loggerRef]);\n const handleClose = useCallback(() => {\n setActiveSection(() => undefined);\n }, []);\n\n const { hints, solution } = questions[activeQuestionIndex]?.metadata || {};\n\n const activeSectionData = useMemo(() => {\n return activeSection === undefined ? undefined : activeSection === 'HINT' ? hints : solution;\n }, [activeSection, hints, solution]);\n\n const sqlRef = useRef<HTMLDivElement>(null) as RefObject<HTMLDivElement>;\n const hintRef = useRef<HTMLDivElement>(null) as RefObject<HTMLDivElement>;\n\n const updatePointerPosition = useCallback((ref: RefObject<HTMLDivElement>) => {\n if (ref.current) {\n const rect = ref.current.getBoundingClientRect();\n\n setPointerPosition({\n top: rect.top + rect.height / 2 - 8,\n left: rect.right - 78, // 52px (sidebar width) + 16px (gutter) + 10px\n });\n }\n }, []);\n\n if (activeSection && activeSectionData && learnosity) {\n learnosity.renderMath('mathjax');\n }\n\n useEffect(() => {\n if (activeSection === 'HINT') {\n updatePointerPosition(hintRef);\n } else if (activeSection === 'SOL') {\n updatePointerPosition(sqlRef);\n } else if (!activeSectionData) {\n setActiveSection(undefined);\n }\n }, [activeSection, updatePointerPosition, activeSectionData]);\n\n return (\n <GuideContainer $background=\"WHITE\">\n {plugins?.stickers ?? null}\n <ArrowTooltip\n renderAs=\"primary\"\n tooltipItem={\n <Text $renderAs=\"ab3\" $color=\"WHITE\">\n Hint\n </Text>\n }\n position=\"left\"\n tooltipXCoOrdinates={'40%'}\n >\n <Clickable label=\"hints\" onClick={handleHintClick} disabled={!hints}>\n <FlexView $alignItems=\"center\" $justifyContent=\"center\" ref={hintRef}>\n <HintIcon width={32} height={32} $disabled={!hints} />\n </FlexView>\n </Clickable>\n </ArrowTooltip>\n <FlexView $gap={8} $alignItems=\"center\">\n <Separator width={24} height={1} background=\"GREY_2\" />\n </FlexView>\n <ArrowTooltip\n renderAs=\"primary\"\n tooltipItem={\n <Text $renderAs=\"ab3\" $color=\"WHITE\">\n Solution\n </Text>\n }\n position=\"left\"\n tooltipXCoOrdinates={'25%'}\n tooltipYCoOrdinates={'5%'}\n >\n <Clickable label=\"solution\" onClick={handleSolClick} disabled={!solution}>\n <FlexView $alignItems=\"center\" $justifyContent=\"center\" ref={sqlRef}>\n <SolIcon width={32} height={32} $disabled={!solution} />\n </FlexView>\n </Clickable>\n </ArrowTooltip>\n {activeSection && top && left && <Pointer topValue={top} leftValue={left} />}\n {activeSection && (\n <SectionContainer\n $background=\"WHITE\"\n $questionWidth={questionWidth}\n $actionbarHeight={actionbarHeight}\n $borderRadius={10}\n >\n <Section\n $gutterX={1}\n $gapX={1}\n $questionWidth={questionWidth}\n $actionbarHeight={actionbarHeight}\n >\n <Clickable label=\"close\" onClick={handleClose}>\n <CloseIcon />\n </Clickable>\n <FlexView $gutterX={0.5}>\n <Text $renderAs=\"eyebrow2\" $color=\"ORANGE_5\" $marginBottomX={0.25}>\n {activeSection === 'HINT' ? 'HINTS:' : 'SOLUTION:'}\n </Text>\n </FlexView>\n {activeSectionData &&\n activeSectionData.map((item, index) => (\n <FlexView $gutterX={0.5} $gapX={0.5} key={index.toString()}>\n {activeSectionData.length > 1 && (\n <Text $renderAs=\"eyebrow2\" $color=\"ORANGE_5\" $marginBottomX={0.25}>\n {activeSection} {index + 1}:\n </Text>\n )}\n <Guide\n dangerouslySetInnerHTML={{\n __html: item,\n }}\n />\n </FlexView>\n ))}\n </Section>\n </SectionContainer>\n )}\n </GuideContainer>\n );\n});\n\nexport default QuestionGuide;\n"],"names":["QuestionGuide","memo","questionWidth","questions","learnosity","actionbarHeight","activeQuestionIndex","loggerRef","plugins","useWorksheetStore","store","activeSection","setActiveSection","useState","pointerPosition","setPointerPosition","top","left","handleHintClick","useCallback","EVENTS","handleSolClick","handleClose","hints","solution","_a","activeSectionData","useMemo","sqlRef","useRef","hintRef","updatePointerPosition","ref","rect","useEffect","jsxs","GuideContainer","jsx","ArrowTooltip","Text","Clickable","FlexView","HintIcon","Separator","SolIcon","Pointer","SectionContainer","Section","CloseIcon","item","index","Guide"],"mappings":"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"}
@@ -1,61 +0,0 @@
1
- import { jsxs as a, jsx as i } from "react/jsx-runtime";
2
- import { memo as f, useCallback as g } from "react";
3
- import k from "../../../ui/layout/flex-view.js";
4
- import x from "../../../ui/separator/separator.js";
5
- import { SIDEBAR_WIDTH as s } from "../constants.js";
6
- import { useWorksheetStore as Q } from "../hooks/use-worksheet-store.js";
7
- import b from "./navigator.js";
8
- import W from "./question-guide.js";
9
- import { SideBarContainer as y, UnderlinedTextWrapper as $, UnderlinedText as T } from "./worksheet-sidebar-styled.js";
10
- const A = f(function() {
11
- const {
12
- activeQuestionIndex: d,
13
- learnosity: u,
14
- questionWidth: o,
15
- questions: n,
16
- userType: c,
17
- height: h,
18
- actionbarHeight: m,
19
- openQuestionFeedbackModal: t
20
- } = Q((e) => ({
21
- activeQuestionIndex: e.activeQuestionIndex,
22
- learnosity: e.learnosity,
23
- questionWidth: e.maxQuestionWidth,
24
- questions: e.questions,
25
- userType: e.userType,
26
- height: e.layout.minQuestionHeight,
27
- actionbarHeight: e.actionbarHeight,
28
- openQuestionFeedbackModal: e.openQuestionFeedbackModal
29
- })), l = n[d], { item_reference: r } = l ?? {}, p = g(() => {
30
- t && t(r || "");
31
- }, [r, t]);
32
- return c !== "TEACHER" || !t ? null : /* @__PURE__ */ a(
33
- y,
34
- {
35
- $width: s,
36
- $questionWidth: o,
37
- $height: h,
38
- $justifyContent: "space-between",
39
- children: [
40
- /* @__PURE__ */ i($, { $width: s, $alignItems: "flex-start", $gapX: 0.5, children: /* @__PURE__ */ i(T, { $renderAs: "cta1", onClick: p, children: "Question Feedback" }) }),
41
- /* @__PURE__ */ a(k, { children: [
42
- /* @__PURE__ */ i(
43
- W,
44
- {
45
- questionWidth: o,
46
- questions: n,
47
- learnosity: u,
48
- actionbarHeight: m
49
- }
50
- ),
51
- /* @__PURE__ */ i(x, { heightX: 0.5 }),
52
- /* @__PURE__ */ i(b, {})
53
- ] })
54
- ]
55
- }
56
- );
57
- });
58
- export {
59
- A as default
60
- };
61
- //# sourceMappingURL=sidebar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sidebar.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-sidebar/sidebar.tsx"],"sourcesContent":["import { memo, useCallback, type FC } from 'react';\n\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport { SIDEBAR_WIDTH } from '../constants';\nimport { useWorksheetStore } from '../hooks/use-worksheet-store';\nimport Navigator from './navigator';\nimport QuestionGuide from './question-guide';\nimport {\n SideBarContainer,\n UnderlinedText,\n UnderlinedTextWrapper,\n} from './worksheet-sidebar-styled';\n\nconst WorksheetSideBar: FC = memo(function WorksheetSideBar() {\n const {\n activeQuestionIndex,\n learnosity,\n questionWidth,\n questions,\n userType,\n height,\n actionbarHeight,\n openQuestionFeedbackModal,\n } = useWorksheetStore(store => ({\n activeQuestionIndex: store.activeQuestionIndex,\n learnosity: store.learnosity,\n questionWidth: store.maxQuestionWidth,\n questions: store.questions,\n userType: store.userType,\n height: store.layout.minQuestionHeight,\n actionbarHeight: store.actionbarHeight,\n openQuestionFeedbackModal: store.openQuestionFeedbackModal,\n }));\n const activeQuestion = questions[activeQuestionIndex];\n const { item_reference: itemRef } = activeQuestion ?? {};\n\n const onFeedbackClick = useCallback(() => {\n if (openQuestionFeedbackModal) {\n openQuestionFeedbackModal(itemRef || '');\n }\n }, [itemRef, openQuestionFeedbackModal]);\n\n if (userType !== 'TEACHER' || !openQuestionFeedbackModal) return null;\n\n return (\n <SideBarContainer\n $width={SIDEBAR_WIDTH}\n $questionWidth={questionWidth}\n $height={height}\n $justifyContent=\"space-between\"\n >\n <UnderlinedTextWrapper $width={SIDEBAR_WIDTH} $alignItems=\"flex-start\" $gapX={0.5}>\n <UnderlinedText $renderAs=\"cta1\" onClick={onFeedbackClick}>\n Question Feedback\n </UnderlinedText>\n </UnderlinedTextWrapper>\n\n <FlexView>\n <QuestionGuide\n questionWidth={questionWidth}\n questions={questions}\n learnosity={learnosity}\n actionbarHeight={actionbarHeight}\n />\n <Separator heightX={0.5} />\n <Navigator />\n </FlexView>\n </SideBarContainer>\n );\n});\n\nexport default WorksheetSideBar;\n"],"names":["WorksheetSideBar","memo","activeQuestionIndex","learnosity","questionWidth","questions","userType","height","actionbarHeight","openQuestionFeedbackModal","useWorksheetStore","store","activeQuestion","itemRef","onFeedbackClick","useCallback","jsxs","SideBarContainer","SIDEBAR_WIDTH","jsx","UnderlinedTextWrapper","UnderlinedText","FlexView","QuestionGuide","Separator","Navigator"],"mappings":";;;;;;;;;AAcM,MAAAA,IAAuBC,EAAK,WAA4B;AACtD,QAAA;AAAA,IACJ,qBAAAC;AAAA,IACA,YAAAC;AAAA,IACA,eAAAC;AAAA,IACA,WAAAC;AAAA,IACA,UAAAC;AAAA,IACA,QAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,2BAAAC;AAAA,EAAA,IACEC,EAAkB,CAAUC,OAAA;AAAA,IAC9B,qBAAqBA,EAAM;AAAA,IAC3B,YAAYA,EAAM;AAAA,IAClB,eAAeA,EAAM;AAAA,IACrB,WAAWA,EAAM;AAAA,IACjB,UAAUA,EAAM;AAAA,IAChB,QAAQA,EAAM,OAAO;AAAA,IACrB,iBAAiBA,EAAM;AAAA,IACvB,2BAA2BA,EAAM;AAAA,EACjC,EAAA,GACIC,IAAiBP,EAAUH,CAAmB,GAC9C,EAAE,gBAAgBW,MAAYD,KAAkB,CAAA,GAEhDE,IAAkBC,EAAY,MAAM;AACxC,IAAIN,KACFA,EAA0BI,KAAW,EAAE;AAAA,EACzC,GACC,CAACA,GAASJ,CAAyB,CAAC;AAEvC,SAAIH,MAAa,aAAa,CAACG,IAAkC,OAG/D,gBAAAO;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,QAAQC;AAAA,MACR,gBAAgBd;AAAA,MAChB,SAASG;AAAA,MACT,iBAAgB;AAAA,MAEhB,UAAA;AAAA,QAAA,gBAAAY,EAACC,GAAsB,EAAA,QAAQF,GAAe,aAAY,cAAa,OAAO,KAC5E,UAAC,gBAAAC,EAAAE,GAAA,EAAe,WAAU,QAAO,SAASP,GAAiB,8BAE3D,CAAA,GACF;AAAA,0BAECQ,GACC,EAAA,UAAA;AAAA,UAAA,gBAAAH;AAAA,YAACI;AAAA,YAAA;AAAA,cACC,eAAAnB;AAAA,cACA,WAAAC;AAAA,cACA,YAAAF;AAAA,cACA,iBAAAK;AAAA,YAAA;AAAA,UACF;AAAA,UACA,gBAAAW,EAACK,GAAU,EAAA,SAAS,IAAK,CAAA;AAAA,4BACxBC,GAAU,EAAA;AAAA,QAAA,GACb;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;"}
@@ -1,91 +0,0 @@
1
- import r from "styled-components";
2
- import c from "../../../../assets/line-icons/icons/cross.js";
3
- import l from "../../../../assets/line-icons/icons/info3.js";
4
- import e from "../../../ui/layout/flex-view.js";
5
- import d from "../../../ui/text/text.js";
6
- import { CustomElement as a } from "../worksheet-question/worksheet-question-styled.js";
7
- import x from "../../../../assets/line-icons/icons/solution.js";
8
- r(e)`
9
- border: 2px solid #000;
10
- `;
11
- const y = r(e)(
12
- ({ $questionWidth: t, $actionbarHeight: o, theme: n }) => `
13
- position: absolute;
14
- bottom: ${o}px;
15
- right: 80px; //52px(sidebar(width) +12px(gutter) + (16px)
16
- width: calc(${t}px - 32px); // 32px is the left + right padding
17
- height: 30%;
18
- display: flex;
19
- border: 1px solid ${n.colors.GREY_2};
20
- overflow: hidden;
21
- `
22
- ), C = r(e)`
23
- cursor: pointer;
24
- `, I = r(d)`
25
- text-decoration: underline;
26
- white-space: nowrap;
27
- writing-mode: vertical-rl;
28
- text-align: right;
29
- `, s = (t) => t.startsWith("calc(") ? t.replace(")", " - 0px)") : t, p = (t) => t.trim().split(/\s+(?=[+-])/).map((i) => i.startsWith("-") ? `+${i.slice(1)}` : i.startsWith("+") ? `-${i.slice(1)}` : `-${i}`).join(" "), f = (t) => t.startsWith("calc(") && t.endsWith(")") ? (t = t.slice(5, -1), `calc(${p(t)})`) : p(t), S = r(e)(
30
- ({ $questionWidth: t }) => `
31
- width: calc(${t}px - 32px); // 32px is the left + right padding
32
- overflow-y: auto;
33
- height: 100%;
34
- display: flex;
35
- `
36
- ), T = r(e)(({ $questionWidth: t, $height: o }) => `
37
- margin-top: ${typeof o == "number" ? `${-o}px` : f(s(o))};
38
- position: sticky;
39
- left: calc((100% - ${t}px ) *.5 + ${t}px + 12px);
40
- bottom: 16px;
41
- align-items: center;
42
- height: ${typeof o == "number" ? `${o}px` : s(o)};
43
- z-index: 1;
44
- `), E = r(e)(
45
- ({ theme: t }) => `
46
- width: 100%;
47
- border-radius: 8px;
48
- border: 1px solid ${t.colors.GREY_2};
49
- justify-content: center;
50
- align-items: center;
51
- padding: 10px;
52
- `
53
- ), G = r.div`
54
- position: fixed;
55
- top: ${({ topValue: t }) => `${t}px`};
56
- left: ${({ leftValue: t }) => `${t}px`};
57
- width: 15px;
58
- height: 15px;
59
- transform: rotate(45deg);
60
- background: white;
61
- border-top: 1px solid #e0e0e0;
62
- border-right: 1px solid #e0e0e0;
63
- `, W = r(c)`
64
- position: absolute;
65
- top: 8px;
66
- right: 16px;
67
- `, v = r(l)(({ theme: t, $disabled: o }) => `
68
- & path {
69
- fill: ${o ? t.colors.GREY_4 : t.colors.BLACK};
70
- }
71
- `), R = r(x)(({ theme: t, $disabled: o }) => `
72
- & path {
73
- fill: ${o ? t.colors.GREY_4 : t.colors.BLACK};
74
- }
75
- `), Y = r(a)``;
76
- export {
77
- W as CloseIcon,
78
- Y as Guide,
79
- E as GuideContainer,
80
- v as HintIcon,
81
- G as Pointer,
82
- S as Section,
83
- y as SectionContainer,
84
- T as SideBarContainer,
85
- R as SolIcon,
86
- I as UnderlinedText,
87
- C as UnderlinedTextWrapper,
88
- s as getMinHeightFromString,
89
- f as negateExpression
90
- };
91
- //# sourceMappingURL=worksheet-sidebar-styled.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"worksheet-sidebar-styled.js","sources":["../../../../../src/features/worksheet/worksheet/worksheet-sidebar/worksheet-sidebar-styled.ts"],"sourcesContent":["import styled from 'styled-components';\n\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport Info3Icon from '../../../../assets/line-icons/icons/info3';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport { CustomElement } from '../worksheet-question/worksheet-question-styled';\nimport SolutionIcon from '../../../../assets/line-icons/icons/solution';\n\nexport const Circle = styled(FlexView)`\n border: 2px solid #000;\n`;\nexport const SectionContainer = styled(FlexView)<{\n $questionWidth: number;\n $actionbarHeight: number;\n}>(\n ({ $questionWidth, $actionbarHeight, theme }) => `\n position: absolute;\n bottom: ${$actionbarHeight}px;\n right: 80px; //52px(sidebar(width) +12px(gutter) + (16px)\n width: calc(${$questionWidth}px - 32px); // 32px is the left + right padding\n height: 30%;\n display: flex;\n border: 1px solid ${theme.colors.GREY_2};\n overflow: hidden;\n`,\n);\n\nexport const UnderlinedTextWrapper = styled(FlexView)`\n cursor: pointer;\n`;\n\nexport const UnderlinedText = styled(Text)`\n text-decoration: underline;\n white-space: nowrap;\n writing-mode: vertical-rl;\n text-align: right;\n`;\n\nexport const getMinHeightFromString = (minHeight: string) => {\n if (minHeight.startsWith('calc(')) {\n return minHeight.replace(')', ' - 0px)');\n }\n\n return minHeight;\n};\n\nconst negateString = (expression: string) => {\n const terms = expression.trim().split(/\\s+(?=[+-])/);\n const negatedTerms = terms.map(term => {\n if (term.startsWith('-')) {\n return `+${term.slice(1)}`; // change - to +\n }\n\n if (term.startsWith('+')) {\n return `-${term.slice(1)}`; // change + to -\n }\n\n return `-${term}`; // add leading '-'\n });\n\n return negatedTerms.join(' ');\n};\n\nexport const negateExpression = (expression: string) => {\n if (expression.startsWith('calc(') && expression.endsWith(')')) {\n expression = expression.slice(5, -1); // Remove 'calc(' and ')'\n const negatedTerms = negateString(expression);\n\n return `calc(${negatedTerms})`;\n }\n\n return negateString(expression);\n};\n\nexport const Section = styled(FlexView)<{\n $questionWidth: number;\n $actionbarHeight: number;\n}>(\n ({ $questionWidth }) => `\n width: calc(${$questionWidth}px - 32px); // 32px is the left + right padding\n overflow-y: auto;\n height: 100%;\n display: flex;\n`,\n);\nexport const SideBarContainer = styled(FlexView)<{\n $questionWidth: number;\n $height: number | string;\n}>(({ $questionWidth, $height }) => {\n return `\n margin-top: ${\n typeof $height === 'number'\n ? `${-$height}px`\n : negateExpression(getMinHeightFromString($height))\n };\n position: sticky;\n left: calc((100% - ${$questionWidth}px ) *.5 + ${$questionWidth}px + 12px);\n bottom: 16px;\n align-items: center;\n height: ${typeof $height === 'number' ? `${$height}px` : getMinHeightFromString($height)};\n z-index: 1;\n`;\n});\n\nexport const GuideContainer = styled(FlexView)(\n ({ theme }) => `\n width: 100%;\n border-radius: 8px;\n border: 1px solid ${theme.colors.GREY_2};\n justify-content: center;\n align-items: center;\n padding: 10px;\n`,\n);\n\nexport const Pointer = styled.div<{ topValue: number; leftValue: number }>`\n position: fixed;\n top: ${({ topValue }) => `${topValue}px`};\n left: ${({ leftValue }) => `${leftValue}px`};\n width: 15px;\n height: 15px;\n transform: rotate(45deg);\n background: white;\n border-top: 1px solid #e0e0e0;\n border-right: 1px solid #e0e0e0;\n`;\n\nexport const CloseIcon = styled(CrossIcon)`\n position: absolute;\n top: 8px;\n right: 16px;\n`;\n\nexport const HintIcon = styled(Info3Icon)<{ $disabled: boolean }>(({ theme, $disabled }) => {\n return `\n & path {\n fill: ${$disabled ? theme.colors.GREY_4 : theme.colors.BLACK};\n }\n `;\n});\n\nexport const SolIcon = styled(SolutionIcon)<{ $disabled: boolean }>(({ theme, $disabled }) => {\n return `\n & path {\n fill: ${$disabled ? theme.colors.GREY_4 : theme.colors.BLACK};\n }\n `;\n});\n\nexport const Guide = styled(CustomElement)``;\n"],"names":["styled","FlexView","SectionContainer","$questionWidth","$actionbarHeight","theme","UnderlinedTextWrapper","UnderlinedText","Text","getMinHeightFromString","minHeight","negateString","expression","term","negateExpression","Section","SideBarContainer","$height","GuideContainer","Pointer","topValue","leftValue","CloseIcon","CrossIcon","HintIcon","Info3Icon","$disabled","SolIcon","SolutionIcon","Guide","CustomElement"],"mappings":";;;;;;;AASsBA,EAAOC,CAAQ;AAAA;AAAA;AAGxB,MAAAC,IAAmBF,EAAOC,CAAQ;AAAA,EAI7C,CAAC,EAAE,gBAAAE,GAAgB,kBAAAC,GAAkB,OAAAC,EAAY,MAAA;AAAA;AAAA,YAEvCD,CAAgB;AAAA;AAAA,gBAEZD,CAAc;AAAA;AAAA;AAAA,sBAGRE,EAAM,OAAO,MAAM;AAAA;AAAA;AAGzC,GAEaC,IAAwBN,EAAOC,CAAQ;AAAA;AAAA,GAIvCM,IAAiBP,EAAOQ,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA,GAO5BC,IAAyB,CAACC,MACjCA,EAAU,WAAW,OAAO,IACvBA,EAAU,QAAQ,KAAK,SAAS,IAGlCA,GAGHC,IAAe,CAACC,MACNA,EAAW,KAAK,EAAE,MAAM,aAAa,EACxB,IAAI,CAAQC,MACjCA,EAAK,WAAW,GAAG,IACd,IAAIA,EAAK,MAAM,CAAC,CAAC,KAGtBA,EAAK,WAAW,GAAG,IACd,IAAIA,EAAK,MAAM,CAAC,CAAC,KAGnB,IAAIA,CAAI,EAChB,EAEmB,KAAK,GAAG,GAGjBC,IAAmB,CAACF,MAC3BA,EAAW,WAAW,OAAO,KAAKA,EAAW,SAAS,GAAG,KAC9CA,IAAAA,EAAW,MAAM,GAAG,EAAE,GAG5B,QAFcD,EAAaC,CAAU,CAEjB,OAGtBD,EAAaC,CAAU,GAGnBG,IAAUf,EAAOC,CAAQ;AAAA,EAIpC,CAAC,EAAE,gBAAAE,EAAA,MAAqB;AAAA,gBACVA,CAAc;AAAA;AAAA;AAAA;AAAA;AAK9B,GACaa,IAAmBhB,EAAOC,CAAQ,EAG5C,CAAC,EAAE,gBAAAE,GAAgB,SAAAc,QACb;AAAA,gBAEL,OAAOA,KAAY,WACf,GAAG,CAACA,CAAO,OACXH,EAAiBL,EAAuBQ,CAAO,CAAC,CACtD;AAAA;AAAA,uBAEqBd,CAAc,cAAcA,CAAc;AAAA;AAAA;AAAA,YAGrD,OAAOc,KAAY,WAAW,GAAGA,CAAO,OAAOR,EAAuBQ,CAAO,CAAC;AAAA;AAAA,CAGzF,GAEYC,IAAiBlB,EAAOC,CAAQ;AAAA,EAC3C,CAAC,EAAE,OAAAI,EAAA,MAAY;AAAA;AAAA;AAAA,sBAGKA,EAAM,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAKzC,GAEac,IAAUnB,EAAO;AAAA;AAAA,SAErB,CAAC,EAAE,UAAAoB,EAAe,MAAA,GAAGA,CAAQ,IAAI;AAAA,UAChC,CAAC,EAAE,WAAAC,EAAgB,MAAA,GAAGA,CAAS,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAShCC,IAAYtB,EAAOuB,CAAS;AAAA;AAAA;AAAA;AAAA,GAM5BC,IAAWxB,EAAOyB,CAAS,EAA0B,CAAC,EAAE,OAAApB,GAAO,WAAAqB,QACnE;AAAA;AAAA,cAEKA,IAAYrB,EAAM,OAAO,SAASA,EAAM,OAAO,KAAK;AAAA;AAAA,GAGjE,GAEYsB,IAAU3B,EAAO4B,CAAY,EAA0B,CAAC,EAAE,OAAAvB,GAAO,WAAAqB,QACrE;AAAA;AAAA,cAEKA,IAAYrB,EAAM,OAAO,SAASA,EAAM,OAAO,KAAK;AAAA;AAAA,GAGjE,GAEYwB,IAAQ7B,EAAO8B,CAAa;"}
@@ -1,289 +0,0 @@
1
- import { createContext as A } from "react";
2
- import { createStore as T } from "zustand";
3
- import { subscribeWithSelector as _ } from "../../../node_modules/zustand/esm/middleware.js";
4
- import { getLastUnlockedQuestionIndex as x, scrollToQuestion as V, getQuestionsFromItems as q, getInitialResponses as w, getInitialQuestionId as B, getLastAttemptableQuestionIndex as M, getWorksheetDimensions as H, getQuestionMetadata as W } from "./worksheet-helpers.js";
5
- const I = ({
6
- teacherValidationEnabled: u,
7
- userType: i,
8
- lastUnlockedQuestion: b,
9
- lastUnlockedQuestionResponse: c
10
- }) => {
11
- if (u) {
12
- const { item_type: r, instructor_stimulus: e, is_optional: n } = b;
13
- if (i === "TEACHER") {
14
- if (r === "exit-ticket" && e !== "SystemIntro")
15
- return c != null && c.submittedByStudent && !(c != null && c.validatedByTeacher) ? "exit-ticket-review-available" : c != null && c.validatedByTeacher ? void 0 : "exit-ticket-teacher-intervention";
16
- if (n)
17
- return c != null && c.assignStatus ? void 0 : "optional-items-assignment";
18
- }
19
- }
20
- }, C = ({
21
- userType: u,
22
- questions: i,
23
- lastUnlockedQuestionIndex: b
24
- }) => i.filter((c, r) => u === "TEACHER" ? !0 : r <= b), Q = (u, i) => {
25
- var p;
26
- const {
27
- learnosityItems: b,
28
- learnosityResponses: c,
29
- updatedResponses: r,
30
- layout: e,
31
- behavior: n,
32
- userType: a,
33
- initialResponseId: l,
34
- initialItemIndex: t
35
- } = u, { navigationMode: o, teacherValidationEnabled: m, initialQuestion: d } = n, s = (i == null ? void 0 : i.questions) ?? q(b, {
36
- sectioned: m && o !== "ADAPTIVE" && o !== "CURRENT",
37
- adaptive: o === "ADAPTIVE"
38
- }), f = r ?? (i == null ? void 0 : i.responses) ?? c ?? w(s), g = x({
39
- questions: s,
40
- responses: f,
41
- behavior: n,
42
- userType: a
43
- }), y = (i == null ? void 0 : i.initialQuestionId) ?? B({
44
- questions: s,
45
- initialQuestion: d,
46
- lastUnlockedQuestionIndex: g,
47
- lastAttemptableQuestionIndex: M({
48
- questions: s,
49
- responses: f,
50
- behavior: n,
51
- userType: a
52
- }),
53
- initialResponseId: l,
54
- initialItemIndex: t
55
- }), v = (i == null ? void 0 : i.activeQuestionId) ?? y, h = s.findIndex(
56
- (E) => E.response_id === v
57
- );
58
- return !i && s[h] && u.onActiveQuestionChange && u.onActiveQuestionChange(s[h]), {
59
- questions: s,
60
- renderableQuestions: C({
61
- questions: s,
62
- userType: a,
63
- lastUnlockedQuestionIndex: g
64
- }),
65
- responses: f,
66
- lastUnlockedQuestionIndex: g,
67
- initialQuestionId: y,
68
- activeQuestionId: v,
69
- activeQuestionIndex: h,
70
- summaryVisible: i ? i.summaryVisible : !1,
71
- calculatorVisible: i ? i.calculatorVisible : !1,
72
- scribblingEnabled: i ? i.scribblingEnabled : !1,
73
- blocker: I({
74
- currentBlocker: i == null ? void 0 : i.blocker,
75
- teacherValidationEnabled: n.teacherValidationEnabled,
76
- userType: a,
77
- lastUnlockedQuestion: s[g],
78
- lastUnlockedQuestionResponse: f[((p = s[g]) == null ? void 0 : p.response_id) ?? ""]
79
- }),
80
- ...H(b, e)
81
- };
82
- }, k = (u, i, b) => {
83
- const c = W(u.questions, i);
84
- return c ? {
85
- ...u,
86
- responses: {
87
- ...u.responses,
88
- [i]: {
89
- ...c,
90
- ...u.responses[i],
91
- ...b
92
- }
93
- }
94
- } : u;
95
- }, P = (u) => {
96
- const i = /* @__PURE__ */ new Set(), b = (r, e) => {
97
- const n = setTimeout(() => {
98
- i.delete(n), r();
99
- }, e);
100
- return i.add(n), n;
101
- }, c = () => {
102
- i.forEach((r) => clearTimeout(r)), i.clear();
103
- };
104
- return T()(
105
- _((r) => ({
106
- // Initialize with exact props passed in
107
- ...u,
108
- ...Q(u),
109
- // Actions
110
- mergeWorksheetProps: (e) => {
111
- r((n) => ({
112
- ...n,
113
- ...e,
114
- ...Q(e, n)
115
- }));
116
- },
117
- setResponses: (e) => {
118
- r((n) => {
119
- var s;
120
- const a = {
121
- ...n,
122
- responses: typeof e == "function" ? e(n.responses) : e
123
- }, { questions: l, responses: t, behavior: o, userType: m } = a, d = x({
124
- questions: l,
125
- responses: t,
126
- behavior: o,
127
- userType: m
128
- });
129
- return {
130
- ...a,
131
- lastUnlockedQuestionIndex: d,
132
- renderableQuestions: C({
133
- questions: l,
134
- lastUnlockedQuestionIndex: d,
135
- userType: m
136
- }),
137
- blocker: I({
138
- currentBlocker: n == null ? void 0 : n.blocker,
139
- teacherValidationEnabled: o.teacherValidationEnabled,
140
- userType: m,
141
- lastUnlockedQuestion: l[d],
142
- lastUnlockedQuestionResponse: t[((s = l[d]) == null ? void 0 : s.response_id) ?? ""]
143
- })
144
- };
145
- });
146
- },
147
- updateResponse: ({ responseId: e, response: n, score: a, answerChecked: l, timeSpent: t }) => {
148
- r((o) => {
149
- var E;
150
- const m = !!l, d = o.responses[e], s = k(o, e, {
151
- response: n,
152
- score: a,
153
- responseEdited: !m,
154
- attemptsHistory: m ? [...(d == null ? void 0 : d.attemptsHistory) ?? [], { response: n, score: a }] : d == null ? void 0 : d.attemptsHistory,
155
- skipped: !n,
156
- timeSpent: t
157
- }), { questions: f, responses: g, behavior: y, userType: v } = s, h = x({
158
- questions: f,
159
- responses: g,
160
- behavior: y,
161
- userType: v
162
- }), p = g[e];
163
- return p && o.onResponseChange && o.onResponseChange({
164
- responseId: e,
165
- response: p,
166
- question: f.find((S) => S.response_id === e),
167
- isNewAttempt: m
168
- }), {
169
- ...s,
170
- lastUnlockedQuestionIndex: h,
171
- renderableQuestions: C({
172
- questions: f,
173
- userType: v,
174
- lastUnlockedQuestionIndex: h
175
- }),
176
- blocker: I({
177
- currentBlocker: o == null ? void 0 : o.blocker,
178
- teacherValidationEnabled: y.teacherValidationEnabled,
179
- userType: v,
180
- lastUnlockedQuestion: f[h],
181
- lastUnlockedQuestionResponse: g[((E = f[h]) == null ? void 0 : E.response_id) ?? ""]
182
- })
183
- };
184
- });
185
- },
186
- updateMediaState: (e, n, a) => {
187
- const l = n === "SIMULATION" ? "simState" : void 0;
188
- l && r((t) => {
189
- if (t.onResponseChange) {
190
- const o = k(t, e, { [l]: a }), m = o == null ? void 0 : o.responses[e];
191
- return m && t.onResponseChange({
192
- responseId: e,
193
- response: m,
194
- isNewAttempt: !1,
195
- question: t.questions.find((d) => d.response_id === e)
196
- }), o;
197
- }
198
- return t.onMediaStateChange && t.onMediaStateChange(
199
- t.questions.find((o) => o.response_id === e),
200
- n,
201
- a
202
- ), t;
203
- });
204
- },
205
- showSummary: () => {
206
- r((e) => ({
207
- ...e,
208
- summaryVisible: !0
209
- }));
210
- },
211
- hideSummary: () => {
212
- r((e) => ({
213
- ...e,
214
- summaryVisible: !1
215
- }));
216
- },
217
- toggleSummary: () => {
218
- r((e) => ({
219
- ...e,
220
- summaryVisible: !e.summaryVisible
221
- }));
222
- },
223
- showCalculator: () => {
224
- r((e) => ({
225
- ...e,
226
- calculatorVisible: !0
227
- }));
228
- },
229
- hideCalculator: () => {
230
- r((e) => ({
231
- ...e,
232
- calculatorVisible: !1
233
- }));
234
- },
235
- toggleScribble: () => {
236
- r((e) => ({
237
- ...e,
238
- scribblingEnabled: !e.scribblingEnabled
239
- }));
240
- },
241
- setBlocker: (e) => {
242
- r((n) => ({
243
- ...n,
244
- blocker: e
245
- }));
246
- },
247
- removeBlocker: () => {
248
- r((e) => {
249
- var n;
250
- if (e.blocker) {
251
- const a = (n = e.questions[e.lastUnlockedQuestionIndex]) == null ? void 0 : n.response_id;
252
- a && b(() => {
253
- V(a);
254
- }, 50);
255
- }
256
- return {
257
- ...e,
258
- blocker: void 0
259
- };
260
- });
261
- },
262
- markForReview: (e, n) => {
263
- r((a) => k(a, e, { markedForReview: n }));
264
- },
265
- changeQuestion: (e, n = !0, a = 0) => {
266
- r((l) => {
267
- var o;
268
- const t = {
269
- ...l,
270
- summaryVisible: !1
271
- };
272
- return n && l.layout.questionsScrollable ? a > 0 ? b(() => {
273
- V(e);
274
- }, a) : requestAnimationFrame(() => V(e)) : l.activeQuestionId !== e && (t.activeQuestionId = e, t.activeQuestionIndex = t.questions.findIndex(
275
- (m) => m.response_id === e
276
- ), (o = t.onActiveQuestionChange) == null || o.call(t, t.questions[t.activeQuestionIndex])), t;
277
- });
278
- },
279
- destroy: () => {
280
- c();
281
- }
282
- }))
283
- );
284
- }, O = A(null);
285
- export {
286
- O as WorksheetContext,
287
- P as createWorksheetStore
288
- };
289
- //# sourceMappingURL=worksheet-store.js.map