@elice/material-exercise 1.240718.0-trasncript.2 → 1.240718.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (459) hide show
  1. package/cjs/assets/empty.png.js +2 -1
  2. package/cjs/components/material-exercise/MaterialExercise.d.ts +1 -1
  3. package/cjs/components/material-exercise/MaterialExercise.js +75 -111
  4. package/cjs/components/material-exercise/MaterialExercise.styled.js +14 -18
  5. package/cjs/components/material-exercise/MaterialExerciseMobile.d.ts +1 -1
  6. package/cjs/components/material-exercise/MaterialExerciseMobile.js +7 -17
  7. package/cjs/components/material-exercise/context/ExerciseProvider.js +58 -68
  8. package/cjs/components/material-exercise/context/ExerciseProviderNoImage.js +30 -39
  9. package/cjs/components/material-exercise/context/context.js +1 -5
  10. package/cjs/components/material-exercise/context/recoil.js +293 -542
  11. package/cjs/components/material-exercise/context/subjects.js +4 -4
  12. package/cjs/components/material-exercise/context/types.d.ts +2 -2
  13. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +78 -100
  14. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -12
  15. package/cjs/components/material-exercise/exercise-file/ExerciseFile.js +27 -30
  16. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +149 -225
  17. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +13 -20
  18. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +29 -49
  19. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.d.ts +2 -1
  20. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +4 -10
  21. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/ExerciseFileTabsFileTreeButton.js +36 -53
  22. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +211 -353
  23. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.d.ts +2 -1
  24. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +4 -10
  25. package/cjs/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +15 -18
  26. package/cjs/components/material-exercise/exercise-menu/ExerciseMenu.js +12 -21
  27. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +11 -12
  28. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +80 -123
  29. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +67 -100
  30. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuReset.js +22 -40
  31. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +119 -144
  32. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +13 -17
  33. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +19 -32
  34. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.d.ts +2 -1
  35. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +4 -10
  36. package/cjs/components/material-exercise/exercise-preview/ExercisePreview.js +24 -31
  37. package/cjs/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +6 -13
  38. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +35 -51
  39. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +6 -14
  40. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +78 -90
  41. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.js +12 -25
  42. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -18
  43. package/cjs/components/material-exercise/exercise-room/ExerciseRoomDetail.js +349 -504
  44. package/cjs/components/material-exercise/exercise-room/ExerciseRoomList.js +132 -197
  45. package/cjs/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -2
  46. package/cjs/components/material-exercise/exercise-runner/ExerciseRunner.js +142 -205
  47. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -5
  48. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerController.js +16 -25
  49. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +86 -118
  50. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +19 -33
  51. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +82 -95
  52. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +52 -68
  53. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +87 -136
  54. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +2 -6
  55. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +15 -21
  56. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +23 -36
  57. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +248 -402
  58. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -12
  59. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +50 -74
  60. package/cjs/components/shared/exercise-menu-button/ExerciseMenuButton.js +23 -32
  61. package/cjs/components/shared/exercise-shimmer/ExerciseFileShimmer.js +38 -44
  62. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +20 -26
  63. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +8 -14
  64. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +22 -28
  65. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +9 -24
  66. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.js +5 -6
  67. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -5
  68. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.js +10 -10
  69. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -13
  70. package/cjs/components/shared/file-icon/FileIcon.js +16 -23
  71. package/cjs/components/shared/file-tabs/FileTab.js +33 -47
  72. package/cjs/components/shared/file-tabs/FileTab.styled.js +15 -23
  73. package/cjs/components/shared/file-tabs/FileTabs.js +39 -66
  74. package/cjs/components/shared/file-tabs/FileTabs.styled.js +2 -6
  75. package/cjs/components/shared/file-tabs/util.js +14 -27
  76. package/cjs/components/shared/file-tree/FileTree.js +10 -20
  77. package/cjs/components/shared/file-tree/FileTreeConfig.js +40 -46
  78. package/cjs/components/shared/file-tree/FileTreeList.js +40 -43
  79. package/cjs/components/shared/file-tree/FileTreeListItemContent.js +99 -128
  80. package/cjs/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -29
  81. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.js +96 -106
  82. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -10
  83. package/cjs/components/shared/file-tree/FileTreeListItemContentMenu.js +91 -133
  84. package/cjs/components/shared/file-tree/FileTreeListItems.js +137 -149
  85. package/cjs/components/shared/file-tree/FileTreeListItems.styled.js +2 -6
  86. package/cjs/components/shared/file-tree/FileTreeToolbar.styled.js +1 -5
  87. package/cjs/components/shared/file-tree/context/FileTreeContext.d.ts +1 -1
  88. package/cjs/components/shared/file-tree/context/FileTreeContext.js +79 -101
  89. package/cjs/components/shared/file-tree/file-tree-toolbar/FileTreeToolbar.js +54 -59
  90. package/cjs/components/shared/file-tree/utils/fileTreeFiles.js +20 -24
  91. package/cjs/components/shared/file-tree/utils/fileTreeGenerator.js +146 -193
  92. package/cjs/components/shared/file-tree/utils/fileTreeInput.js +0 -11
  93. package/cjs/components/shared/file-tree/utils/fileTreeItem.js +1 -1
  94. package/cjs/components/shared/file-tree/utils/fileTreePath.js +6 -5
  95. package/cjs/components/shared/file-viewer/FileViewer.js +46 -76
  96. package/cjs/components/shared/file-viewer/FileViewerCsv.js +167 -262
  97. package/cjs/components/shared/file-viewer/FileViewerImage.js +12 -16
  98. package/cjs/components/shared/file-viewer/FileViewerIpynb.js +11 -27
  99. package/cjs/components/shared/file-viewer/FileViewerNonViewable.js +47 -65
  100. package/cjs/components/shared/file-viewer/FileViewerText.js +11 -23
  101. package/cjs/components/shared/material-modal/MaterialModal.js +11 -20
  102. package/cjs/components/shared/material-modal/MaterialModal.styled.js +5 -9
  103. package/cjs/components/shared/monaco-editor/MonacoEditor.js +74 -102
  104. package/cjs/components/shared/monaco-editor/MonacoEditorLazy.js +7 -15
  105. package/cjs/components/shared/monaco-editor/MonacoEditorMobile.js +34 -49
  106. package/cjs/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +194 -249
  107. package/cjs/components/shared/monaco-editor/constants/grammars/index.js +28 -82
  108. package/cjs/components/shared/monaco-editor/constants/monaco/preferences.js +5 -5
  109. package/cjs/components/shared/monaco-editor/constants/themes/index.js +17 -49
  110. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -11
  111. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -15
  112. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -9
  113. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -34
  114. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -9
  115. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -6
  116. package/cjs/components/shared/monaco-editor/editor-languages/css/formatter.js +10 -33
  117. package/cjs/components/shared/monaco-editor/editor-languages/css/index.js +2 -3
  118. package/cjs/components/shared/monaco-editor/editor-languages/html/formatter.js +10 -33
  119. package/cjs/components/shared/monaco-editor/editor-languages/html/index.js +2 -3
  120. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -1
  121. package/cjs/components/shared/monaco-editor/editor-languages/typescript/formatter.js +10 -37
  122. package/cjs/components/shared/monaco-editor/editor-languages/typescript/index.js +5 -6
  123. package/cjs/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -11
  124. package/cjs/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -10
  125. package/cjs/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -12
  126. package/cjs/components/shared/monaco-editor/utils/grammar/index.js +24 -67
  127. package/cjs/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -25
  128. package/cjs/components/shared/monaco-editor/utils/grammar/textmate.js +37 -70
  129. package/cjs/components/shared/monaco-editor/utils/monacoLanguage.js +7 -8
  130. package/cjs/components/shared/monaco-editor/utils/monacoPreference.js +4 -6
  131. package/cjs/components/shared/monaco-editor/utils/prettier/config.js +2 -2
  132. package/cjs/components/shared/monaco-editor/utils/prettier/index.js +7 -27
  133. package/cjs/components/shared/monaco-editor/utils/theme/convert.js +14 -24
  134. package/cjs/components/shared/monaco-editor/utils/theme/index.js +3 -22
  135. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -77
  136. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -82
  137. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -120
  138. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +132 -155
  139. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -104
  140. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -2
  141. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -1
  142. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -2
  143. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +158 -177
  144. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -3
  145. package/cjs/components/shared/no-vnc/NoVnc.js +78 -118
  146. package/cjs/components/shared/no-vnc/NoVncLazy.js +7 -15
  147. package/cjs/components/shared/preview-container/PreviewContainer.js +13 -18
  148. package/cjs/components/shared/web-browser/WebBrowser.js +52 -74
  149. package/cjs/components/shared/xterm/Xterm.js +57 -82
  150. package/cjs/components/shared/xterm/XtermLazy.js +7 -15
  151. package/cjs/constants/arduino.js +10 -10
  152. package/cjs/constants/color.js +1 -1
  153. package/cjs/constants/shortcutKeyMap.js +1 -3
  154. package/cjs/constants/stylesheets.js +5 -7
  155. package/cjs/hooks/useArduino.js +141 -282
  156. package/cjs/hooks/useExerciseFile.js +22 -24
  157. package/cjs/hooks/useExericseShortcut.js +4 -6
  158. package/cjs/hooks/useMaterialExerciseFileUrl.js +33 -55
  159. package/cjs/hooks/useRunnerRoomWebSocket.js +27 -51
  160. package/cjs/hooks/useStdioTextConcator.js +11 -15
  161. package/cjs/hooks/useStdioWebSocket.js +28 -32
  162. package/cjs/hooks/useUsercodeEditWebSocket.js +158 -238
  163. package/cjs/hooks/useUsercodeHistory.js +63 -115
  164. package/cjs/utils/arduino.js +11 -23
  165. package/cjs/utils/exerciseFile.js +10 -8
  166. package/cjs/utils/runner.js +17 -33
  167. package/es/assets/empty.png.js +2 -1
  168. package/es/components/material-exercise/MaterialExercise.d.ts +1 -1
  169. package/es/components/material-exercise/MaterialExercise.js +75 -107
  170. package/es/components/material-exercise/MaterialExercise.styled.js +14 -14
  171. package/es/components/material-exercise/MaterialExerciseMobile.d.ts +1 -1
  172. package/es/components/material-exercise/MaterialExerciseMobile.js +7 -13
  173. package/es/components/material-exercise/context/ExerciseProvider.js +58 -63
  174. package/es/components/material-exercise/context/ExerciseProviderNoImage.js +30 -35
  175. package/es/components/material-exercise/context/context.js +1 -1
  176. package/es/components/material-exercise/context/recoil.js +290 -535
  177. package/es/components/material-exercise/context/subjects.js +4 -4
  178. package/es/components/material-exercise/context/types.d.ts +2 -2
  179. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +78 -95
  180. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -8
  181. package/es/components/material-exercise/exercise-file/ExerciseFile.js +27 -25
  182. package/es/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +149 -221
  183. package/es/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +13 -15
  184. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +29 -44
  185. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.d.ts +2 -1
  186. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +4 -6
  187. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/ExerciseFileTabsFileTreeButton.js +36 -48
  188. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +211 -348
  189. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.d.ts +2 -1
  190. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +4 -6
  191. package/es/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +15 -14
  192. package/es/components/material-exercise/exercise-menu/ExerciseMenu.js +12 -16
  193. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +11 -12
  194. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +80 -119
  195. package/es/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +67 -96
  196. package/es/components/material-exercise/exercise-menu/ExerciseMenuReset.js +23 -41
  197. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +122 -143
  198. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +13 -13
  199. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +19 -28
  200. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.d.ts +2 -1
  201. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +4 -6
  202. package/es/components/material-exercise/exercise-preview/ExercisePreview.js +24 -26
  203. package/es/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +7 -14
  204. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +35 -47
  205. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +6 -10
  206. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +78 -85
  207. package/es/components/material-exercise/exercise-room/ExerciseRoom.js +12 -21
  208. package/es/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -14
  209. package/es/components/material-exercise/exercise-room/ExerciseRoomDetail.js +349 -498
  210. package/es/components/material-exercise/exercise-room/ExerciseRoomList.js +133 -193
  211. package/es/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -2
  212. package/es/components/material-exercise/exercise-runner/ExerciseRunner.js +142 -200
  213. package/es/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -1
  214. package/es/components/material-exercise/exercise-runner/ExerciseRunnerController.js +16 -20
  215. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +85 -112
  216. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +20 -30
  217. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +82 -90
  218. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +52 -63
  219. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +87 -131
  220. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +2 -2
  221. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +15 -17
  222. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +23 -31
  223. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +250 -399
  224. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -8
  225. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +49 -68
  226. package/es/components/shared/exercise-menu-button/ExerciseMenuButton.js +24 -29
  227. package/es/components/shared/exercise-shimmer/ExerciseFileShimmer.js +38 -40
  228. package/es/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +20 -22
  229. package/es/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +8 -10
  230. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +22 -24
  231. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +9 -19
  232. package/es/components/shared/exercise-version-list/ExerciseVersionList.js +5 -6
  233. package/es/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -1
  234. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.js +10 -10
  235. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -9
  236. package/es/components/shared/file-icon/FileIcon.js +16 -19
  237. package/es/components/shared/file-tabs/FileTab.js +33 -43
  238. package/es/components/shared/file-tabs/FileTab.styled.js +15 -19
  239. package/es/components/shared/file-tabs/FileTabs.js +40 -62
  240. package/es/components/shared/file-tabs/FileTabs.styled.js +2 -2
  241. package/es/components/shared/file-tabs/util.js +14 -27
  242. package/es/components/shared/file-tree/FileTree.js +10 -16
  243. package/es/components/shared/file-tree/FileTreeConfig.js +39 -39
  244. package/es/components/shared/file-tree/FileTreeList.js +40 -38
  245. package/es/components/shared/file-tree/FileTreeListItemContent.js +99 -124
  246. package/es/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -25
  247. package/es/components/shared/file-tree/FileTreeListItemContentInput.js +96 -102
  248. package/es/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -6
  249. package/es/components/shared/file-tree/FileTreeListItemContentMenu.js +91 -129
  250. package/es/components/shared/file-tree/FileTreeListItems.js +137 -149
  251. package/es/components/shared/file-tree/FileTreeListItems.styled.js +2 -2
  252. package/es/components/shared/file-tree/FileTreeToolbar.styled.js +1 -1
  253. package/es/components/shared/file-tree/context/FileTreeContext.d.ts +1 -1
  254. package/es/components/shared/file-tree/context/FileTreeContext.js +79 -97
  255. package/es/components/shared/file-tree/file-tree-toolbar/FileTreeToolbar.js +54 -55
  256. package/es/components/shared/file-tree/utils/fileTreeFiles.js +20 -20
  257. package/es/components/shared/file-tree/utils/fileTreeGenerator.js +146 -193
  258. package/es/components/shared/file-tree/utils/fileTreeInput.js +1 -11
  259. package/es/components/shared/file-tree/utils/fileTreeItem.js +1 -1
  260. package/es/components/shared/file-tree/utils/fileTreePath.js +6 -5
  261. package/es/components/shared/file-viewer/FileViewer.js +46 -69
  262. package/es/components/shared/file-viewer/FileViewerCsv.js +167 -257
  263. package/es/components/shared/file-viewer/FileViewerImage.js +12 -12
  264. package/es/components/shared/file-viewer/FileViewerIpynb.js +11 -21
  265. package/es/components/shared/file-viewer/FileViewerNonViewable.js +47 -60
  266. package/es/components/shared/file-viewer/FileViewerText.js +11 -19
  267. package/es/components/shared/material-modal/MaterialModal.js +11 -20
  268. package/es/components/shared/material-modal/MaterialModal.styled.js +5 -5
  269. package/es/components/shared/monaco-editor/MonacoEditor.js +72 -95
  270. package/es/components/shared/monaco-editor/MonacoEditorLazy.js +7 -11
  271. package/es/components/shared/monaco-editor/MonacoEditorMobile.js +32 -43
  272. package/es/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +194 -244
  273. package/es/components/shared/monaco-editor/constants/grammars/index.js +28 -82
  274. package/es/components/shared/monaco-editor/constants/monaco/preferences.js +5 -5
  275. package/es/components/shared/monaco-editor/constants/themes/index.js +17 -49
  276. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -11
  277. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -15
  278. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -9
  279. package/es/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -34
  280. package/es/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -9
  281. package/es/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -6
  282. package/es/components/shared/monaco-editor/editor-languages/css/formatter.js +10 -33
  283. package/es/components/shared/monaco-editor/editor-languages/html/formatter.js +10 -33
  284. package/es/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -1
  285. package/es/components/shared/monaco-editor/editor-languages/typescript/formatter.js +10 -37
  286. package/es/components/shared/monaco-editor/editor-languages/typescript/index.js +3 -3
  287. package/es/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -11
  288. package/es/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -10
  289. package/es/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -12
  290. package/es/components/shared/monaco-editor/utils/grammar/index.js +24 -67
  291. package/es/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -25
  292. package/es/components/shared/monaco-editor/utils/grammar/textmate.js +35 -67
  293. package/es/components/shared/monaco-editor/utils/monacoLanguage.js +5 -5
  294. package/es/components/shared/monaco-editor/utils/monacoPreference.js +4 -6
  295. package/es/components/shared/monaco-editor/utils/prettier/config.js +2 -2
  296. package/es/components/shared/monaco-editor/utils/prettier/index.js +7 -27
  297. package/es/components/shared/monaco-editor/utils/theme/convert.js +13 -19
  298. package/es/components/shared/monaco-editor/utils/theme/index.js +3 -22
  299. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -77
  300. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -82
  301. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -120
  302. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +130 -152
  303. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -104
  304. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -2
  305. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -1
  306. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -2
  307. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +156 -171
  308. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -3
  309. package/es/components/shared/no-vnc/NoVnc.js +71 -99
  310. package/es/components/shared/no-vnc/NoVncLazy.js +7 -11
  311. package/es/components/shared/preview-container/PreviewContainer.js +14 -15
  312. package/es/components/shared/web-browser/WebBrowser.js +52 -69
  313. package/es/components/shared/xterm/Xterm.js +57 -77
  314. package/es/components/shared/xterm/XtermLazy.js +7 -11
  315. package/es/constants/arduino.js +10 -10
  316. package/es/constants/color.js +1 -1
  317. package/es/constants/shortcutKeyMap.js +1 -3
  318. package/es/constants/stylesheets.js +5 -7
  319. package/es/hooks/useArduino.js +141 -278
  320. package/es/hooks/useExerciseFile.js +22 -24
  321. package/es/hooks/useExericseShortcut.js +4 -6
  322. package/es/hooks/useMaterialExerciseFileUrl.js +34 -52
  323. package/es/hooks/useRunnerRoomWebSocket.js +27 -51
  324. package/es/hooks/useStdioTextConcator.js +11 -11
  325. package/es/hooks/useStdioWebSocket.js +28 -32
  326. package/es/hooks/useUsercodeEditWebSocket.js +157 -232
  327. package/es/hooks/useUsercodeHistory.js +63 -115
  328. package/es/utils/arduino.js +12 -24
  329. package/es/utils/exerciseFile.js +10 -8
  330. package/es/utils/runner.js +17 -33
  331. package/package.json +15 -11
  332. package/cjs/_virtual/_rollupPluginBabelHelpers.js +0 -519
  333. package/cjs/components/index.js +0 -25
  334. package/cjs/components/locales/index.js +0 -13
  335. package/cjs/components/material-exercise/context/index.js +0 -57
  336. package/cjs/components/material-exercise/exercise-code-history/index.js +0 -7
  337. package/cjs/components/material-exercise/exercise-code-history/locales/index.js +0 -13
  338. package/cjs/components/material-exercise/exercise-file/index.js +0 -7
  339. package/cjs/components/material-exercise/exercise-file-editor/index.js +0 -7
  340. package/cjs/components/material-exercise/exercise-file-editor/locales/index.js +0 -13
  341. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/index.js +0 -7
  342. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/locales/index.js +0 -13
  343. package/cjs/components/material-exercise/exercise-file-tabs/index.js +0 -9
  344. package/cjs/components/material-exercise/exercise-file-tabs/locales/index.js +0 -13
  345. package/cjs/components/material-exercise/exercise-file-tree/index.js +0 -9
  346. package/cjs/components/material-exercise/exercise-file-tree/locales/index.js +0 -13
  347. package/cjs/components/material-exercise/exercise-file-viewer/index.js +0 -7
  348. package/cjs/components/material-exercise/exercise-menu/index.js +0 -7
  349. package/cjs/components/material-exercise/exercise-menu/locales/index.js +0 -13
  350. package/cjs/components/material-exercise/exercise-multilang-dropdown/index.js +0 -9
  351. package/cjs/components/material-exercise/exercise-preview/index.js +0 -7
  352. package/cjs/components/material-exercise/exercise-preview/locales/index.js +0 -13
  353. package/cjs/components/material-exercise/exercise-rightpane/index.js +0 -7
  354. package/cjs/components/material-exercise/exercise-rightpane/locales/index.js +0 -13
  355. package/cjs/components/material-exercise/exercise-room/helpers/index.js +0 -7
  356. package/cjs/components/material-exercise/exercise-room/index.js +0 -7
  357. package/cjs/components/material-exercise/exercise-room/locales/index.js +0 -13
  358. package/cjs/components/material-exercise/exercise-runner/index.js +0 -7
  359. package/cjs/components/material-exercise/exercise-runner/locales/index.js +0 -13
  360. package/cjs/components/material-exercise/exercise-submit-history/index.js +0 -7
  361. package/cjs/components/material-exercise/exercise-submit-history/locales/index.js +0 -13
  362. package/cjs/components/material-exercise/index.js +0 -9
  363. package/cjs/components/shared/exercise-menu-button/index.js +0 -7
  364. package/cjs/components/shared/exercise-shimmer/index.js +0 -15
  365. package/cjs/components/shared/exercise-version-list/index.js +0 -9
  366. package/cjs/components/shared/file-icon/index.js +0 -7
  367. package/cjs/components/shared/file-tabs/index.js +0 -7
  368. package/cjs/components/shared/file-tree/context/index.js +0 -9
  369. package/cjs/components/shared/file-tree/file-tree-toolbar/index.js +0 -7
  370. package/cjs/components/shared/file-tree/file-tree-toolbar/locales/index.js +0 -13
  371. package/cjs/components/shared/file-tree/index.js +0 -7
  372. package/cjs/components/shared/file-tree/locales/index.js +0 -13
  373. package/cjs/components/shared/file-tree/utils/index.js +0 -20
  374. package/cjs/components/shared/file-viewer/index.js +0 -7
  375. package/cjs/components/shared/file-viewer/locales/index.js +0 -21
  376. package/cjs/components/shared/material-modal/index.js +0 -7
  377. package/cjs/components/shared/monaco-editor/constants/index.js +0 -13
  378. package/cjs/components/shared/monaco-editor/constants/monaco/index.js +0 -11
  379. package/cjs/components/shared/monaco-editor/editor-hooks/index.js +0 -17
  380. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/index.js +0 -11
  381. package/cjs/components/shared/monaco-editor/hooks/index.js +0 -7
  382. package/cjs/components/shared/monaco-editor/index.js +0 -21
  383. package/cjs/components/shared/monaco-editor/locales/index.js +0 -13
  384. package/cjs/components/shared/monaco-editor/utils/emmet/index.js +0 -9
  385. package/cjs/components/shared/monaco-editor/utils/index.js +0 -9
  386. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/index.js +0 -12
  387. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/index.js +0 -11
  388. package/cjs/components/shared/no-vnc/index.js +0 -7
  389. package/cjs/components/shared/preview-container/index.js +0 -9
  390. package/cjs/components/shared/web-browser/index.js +0 -7
  391. package/cjs/components/shared/xterm/index.js +0 -7
  392. package/cjs/components/shared/xterm/locales/index.js +0 -13
  393. package/cjs/constants/index.js +0 -7
  394. package/cjs/hooks/index.js +0 -20
  395. package/cjs/utils/index.js +0 -10
  396. package/es/_virtual/_rollupPluginBabelHelpers.js +0 -499
  397. package/es/components/index.js +0 -8
  398. package/es/components/locales/index.js +0 -4
  399. package/es/components/material-exercise/context/index.js +0 -5
  400. package/es/components/material-exercise/exercise-code-history/index.js +0 -1
  401. package/es/components/material-exercise/exercise-code-history/locales/index.js +0 -4
  402. package/es/components/material-exercise/exercise-file/index.js +0 -1
  403. package/es/components/material-exercise/exercise-file-editor/index.js +0 -1
  404. package/es/components/material-exercise/exercise-file-editor/locales/index.js +0 -4
  405. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/index.js +0 -1
  406. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/locales/index.js +0 -4
  407. package/es/components/material-exercise/exercise-file-tabs/index.js +0 -2
  408. package/es/components/material-exercise/exercise-file-tabs/locales/index.js +0 -4
  409. package/es/components/material-exercise/exercise-file-tree/index.js +0 -2
  410. package/es/components/material-exercise/exercise-file-tree/locales/index.js +0 -4
  411. package/es/components/material-exercise/exercise-file-viewer/index.js +0 -1
  412. package/es/components/material-exercise/exercise-menu/index.js +0 -1
  413. package/es/components/material-exercise/exercise-menu/locales/index.js +0 -4
  414. package/es/components/material-exercise/exercise-multilang-dropdown/index.js +0 -2
  415. package/es/components/material-exercise/exercise-preview/index.js +0 -1
  416. package/es/components/material-exercise/exercise-preview/locales/index.js +0 -4
  417. package/es/components/material-exercise/exercise-rightpane/index.js +0 -1
  418. package/es/components/material-exercise/exercise-rightpane/locales/index.js +0 -4
  419. package/es/components/material-exercise/exercise-room/helpers/index.js +0 -1
  420. package/es/components/material-exercise/exercise-room/index.js +0 -1
  421. package/es/components/material-exercise/exercise-room/locales/index.js +0 -4
  422. package/es/components/material-exercise/exercise-runner/index.js +0 -1
  423. package/es/components/material-exercise/exercise-runner/locales/index.js +0 -4
  424. package/es/components/material-exercise/exercise-submit-history/index.js +0 -1
  425. package/es/components/material-exercise/exercise-submit-history/locales/index.js +0 -4
  426. package/es/components/material-exercise/index.js +0 -2
  427. package/es/components/shared/exercise-menu-button/index.js +0 -1
  428. package/es/components/shared/exercise-shimmer/index.js +0 -5
  429. package/es/components/shared/exercise-version-list/index.js +0 -2
  430. package/es/components/shared/file-icon/index.js +0 -1
  431. package/es/components/shared/file-tabs/index.js +0 -1
  432. package/es/components/shared/file-tree/context/index.js +0 -1
  433. package/es/components/shared/file-tree/file-tree-toolbar/index.js +0 -1
  434. package/es/components/shared/file-tree/file-tree-toolbar/locales/index.js +0 -4
  435. package/es/components/shared/file-tree/index.js +0 -1
  436. package/es/components/shared/file-tree/locales/index.js +0 -4
  437. package/es/components/shared/file-tree/utils/index.js +0 -5
  438. package/es/components/shared/file-viewer/index.js +0 -1
  439. package/es/components/shared/file-viewer/locales/index.js +0 -8
  440. package/es/components/shared/material-modal/index.js +0 -1
  441. package/es/components/shared/monaco-editor/constants/index.js +0 -2
  442. package/es/components/shared/monaco-editor/constants/monaco/index.js +0 -1
  443. package/es/components/shared/monaco-editor/editor-hooks/index.js +0 -6
  444. package/es/components/shared/monaco-editor/editor-languages/typescript/dts/index.js +0 -3
  445. package/es/components/shared/monaco-editor/hooks/index.js +0 -1
  446. package/es/components/shared/monaco-editor/index.js +0 -6
  447. package/es/components/shared/monaco-editor/locales/index.js +0 -4
  448. package/es/components/shared/monaco-editor/utils/emmet/index.js +0 -1
  449. package/es/components/shared/monaco-editor/utils/index.js +0 -2
  450. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/index.js +0 -3
  451. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/index.js +0 -2
  452. package/es/components/shared/no-vnc/index.js +0 -1
  453. package/es/components/shared/preview-container/index.js +0 -1
  454. package/es/components/shared/web-browser/index.js +0 -1
  455. package/es/components/shared/xterm/index.js +0 -1
  456. package/es/components/shared/xterm/locales/index.js +0 -4
  457. package/es/constants/index.js +0 -1
  458. package/es/hooks/index.js +0 -7
  459. package/es/utils/index.js +0 -2
@@ -3,5 +3,6 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var img = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAASwAAAEsCAYAAAB5fY51AAAACXBIWXMAABYlAAAWJQFJUiTwAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAABzySURBVHgB7d1NbFxVlgfwc1/ZjhOTpMqQMElrRKXp2dCRcCToXTfOpluaHg1hMYgdzrLFSIHWzGyTbLulDkjTYhlnxzALktGwgE2KZgdIGCmw4uOxGJgEiJ0GJyZ2vdv3vHpll8v18arqfZx77/8nFZUPT49dcf19znn33asIoMvq17pOFaqSpjopqkY6Ms/BYaKoqrSq8p+ZD6tv/x+o+GOrA/9HFa2Zj1lLfreWPMwf6ZAoMH8X3QlUEMYfE5jHFoW1YyokgA6KwEtJKC1GKuKweTwJogXqDCIZQn7Ewabpy4CCFfN5hrWjaoXAOwgsx8XBFNBCFJgqiYOJ1CLJC6VxrZivicPsoyAIGjRFK7WaWiNwFgLLIaurumpaqYWIogUVqaeEVkx540psRQf6Ha7GakdUg8AZCCyLbQeUpqcVaQ6nRYJeGprUSqDoGqowuyGwLLN6Sy+YudOimTk9HVdQw4bd0EtDK30t0EEDszC7ILCE21VFKb2EgMocz8Aa5grlFbSP8iGwBNoJqeh5pdQZhFRBFK1pra+ayuta7WF1lUAcBJYgq9/oRYSUEO3wQuUlCgKrZK2QQrsnXKttnA4umoF9SFAaBFYJuOWLtqKleHCOK3u2WYkoeqUyXbmKq43FQ2AVCNWUQ9otI6quQiGwCsBBZb65zxOqKVc1TLX8Cgb1+UNg5aSj7TtH/q0291Vo2sWLDx2dWibIBQIrY8mShHNmSPsi2j5vxcFl5lwNtIvZQmBlBEEFPYRKqWWaoisIrmwgsCaEoIIU2sH1Cq4sTgaBNSYEFYwBM64JIbDG8O3NrTOBCi4RhukwHgTXmBBYI8DyBMhYqKbVacy30kNgpRAvUdikS4r0EgFkzIwVlrEANR0E1hCmqjqPORUUYM0M5l+uHVEXCfpCYPWRtH88p1oggOKgTRwAgdUlufp33oTViwRQEm2qraC1DCIk2IbA6pBUVZcJV/9ABlxN7ILAIlRVIBuG8ju8DyxUVWAJXi1/1vfdTwPyFFdVJqwumbC6TggrkK/O36t81Zo85mWFZcKqrjf1G4QrgGAnb68keldhrd7S5/SW/pAQVmAv/oH74Xf/3/Ru5upNhYXBOrgoWf5w0ZddILwIrKQFxKwKXOVNi+h8S8g7KyQtYJ0A3BS3iKs39RlynNOBxVdUAhW8gfsAwQNVrfQbrl9FdLIljOdVm3RJY3cF8FCy0PQlF+dazgUWliwAxJycazkVWBiuA+ziXGg5M8OKb7HBcB2gU2sYb94b5AgnAmv1ln4+vsUGw3WAblV+b7iyyNT6wEp2BF0mAOhLBeqSC1cQrZ5hxWGl9QUCgFSUUhds3obZ2sBCWAGMx+bQsjKwEFYAk7E1tKwLLDNgv4wFoQCT4xunHzyiXiKLWBVYyYZ72G0BICN8werBo5WzZAlrrhImbSDCCiBDitSSTVcPraiwMLMCyJctMy3xgYWwAiiGDaElOrAQVgDFkh5aYgMr3nud9MsEAIWaCtTSoYfUFRJIZGAlZwVeJwAoham0Tks8A1FcYMVbxPCuC7iRGaBMa2panZK2NY2oZQ3b+1khrADKVuX3Ir8nSRAxFRZva8x79xD2swKQZCXZBFDEdstiKqxoky4RwgpAmoVoM7pEQogILF6+oHB/IIBIklbDl94S8rmB8VFcACCa0uqZ2sPqKpWo1MDCFUEAq5R+5bC0wMKQHcBKYRJapQzhy5thbRH3xHUCAJvUo9Z7txSlBFZ82w22igGwkjLv3bJO4Sm8JcTcCsAJpcyzCq+wsJIdwAk8g36DZ9FUoEIDK1nLUScAcMFC0fOswlpC7MAA4KYid3YoJLC2b2pGdQXgosKWOhTSEkabWMIA4LDCljrkXmF9e2trKaDgMgGA04poDXMNLLSCAF7JvTXMtyXconOEsALwRe6tYW4VVlJdfUEA4JU8W8PcKqykFQQAz2itc9vwL5fAwgJRAK8tfHezeYFykHlLiHsFAYBa9xqeyHoAP0UZ4zVXJgURVn2Y3p7AHaabIOipmuwFf5YylOm7B4P24RBYbkFgDZb1AD7TGRYG7YMFFQLHBKJO9pTHDOAzXeaQ2cvNK9oJg/aB8M3tHoV/02EWV2/qM5SRzF7ugAIRxwBJptANOgdV83Ba6UtZ7ZuVSWChukqnkvklDigbquZU6tH9KJMtlSf+mY/Tb9J74JCi6X0EDvlxQ9Pd7wmGy2SZw+Q/H3C/YGqosNwzPY0+P6VqFlXWRIEVL2PQOGI+DQ4rzDvcw/+maAvTUUqdm3SWNdlLvUXPE6qrVKamCRyFNj+1iaussetZ7HU1moNVhdBy1NYm0fdrWECa0kSzrLErrOZmc5EQVqlw24Cwchf/22LJSmoTVVljv8y3b0V8C06dYKi5g4pmZgkctrGu6d5dgnTGrrLGqrCw7io9VFd+2HdAocpKrxr9GC3RGMYKLKxqT29mVuHqoAc4rGb3E6SkAnWOxjByYH377RbfF1QnGIqDah+uIHkDVdZI6ny4Mo1o5MAKomCsZPTR/gOornzCYbV/DomV1jg7OYwUWLyUwTwtEgzFQYVBu3/27cfMcgSLo1ZZIwVWcoIzDME/aQ8exk9aX/FVYbSG6UTNaKStZ1K/rMlNzryUAdsfD4FlDPDjPaK7P2AxaQojLXFIXWE1N5uchAirIWbnEFbQag33HSAYbqQlDqkDK1AYtg/DSxj245sUEgfwwysVFainU39smg/C4RLDcVjNHSSAPda/13R/g2CAtIdVpKqwMGwfDGEFg2CmOVza4XuqwFI0+gIvX/DMCmEFw3BoYY1Wf6YtfD7Nxw0NrGSdRJ1gF75sPXcIMytIb9Z8rxx4AEse+qimWZM1NLAiTamSzye8MPBQzZT5uO0GRsRXD/l7B3dA9KCjoVkzNOtv34pWCcsZYu1bL/bhJlfIAA/i793VZn5D0DJ0TdbACiu50dn7sGoH1eF5hBVkhwfxfEcEr9dCmxir0hYtDPqAgYGlokrq9REu4oMj2kHF8wec8gtZ49aQ12txm8iDee9bxSFt4cBc97Ed5BNQ+FCBmX3Ygx3KwXvE83mH/OxhuziwLex7Uh5P7LXWzoYVBxNXTFxFcTlemTJD9BlUUVA+/kE5lZx3yIHVNI/N+2bWFbV+r/k5Ile128JGr7/sG1h8ddDFtrp2BMMCsEd87qF5TM/0/r41hQW5JllE2uj1d33rCSwWBYAyDFpE2rPCWr2lFzTFm/UB7HJvXdNX4aZ5NM2Ms2l+wpvnbyLz51H8d3x6TCe+E4AvXMwfqcTPNfM8f7RCx+v8mMbqb+ilyhlUO6pWuv+iZ2BFUbRoUo4AOIRuvL9Bn9/Yok8/uW9+mI02PNlIQqzf/93xE1N0/JEp+tnJafrpYzMmzDBEhFYGmac9gdUzlczVQT7ReZEchBnWcBxSHzQ26MZ7P9JnH29SkR79+TQ9eXoW4ZWSizOsRMP8+5/u/sM9795kZ9FVchQCq7/PPr5Pb79+t/CQ6ufkL2boicVZ84x7oPpxOLB6Lm/Y2xIOWWkKbmlXU395855p22Qt+rnx3v34UTMzr988eyAOL/BGz+UNewIr0tEZRahCfPDu/96jt/57fc+gXBoO0tf+83t6y1R/CC5/9FresCeZXJ5fMbSErdbvtT//IK6iSgsV1w6HW0K2Z47VK7CcfgV8Dizzb0vXLv9AH7//I7mAA+vXz855PZx3PLDIzLFqnXOsXS1hcjsOgXs+uL5BV5d/EN/+jYJnb599solqy2Vdc6xdP5pMz4iBu2N4qM5V1Wt//t6psGprz7f4a7x3190b7HzVnUm7AktVgqcInMEt4J/+fZXeNVcAXcdf45/+bS3+msEd5gLgYufvdzf/WqPCcsT/hVsmrG5bO1gfB3+tr15Yo6/M1w6OCOjxzt9uT6BdXzDa5sPQnedV3AL67LkXDtITp92fa7k+dGeqqU7UjqmQf71TYWHBqBN4bZXvYcX4NXj3zbsEDpjeyabtwEpuNgSLcVhdM1cCoeXa5XWElgOiraje/vV2YKkgeJzAWtwGIqz24tDi1wbsFXTMsTqG7tj/ylY8YEcb2B+/NhjE20t3XCkMOv4UMywL8WX85T/8lWCwV89jyYPF6u1fxIHFu/sRWIcXhfJlfJ+WLoyr/VphcamdVr9udYBxYDWDZp3AOm+/vo6wGgG/Vm//F4bwNmpWmov8HAeWaipUWJbh++h8WMGeNX7NMIS3j4pUfORge4ZVJ7AGz2J4bygYD19NxTzLLu0rha0KS6lHCKyBVnAyPM/6n2VcVbWJjlSNn5MKS9UJrMCtID9gMrz1spS96yGFzgoLa7DsgVYwO1i7ZpU6/ydoXy4E+biyyrsVrMWHnE5R2fi8Qv5c8sSvJW7dsQdnVUBTGLjbIu/qigPidxcO0+8uVksNLQ6r+PMwj7xDi481w9osS1SoGjRVs0ogXt7VVTus+Bh5Pj6+rNBqh9X+uSD+XPIOrfiYMyxzsENApsKKKggsC+RZXXWGVVsZodUZVm1FhNZf3kRg2aAZNauB0jtbN4BMfEUrr+qqV1i1FRlavcKqLe/Q4tcWVwzlU1qZCksRKizh3s+pZRkUVm1FhNagsGrLO7R4bRsIp80Mi/9DIBavyM7rHEEOo/0PqFQfl1dopQmrnc8jiD+XPHCFheG7bEFAhwOscpft80/uU16++mKLXj1/J9UbNY/QGiWs2rst8OecFwzfZePV7v4emWuJ93N+E5UVWtLCivGsEATjCgszLLm4HSxiGFx0aEkMK4a2UDwzdNcKgSVUnu1gt6JCS2pYtX2MKks0tISCfXqj2EvteYeW9LBin93A8gbJzHeORoUlVBkHJ+QVWjaEFfv0EwSWYFX+7kFgCcRv2rJOesk6tGwJK8aLSDHHEquKllCor8Jyf9JnFVo2hVXbV19gc0SpEFhCSXjTTBpaNoYVK/uHBfSHwBLq9jcyfsqPG1q2hhW7/Q1aQqkQWEJJOiRhnNCyNawY9suXC4El1Iawwe+ooWVrWDFUWHIhsISS0hJ2GiW0hpEaVow/N5AJgSXUhtA3TRahJTms2MY6KiypOLDWCMSR/FN+ktCSHlYMFZZYayawFAILRjZOaNkQViDaGlpCmMyoxQiKF5gAAgvGMso6q7YyT+MBJ3CFpUMCcfLaCjgL44RVmw2hJfm195wJLIUZlkSzQt80k4RVm/TQmp1D4yFVoKPoDoE4+w/Ie9NkEVZtkkNr/ggCSyJlukHeIhkVlkC1I/ke0T6qUe8NLOtgiyygJZQpiugOH/OFwBJo/qicn/Lj3Mhc5mk8k8rzlGmYgCmuAq2CkECceSEV1ri7LpR9hNgk0BLKpBW3hEETFZZAHBQSPodJdl2wNbSO16cJ5KkElbWgElVCAnHKfuNmtZ+VjaF1/ARaQpE0L2toYoYlEb95ayXNsbLefM+m0OKvXeIVWjC2KAxqx1RIINKjjxXfmuS1U6gtoXX8EazCl4qzKvmuRGhJ9OjJGSpS3tsa2xBaPzuJ+ZVQIf+n9Z2paIVAnJNP7qOiFLUHu/TQ+uljCCyhQv5P/N2J1e4y8Rv20Z/n/wYq+sAIqaHFr/U81mCJpJJ7nlvfoRoVllR5V1llnW4jMbSePD1LIFOk6Ut+blVYQYArhUI9keObqOyjuKSFFtpBuYJKEBdV8XdqpUkNApHybAvje/7W031cXjuFjhJarXsU89kB8OQvZtAOShZ1zLCwtEG2Xz87R3ng8/c4iAadgVjEtsZpQos/R/488joz8Am0g6LVjqqdCqsFoSUVV1h53ZA7KLSK3IN9UGjlHVb82hZ5RRZGtj1j3w4sraN3CMT61T/up7z0Cq0yDozoFVp5hxX7zbMHCASLWgN3tlNh4UqhaNyy5LlPU2dolXm6TWdoFRFWXF09sYh2UDKt9HY2bb8Dvv1260wQBW+Q42pH7N2c7d0379G1yz9QnvgNzMFY9lFcfAWTgzPPsGLP/etBqwNr9Rv3jyFSSp0279sG/3q7wqpsVlBhCffL3+7PfXM5DggJ5wby55B3WKG6ssRUjxlW60ohBu/SPffCQYJsYHZlhbBW2zkoZ/eKQdxTKB5fMcQVrclxZYXqygIRfdT5212BpZu4UmiDfz47h4MSJsCt4K9RXVlBk250/n5XYLWXv4NsvCL76aUHCMbDrSBWtduhO5N2t4RTaAltwcscfvlbVAmj+uU/7UcraJH21cG2XYGVDLcaBFbgtgZHUqUXt4L/gpC3SKP7D/bcpm96xo8IrBDvYBDvtoB51jAcVlmdWg3F0NHeLNrzrxeo4CqBNXgWw9uuwGBL/3EIcyvLmPnVniza++OmNcfC/lgW4T2isD6rv+deOEQ/EXSyNKTUY6a+J7CSORaG75bhIfzTZ3HlsBu/Jk+cxro1CzU6F4y29WzoTe94jcA6fOsOQmsHvxb8moB9+mVQz8AKgqBBYCV+g6I9bLWBCCt79cugvpeXbt+KVs2Tc9Ncm3drGMVX4RZd/sNfc7+BWJrZZO93X2ZWju7WEM4fDU70+ou+13g16SsE1uJBPF/G92mdFn+tv/9jDQN2y6mu23E69Q0sLG+w33zyBvZhRTyvYP/9H6tYuuACFfQtlvr2R6uruqo39RfkWFvoS0vY7YPGBr31+l3nWkRuAc8sHfT2SqCDLeGaaQdr/f6yb+3MlxS/u9m8ppR6nsB6fP8cn7v3tgktDi8X/PzJfeZK4ByqKoeYdvDq4L8fwKT3otb6OjnE1wqrk+3VFs+q+EpoXuc12sS1CksF6pnaQ6pvaA0OLAfbQgTWDtuCi9u/3zw7h+UKHRwLrIHtIBv67jVt4bJLbSECay/pwcUV1a9+y9vC7MPNy11cCizTDi6bf+uzgz9mCNfaQgRWfzfeu08fXN+gG+//SBJwy8enXqP168+pwOo4Hafvx1AKLi0iRWANd9tUWp9/sknvm/D67ONNKlK8Z/0v9qGaSsmhwOq7WLRTqhV2vIhUkTpH4AW+6jafHIHVDq9Pb2zGq+f5kaXa0YB+9tgM/fQkH64xg5Dy1KDFors/LgWX2kJUWJO5tx6Z0GrGwcVhtsonRfMpzd8044NPN9Z3/8TnQTlvMLj/QEDzRypxQHEY8kr84/UKAmpCrlRYqqlOtI4aHPJxlJJpCzmwFslyCCxwiSOBtWLawVNpPjD1jzdsOQMAeVAUvZL2Y1MHVrAvWCbsRAoA2Vqj6Urq+5ZTBxbfqoMdHAAgS3wrTq+dRfsZaeKJHRwAIFPN4OIoHz5SYCWLuhoEADC5Rporg51GvqaslBopEQEAelGBSj1sbxs5sOIqS+FUHQCYSDhoV4Z+xlq1p5sYvgPA+BRFY3VqY62itHnbGSwcBZdYunA01X2DvYxVYcVLHLQeuf8EABi3umJj38gVzAQvExaSAsBoQmpWGjSmsc9DSvZ8f8VcNTxPIFbUJLpzm29KJtq4S06amSU6NE90sIp2XzrTmV2ZPxaENKaJ/oVtnGX5NMPauk/09Zeatord0qo0U9NExx5RNDVD3rBshhWqpjo96tqrThPt7YFZlmw+hRXjr5W/5sivw66twdXVJGHFJt6MCLMsmX5Y8yus2vhr5hYYxAmDu3FWTGTiwEKVJdOd2+QtnteBLHxlsHZCTVzYZLLdY1JlhQRi3HfjrNSxuHpxwWJh7ejUMmUgk8DiKksF6iUCAOgyybqrbpltqJ3cF9QgEGH2AHmLlzmAGJlVVyzTEwCwk4Mcs3PkrUPzWI8lBS9joAxlGli8kwNfuiQo3WHzpp3y8PxR/poPOnGCpv3ik5wnXMbQLfMzlswA/kXCMofSBRWiY3W/QiteOFpHdSWCMhkw4m6iaWQeWFjmIAe/gf/+HxQdOa6cnuvwvI7vYPjJo35WlRLpSL+SdXXFcvtxdPtW9KF5WiBhsL0MuETorTljbx8zTG7H7poBPJY5AHgo60F7p9wCKx7AE1pDAJ/k1Qq25RZY8f/4dHCBsAIewBdhoCe/X3CQXAMrXgGv1FkCAOfF9wvmWF2xXAOLoTUEcF+85irDFe395B5Y8f8TtIYALgvzWHPVSyGBhdYQwF383s67FWwrJLAYWkMA92itL8aHKxek0FWUyR7w16nEBaVYOAouKXnhaG4LRPsprMJicWvYVM8Q7jUEsJuitTwXiPZTaGAx7nVVpLENDYDFdFNfLGpu1WnscwknUfu7ysvf3WrWFalzBD35cJ6gNDjfMB1ezf6geQ9TCUr7l0nmWXyDdJ0KZMMMy7fzBKWx6XzDEmZYoVpXp7I4UGIchbeEbck8i3tgzLO6IKzKhfMN+0jmVmWFFSstsFg8zwqwPquTr+cJSoPzDfdSUXHrrfopNbAYH17BazkIYj6fJygNzjfcEa+3ejg+aKZUpQcWe/DhyoUIe8HHfD5PUBpc7Gjh+wT5PUoCiAgsVmntBb9CACBJSOuBmM04xQRWx6LSkDzm83mC0uB8Q3NFsOQhezcxgcXiIbznVw59Pk9QGq/PN2xfESx5yN5NVGCxOLRUXGl5ydfzBKXx/XxDReoZaWHFxAUW47u/zQvm5XIHH88TlMb38w11pF8qcgeGUYgMLFY7qpZ9Xe7gy3mC0uB8w9byhbJuu0lD/I+R7242L5gW8TxlBNvLgEuyvDUnDishyxf6EVthtfELiIWlAPmyIayY+MBiCC2A/NgSVsyKwGJYDQ+QvXirGEvCilkTWOyhhytL2BceIBumsrpiBuwvkkWsCiz24NHKi2gPASaTtIFLZBnrAothpgUwPptmVt2sDCyG0AIYnc1hxawNLIbQAkjP9rBiVgcW438AFWkx218ASBQ1o7O2hxWzPrAYn8KjFPaHB9iDd10w742Hjk0tkwOcCCwW3zDdVKfI8/20ADqEakudknoj8zicCSzWsZ9WSAB+W5G4n9WknAosFofWtDqlsSoePMXf+2rdvbBipZz8nDfebtk8LX13sxlmudMDgHQuXAkcxLkKq1N8BTGIdy/FMB7cxsN1rZ5xOayY04HF+NxDDOPBca3huoBzA/PmfGCx7bkWbpwGx/BuC2ZedcrFeVUv3m2/aXp8vjud51oeHzEADuAxx0UzoxW7nXEevNwv2IRW3TxdN486AdiHDxx+xoRVSJ7xoiXsxv/Q5nHC/BL3IYJteKxx2sewYt6fyGCqrUXzdJlQbYFsoXmcNUHVII95WWF1Sr4BeHU8FpqCVFxVnfI9rBjOvOpgqq0lag3k6wRQvpBQVe3ifYXVyXxjLFOr2sLyBygbqqoeUGH1gSuJUBK+AvgSgqo3VFh9dF1JxK09kLf2uipUVQOgwkohqbYumMfzBJC9ZWpVVfjBOAQCawRoEyFjDWpVVQ2CVNASjqCjTTxLuJkaxhdSa6X6aYTVaFBhTQDLIGBE3PLx1b+X0f6NB4E1IRNafBM131DN8606AeyFoMoIAisjyXxriRBcsANBlTEEVsaS4FoktIo+Q1DlBIGVI8y4vMOLPvme1GUEVT4QWAUwwXXGPJ2jVuUF7mkQlicUAoFVoI4FqE8Tdjy1HVdQXE1dRVAVB4FVguTKYrvqWiCwScM8rhHavlIgsErWUXU9RZh1SYVqSggEliDJ7qdLhJZRAg4pPjbrCkJKDgSWUMmgnh8Ir+Jsh5R5rKDlkweBZYGOygttY/a22z1CSImHwLKMCS8e0i9Sq/JaJBgVBxKvl+LBecME1AqBNRBYFkuuNnKAcev4OCHA+mmYx0eEKsp6CCzHJO0jh9hTyXOd/BJSq4J6J3lGQDkEgeW4jipskVpVWJ3cWfsV0k71FP8a4eQ2BJankllYnVrh9Ujy6/ZDkpBalRIH0UfJc8PXk499h8CCPZLFrPyoJo/2rw/TTqC1/6771/2s0e7DPMKOP7uTPIedzwgl6PY3RiaOTzFx/lcAAAAASUVORK5CYII=";
6
+ var emptyImg = img;
6
7
 
7
- exports.default = img;
8
+ exports.default = emptyImg;
@@ -6,5 +6,5 @@ export interface MaterialExerciseProps extends MaterialExerciseCommonProps {
6
6
  export type MaterialExerciseApis = MaterialExerciseCommonApis;
7
7
  declare const _default: React.ForwardRefExoticComponent<Omit<import("@elice/intl").IntlComponentExtraProps & Omit<Omit<import("@elice/intl").IntlComponentExtraProps & Omit<MaterialExerciseProps, keyof import("@elice/intl").IntlComponentExtraProps | "__intl"> & {
8
8
  __intl: import("@elice/intl").EliceIntlShape;
9
- } & React.RefAttributes<MaterialExerciseCommonApis>, "ref"> & React.RefAttributes<MaterialExerciseCommonApis>, keyof import("@elice/intl").IntlComponentExtraProps | "__intl">, "ref"> & React.RefAttributes<MaterialExerciseCommonApis>>;
9
+ } & React.RefAttributes<MaterialExerciseCommonApis> & import("@elice/material-shared-utils").MaterialCommponentCommonProps, "ref"> & React.RefAttributes<MaterialExerciseCommonApis>, keyof import("@elice/intl").IntlComponentExtraProps | "__intl">, "ref"> & React.RefAttributes<MaterialExerciseCommonApis>>;
10
10
  export default _default;
@@ -2,7 +2,6 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var jsxRuntime = require('react/jsx-runtime');
6
5
  var React = require('react');
7
6
  var apiClient = require('@elice/api-client');
8
7
  var blocks = require('@elice/blocks');
@@ -32,113 +31,100 @@ var ExerciseRightpane = require('./exercise-rightpane/ExerciseRightpane.js');
32
31
  var ExerciseRunner = require('./exercise-runner/ExerciseRunner.js');
33
32
  var MaterialExercise_styled = require('./MaterialExercise.styled.js');
34
33
 
35
- function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
36
-
37
- var React__default = /*#__PURE__*/_interopDefaultCompat(React);
38
-
39
34
  //
40
35
  //
41
36
  //
42
37
  /**
43
38
  * Material exercise.
44
39
  */
45
- var MaterialExercise = React.forwardRef(function (props, ref) {
46
- var __intl = props.__intl;
47
- var _React$useContext = React__default.default.useContext(context.ExerciseContext),
48
- onReferenceDocsToggle = _React$useContext.onReferenceDocsToggle;
49
- var _useRecoilValue = recoil.useRecoilValue(recoil$1.exerciseContainerSizeState),
50
- width = _useRecoilValue.width,
51
- height = _useRecoilValue.height;
52
- var exercise = recoil.useRecoilValue(recoil$1.exerciseState(props.materialExerciseId));
53
- var exerciseFileTreeOpened = recoil.useRecoilValue(recoil$1.exerciseFileTreeOpenedState);
54
- var exercisePreviewType = recoil.useRecoilValue(recoil$1.exercisePreviewTypeState(props.materialExerciseId));
55
- var exercisePreviewDisplayMode = recoil.useRecoilValue(recoil$1.exercisePreviewDisplayModeState);
56
- var exerciseMonacoEditorApis = recoil.useRecoilValue(recoil$1.exerciseMonacoEditorApisState);
40
+ const MaterialExercise = React.forwardRef((props, ref) => {
41
+ const {
42
+ __intl
43
+ } = props;
44
+ const {
45
+ onReferenceDocsToggle
46
+ } = React.useContext(context.ExerciseContext);
47
+ const {
48
+ width,
49
+ height
50
+ } = recoil.useRecoilValue(recoil$1.exerciseContainerSizeState);
51
+ const exercise = recoil.useRecoilValue(recoil$1.exerciseState(props.materialExerciseId));
52
+ const exerciseFileTreeOpened = recoil.useRecoilValue(recoil$1.exerciseFileTreeOpenedState);
53
+ const exercisePreviewType = recoil.useRecoilValue(recoil$1.exercisePreviewTypeState(props.materialExerciseId));
54
+ const exercisePreviewDisplayMode = recoil.useRecoilValue(recoil$1.exercisePreviewDisplayModeState);
55
+ const exerciseMonacoEditorApis = recoil.useRecoilValue(recoil$1.exerciseMonacoEditorApisState);
57
56
  /**
58
57
  * File tree
59
58
  */
60
- var renderExerciseFileTree = function renderExerciseFileTree() {
61
- return jsxRuntime.jsx(MaterialExercise_styled.StyledxerciseFileTreeContaner, {
62
- "aria-hidden": !exerciseFileTreeOpened,
63
- children: jsxRuntime.jsx(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
64
- initialWidth: Math.max(MaterialExercise_styled.EXERCISE_FILE_TREE_MIN_WIDTH, width * MaterialExercise_styled.EXERCISE_HORIZONTAL_RATIO.FILETREE),
65
- minConstraints: [MaterialExercise_styled.EXERCISE_FILE_TREE_MIN_WIDTH, Infinity],
66
- resizeHandles: ['e'],
67
- children: jsxRuntime.jsx(MaterialExercise_styled.StyledExerciseFileTreeWrap, {
68
- children: jsxRuntime.jsx(ExerciseFileTreeLazy.default, {})
69
- })
70
- }))
71
- });
59
+ const renderExerciseFileTree = () => {
60
+ return React.createElement(MaterialExercise_styled.StyledxerciseFileTreeContaner, {
61
+ "aria-hidden": !exerciseFileTreeOpened
62
+ }, React.createElement(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
63
+ initialWidth: Math.max(MaterialExercise_styled.EXERCISE_FILE_TREE_MIN_WIDTH, width * MaterialExercise_styled.EXERCISE_HORIZONTAL_RATIO.FILETREE),
64
+ minConstraints: [MaterialExercise_styled.EXERCISE_FILE_TREE_MIN_WIDTH, Infinity],
65
+ resizeHandles: ['e']
66
+ }), React.createElement(MaterialExercise_styled.StyledExerciseFileTreeWrap, null, React.createElement(ExerciseFileTreeLazy.default, null))));
72
67
  };
73
68
  /**
74
69
  * File tree toggle button
75
70
  */
76
- var renderExerciseFileTreeButton = function renderExerciseFileTreeButton() {
77
- return jsxRuntime.jsx(ExerciseFileTabsFileTreeButton.default, {});
71
+ const renderExerciseFileTreeButton = () => {
72
+ return React.createElement(ExerciseFileTabsFileTreeButton.default, null);
78
73
  };
79
74
  /**
80
75
  * File tabs
81
76
  */
82
- var renderExerciseFileTabs = function renderExerciseFileTabs() {
83
- return jsxRuntime.jsx(MaterialExercise_styled.StyledExerciseTabsWrap, {
84
- children: jsxRuntime.jsx(ExerciseFileTabsLazy.default, {})
85
- });
77
+ const renderExerciseFileTabs = () => {
78
+ return React.createElement(MaterialExercise_styled.StyledExerciseTabsWrap, null, React.createElement(ExerciseFileTabsLazy.default, null));
86
79
  };
87
80
  /**
88
81
  * reference docs toggle button
89
82
  */
90
- var renderExerciseReferenceDocsToggleButton = function renderExerciseReferenceDocsToggleButton() {
83
+ const renderExerciseReferenceDocsToggleButton = () => {
91
84
  if (typeof onReferenceDocsToggle !== 'function') {
92
85
  return null;
93
86
  }
94
- return jsxRuntime.jsxs(jsxRuntime.Fragment, {
95
- children: [jsxRuntime.jsxs(blocks.Button, {
96
- size: "micro",
97
- role: "navy3",
98
- style: {
99
- width: '100%'
100
- },
101
- onClick: onReferenceDocsToggle,
102
- children: [jsxRuntime.jsx(blocks.Icon, {
103
- icon: icons.eilClassroom
104
- }), jsxRuntime.jsx(blocks.Hspace, {
105
- width: 0.25
106
- }), __intl.formatMessage({
107
- id: 'materialExercise.button.referenceDocs'
108
- })]
109
- }), jsxRuntime.jsx(blocks.Hspace, {
110
- width: 0.5
111
- })]
112
- });
87
+ return React.createElement(React.Fragment, null, React.createElement(blocks.Button, {
88
+ size: "micro",
89
+ role: "navy3",
90
+ style: {
91
+ width: '100%'
92
+ },
93
+ onClick: onReferenceDocsToggle
94
+ }, React.createElement(blocks.Icon, {
95
+ icon: icons.eilClassroom
96
+ }), React.createElement(blocks.Hspace, {
97
+ width: 0.25
98
+ }), __intl.formatMessage({
99
+ id: 'materialExercise.button.referenceDocs'
100
+ })), React.createElement(blocks.Hspace, {
101
+ width: 0.5
102
+ }));
113
103
  };
114
104
  /**
115
105
  * Menu
116
106
  */
117
- var renderExerciseMenu = function renderExerciseMenu() {
118
- return jsxRuntime.jsxs(MaterialExercise_styled.StyledExerciseTabMenuWrap, {
119
- children: [renderExerciseReferenceDocsToggleButton(), jsxRuntime.jsx(ExerciseMultilangDropdownLazy.default, {}), jsxRuntime.jsx(ExerciseMenu.default, {})]
120
- });
107
+ const renderExerciseMenu = () => {
108
+ return React.createElement(MaterialExercise_styled.StyledExerciseTabMenuWrap, null, renderExerciseReferenceDocsToggleButton(), React.createElement(ExerciseMultilangDropdownLazy.default, null), React.createElement(ExerciseMenu.default, null));
121
109
  };
122
110
  /**
123
111
  * Code editor and file viewer
124
112
  */
125
- var renderExerciseFile = function renderExerciseFile() {
126
- return jsxRuntime.jsx(MaterialExercise_styled.StyledExerciseFileWrap, {
127
- children: jsxRuntime.jsx(ExerciseFile.default, {})
128
- });
113
+ const renderExerciseFile = () => {
114
+ return React.createElement(MaterialExercise_styled.StyledExerciseFileWrap, null, React.createElement(ExerciseFile.default, null));
129
115
  };
130
116
  /**
131
117
  * Exercise preview (side by side)
132
118
  */
133
- var renderExercisePreviewSideBySide = function renderExercisePreviewSideBySide() {
119
+ const renderExercisePreviewSideBySide = () => {
134
120
  if (exercisePreviewType === recoilTypes.ExercisePreviewType.None) {
135
121
  return null;
136
122
  }
137
123
  if (exercisePreviewDisplayMode !== recoilTypes.ExercisePreviewDisplayMode.SideBySide) {
138
124
  return null;
139
125
  }
140
- return jsxRuntime.jsx(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
141
- children: jsxRuntime.jsx(ExercisePreview.default, {}),
126
+ return React.createElement(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
127
+ children: React.createElement(ExercisePreview.default, null),
142
128
  initialWidth: Math.max(MaterialExercise_styled.EXERCISE_PREVIEW_MIN_WIDTH, width * MaterialExercise_styled.EXERCISE_HORIZONTAL_RATIO.PREVIEW),
143
129
  minConstraints: [MaterialExercise_styled.EXERCISE_PREVIEW_MIN_WIDTH, Infinity],
144
130
  resizeHandles: ['w']
@@ -147,74 +133,52 @@ var MaterialExercise = React.forwardRef(function (props, ref) {
147
133
  /**
148
134
  * Exercise main
149
135
  */
150
- var renderExerciseMain = function renderExerciseMain() {
136
+ const renderExerciseMain = () => {
151
137
  if (exercise === null || exercise === void 0 ? void 0 : exercise.uiConfig.isEditorDisabled) {
152
138
  return null;
153
139
  }
154
- return jsxRuntime.jsxs(MaterialExercise_styled.StyledExerciseMain, {
155
- children: [renderExerciseFileTree(), jsxRuntime.jsxs(MaterialExercise_styled.StyledExerciseFileAndTabWrap, {
156
- children: [jsxRuntime.jsxs(MaterialExercise_styled.StyledExerciseTabBar, {
157
- children: [renderExerciseFileTreeButton(), renderExerciseFileTabs(), renderExerciseMenu()]
158
- }), renderExerciseFile()]
159
- }), jsxRuntime.jsx(ExerciseRightpane.default, {})]
160
- });
140
+ return React.createElement(MaterialExercise_styled.StyledExerciseMain, null, renderExerciseFileTree(), React.createElement(MaterialExercise_styled.StyledExerciseFileAndTabWrap, null, React.createElement(MaterialExercise_styled.StyledExerciseTabBar, null, renderExerciseFileTreeButton(), renderExerciseFileTabs(), renderExerciseMenu()), renderExerciseFile()), React.createElement(ExerciseRightpane.default, null));
161
141
  };
162
142
  /**
163
143
  * Exercise Runner
164
144
  */
165
- var renderExerciseRunner = function renderExerciseRunner() {
166
- var _runner = jsxRuntime.jsx(MaterialExercise_styled.StyledExerciseRunnerWrap, {
167
- children: jsxRuntime.jsx(ExerciseRunner.default, {
168
- exercisePreview: jsxRuntime.jsx(ExercisePreview.default, {})
169
- })
170
- });
145
+ const renderExerciseRunner = () => {
146
+ const _runner = React.createElement(MaterialExercise_styled.StyledExerciseRunnerWrap, null, React.createElement(ExerciseRunner.default, {
147
+ exercisePreview: React.createElement(ExercisePreview.default, null)
148
+ }));
171
149
  if (exercise === null || exercise === void 0 ? void 0 : exercise.uiConfig.isEditorDisabled) {
172
150
  return _runner;
173
151
  }
174
- return jsxRuntime.jsx(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
152
+ return React.createElement(blocks.ResizableNext, Object.assign({}, stylesheets.MATERIAL_RESIZABLE_COMMON_PROPS, {
175
153
  initialHeight: Math.max(MaterialExercise_styled.EXERCISE_RUNNER_MIN_HEIGHT, height * 0.35),
176
154
  minConstraints: [Infinity, MaterialExercise_styled.EXERCISE_RUNNER_MIN_HEIGHT],
177
- resizeHandles: ['n'],
178
- children: _runner
179
- }));
155
+ resizeHandles: ['n']
156
+ }), _runner);
180
157
  };
181
158
  //
182
159
  //
183
160
  //
184
- React__default.default.useImperativeHandle(ref, function () {
185
- return {
186
- sendTextToRunner: function sendTextToRunner(text) {
187
- subjects.exerciseRunnerTextSend$.next(text);
188
- },
189
- getMonacoEditorApis: function getMonacoEditorApis() {
190
- return exerciseMonacoEditorApis;
191
- },
192
- openRunnerRooms: function openRunnerRooms() {
193
- return subjects.exerciseRunnerRoomsOpen$.next();
194
- }
195
- };
196
- }, [exerciseMonacoEditorApis]);
161
+ React.useImperativeHandle(ref, () => ({
162
+ sendTextToRunner: text => {
163
+ subjects.exerciseRunnerTextSend$.next(text);
164
+ },
165
+ getMonacoEditorApis: () => exerciseMonacoEditorApis,
166
+ openRunnerRooms: () => subjects.exerciseRunnerRoomsOpen$.next()
167
+ }), [exerciseMonacoEditorApis]);
197
168
  //
198
169
  //
199
170
  //
200
- return jsxRuntime.jsxs(jsxRuntime.Fragment, {
201
- children: [jsxRuntime.jsxs(MaterialExercise_styled.StyledExerciseContainer, {
202
- children: [renderExerciseMain(), renderExerciseRunner()]
203
- }), renderExercisePreviewSideBySide()]
204
- });
171
+ return React.createElement(React.Fragment, null, React.createElement(MaterialExercise_styled.StyledExerciseContainer, null, renderExerciseMain(), renderExerciseRunner()), renderExercisePreviewSideBySide());
205
172
  });
206
173
  //
207
174
  //
208
175
  //
209
- var MaterialExercise$1 = new intl.IntlComponentBuilder(materialSharedUtils.withForwardRefMaterial(React.forwardRef(function (props, ref) {
210
- return jsxRuntime.jsx(intl.RawEliceIntlProvider, {
211
- value: props.__intl,
212
- children: jsxRuntime.jsx(ExerciseProvider.default, Object.assign({}, props, {
213
- children: jsxRuntime.jsx(MaterialExercise, Object.assign({}, props, {
214
- ref: ref
215
- }))
216
- }))
217
- });
176
+ var MaterialExercise$1 = new intl.IntlComponentBuilder(materialSharedUtils.withForwardRefMaterial(React.forwardRef((props, ref) => {
177
+ return React.createElement(intl.RawEliceIntlProvider, {
178
+ value: props.__intl
179
+ }, React.createElement(ExerciseProvider.default, Object.assign({}, props), React.createElement(MaterialExercise, Object.assign({}, props, {
180
+ ref: ref
181
+ }))));
218
182
  }), apiClient.config.init, {
219
183
  overrideRecoilScope: true
220
184
  })).add('en', en.default).add('ko', ko.default).addAsync('th', Promise.resolve().then(function () { return require('../locales/th.json.js'); })).addAsync('ja', Promise.resolve().then(function () { return require('../locales/ja.json.js'); })).build();
@@ -4,14 +4,10 @@ var designTokens = require('@elice/design-tokens');
4
4
  var styled = require('styled-components');
5
5
  var stylesheets = require('../../constants/stylesheets.js');
6
6
 
7
- function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
8
-
9
- var styled__default = /*#__PURE__*/_interopDefaultCompat(styled);
10
-
11
- var EXERCISE_FILE_TREE_MIN_WIDTH = 128;
12
- var EXERCISE_PREVIEW_MIN_WIDTH = 128;
13
- var EXERCISE_RUNNER_MIN_HEIGHT = 128;
14
- var EXERCISE_HORIZONTAL_RATIO = {
7
+ const EXERCISE_FILE_TREE_MIN_WIDTH = 128;
8
+ const EXERCISE_PREVIEW_MIN_WIDTH = 128;
9
+ const EXERCISE_RUNNER_MIN_HEIGHT = 128;
10
+ const EXERCISE_HORIZONTAL_RATIO = {
15
11
  FILETREE: 0.15,
16
12
  EDITOR: 0.45,
17
13
  PREVIEW: 0.4
@@ -23,7 +19,7 @@ var EXERCISE_HORIZONTAL_RATIO = {
23
19
  * - File (Editor)
24
20
  * - Runner
25
21
  */
26
- var StyledExerciseContainer = styled__default.default.div.withConfig({
22
+ const StyledExerciseContainer = styled.div.withConfig({
27
23
  componentId: "sc-9joi7g-0"
28
24
  })(["flex:1;display:flex;flex-direction:column;height:100%;min-width:0;min-height:0;"]);
29
25
  /**
@@ -32,7 +28,7 @@ var StyledExerciseContainer = styled__default.default.div.withConfig({
32
28
  * - FileTabs
33
29
  * - File (Editor)
34
30
  */
35
- var StyledExerciseMain = styled__default.default.div.withConfig({
31
+ const StyledExerciseMain = styled.div.withConfig({
36
32
  componentId: "sc-9joi7g-1"
37
33
  })(["flex:1;display:flex;width:100%;min-width:0;min-height:0;"]);
38
34
  /**
@@ -40,31 +36,31 @@ var StyledExerciseMain = styled__default.default.div.withConfig({
40
36
  * - FileTabs
41
37
  * - File (Editor)
42
38
  */
43
- var StyledExerciseFileAndTabWrap = styled__default.default.div.withConfig({
39
+ const StyledExerciseFileAndTabWrap = styled.div.withConfig({
44
40
  componentId: "sc-9joi7g-2"
45
41
  })(["flex:1;display:flex;flex-direction:column;height:100%;min-width:0;min-height:0;background-color:", ";"], designTokens.base.color.navy9);
46
- var StyledExerciseFileWrap = styled__default.default.div.withConfig({
42
+ const StyledExerciseFileWrap = styled.div.withConfig({
47
43
  componentId: "sc-9joi7g-3"
48
44
  })(["flex:1;min-height:0;"]);
49
45
  // ========== Exercise FileTab ==========
50
- var StyledExerciseTabBar = styled__default.default.div.withConfig({
46
+ const StyledExerciseTabBar = styled.div.withConfig({
51
47
  componentId: "sc-9joi7g-4"
52
48
  })(["display:flex;border-bottom:", ";"], stylesheets.MATERIAL_DIVIDER_BORDER_VALUE);
53
- var StyledExerciseTabsWrap = styled__default.default.div.withConfig({
49
+ const StyledExerciseTabsWrap = styled.div.withConfig({
54
50
  componentId: "sc-9joi7g-5"
55
51
  })(["flex:1;min-width:0;"]);
56
- var StyledExerciseTabMenuWrap = styled__default.default.div.withConfig({
52
+ const StyledExerciseTabMenuWrap = styled.div.withConfig({
57
53
  componentId: "sc-9joi7g-6"
58
54
  })(["display:flex;justify-content:center;align-items:center;padding:0 0.5rem 0 1rem;background-color:", ";"], designTokens.base.color.navy8);
59
55
  // ========== Exercise FileTree ==========
60
- var StyledExerciseFileTreeWrap = styled__default.default.div.withConfig({
56
+ const StyledExerciseFileTreeWrap = styled.div.withConfig({
61
57
  componentId: "sc-9joi7g-7"
62
58
  })(["flex:1;display:flex;flex-direction:column;min-width:0;height:100%;border-right:", ";"], stylesheets.MATERIAL_DIVIDER_BORDER_VALUE);
63
- var StyledxerciseFileTreeContaner = styled__default.default.div.withConfig({
59
+ const StyledxerciseFileTreeContaner = styled.div.withConfig({
64
60
  componentId: "sc-9joi7g-8"
65
61
  })(["display:flex;height:100%;max-width:auto;&[aria-hidden='true']{max-width:0;overflow:hidden;}"]);
66
62
  // ========== Exercise Runner ==========
67
- var StyledExerciseRunnerWrap = styled__default.default.div.withConfig({
63
+ const StyledExerciseRunnerWrap = styled.div.withConfig({
68
64
  componentId: "sc-9joi7g-9"
69
65
  })(["width:100%;height:100%;border-top:", ";"], stylesheets.MATERIAL_DIVIDER_BORDER_VALUE);
70
66
 
@@ -4,5 +4,5 @@ type PickedMaterialExerciseCommonProps = Pick<MaterialExerciseCommonProps, 'mate
4
4
  export interface MaterialExerciseMobileProps extends PickedMaterialExerciseCommonProps {
5
5
  filename: string;
6
6
  }
7
- declare const _default: React.VFC<MaterialExerciseMobileProps>;
7
+ declare const _default: React.VFC<MaterialExerciseMobileProps & import("@elice/material-shared-utils").MaterialCommponentCommonProps>;
8
8
  export default _default;
@@ -2,7 +2,6 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var jsxRuntime = require('react/jsx-runtime');
6
5
  var React = require('react');
7
6
  var apiClient = require('@elice/api-client');
8
7
  var materialSharedUtils = require('@elice/material-shared-utils');
@@ -14,37 +13,28 @@ require('./context/subjects.js');
14
13
  var ExerciseProvider = require('./context/ExerciseProvider.js');
15
14
  var ExerciseFile = require('./exercise-file/ExerciseFile.js');
16
15
 
17
- function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
18
-
19
- var React__default = /*#__PURE__*/_interopDefaultCompat(React);
20
-
21
16
  //
22
17
  //
23
18
  //
24
19
  /**
25
20
  * Material exercise.
26
21
  */
27
- var MaterialExerciseMobile = function MaterialExerciseMobile(_ref) {
28
- var filename = _ref.filename;
29
- var setExerciseActiveFilename = recoil.useSetRecoilState(recoil$1.exerciseActiveFilenameState);
30
- React__default.default.useEffect(function () {
31
- return setExerciseActiveFilename(filename);
32
- },
22
+ const MaterialExerciseMobile = ({
23
+ filename
24
+ }) => {
25
+ const setExerciseActiveFilename = recoil.useSetRecoilState(recoil$1.exerciseActiveFilenameState);
26
+ React.useEffect(() => setExerciseActiveFilename(filename),
33
27
  // eslint-disable-next-line react-hooks/exhaustive-deps
34
28
  [filename]);
35
29
  //
36
30
  //
37
31
  //
38
- return jsxRuntime.jsx(ExerciseFile.default, {});
32
+ return React.createElement(ExerciseFile.default, null);
39
33
  };
40
34
  //
41
35
  //
42
36
  //
43
- var MaterialExerciseMobile$1 = materialSharedUtils.withMaterial(function (props) {
44
- return jsxRuntime.jsx(ExerciseProvider.default, Object.assign({}, props, {
45
- children: jsxRuntime.jsx(MaterialExerciseMobile, Object.assign({}, props))
46
- }));
47
- }, apiClient.config.init, {
37
+ var MaterialExerciseMobile$1 = materialSharedUtils.withMaterial(props => React.createElement(ExerciseProvider.default, Object.assign({}, props), React.createElement(MaterialExerciseMobile, Object.assign({}, props))), apiClient.config.init, {
48
38
  overrideRecoilScope: true
49
39
  });
50
40