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

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 +117 -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 +120 -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
@@ -1,5 +1,3 @@
1
- import { slicedToArray as _slicedToArray, toConsumableArray as _toConsumableArray } from '../../../_virtual/_rollupPluginBabelHelpers.js';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
3
1
  import React from 'react';
4
2
  import { Hr, Flex, Text, IconButton, Hspace, AntSwitch } from '@elice/blocks';
5
3
  import { base } from '@elice/design-tokens';
@@ -15,8 +13,8 @@ import '../exercise-shimmer/ExerciseFileTreeListItemShimmer.js';
15
13
  //
16
14
  //
17
15
  //
18
- var OPTIONS_PER_PAGE = [10, 25, 50];
19
- var OPTIONS_DELIMITER = [{
16
+ const OPTIONS_PER_PAGE = [10, 25, 50];
17
+ const OPTIONS_DELIMITER = [{
20
18
  char: ',',
21
19
  label: 'Comma [,]'
22
20
  }, {
@@ -35,338 +33,250 @@ var OPTIONS_DELIMITER = [{
35
33
  //
36
34
  //
37
35
  //
38
- var StyledViewer = styled.div.withConfig({
36
+ const StyledViewer = styled.div.withConfig({
39
37
  componentId: "sc-pyv7uu-0"
40
38
  })(["flex:1;display:flex;flex-direction:column;width:100%;height:100%;min-width:0;min-height:0;background-color:", ";"], base.color.navy9);
41
- var StyledViewerTableWrap = styled.div.withConfig({
39
+ const StyledViewerTableWrap = styled.div.withConfig({
42
40
  componentId: "sc-pyv7uu-1"
43
41
  })(["flex:1;overflow:auto;"]);
44
- var StyledViewerTable = styled.table.withConfig({
42
+ const StyledViewerTable = styled.table.withConfig({
45
43
  componentId: "sc-pyv7uu-2"
46
44
  })(["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:", ";}}"], base.color.white, base.color.navy5, base.color.gray5, base.color.navy8, base.color.navy6);
47
- var StyledViewerFooter = styled.div.withConfig({
45
+ const StyledViewerFooter = styled.div.withConfig({
48
46
  componentId: "sc-pyv7uu-3"
49
47
  })(["flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:0.5rem;"]);
50
- var StyledViewerFooterSelect = styled.select.withConfig({
48
+ const StyledViewerFooterSelect = styled.select.withConfig({
51
49
  componentId: "sc-pyv7uu-4"
52
- })(["width:", "rem;border-radius:0.25rem;"], function (props) {
53
- return props.width;
54
- });
55
- var StyledViewerFooterHr = styled(Hr).withConfig({
50
+ })(["width:", "rem;border-radius:0.25rem;"], props => props.width);
51
+ const StyledViewerFooterHr = styled(Hr).withConfig({
56
52
  componentId: "sc-pyv7uu-5"
57
53
  })(["height:1rem;"]);
58
54
  //
59
55
  //
60
56
  //
61
- var FileViewerCsv = function FileViewerCsv(_ref) {
62
- var fileurl = _ref.fileurl;
63
- var intl = useRawEliceIntl();
64
- var _React$useState = React.useState(''),
65
- _React$useState2 = _slicedToArray(_React$useState, 2),
66
- csv = _React$useState2[0],
67
- setCsv = _React$useState2[1];
68
- var _React$useState3 = React.useState(null),
69
- _React$useState4 = _slicedToArray(_React$useState3, 2),
70
- csvHeader = _React$useState4[0],
71
- setCsvHeader = _React$useState4[1];
72
- var _React$useState5 = React.useState([]),
73
- _React$useState6 = _slicedToArray(_React$useState5, 2),
74
- csvRecords = _React$useState6[0],
75
- setCsvRecords = _React$useState6[1];
76
- var _React$useState7 = React.useState('idle'),
77
- _React$useState8 = _slicedToArray(_React$useState7, 2),
78
- csvStatus = _React$useState8[0],
79
- setCsvStatus = _React$useState8[1];
80
- var _React$useState9 = React.useState(1),
81
- _React$useState10 = _slicedToArray(_React$useState9, 2),
82
- page = _React$useState10[0],
83
- setPage = _React$useState10[1];
84
- var _React$useState11 = React.useState(OPTIONS_PER_PAGE[0]),
85
- _React$useState12 = _slicedToArray(_React$useState11, 2),
86
- perPage = _React$useState12[0],
87
- setPerPage = _React$useState12[1];
88
- var _React$useState13 = React.useState(OPTIONS_DELIMITER[0].char),
89
- _React$useState14 = _slicedToArray(_React$useState13, 2),
90
- delimiter = _React$useState14[0],
91
- setDelimiter = _React$useState14[1];
92
- var _React$useState15 = React.useState(true),
93
- _React$useState16 = _slicedToArray(_React$useState15, 2),
94
- isUsingHeader = _React$useState16[0],
95
- setUsingHeader = _React$useState16[1];
96
- var csvRecordCount = csvRecords.length + (csvHeader ? -1 : 0);
97
- var maxPage = Math.ceil(csvRecordCount / perPage);
98
- var tableWrapElRef = React.useRef(null);
57
+ const FileViewerCsv = ({
58
+ fileurl
59
+ }) => {
60
+ const intl = useRawEliceIntl();
61
+ const [csv, setCsv] = React.useState('');
62
+ const [csvHeader, setCsvHeader] = React.useState(null);
63
+ const [csvRecords, setCsvRecords] = React.useState([]);
64
+ const [csvStatus, setCsvStatus] = React.useState('idle');
65
+ const [page, setPage] = React.useState(1);
66
+ const [perPage, setPerPage] = React.useState(OPTIONS_PER_PAGE[0]);
67
+ const [delimiter, setDelimiter] = React.useState(OPTIONS_DELIMITER[0].char);
68
+ const [isUsingHeader, setUsingHeader] = React.useState(true);
69
+ const csvRecordCount = csvRecords.length + (csvHeader ? -1 : 0);
70
+ const maxPage = Math.ceil(csvRecordCount / perPage);
71
+ const tableWrapElRef = React.useRef(null);
99
72
  //
100
73
  // Fetch csv file
101
74
  //
102
- React.useEffect(function () {
75
+ React.useEffect(() => {
103
76
  if (!fileurl) {
104
77
  setCsvRecords([]);
105
78
  return;
106
79
  }
107
- var abortCtrl = new AbortController();
80
+ const abortCtrl = new AbortController();
108
81
  setCsvStatus('pending');
109
82
  fetch(fileurl, {
110
83
  signal: abortCtrl.signal
111
- }).then(function (res) {
112
- return res.text();
113
- }).then(setCsv).then(function () {
114
- return setCsvStatus('resolved');
115
- }).catch(function (err) {
84
+ }).then(res => res.text()).then(setCsv).then(() => setCsvStatus('resolved')).catch(err => {
116
85
  if (err.name === 'AbortError') {
117
86
  return;
118
87
  }
119
88
  setCsvRecords([]);
120
89
  setCsvStatus('rejected');
121
90
  });
122
- return function () {
91
+ return () => {
123
92
  abortCtrl.abort();
124
93
  };
125
94
  }, [fileurl]);
126
95
  //
127
96
  // Parse csv file and save as records
128
97
  //
129
- React.useEffect(function () {
130
- return setCsvRecords(csv.split('\n').filter(Boolean).map(function (row) {
131
- return row.split(delimiter);
132
- }));
133
- }, [csv, delimiter]);
98
+ React.useEffect(() => setCsvRecords(csv.split('\n').filter(Boolean).map(row => row.split(delimiter))), [csv, delimiter]);
134
99
  //
135
100
  // Set CSV header.
136
101
  //
137
- React.useEffect(function () {
138
- return setCsvHeader(isUsingHeader ? csvRecords[0] : null);
139
- }, [csvRecords, isUsingHeader]);
102
+ React.useEffect(() => setCsvHeader(isUsingHeader ? csvRecords[0] : null), [csvRecords, isUsingHeader]);
140
103
  //
141
104
  // Scroll to top when page changes.
142
105
  //
143
- React.useEffect(function () {
106
+ React.useEffect(() => {
144
107
  var _a;
145
108
  return (_a = tableWrapElRef.current) === null || _a === void 0 ? void 0 : _a.scrollTo(0, 0);
146
109
  }, [page]);
147
110
  /**
148
111
  *
149
112
  */
150
- var renderViewerTableThead = function renderViewerTableThead() {
113
+ const renderViewerTableThead = () => {
151
114
  if (!csvHeader) {
152
115
  return null;
153
116
  }
154
- var colunms = [''].concat(_toConsumableArray(csvHeader));
155
- return jsx("thead", {
156
- children: jsx("tr", {
157
- children: colunms.map(function (col, colIdx) {
158
- return jsx("th", {
159
- children: col
160
- }, colIdx);
161
- })
162
- })
163
- });
117
+ const colunms = ['', ...csvHeader];
118
+ return React.createElement("thead", null, React.createElement("tr", null, colunms.map((col, colIdx) => React.createElement("th", {
119
+ key: colIdx
120
+ }, col))));
164
121
  };
165
122
  /**
166
123
  *
167
124
  */
168
- var renderViewerTableTbody = function renderViewerTableTbody() {
169
- var start = (page - 1) * perPage;
170
- var end = page * perPage;
171
- var records = csvRecords.slice(csvHeader ? 1 : 0).slice(start, end);
172
- return jsx("tbody", {
173
- children: records.map(function (row, rowIdx) {
174
- var curRecordNo = start + rowIdx + 1;
175
- var curRow = [curRecordNo].concat(_toConsumableArray(row));
176
- return jsx("tr", {
177
- children: curRow.map(function (col, colIdx) {
178
- return jsx("td", {
179
- style: {
180
- // test whether the column is number, and align right
181
- textAlign:
182
- // eslint-disable-next-line no-self-compare
183
- +col === +col ? 'right' : 'left'
184
- },
185
- children: col
186
- }, colIdx);
187
- })
188
- }, curRecordNo);
189
- })
190
- });
125
+ const renderViewerTableTbody = () => {
126
+ const start = (page - 1) * perPage;
127
+ const end = page * perPage;
128
+ const records = csvRecords.slice(csvHeader ? 1 : 0).slice(start, end);
129
+ return React.createElement("tbody", null, records.map((row, rowIdx) => {
130
+ const curRecordNo = start + rowIdx + 1;
131
+ const curRow = [curRecordNo, ...row];
132
+ return React.createElement("tr", {
133
+ key: curRecordNo
134
+ }, curRow.map((col, colIdx) => React.createElement("td", {
135
+ key: colIdx,
136
+ style: {
137
+ // test whether the column is number, and align right
138
+ textAlign:
139
+ // eslint-disable-next-line no-self-compare
140
+ +col === +col ? 'right' : 'left'
141
+ }
142
+ }, col)));
143
+ }));
191
144
  };
192
145
  /**
193
146
  *
194
147
  */
195
- var renderViewerTable = function renderViewerTable() {
196
- return jsx(StyledViewerTableWrap, {
197
- ref: tableWrapElRef,
198
- children: jsxs(StyledViewerTable, {
199
- children: [renderViewerTableThead(), renderViewerTableTbody()]
200
- })
201
- });
148
+ const renderViewerTable = () => {
149
+ return React.createElement(StyledViewerTableWrap, {
150
+ ref: tableWrapElRef
151
+ }, React.createElement(StyledViewerTable, null, renderViewerTableThead(), renderViewerTableTbody()));
202
152
  };
203
153
  /**
204
154
  *
205
155
  */
206
- var renderViewerFooterPagination = function renderViewerFooterPagination() {
207
- return jsxs(Flex, {
208
- align: "center",
209
- children: [jsxs(Text, {
210
- role: "gray1",
211
- size: "small",
212
- children: [csvRecordCount, " records"]
213
- }), jsx(StyledViewerFooterHr, {
214
- vertical: true,
215
- color: base.color.navy5
216
- }), jsxs(Flex, {
217
- align: "center",
218
- children: [jsx(IconButton, {
219
- icon: eilArrowLeftwardsDouble,
220
- role: "navy3",
221
- size: "nano",
222
- disabled: page <= 1,
223
- onClick: function onClick() {
224
- return setPage(1);
225
- }
226
- }), jsx(Hspace, {
227
- width: 0.25
228
- }), jsx(IconButton, {
229
- icon: eilArrowLeftwardsSingle,
230
- role: "navy3",
231
- size: "nano",
232
- disabled: page <= 1,
233
- onClick: function onClick() {
234
- return setPage(function (prevPage) {
235
- return prevPage - 1;
236
- });
237
- }
238
- }), jsx(Hspace, {
239
- width: 0.5
240
- }), jsxs(Text, {
241
- role: "gray1",
242
- size: "small",
243
- children: [page, " / ", maxPage]
244
- }), jsx(Hspace, {
245
- width: 0.5
246
- }), jsx(IconButton, {
247
- icon: eilArrowRightwardsSingle,
248
- role: "navy3",
249
- size: "nano",
250
- disabled: page >= maxPage,
251
- onClick: function onClick() {
252
- return setPage(function (prevPage) {
253
- return prevPage + 1;
254
- });
255
- }
256
- }), jsx(Hspace, {
257
- width: 0.25
258
- }), jsx(IconButton, {
259
- icon: eilArrowRightwardsDouble,
260
- role: "navy3",
261
- size: "nano",
262
- disabled: page >= maxPage,
263
- onClick: function onClick() {
264
- return setPage(maxPage);
265
- }
266
- })]
267
- })]
268
- });
156
+ const renderViewerFooterPagination = () => {
157
+ return React.createElement(Flex, {
158
+ align: "center"
159
+ }, React.createElement(Text, {
160
+ role: "gray1",
161
+ size: "small"
162
+ }, csvRecordCount, " records"), React.createElement(StyledViewerFooterHr, {
163
+ vertical: true,
164
+ color: base.color.navy5
165
+ }), React.createElement(Flex, {
166
+ align: "center"
167
+ }, React.createElement(IconButton, {
168
+ icon: eilArrowLeftwardsDouble,
169
+ role: "navy3",
170
+ size: "nano",
171
+ disabled: page <= 1,
172
+ onClick: () => setPage(1)
173
+ }), React.createElement(Hspace, {
174
+ width: 0.25
175
+ }), React.createElement(IconButton, {
176
+ icon: eilArrowLeftwardsSingle,
177
+ role: "navy3",
178
+ size: "nano",
179
+ disabled: page <= 1,
180
+ onClick: () => setPage(prevPage => prevPage - 1)
181
+ }), React.createElement(Hspace, {
182
+ width: 0.5
183
+ }), React.createElement(Text, {
184
+ role: "gray1",
185
+ size: "small"
186
+ }, page, " / ", maxPage), React.createElement(Hspace, {
187
+ width: 0.5
188
+ }), React.createElement(IconButton, {
189
+ icon: eilArrowRightwardsSingle,
190
+ role: "navy3",
191
+ size: "nano",
192
+ disabled: page >= maxPage,
193
+ onClick: () => setPage(prevPage => prevPage + 1)
194
+ }), React.createElement(Hspace, {
195
+ width: 0.25
196
+ }), React.createElement(IconButton, {
197
+ icon: eilArrowRightwardsDouble,
198
+ role: "navy3",
199
+ size: "nano",
200
+ disabled: page >= maxPage,
201
+ onClick: () => setPage(maxPage)
202
+ })));
269
203
  };
270
204
  /**
271
205
  *
272
206
  */
273
- var renderViewerFooterSettings = function renderViewerFooterSettings() {
274
- return jsxs(Flex, {
275
- align: "center",
276
- children: [jsxs(Flex, {
277
- align: "center",
278
- children: [jsx(Text, {
279
- role: "gray1",
280
- size: "small",
281
- children: intl.formatMessage({
282
- id: '헤더 사용'
283
- })
284
- }), jsx(Hspace, {
285
- width: 0.5
286
- }), jsx(AntSwitch, {
287
- size: "small",
288
- checked: isUsingHeader,
289
- onChange: setUsingHeader
290
- })]
291
- }), jsx(StyledViewerFooterHr, {
292
- vertical: true,
293
- color: base.color.navy5
294
- }), jsxs(Flex, {
295
- align: "center",
296
- children: [jsx(Text, {
297
- role: "gray1",
298
- size: "small",
299
- children: intl.formatMessage({
300
- id: '구분자:'
301
- })
302
- }), jsx(Hspace, {
303
- width: 0.5
304
- }), jsx(StyledViewerFooterSelect, {
305
- width: 7.5,
306
- value: delimiter,
307
- onChange: function onChange(e) {
308
- return setDelimiter(e.target.value);
309
- },
310
- children: OPTIONS_DELIMITER.map(function (_ref2) {
311
- var char = _ref2.char,
312
- label = _ref2.label;
313
- return jsx("option", {
314
- value: char,
315
- children: label
316
- });
317
- })
318
- })]
319
- }), jsx(StyledViewerFooterHr, {
320
- vertical: true,
321
- color: base.color.navy5
322
- }), jsxs(Flex, {
323
- align: "center",
324
- children: [jsx(Text, {
325
- role: "gray1",
326
- size: "small",
327
- children: intl.formatMessage({
328
- id: '페이지당 행:'
329
- })
330
- }), jsx(Hspace, {
331
- width: 0.5
332
- }), jsx(StyledViewerFooterSelect, {
333
- width: 3,
334
- value: perPage,
335
- onChange: function onChange(e) {
336
- return setPerPage(Number(e.target.value));
337
- },
338
- children: OPTIONS_PER_PAGE.map(function (perPage) {
339
- return jsx("option", {
340
- value: perPage,
341
- children: perPage
342
- });
343
- })
344
- })]
345
- })]
346
- });
207
+ const renderViewerFooterSettings = () => {
208
+ return React.createElement(Flex, {
209
+ align: "center"
210
+ }, React.createElement(Flex, {
211
+ align: "center"
212
+ }, React.createElement(Text, {
213
+ role: "gray1",
214
+ size: "small"
215
+ }, intl.formatMessage({
216
+ id: '헤더 사용'
217
+ })), React.createElement(Hspace, {
218
+ width: 0.5
219
+ }), React.createElement(AntSwitch, {
220
+ size: "small",
221
+ checked: isUsingHeader,
222
+ onChange: setUsingHeader
223
+ })), React.createElement(StyledViewerFooterHr, {
224
+ vertical: true,
225
+ color: base.color.navy5
226
+ }), React.createElement(Flex, {
227
+ align: "center"
228
+ }, React.createElement(Text, {
229
+ role: "gray1",
230
+ size: "small"
231
+ }, intl.formatMessage({
232
+ id: '구분자:'
233
+ })), React.createElement(Hspace, {
234
+ width: 0.5
235
+ }), React.createElement(StyledViewerFooterSelect, {
236
+ width: 7.5,
237
+ value: delimiter,
238
+ onChange: e => setDelimiter(e.target.value)
239
+ }, OPTIONS_DELIMITER.map(({
240
+ char,
241
+ label
242
+ }) => React.createElement("option", {
243
+ value: char
244
+ }, label)))), React.createElement(StyledViewerFooterHr, {
245
+ vertical: true,
246
+ color: base.color.navy5
247
+ }), React.createElement(Flex, {
248
+ align: "center"
249
+ }, React.createElement(Text, {
250
+ role: "gray1",
251
+ size: "small"
252
+ }, intl.formatMessage({
253
+ id: '페이지당 행:'
254
+ })), React.createElement(Hspace, {
255
+ width: 0.5
256
+ }), React.createElement(StyledViewerFooterSelect, {
257
+ width: 3,
258
+ value: perPage,
259
+ onChange: e => setPerPage(Number(e.target.value))
260
+ }, OPTIONS_PER_PAGE.map(perPage => React.createElement("option", {
261
+ value: perPage
262
+ }, perPage)))));
347
263
  };
348
264
  /**
349
265
  *
350
266
  */
351
- var renderViewerFooter = function renderViewerFooter() {
352
- return jsxs(StyledViewerFooter, {
353
- children: [renderViewerFooterPagination(), renderViewerFooterSettings()]
354
- });
267
+ const renderViewerFooter = () => {
268
+ return React.createElement(StyledViewerFooter, null, renderViewerFooterPagination(), renderViewerFooterSettings());
355
269
  };
356
270
  //
357
271
  //
358
272
  //
359
273
  if (csvStatus === 'idle' || csvStatus === 'pending') {
360
- return jsx(ExerciseFileShimmer, {});
274
+ return React.createElement(ExerciseFileShimmer, null);
361
275
  }
362
276
  if (csvStatus === 'rejected') {
363
- return jsx("div", {
364
- children: "error"
365
- });
277
+ return React.createElement("div", null, "error");
366
278
  }
367
- return jsxs(StyledViewer, {
368
- children: [renderViewerTable(), renderViewerFooter()]
369
- });
279
+ return React.createElement(StyledViewer, null, renderViewerTable(), renderViewerFooter());
370
280
  };
371
281
 
372
282
  export { FileViewerCsv as default };
@@ -1,4 +1,4 @@
1
- import { jsx } from 'react/jsx-runtime';
1
+ import React from 'react';
2
2
  import { Flex } from '@elice/blocks';
3
3
  import styled from 'styled-components';
4
4
  import ExerciseFileShimmer from '../exercise-shimmer/ExerciseFileShimmer.js';
@@ -7,24 +7,24 @@ import '../exercise-shimmer/ExerciseFileTabShimmer.js';
7
7
  import '../exercise-shimmer/ExerciseFileTreeListShimmer.js';
8
8
  import '../exercise-shimmer/ExerciseFileTreeListItemShimmer.js';
9
9
 
10
- var StyledImage = styled.img.withConfig({
10
+ const StyledImage = styled.img.withConfig({
11
11
  componentId: "sc-1bnx7lz-0"
12
12
  })(["max-width:100%;max-height:100%;height:auto;width:auto;"]);
13
- var FileViewerImage = function FileViewerImage(_ref) {
14
- var fileurl = _ref.fileurl;
13
+ const FileViewerImage = ({
14
+ fileurl
15
+ }) => {
15
16
  if (!fileurl) {
16
- return jsx(ExerciseFileShimmer, {});
17
+ return React.createElement(ExerciseFileShimmer, null);
17
18
  }
18
- return jsx(Flex, {
19
+ return React.createElement(Flex, {
19
20
  align: "center",
20
21
  justify: "center",
21
22
  auto: true,
22
- overflow: "hidden",
23
- children: jsx(StyledImage, {
24
- src: fileurl,
25
- alt: fileurl
26
- })
27
- });
23
+ overflow: "hidden"
24
+ }, React.createElement(StyledImage, {
25
+ src: fileurl,
26
+ alt: fileurl
27
+ }));
28
28
  };
29
29
 
30
30
  export { FileViewerImage as default };
@@ -1,5 +1,3 @@
1
- import { slicedToArray as _slicedToArray } from '../../../_virtual/_rollupPluginBabelHelpers.js';
2
- import { jsx } from 'react/jsx-runtime';
3
1
  import React from 'react';
4
2
  import NotebookPreview from '@nteract/notebook-preview';
5
3
  import styled from 'styled-components';
@@ -9,36 +7,28 @@ import '../exercise-shimmer/ExerciseFileTabShimmer.js';
9
7
  import '../exercise-shimmer/ExerciseFileTreeListShimmer.js';
10
8
  import '../exercise-shimmer/ExerciseFileTreeListItemShimmer.js';
11
9
 
12
- var StyledNotebookWrapper = styled.div.withConfig({
10
+ const StyledNotebookWrapper = styled.div.withConfig({
13
11
  componentId: "sc-1fmae1h-0"
14
12
  })(["width:100%;height:100%;overflow:auto;background-color:white;padding:1rem;.notebook-preview{width:100%;height:100%;}"]);
15
- var FileViewerIpynb = function FileViewerIpynb(_ref) {
16
- var fileurl = _ref.fileurl;
17
- var _React$useState = React.useState(null),
18
- _React$useState2 = _slicedToArray(_React$useState, 2),
19
- content = _React$useState2[0],
20
- setContent = _React$useState2[1];
21
- React.useEffect(function () {
13
+ const FileViewerIpynb = ({
14
+ fileurl
15
+ }) => {
16
+ const [content, setContent] = React.useState(null);
17
+ React.useEffect(() => {
22
18
  if (!fileurl) {
23
19
  return;
24
20
  }
25
- fetch(fileurl).then(function (res) {
26
- return res.text();
27
- }).then(JSON.parse).then(setContent).catch(function (err) {
28
- return console.error(err);
29
- });
21
+ fetch(fileurl).then(res => res.text()).then(JSON.parse).then(setContent).catch(err => console.error(err));
30
22
  }, [fileurl]);
31
23
  //
32
24
  //
33
25
  //
34
26
  if (!content) {
35
- return jsx(ExerciseFileShimmer, {});
27
+ return React.createElement(ExerciseFileShimmer, null);
36
28
  }
37
- return jsx(StyledNotebookWrapper, {
38
- children: jsx(NotebookPreview, {
39
- notebook: content
40
- })
41
- });
29
+ return React.createElement(StyledNotebookWrapper, null, React.createElement(NotebookPreview, {
30
+ notebook: content
31
+ }));
42
32
  };
43
33
 
44
34
  export { FileViewerIpynb as default };