@elice/material-exercise 1.231212.0 → 1.231228.0

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 (395) hide show
  1. package/cjs/components/material-exercise/MaterialExercise.i18n.js +2 -4
  2. package/cjs/components/material-exercise/MaterialExercise.js +54 -59
  3. package/cjs/components/material-exercise/MaterialExercise.styled.js +14 -20
  4. package/cjs/components/material-exercise/MaterialExerciseMobile.js +8 -15
  5. package/cjs/components/material-exercise/context/ExerciseIntlProvider.js +14 -18
  6. package/cjs/components/material-exercise/context/ExerciseProvider.js +58 -66
  7. package/cjs/components/material-exercise/context/ExerciseProviderNoImage.js +19 -24
  8. package/cjs/components/material-exercise/context/context.js +1 -7
  9. package/cjs/components/material-exercise/context/locales/noImage.en.json.js +1 -1
  10. package/cjs/components/material-exercise/context/locales/noImage.ko.json.js +1 -1
  11. package/cjs/components/material-exercise/context/recoil.js +293 -544
  12. package/cjs/components/material-exercise/context/recoilTypes.js +0 -2
  13. package/cjs/components/material-exercise/context/subjects.js +3 -5
  14. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +60 -67
  15. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -14
  16. package/cjs/components/material-exercise/exercise-code-history/locales/en.json.js +1 -1
  17. package/cjs/components/material-exercise/exercise-code-history/locales/ko.json.js +1 -1
  18. package/cjs/components/material-exercise/exercise-file/ExerciseFile.js +17 -21
  19. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +133 -203
  20. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +8 -12
  21. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +24 -40
  22. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsFileTreeButton.js +38 -52
  23. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +5 -9
  24. package/cjs/components/material-exercise/exercise-file-tabs/locales/fileTreeButton.en.json.js +1 -1
  25. package/cjs/components/material-exercise/exercise-file-tabs/locales/fileTreeButton.ko.json.js +1 -1
  26. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +189 -328
  27. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +5 -9
  28. package/cjs/components/material-exercise/exercise-file-tree/locales/en.json.js +1 -1
  29. package/cjs/components/material-exercise/exercise-file-tree/locales/ko.json.js +1 -1
  30. package/cjs/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +14 -17
  31. package/cjs/components/material-exercise/exercise-menu/ExerciseMenu.js +11 -15
  32. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +7 -11
  33. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +44 -65
  34. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +32 -61
  35. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuReset.js +19 -35
  36. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +48 -62
  37. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +12 -18
  38. package/cjs/components/material-exercise/exercise-menu/locales/en.json.js +1 -1
  39. package/cjs/components/material-exercise/exercise-menu/locales/ko.json.js +1 -1
  40. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +21 -32
  41. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +4 -8
  42. package/cjs/components/material-exercise/exercise-preview/ExercisePreview.js +23 -27
  43. package/cjs/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +7 -17
  44. package/cjs/components/material-exercise/exercise-preview/locales/en.json.js +1 -1
  45. package/cjs/components/material-exercise/exercise-preview/locales/ko.json.js +1 -1
  46. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +23 -32
  47. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +7 -15
  48. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +79 -86
  49. package/cjs/components/material-exercise/exercise-rightpane/locales/en.json.js +1 -1
  50. package/cjs/components/material-exercise/exercise-rightpane/locales/ko.json.js +1 -1
  51. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.js +11 -22
  52. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -20
  53. package/cjs/components/material-exercise/exercise-room/ExerciseRoomDetail.js +180 -288
  54. package/cjs/components/material-exercise/exercise-room/ExerciseRoomList.js +82 -116
  55. package/cjs/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -4
  56. package/cjs/components/material-exercise/exercise-room/locales/en.json.js +1 -1
  57. package/cjs/components/material-exercise/exercise-room/locales/ko.json.js +1 -1
  58. package/cjs/components/material-exercise/exercise-runner/ExerciseRunner.js +125 -181
  59. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -7
  60. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerController.js +13 -17
  61. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +43 -58
  62. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +15 -27
  63. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +65 -68
  64. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +23 -32
  65. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +58 -92
  66. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +3 -7
  67. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +11 -16
  68. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +18 -29
  69. package/cjs/components/material-exercise/exercise-runner/locales/en.json.js +1 -1
  70. package/cjs/components/material-exercise/exercise-runner/locales/ko.json.js +1 -1
  71. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +162 -282
  72. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -14
  73. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +41 -54
  74. package/cjs/components/material-exercise/exercise-submit-history/locales/en.json.js +1 -1
  75. package/cjs/components/material-exercise/exercise-submit-history/locales/ko.json.js +1 -1
  76. package/cjs/components/shared/exercise-menu-button/ExerciseMenuButton.js +15 -21
  77. package/cjs/components/shared/exercise-shimmer/ExerciseFileShimmer.js +14 -19
  78. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +16 -21
  79. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +5 -10
  80. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +18 -23
  81. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +10 -21
  82. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.js +5 -8
  83. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -7
  84. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.js +8 -11
  85. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -15
  86. package/cjs/components/shared/file-icon/FileIcon.js +17 -23
  87. package/cjs/components/shared/file-tabs/FileTab.js +30 -36
  88. package/cjs/components/shared/file-tabs/FileTab.styled.js +15 -25
  89. package/cjs/components/shared/file-tabs/FileTabs.js +38 -63
  90. package/cjs/components/shared/file-tabs/FileTabs.styled.js +2 -8
  91. package/cjs/components/shared/file-tabs/util.js +14 -29
  92. package/cjs/components/shared/file-tree/FileTree.js +12 -17
  93. package/cjs/components/shared/file-tree/FileTreeConfig.js +22 -25
  94. package/cjs/components/shared/file-tree/FileTreeList.js +37 -39
  95. package/cjs/components/shared/file-tree/FileTreeListItemContent.js +61 -75
  96. package/cjs/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -31
  97. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.js +64 -72
  98. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -12
  99. package/cjs/components/shared/file-tree/FileTreeListItemContentMenu.js +63 -74
  100. package/cjs/components/shared/file-tree/FileTreeListItems.js +136 -151
  101. package/cjs/components/shared/file-tree/FileTreeListItems.styled.js +2 -8
  102. package/cjs/components/shared/file-tree/FileTreeToolbar.js +31 -32
  103. package/cjs/components/shared/file-tree/FileTreeToolbar.styled.js +1 -7
  104. package/cjs/components/shared/file-tree/context/FileTreeContext.js +76 -97
  105. package/cjs/components/shared/file-tree/locales/en.json.js +1 -1
  106. package/cjs/components/shared/file-tree/locales/ko.json.js +1 -1
  107. package/cjs/components/shared/file-tree/utils/fileTreeFiles.js +20 -26
  108. package/cjs/components/shared/file-tree/utils/fileTreeGenerator.js +146 -195
  109. package/cjs/components/shared/file-tree/utils/fileTreeInput.js +0 -2
  110. package/cjs/components/shared/file-tree/utils/fileTreeItem.js +1 -3
  111. package/cjs/components/shared/file-tree/utils/fileTreePath.js +6 -7
  112. package/cjs/components/shared/file-viewer/FileViewer.js +37 -61
  113. package/cjs/components/shared/file-viewer/FileViewerCsv.js +108 -172
  114. package/cjs/components/shared/file-viewer/FileViewerImage.js +8 -12
  115. package/cjs/components/shared/file-viewer/FileViewerIpynb.js +10 -23
  116. package/cjs/components/shared/file-viewer/FileViewerNonViewable.js +33 -42
  117. package/cjs/components/shared/file-viewer/FileViewerText.js +12 -24
  118. package/cjs/components/shared/file-viewer/locales/en.json.js +1 -1
  119. package/cjs/components/shared/file-viewer/locales/ko.json.js +1 -1
  120. package/cjs/components/shared/file-viewer/locales/nonViewable.en.json.js +1 -1
  121. package/cjs/components/shared/file-viewer/locales/nonViewable.ko.json.js +1 -1
  122. package/cjs/components/shared/material-modal/MaterialModal.js +11 -14
  123. package/cjs/components/shared/material-modal/MaterialModal.styled.js +5 -11
  124. package/cjs/components/shared/monaco-editor/MonacoEditor.js +74 -99
  125. package/cjs/components/shared/monaco-editor/MonacoEditorLazy.js +6 -12
  126. package/cjs/components/shared/monaco-editor/MonacoEditorMobile.js +36 -50
  127. package/cjs/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +91 -110
  128. package/cjs/components/shared/monaco-editor/constants/grammars/JSON.tmLanguage.json.js +1 -1
  129. package/cjs/components/shared/monaco-editor/constants/grammars/MagicPython.tmLanguage.json.js +1 -1
  130. package/cjs/components/shared/monaco-editor/constants/grammars/TypeScriptReact.tmLanguage.json.js +1 -1
  131. package/cjs/components/shared/monaco-editor/constants/grammars/asp-vb-net.tmlanguage.json.js +1 -1
  132. package/cjs/components/shared/monaco-editor/constants/grammars/c.tmLanguage.json.js +1 -1
  133. package/cjs/components/shared/monaco-editor/constants/grammars/cpp.tmLanguage.json.js +1 -1
  134. package/cjs/components/shared/monaco-editor/constants/grammars/csharp.tmLanguage.json.js +1 -1
  135. package/cjs/components/shared/monaco-editor/constants/grammars/css.tmLanguage.json.js +1 -1
  136. package/cjs/components/shared/monaco-editor/constants/grammars/dart.tmLanguage.json.js +1 -1
  137. package/cjs/components/shared/monaco-editor/constants/grammars/fsharp.tmLanguage.json.js +1 -1
  138. package/cjs/components/shared/monaco-editor/constants/grammars/go.tmLanguage.json.js +1 -1
  139. package/cjs/components/shared/monaco-editor/constants/grammars/html.tmLanguage.json.js +1 -1
  140. package/cjs/components/shared/monaco-editor/constants/grammars/index.js +28 -84
  141. package/cjs/components/shared/monaco-editor/constants/grammars/java.tmLanguage.json.js +1 -1
  142. package/cjs/components/shared/monaco-editor/constants/grammars/lua.tmLanguage.json.js +1 -1
  143. package/cjs/components/shared/monaco-editor/constants/grammars/objective-c.tmLanguage.json.js +1 -1
  144. package/cjs/components/shared/monaco-editor/constants/grammars/php.tmLanguage.json.js +1 -1
  145. package/cjs/components/shared/monaco-editor/constants/grammars/r.tmLanguage.json.js +1 -1
  146. package/cjs/components/shared/monaco-editor/constants/grammars/ruby.tmLanguage.json.js +1 -1
  147. package/cjs/components/shared/monaco-editor/constants/grammars/rust.tmLanguage.json.js +1 -1
  148. package/cjs/components/shared/monaco-editor/constants/grammars/scss.tmLanguage.json.js +1 -1
  149. package/cjs/components/shared/monaco-editor/constants/grammars/sql.tmLanguage.json.js +1 -1
  150. package/cjs/components/shared/monaco-editor/constants/grammars/swift.tmLanguage.json.js +1 -1
  151. package/cjs/components/shared/monaco-editor/constants/grammars/xml.tmLanguage.json.js +1 -1
  152. package/cjs/components/shared/monaco-editor/constants/grammars/yaml.tmLanguage.json.js +1 -1
  153. package/cjs/components/shared/monaco-editor/constants/monaco/preferences.js +5 -7
  154. package/cjs/components/shared/monaco-editor/constants/themes/abyss.json.js +1 -1
  155. package/cjs/components/shared/monaco-editor/constants/themes/elice.json.js +1 -1
  156. package/cjs/components/shared/monaco-editor/constants/themes/index.js +17 -51
  157. package/cjs/components/shared/monaco-editor/constants/themes/kimbie-dark.json.js +1 -1
  158. package/cjs/components/shared/monaco-editor/constants/themes/monokai.json.js +1 -1
  159. package/cjs/components/shared/monaco-editor/constants/themes/quietlight.json.js +1 -1
  160. package/cjs/components/shared/monaco-editor/constants/themes/red.json.js +1 -1
  161. package/cjs/components/shared/monaco-editor/constants/themes/solarized-dark.json.js +1 -1
  162. package/cjs/components/shared/monaco-editor/constants/themes/solarized-light.json.js +1 -1
  163. package/cjs/components/shared/monaco-editor/constants/themes/tomorrow-night-blue.json.js +1 -1
  164. package/cjs/components/shared/monaco-editor/constants/themes/vs-dark-plus.json.js +1 -1
  165. package/cjs/components/shared/monaco-editor/constants/themes/vs-dark.json.js +1 -1
  166. package/cjs/components/shared/monaco-editor/constants/themes/vs-hc-black.json.js +1 -1
  167. package/cjs/components/shared/monaco-editor/constants/themes/vs-hc-light.json.js +1 -1
  168. package/cjs/components/shared/monaco-editor/constants/themes/vs-light-plus.json.js +1 -1
  169. package/cjs/components/shared/monaco-editor/constants/themes/vs-light.json.js +1 -1
  170. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -13
  171. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -17
  172. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -11
  173. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -36
  174. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -11
  175. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -8
  176. package/cjs/components/shared/monaco-editor/editor-languages/css/formatter.js +11 -52
  177. package/cjs/components/shared/monaco-editor/editor-languages/css/index.js +7 -8
  178. package/cjs/components/shared/monaco-editor/editor-languages/html/formatter.js +11 -52
  179. package/cjs/components/shared/monaco-editor/editor-languages/html/index.js +5 -6
  180. package/cjs/components/shared/monaco-editor/editor-languages/index.js +4 -4
  181. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -3
  182. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/express.js +1 -1
  183. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/propTypes.js +1 -1
  184. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/react.js +1 -1
  185. package/cjs/components/shared/monaco-editor/editor-languages/typescript/formatter.js +11 -56
  186. package/cjs/components/shared/monaco-editor/editor-languages/typescript/index.js +17 -18
  187. package/cjs/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -13
  188. package/cjs/components/shared/monaco-editor/locales/en.json.js +1 -1
  189. package/cjs/components/shared/monaco-editor/locales/ko.json.js +1 -1
  190. package/cjs/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -12
  191. package/cjs/components/shared/monaco-editor/utils/emmet/emmet.js +0 -2
  192. package/cjs/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -14
  193. package/cjs/components/shared/monaco-editor/utils/grammar/index.js +25 -69
  194. package/cjs/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -27
  195. package/cjs/components/shared/monaco-editor/utils/grammar/textmate.js +38 -73
  196. package/cjs/components/shared/monaco-editor/utils/monacoLanguage.js +8 -11
  197. package/cjs/components/shared/monaco-editor/utils/monacoPreference.js +4 -8
  198. package/cjs/components/shared/monaco-editor/utils/prettier/config.js +2 -4
  199. package/cjs/components/shared/monaco-editor/utils/prettier/index.js +8 -46
  200. package/cjs/components/shared/monaco-editor/utils/theme/convert.js +14 -26
  201. package/cjs/components/shared/monaco-editor/utils/theme/index.js +3 -24
  202. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -79
  203. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -84
  204. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -122
  205. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +133 -158
  206. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -106
  207. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -4
  208. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -3
  209. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -4
  210. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +158 -179
  211. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -5
  212. package/cjs/components/shared/no-vnc/NoVnc.js +57 -86
  213. package/cjs/components/shared/no-vnc/NoVncLazy.js +5 -11
  214. package/cjs/components/shared/preview-container/PreviewContainer.js +11 -15
  215. package/cjs/components/shared/web-browser/WebBrowser.js +37 -53
  216. package/cjs/components/shared/xterm/Xterm.js +58 -81
  217. package/cjs/components/shared/xterm/XtermLazy.js +5 -11
  218. package/cjs/components/shared/xterm/locales/en.json.js +1 -1
  219. package/cjs/components/shared/xterm/locales/ko.json.js +1 -1
  220. package/cjs/components/shared/xterm/utils/index.js +0 -2
  221. package/cjs/constants/arduino.js +10 -12
  222. package/cjs/constants/shortcutKeyMap.js +2 -4
  223. package/cjs/constants/stylesheets.js +5 -9
  224. package/cjs/hooks/useArduino.js +141 -284
  225. package/cjs/hooks/useExerciseFile.js +22 -26
  226. package/cjs/hooks/useExericseShortcut.js +4 -8
  227. package/cjs/hooks/useMaterialExerciseFileUrl.js +33 -57
  228. package/cjs/hooks/useRunnerRoomWebSocket.js +27 -53
  229. package/cjs/hooks/useStdioTextConcator.js +10 -22
  230. package/cjs/hooks/useStdioWebSocket.js +28 -34
  231. package/cjs/hooks/useUsercodeEditWebSocket.js +158 -240
  232. package/cjs/hooks/useUsercodeHistory.js +63 -117
  233. package/cjs/index.js +4 -6
  234. package/cjs/utils/arduino.js +11 -25
  235. package/cjs/utils/exerciseFile.js +10 -10
  236. package/cjs/utils/runner.js +15 -31
  237. package/es/components/material-exercise/MaterialExercise.i18n.js +2 -2
  238. package/es/components/material-exercise/MaterialExercise.js +34 -35
  239. package/es/components/material-exercise/MaterialExercise.styled.js +14 -14
  240. package/es/components/material-exercise/MaterialExerciseMobile.js +6 -9
  241. package/es/components/material-exercise/context/ExerciseIntlProvider.js +10 -8
  242. package/es/components/material-exercise/context/ExerciseProvider.js +52 -55
  243. package/es/components/material-exercise/context/ExerciseProviderNoImage.js +10 -10
  244. package/es/components/material-exercise/context/context.js +1 -1
  245. package/es/components/material-exercise/context/recoil.js +290 -535
  246. package/es/components/material-exercise/context/subjects.js +3 -3
  247. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +51 -53
  248. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -8
  249. package/es/components/material-exercise/exercise-file/ExerciseFile.js +9 -8
  250. package/es/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +127 -193
  251. package/es/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +5 -4
  252. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +20 -31
  253. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsFileTreeButton.js +35 -44
  254. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +1 -1
  255. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +181 -315
  256. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +1 -1
  257. package/es/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +11 -10
  258. package/es/components/material-exercise/exercise-menu/ExerciseMenu.js +7 -6
  259. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +3 -3
  260. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +25 -42
  261. package/es/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +26 -51
  262. package/es/components/material-exercise/exercise-menu/ExerciseMenuReset.js +11 -23
  263. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +21 -31
  264. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +12 -12
  265. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +19 -26
  266. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +1 -1
  267. package/es/components/material-exercise/exercise-preview/ExercisePreview.js +15 -14
  268. package/es/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +5 -11
  269. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +11 -15
  270. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +5 -9
  271. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +78 -80
  272. package/es/components/material-exercise/exercise-room/ExerciseRoom.js +6 -13
  273. package/es/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -14
  274. package/es/components/material-exercise/exercise-room/ExerciseRoomDetail.js +134 -236
  275. package/es/components/material-exercise/exercise-room/ExerciseRoomList.js +65 -94
  276. package/es/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -2
  277. package/es/components/material-exercise/exercise-runner/ExerciseRunner.js +116 -167
  278. package/es/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -1
  279. package/es/components/material-exercise/exercise-runner/ExerciseRunnerController.js +8 -7
  280. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +17 -27
  281. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +11 -18
  282. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +52 -50
  283. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +10 -14
  284. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +46 -75
  285. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +2 -2
  286. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +4 -4
  287. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +15 -21
  288. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +138 -253
  289. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -8
  290. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +29 -37
  291. package/es/components/shared/exercise-menu-button/ExerciseMenuButton.js +12 -13
  292. package/es/components/shared/exercise-shimmer/ExerciseFileShimmer.js +2 -2
  293. package/es/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +12 -12
  294. package/es/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +2 -2
  295. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +14 -14
  296. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +9 -15
  297. package/es/components/shared/exercise-version-list/ExerciseVersionList.js +3 -2
  298. package/es/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -1
  299. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.js +6 -5
  300. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -9
  301. package/es/components/shared/file-icon/FileIcon.js +15 -17
  302. package/es/components/shared/file-tabs/FileTab.js +22 -24
  303. package/es/components/shared/file-tabs/FileTab.styled.js +15 -19
  304. package/es/components/shared/file-tabs/FileTabs.js +35 -55
  305. package/es/components/shared/file-tabs/FileTabs.styled.js +2 -2
  306. package/es/components/shared/file-tabs/util.js +14 -27
  307. package/es/components/shared/file-tree/FileTree.js +3 -3
  308. package/es/components/shared/file-tree/FileTreeConfig.js +18 -15
  309. package/es/components/shared/file-tree/FileTreeList.js +33 -29
  310. package/es/components/shared/file-tree/FileTreeListItemContent.js +45 -55
  311. package/es/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -25
  312. package/es/components/shared/file-tree/FileTreeListItemContentInput.js +60 -64
  313. package/es/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -6
  314. package/es/components/shared/file-tree/FileTreeListItemContentMenu.js +39 -46
  315. package/es/components/shared/file-tree/FileTreeListItems.js +134 -145
  316. package/es/components/shared/file-tree/FileTreeListItems.styled.js +2 -2
  317. package/es/components/shared/file-tree/FileTreeToolbar.js +25 -22
  318. package/es/components/shared/file-tree/FileTreeToolbar.styled.js +1 -1
  319. package/es/components/shared/file-tree/context/FileTreeContext.js +74 -89
  320. package/es/components/shared/file-tree/utils/fileTreeFiles.js +20 -20
  321. package/es/components/shared/file-tree/utils/fileTreeGenerator.js +146 -193
  322. package/es/components/shared/file-tree/utils/fileTreeItem.js +1 -1
  323. package/es/components/shared/file-tree/utils/fileTreePath.js +6 -5
  324. package/es/components/shared/file-viewer/FileViewer.js +21 -38
  325. package/es/components/shared/file-viewer/FileViewerCsv.js +70 -129
  326. package/es/components/shared/file-viewer/FileViewerImage.js +4 -3
  327. package/es/components/shared/file-viewer/FileViewerIpynb.js +7 -14
  328. package/es/components/shared/file-viewer/FileViewerNonViewable.js +15 -18
  329. package/es/components/shared/file-viewer/FileViewerText.js +9 -17
  330. package/es/components/shared/material-modal/MaterialModal.js +8 -7
  331. package/es/components/shared/material-modal/MaterialModal.styled.js +5 -5
  332. package/es/components/shared/monaco-editor/MonacoEditor.js +67 -87
  333. package/es/components/shared/monaco-editor/MonacoEditorLazy.js +2 -4
  334. package/es/components/shared/monaco-editor/MonacoEditorMobile.js +31 -41
  335. package/es/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +52 -66
  336. package/es/components/shared/monaco-editor/constants/grammars/index.js +28 -82
  337. package/es/components/shared/monaco-editor/constants/monaco/preferences.js +5 -5
  338. package/es/components/shared/monaco-editor/constants/themes/index.js +17 -49
  339. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -11
  340. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -15
  341. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -9
  342. package/es/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -34
  343. package/es/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -9
  344. package/es/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -6
  345. package/es/components/shared/monaco-editor/editor-languages/css/formatter.js +10 -33
  346. package/es/components/shared/monaco-editor/editor-languages/html/formatter.js +10 -33
  347. package/es/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -1
  348. package/es/components/shared/monaco-editor/editor-languages/typescript/formatter.js +10 -37
  349. package/es/components/shared/monaco-editor/editor-languages/typescript/index.js +3 -3
  350. package/es/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -11
  351. package/es/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -10
  352. package/es/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -12
  353. package/es/components/shared/monaco-editor/utils/grammar/index.js +24 -68
  354. package/es/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -25
  355. package/es/components/shared/monaco-editor/utils/grammar/textmate.js +35 -67
  356. package/es/components/shared/monaco-editor/utils/monacoLanguage.js +5 -5
  357. package/es/components/shared/monaco-editor/utils/monacoPreference.js +4 -6
  358. package/es/components/shared/monaco-editor/utils/prettier/config.js +2 -2
  359. package/es/components/shared/monaco-editor/utils/prettier/index.js +7 -27
  360. package/es/components/shared/monaco-editor/utils/theme/convert.js +13 -19
  361. package/es/components/shared/monaco-editor/utils/theme/index.js +3 -22
  362. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -77
  363. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -82
  364. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -120
  365. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +130 -152
  366. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -104
  367. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -2
  368. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -1
  369. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -2
  370. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +157 -172
  371. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -3
  372. package/es/components/shared/no-vnc/NoVnc.js +42 -59
  373. package/es/components/shared/no-vnc/NoVncLazy.js +2 -4
  374. package/es/components/shared/preview-container/PreviewContainer.js +8 -7
  375. package/es/components/shared/web-browser/WebBrowser.js +29 -40
  376. package/es/components/shared/xterm/Xterm.js +51 -69
  377. package/es/components/shared/xterm/XtermLazy.js +2 -4
  378. package/es/constants/arduino.js +10 -10
  379. package/es/constants/shortcutKeyMap.js +1 -3
  380. package/es/constants/stylesheets.js +5 -7
  381. package/es/hooks/useArduino.js +141 -278
  382. package/es/hooks/useExerciseFile.js +22 -24
  383. package/es/hooks/useExericseShortcut.js +4 -6
  384. package/es/hooks/useMaterialExerciseFileUrl.js +34 -52
  385. package/es/hooks/useRunnerRoomWebSocket.js +27 -51
  386. package/es/hooks/useStdioTextConcator.js +10 -16
  387. package/es/hooks/useStdioWebSocket.js +28 -32
  388. package/es/hooks/useUsercodeEditWebSocket.js +157 -232
  389. package/es/hooks/useUsercodeHistory.js +63 -115
  390. package/es/utils/arduino.js +11 -23
  391. package/es/utils/exerciseFile.js +10 -8
  392. package/es/utils/runner.js +15 -29
  393. package/package.json +11 -7
  394. package/cjs/_virtual/_rollupPluginBabelHelpers.js +0 -521
  395. package/es/_virtual/_rollupPluginBabelHelpers.js +0 -499
@@ -2,7 +2,6 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var _rollupPluginBabelHelpers = require('../../../_virtual/_rollupPluginBabelHelpers.js');
6
5
  var React = require('react');
7
6
  var reactIntl = require('react-intl');
8
7
  var blocks = require('@elice/blocks');
@@ -15,16 +14,11 @@ require('../exercise-shimmer/ExerciseFileTabShimmer.js');
15
14
  require('../exercise-shimmer/ExerciseFileTreeListShimmer.js');
16
15
  require('../exercise-shimmer/ExerciseFileTreeListItemShimmer.js');
17
16
 
18
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
19
-
20
- var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
21
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
22
-
23
17
  //
24
18
  //
25
19
  //
26
- var OPTIONS_PER_PAGE = [10, 25, 50];
27
- var OPTIONS_DELIMITER = [{
20
+ const OPTIONS_PER_PAGE = [10, 25, 50];
21
+ const OPTIONS_DELIMITER = [{
28
22
  char: ',',
29
23
  label: 'Comma [,]'
30
24
  }, {
@@ -43,307 +37,249 @@ var OPTIONS_DELIMITER = [{
43
37
  //
44
38
  //
45
39
  //
46
- var StyledViewer = styled__default["default"].div.withConfig({
40
+ const StyledViewer = styled.div.withConfig({
47
41
  componentId: "sc-pyv7uu-0"
48
42
  })(["flex:1;display:flex;flex-direction:column;width:100%;height:100%;min-width:0;min-height:0;background-color:", ";"], designTokens.base.color.navy9);
49
- var StyledViewerTableWrap = styled__default["default"].div.withConfig({
43
+ const StyledViewerTableWrap = styled.div.withConfig({
50
44
  componentId: "sc-pyv7uu-1"
51
45
  })(["flex:1;overflow:auto;"]);
52
- var StyledViewerTable = styled__default["default"].table.withConfig({
46
+ const StyledViewerTable = styled.table.withConfig({
53
47
  componentId: "sc-pyv7uu-2"
54
48
  })(["border:none;border-collapse:collapse;color:", ";font-family:'Elice Digital Coding',monospace,fixed-width;th,td{border:1px solid ", ";padding:0.5rem;white-space:pre;&:first-of-type{color:", ";border-left:none;}&:last-of-type{border-right:none;}}tbody{tr:nth-child(odd){background:", ";}tr:hover{background:", ";}}"], designTokens.base.color.white, designTokens.base.color.navy5, designTokens.base.color.gray5, designTokens.base.color.navy8, designTokens.base.color.navy6);
55
- var StyledViewerFooter = styled__default["default"].div.withConfig({
49
+ const StyledViewerFooter = styled.div.withConfig({
56
50
  componentId: "sc-pyv7uu-3"
57
51
  })(["flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:0.5rem;"]);
58
- var StyledViewerFooterSelect = styled__default["default"].select.withConfig({
52
+ const StyledViewerFooterSelect = styled.select.withConfig({
59
53
  componentId: "sc-pyv7uu-4"
60
- })(["width:", "rem;border-radius:0.25rem;"], function (props) {
61
- return props.width;
62
- });
63
- var StyledViewerFooterHr = styled__default["default"](blocks.Hr).withConfig({
54
+ })(["width:", "rem;border-radius:0.25rem;"], props => props.width);
55
+ const StyledViewerFooterHr = styled(blocks.Hr).withConfig({
64
56
  componentId: "sc-pyv7uu-5"
65
57
  })(["height:1rem;"]);
66
58
  //
67
59
  //
68
60
  //
69
- var FileViewerCsv = function FileViewerCsv(_ref) {
70
- var fileurl = _ref.fileurl;
71
- var _React$useState = React__default["default"].useState(''),
72
- _React$useState2 = _rollupPluginBabelHelpers.slicedToArray(_React$useState, 2),
73
- csv = _React$useState2[0],
74
- setCsv = _React$useState2[1];
75
- var _React$useState3 = React__default["default"].useState(null),
76
- _React$useState4 = _rollupPluginBabelHelpers.slicedToArray(_React$useState3, 2),
77
- csvHeader = _React$useState4[0],
78
- setCsvHeader = _React$useState4[1];
79
- var _React$useState5 = React__default["default"].useState([]),
80
- _React$useState6 = _rollupPluginBabelHelpers.slicedToArray(_React$useState5, 2),
81
- csvRecords = _React$useState6[0],
82
- setCsvRecords = _React$useState6[1];
83
- var _React$useState7 = React__default["default"].useState('idle'),
84
- _React$useState8 = _rollupPluginBabelHelpers.slicedToArray(_React$useState7, 2),
85
- csvStatus = _React$useState8[0],
86
- setCsvStatus = _React$useState8[1];
87
- var _React$useState9 = React__default["default"].useState(1),
88
- _React$useState10 = _rollupPluginBabelHelpers.slicedToArray(_React$useState9, 2),
89
- page = _React$useState10[0],
90
- setPage = _React$useState10[1];
91
- var _React$useState11 = React__default["default"].useState(OPTIONS_PER_PAGE[0]),
92
- _React$useState12 = _rollupPluginBabelHelpers.slicedToArray(_React$useState11, 2),
93
- perPage = _React$useState12[0],
94
- setPerPage = _React$useState12[1];
95
- var _React$useState13 = React__default["default"].useState(OPTIONS_DELIMITER[0].char),
96
- _React$useState14 = _rollupPluginBabelHelpers.slicedToArray(_React$useState13, 2),
97
- delimiter = _React$useState14[0],
98
- setDelimiter = _React$useState14[1];
99
- var _React$useState15 = React__default["default"].useState(true),
100
- _React$useState16 = _rollupPluginBabelHelpers.slicedToArray(_React$useState15, 2),
101
- isUsingHeader = _React$useState16[0],
102
- setUsingHeader = _React$useState16[1];
103
- var csvRecordCount = csvRecords.length + (csvHeader ? -1 : 0);
104
- var maxPage = Math.ceil(csvRecordCount / perPage);
105
- var tableWrapElRef = React__default["default"].useRef(null);
61
+ const FileViewerCsv = ({
62
+ fileurl
63
+ }) => {
64
+ const [csv, setCsv] = React.useState('');
65
+ const [csvHeader, setCsvHeader] = React.useState(null);
66
+ const [csvRecords, setCsvRecords] = React.useState([]);
67
+ const [csvStatus, setCsvStatus] = React.useState('idle');
68
+ const [page, setPage] = React.useState(1);
69
+ const [perPage, setPerPage] = React.useState(OPTIONS_PER_PAGE[0]);
70
+ const [delimiter, setDelimiter] = React.useState(OPTIONS_DELIMITER[0].char);
71
+ const [isUsingHeader, setUsingHeader] = React.useState(true);
72
+ const csvRecordCount = csvRecords.length + (csvHeader ? -1 : 0);
73
+ const maxPage = Math.ceil(csvRecordCount / perPage);
74
+ const tableWrapElRef = React.useRef(null);
106
75
  //
107
76
  // Fetch csv file
108
77
  //
109
- React__default["default"].useEffect(function () {
78
+ React.useEffect(() => {
110
79
  if (!fileurl) {
111
80
  setCsvRecords([]);
112
81
  return;
113
82
  }
114
- var abortCtrl = new AbortController();
83
+ const abortCtrl = new AbortController();
115
84
  setCsvStatus('pending');
116
85
  fetch(fileurl, {
117
86
  signal: abortCtrl.signal
118
- }).then(function (res) {
119
- return res.text();
120
- }).then(setCsv).then(function () {
121
- return setCsvStatus('resolved');
122
- }).catch(function (err) {
87
+ }).then(res => res.text()).then(setCsv).then(() => setCsvStatus('resolved')).catch(err => {
123
88
  if (err.name === 'AbortError') {
124
89
  return;
125
90
  }
126
91
  setCsvRecords([]);
127
92
  setCsvStatus('rejected');
128
93
  });
129
- return function () {
94
+ return () => {
130
95
  abortCtrl.abort();
131
96
  };
132
97
  }, [fileurl]);
133
98
  //
134
99
  // Parse csv file and save as records
135
100
  //
136
- React__default["default"].useEffect(function () {
137
- return setCsvRecords(csv.split('\n').filter(Boolean).map(function (row) {
138
- return row.split(delimiter);
139
- }));
140
- }, [csv, delimiter]);
101
+ React.useEffect(() => setCsvRecords(csv.split('\n').filter(Boolean).map(row => row.split(delimiter))), [csv, delimiter]);
141
102
  //
142
103
  // Set CSV header.
143
104
  //
144
- React__default["default"].useEffect(function () {
145
- return setCsvHeader(isUsingHeader ? csvRecords[0] : null);
146
- }, [csvRecords, isUsingHeader]);
105
+ React.useEffect(() => setCsvHeader(isUsingHeader ? csvRecords[0] : null), [csvRecords, isUsingHeader]);
147
106
  //
148
107
  // Scroll to top when page changes.
149
108
  //
150
- React__default["default"].useEffect(function () {
109
+ React.useEffect(() => {
151
110
  var _a;
152
111
  return (_a = tableWrapElRef.current) === null || _a === void 0 ? void 0 : _a.scrollTo(0, 0);
153
112
  }, [page]);
154
113
  /**
155
114
  *
156
115
  */
157
- var renderViewerTableThead = function renderViewerTableThead() {
116
+ const renderViewerTableThead = () => {
158
117
  if (!csvHeader) {
159
118
  return null;
160
119
  }
161
- var colunms = [''].concat(_rollupPluginBabelHelpers.toConsumableArray(csvHeader));
162
- return React__default["default"].createElement("thead", null, React__default["default"].createElement("tr", null, colunms.map(function (col, colIdx) {
163
- return React__default["default"].createElement("th", {
164
- key: colIdx
165
- }, col);
166
- })));
120
+ const colunms = ['', ...csvHeader];
121
+ return React.createElement("thead", null, React.createElement("tr", null, colunms.map((col, colIdx) => React.createElement("th", {
122
+ key: colIdx
123
+ }, col))));
167
124
  };
168
125
  /**
169
126
  *
170
127
  */
171
- var renderViewerTableTbody = function renderViewerTableTbody() {
172
- var start = (page - 1) * perPage;
173
- var end = page * perPage;
174
- var records = csvRecords.slice(csvHeader ? 1 : 0).slice(start, end);
175
- return React__default["default"].createElement("tbody", null, records.map(function (row, rowIdx) {
176
- var curRecordNo = start + rowIdx + 1;
177
- var curRow = [curRecordNo].concat(_rollupPluginBabelHelpers.toConsumableArray(row));
178
- return React__default["default"].createElement("tr", {
128
+ const renderViewerTableTbody = () => {
129
+ const start = (page - 1) * perPage;
130
+ const end = page * perPage;
131
+ const records = csvRecords.slice(csvHeader ? 1 : 0).slice(start, end);
132
+ return React.createElement("tbody", null, records.map((row, rowIdx) => {
133
+ const curRecordNo = start + rowIdx + 1;
134
+ const curRow = [curRecordNo, ...row];
135
+ return React.createElement("tr", {
179
136
  key: curRecordNo
180
- }, curRow.map(function (col, colIdx) {
181
- return React__default["default"].createElement("td", {
182
- key: colIdx,
183
- style: {
184
- // test whether the column is number, and align right
185
- textAlign:
186
- // eslint-disable-next-line no-self-compare
187
- +col === +col ? 'right' : 'left'
188
- }
189
- }, col);
190
- }));
137
+ }, curRow.map((col, colIdx) => React.createElement("td", {
138
+ key: colIdx,
139
+ style: {
140
+ // test whether the column is number, and align right
141
+ textAlign:
142
+ // eslint-disable-next-line no-self-compare
143
+ +col === +col ? 'right' : 'left'
144
+ }
145
+ }, col)));
191
146
  }));
192
147
  };
193
148
  /**
194
149
  *
195
150
  */
196
- var renderViewerTable = function renderViewerTable() {
197
- return React__default["default"].createElement(StyledViewerTableWrap, {
151
+ const renderViewerTable = () => {
152
+ return React.createElement(StyledViewerTableWrap, {
198
153
  ref: tableWrapElRef
199
- }, React__default["default"].createElement(StyledViewerTable, null, renderViewerTableThead(), renderViewerTableTbody()));
154
+ }, React.createElement(StyledViewerTable, null, renderViewerTableThead(), renderViewerTableTbody()));
200
155
  };
201
156
  /**
202
157
  *
203
158
  */
204
- var renderViewerFooterPagination = function renderViewerFooterPagination() {
205
- return React__default["default"].createElement(blocks.Flex, {
159
+ const renderViewerFooterPagination = () => {
160
+ return React.createElement(blocks.Flex, {
206
161
  align: "center"
207
- }, React__default["default"].createElement(blocks.Text, {
162
+ }, React.createElement(blocks.Text, {
208
163
  role: "gray1",
209
164
  size: "small"
210
- }, csvRecordCount, " records"), React__default["default"].createElement(StyledViewerFooterHr, {
165
+ }, csvRecordCount, " records"), React.createElement(StyledViewerFooterHr, {
211
166
  vertical: true,
212
167
  color: designTokens.base.color.navy5
213
- }), React__default["default"].createElement(blocks.Flex, {
168
+ }), React.createElement(blocks.Flex, {
214
169
  align: "center"
215
- }, React__default["default"].createElement(blocks.IconButton, {
170
+ }, React.createElement(blocks.IconButton, {
216
171
  icon: icons.eilArrowLeftwardsDouble,
217
172
  role: "navy3",
218
173
  size: "nano",
219
174
  disabled: page <= 1,
220
- onClick: function onClick() {
221
- return setPage(1);
222
- }
223
- }), React__default["default"].createElement(blocks.Hspace, {
175
+ onClick: () => setPage(1)
176
+ }), React.createElement(blocks.Hspace, {
224
177
  width: 0.25
225
- }), React__default["default"].createElement(blocks.IconButton, {
178
+ }), React.createElement(blocks.IconButton, {
226
179
  icon: icons.eilArrowLeftwardsSingle,
227
180
  role: "navy3",
228
181
  size: "nano",
229
182
  disabled: page <= 1,
230
- onClick: function onClick() {
231
- return setPage(function (prevPage) {
232
- return prevPage - 1;
233
- });
234
- }
235
- }), React__default["default"].createElement(blocks.Hspace, {
183
+ onClick: () => setPage(prevPage => prevPage - 1)
184
+ }), React.createElement(blocks.Hspace, {
236
185
  width: 0.5
237
- }), React__default["default"].createElement(blocks.Text, {
186
+ }), React.createElement(blocks.Text, {
238
187
  role: "gray1",
239
188
  size: "small"
240
- }, page, " / ", maxPage), React__default["default"].createElement(blocks.Hspace, {
189
+ }, page, " / ", maxPage), React.createElement(blocks.Hspace, {
241
190
  width: 0.5
242
- }), React__default["default"].createElement(blocks.IconButton, {
191
+ }), React.createElement(blocks.IconButton, {
243
192
  icon: icons.eilArrowRightwardsSingle,
244
193
  role: "navy3",
245
194
  size: "nano",
246
195
  disabled: page >= maxPage,
247
- onClick: function onClick() {
248
- return setPage(function (prevPage) {
249
- return prevPage + 1;
250
- });
251
- }
252
- }), React__default["default"].createElement(blocks.Hspace, {
196
+ onClick: () => setPage(prevPage => prevPage + 1)
197
+ }), React.createElement(blocks.Hspace, {
253
198
  width: 0.25
254
- }), React__default["default"].createElement(blocks.IconButton, {
199
+ }), React.createElement(blocks.IconButton, {
255
200
  icon: icons.eilArrowRightwardsDouble,
256
201
  role: "navy3",
257
202
  size: "nano",
258
203
  disabled: page >= maxPage,
259
- onClick: function onClick() {
260
- return setPage(maxPage);
261
- }
204
+ onClick: () => setPage(maxPage)
262
205
  })));
263
206
  };
264
207
  /**
265
208
  *
266
209
  */
267
- var renderViewerFooterSettings = function renderViewerFooterSettings() {
268
- return React__default["default"].createElement(blocks.Flex, {
210
+ const renderViewerFooterSettings = () => {
211
+ return React.createElement(blocks.Flex, {
269
212
  align: "center"
270
- }, React__default["default"].createElement(blocks.Flex, {
213
+ }, React.createElement(blocks.Flex, {
271
214
  align: "center"
272
- }, React__default["default"].createElement(blocks.Text, {
215
+ }, React.createElement(blocks.Text, {
273
216
  role: "gray1",
274
217
  size: "small"
275
- }, React__default["default"].createElement(reactIntl.FormattedMessage, {
218
+ }, React.createElement(reactIntl.FormattedMessage, {
276
219
  id: "\uD5E4\uB354 \uC0AC\uC6A9"
277
- })), React__default["default"].createElement(blocks.Hspace, {
220
+ })), React.createElement(blocks.Hspace, {
278
221
  width: 0.5
279
- }), React__default["default"].createElement(blocks.AntSwitch, {
222
+ }), React.createElement(blocks.AntSwitch, {
280
223
  size: "small",
281
224
  checked: isUsingHeader,
282
225
  onChange: setUsingHeader
283
- })), React__default["default"].createElement(StyledViewerFooterHr, {
226
+ })), React.createElement(StyledViewerFooterHr, {
284
227
  vertical: true,
285
228
  color: designTokens.base.color.navy5
286
- }), React__default["default"].createElement(blocks.Flex, {
229
+ }), React.createElement(blocks.Flex, {
287
230
  align: "center"
288
- }, React__default["default"].createElement(blocks.Text, {
231
+ }, React.createElement(blocks.Text, {
289
232
  role: "gray1",
290
233
  size: "small"
291
- }, React__default["default"].createElement(reactIntl.FormattedMessage, {
234
+ }, React.createElement(reactIntl.FormattedMessage, {
292
235
  id: "\uAD6C\uBD84\uC790:"
293
- })), React__default["default"].createElement(blocks.Hspace, {
236
+ })), React.createElement(blocks.Hspace, {
294
237
  width: 0.5
295
- }), React__default["default"].createElement(StyledViewerFooterSelect, {
238
+ }), React.createElement(StyledViewerFooterSelect, {
296
239
  width: 7.5,
297
240
  value: delimiter,
298
- onChange: function onChange(e) {
299
- return setDelimiter(e.target.value);
300
- }
301
- }, OPTIONS_DELIMITER.map(function (_ref2) {
302
- var char = _ref2.char,
303
- label = _ref2.label;
304
- return React__default["default"].createElement("option", {
305
- value: char
306
- }, label);
307
- }))), React__default["default"].createElement(StyledViewerFooterHr, {
241
+ onChange: e => setDelimiter(e.target.value)
242
+ }, OPTIONS_DELIMITER.map(({
243
+ char,
244
+ label
245
+ }) => React.createElement("option", {
246
+ value: char
247
+ }, label)))), React.createElement(StyledViewerFooterHr, {
308
248
  vertical: true,
309
249
  color: designTokens.base.color.navy5
310
- }), React__default["default"].createElement(blocks.Flex, {
250
+ }), React.createElement(blocks.Flex, {
311
251
  align: "center"
312
- }, React__default["default"].createElement(blocks.Text, {
252
+ }, React.createElement(blocks.Text, {
313
253
  role: "gray1",
314
254
  size: "small"
315
- }, React__default["default"].createElement(reactIntl.FormattedMessage, {
255
+ }, React.createElement(reactIntl.FormattedMessage, {
316
256
  id: "\uD398\uC774\uC9C0\uB2F9 \uD589:"
317
- })), React__default["default"].createElement(blocks.Hspace, {
257
+ })), React.createElement(blocks.Hspace, {
318
258
  width: 0.5
319
- }), React__default["default"].createElement(StyledViewerFooterSelect, {
259
+ }), React.createElement(StyledViewerFooterSelect, {
320
260
  width: 3,
321
261
  value: perPage,
322
- onChange: function onChange(e) {
323
- return setPerPage(Number(e.target.value));
324
- }
325
- }, OPTIONS_PER_PAGE.map(function (perPage) {
326
- return React__default["default"].createElement("option", {
327
- value: perPage
328
- }, perPage);
329
- }))));
262
+ onChange: e => setPerPage(Number(e.target.value))
263
+ }, OPTIONS_PER_PAGE.map(perPage => React.createElement("option", {
264
+ value: perPage
265
+ }, perPage)))));
330
266
  };
331
267
  /**
332
268
  *
333
269
  */
334
- var renderViewerFooter = function renderViewerFooter() {
335
- return React__default["default"].createElement(StyledViewerFooter, null, renderViewerFooterPagination(), renderViewerFooterSettings());
270
+ const renderViewerFooter = () => {
271
+ return React.createElement(StyledViewerFooter, null, renderViewerFooterPagination(), renderViewerFooterSettings());
336
272
  };
337
273
  //
338
274
  //
339
275
  //
340
276
  if (csvStatus === 'idle' || csvStatus === 'pending') {
341
- return React__default["default"].createElement(ExerciseFileShimmer["default"], null);
277
+ return React.createElement(ExerciseFileShimmer.default, null);
342
278
  }
343
279
  if (csvStatus === 'rejected') {
344
- return React__default["default"].createElement("div", null, "error");
280
+ return React.createElement("div", null, "error");
345
281
  }
346
- return React__default["default"].createElement(StyledViewer, null, renderViewerTable(), renderViewerFooter());
282
+ return React.createElement(StyledViewer, null, renderViewerTable(), renderViewerFooter());
347
283
  };
348
284
 
349
- exports["default"] = FileViewerCsv;
285
+ exports.default = FileViewerCsv;
@@ -11,28 +11,24 @@ require('../exercise-shimmer/ExerciseFileTabShimmer.js');
11
11
  require('../exercise-shimmer/ExerciseFileTreeListShimmer.js');
12
12
  require('../exercise-shimmer/ExerciseFileTreeListItemShimmer.js');
13
13
 
14
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
15
-
16
- var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
17
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
18
-
19
- var StyledImage = styled__default["default"].img.withConfig({
14
+ const StyledImage = styled.img.withConfig({
20
15
  componentId: "sc-1bnx7lz-0"
21
16
  })(["max-width:100%;max-height:100%;height:auto;width:auto;"]);
22
- var FileViewerImage = function FileViewerImage(_ref) {
23
- var fileurl = _ref.fileurl;
17
+ const FileViewerImage = ({
18
+ fileurl
19
+ }) => {
24
20
  if (!fileurl) {
25
- return React__default["default"].createElement(ExerciseFileShimmer["default"], null);
21
+ return React.createElement(ExerciseFileShimmer.default, null);
26
22
  }
27
- return React__default["default"].createElement(blocks.Flex, {
23
+ return React.createElement(blocks.Flex, {
28
24
  align: "center",
29
25
  justify: "center",
30
26
  auto: true,
31
27
  overflow: "hidden"
32
- }, React__default["default"].createElement(StyledImage, {
28
+ }, React.createElement(StyledImage, {
33
29
  src: fileurl,
34
30
  alt: fileurl
35
31
  }));
36
32
  };
37
33
 
38
- exports["default"] = FileViewerImage;
34
+ exports.default = FileViewerImage;
@@ -2,7 +2,6 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var _rollupPluginBabelHelpers = require('../../../_virtual/_rollupPluginBabelHelpers.js');
6
5
  var React = require('react');
7
6
  var NotebookPreview = require('@nteract/notebook-preview');
8
7
  var styled = require('styled-components');
@@ -12,40 +11,28 @@ require('../exercise-shimmer/ExerciseFileTabShimmer.js');
12
11
  require('../exercise-shimmer/ExerciseFileTreeListShimmer.js');
13
12
  require('../exercise-shimmer/ExerciseFileTreeListItemShimmer.js');
14
13
 
15
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
-
17
- var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
18
- var NotebookPreview__default = /*#__PURE__*/_interopDefaultLegacy(NotebookPreview);
19
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
20
-
21
- var StyledNotebookWrapper = styled__default["default"].div.withConfig({
14
+ const StyledNotebookWrapper = styled.div.withConfig({
22
15
  componentId: "sc-1fmae1h-0"
23
16
  })(["width:100%;height:100%;overflow:auto;background-color:white;padding:1rem;.notebook-preview{width:100%;height:100%;}"]);
24
- var FileViewerIpynb = function FileViewerIpynb(_ref) {
25
- var fileurl = _ref.fileurl;
26
- var _React$useState = React__default["default"].useState(null),
27
- _React$useState2 = _rollupPluginBabelHelpers.slicedToArray(_React$useState, 2),
28
- content = _React$useState2[0],
29
- setContent = _React$useState2[1];
30
- React__default["default"].useEffect(function () {
17
+ const FileViewerIpynb = ({
18
+ fileurl
19
+ }) => {
20
+ const [content, setContent] = React.useState(null);
21
+ React.useEffect(() => {
31
22
  if (!fileurl) {
32
23
  return;
33
24
  }
34
- fetch(fileurl).then(function (res) {
35
- return res.text();
36
- }).then(JSON.parse).then(setContent).catch(function (err) {
37
- return console.error(err);
38
- });
25
+ fetch(fileurl).then(res => res.text()).then(JSON.parse).then(setContent).catch(err => console.error(err));
39
26
  }, [fileurl]);
40
27
  //
41
28
  //
42
29
  //
43
30
  if (!content) {
44
- return React__default["default"].createElement(ExerciseFileShimmer["default"], null);
31
+ return React.createElement(ExerciseFileShimmer.default, null);
45
32
  }
46
- return React__default["default"].createElement(StyledNotebookWrapper, null, React__default["default"].createElement(NotebookPreview__default["default"], {
33
+ return React.createElement(StyledNotebookWrapper, null, React.createElement(NotebookPreview, {
47
34
  notebook: content
48
35
  }));
49
36
  };
50
37
 
51
- exports["default"] = FileViewerIpynb;
38
+ exports.default = FileViewerIpynb;