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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (459) hide show
  1. package/cjs/assets/empty.png.js +2 -1
  2. package/cjs/components/material-exercise/MaterialExercise.d.ts +1 -1
  3. package/cjs/components/material-exercise/MaterialExercise.js +75 -111
  4. package/cjs/components/material-exercise/MaterialExercise.styled.js +14 -18
  5. package/cjs/components/material-exercise/MaterialExerciseMobile.d.ts +1 -1
  6. package/cjs/components/material-exercise/MaterialExerciseMobile.js +7 -17
  7. package/cjs/components/material-exercise/context/ExerciseProvider.js +58 -68
  8. package/cjs/components/material-exercise/context/ExerciseProviderNoImage.js +30 -39
  9. package/cjs/components/material-exercise/context/context.js +1 -5
  10. package/cjs/components/material-exercise/context/recoil.js +293 -542
  11. package/cjs/components/material-exercise/context/subjects.js +4 -4
  12. package/cjs/components/material-exercise/context/types.d.ts +2 -2
  13. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +78 -100
  14. package/cjs/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -12
  15. package/cjs/components/material-exercise/exercise-file/ExerciseFile.js +27 -30
  16. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +149 -225
  17. package/cjs/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +13 -20
  18. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +29 -49
  19. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.d.ts +2 -1
  20. package/cjs/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +4 -10
  21. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/ExerciseFileTabsFileTreeButton.js +36 -53
  22. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +211 -353
  23. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.d.ts +2 -1
  24. package/cjs/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +4 -10
  25. package/cjs/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +15 -18
  26. package/cjs/components/material-exercise/exercise-menu/ExerciseMenu.js +12 -21
  27. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +11 -12
  28. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +80 -123
  29. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +67 -100
  30. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuReset.js +22 -40
  31. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +119 -144
  32. package/cjs/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +13 -17
  33. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +19 -32
  34. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.d.ts +2 -1
  35. package/cjs/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +4 -10
  36. package/cjs/components/material-exercise/exercise-preview/ExercisePreview.js +24 -31
  37. package/cjs/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +6 -13
  38. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +35 -51
  39. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +6 -14
  40. package/cjs/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +78 -90
  41. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.js +12 -25
  42. package/cjs/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -18
  43. package/cjs/components/material-exercise/exercise-room/ExerciseRoomDetail.js +349 -504
  44. package/cjs/components/material-exercise/exercise-room/ExerciseRoomList.js +132 -197
  45. package/cjs/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -2
  46. package/cjs/components/material-exercise/exercise-runner/ExerciseRunner.js +142 -205
  47. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -5
  48. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerController.js +16 -25
  49. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +86 -118
  50. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +19 -33
  51. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +82 -95
  52. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +52 -68
  53. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +87 -136
  54. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +2 -6
  55. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +15 -21
  56. package/cjs/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +23 -36
  57. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +248 -402
  58. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -12
  59. package/cjs/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +50 -74
  60. package/cjs/components/shared/exercise-menu-button/ExerciseMenuButton.js +23 -32
  61. package/cjs/components/shared/exercise-shimmer/ExerciseFileShimmer.js +38 -44
  62. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +20 -26
  63. package/cjs/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +8 -14
  64. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +22 -28
  65. package/cjs/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +9 -24
  66. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.js +5 -6
  67. package/cjs/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -5
  68. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.js +10 -10
  69. package/cjs/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -13
  70. package/cjs/components/shared/file-icon/FileIcon.js +16 -23
  71. package/cjs/components/shared/file-tabs/FileTab.js +33 -47
  72. package/cjs/components/shared/file-tabs/FileTab.styled.js +15 -23
  73. package/cjs/components/shared/file-tabs/FileTabs.js +39 -66
  74. package/cjs/components/shared/file-tabs/FileTabs.styled.js +2 -6
  75. package/cjs/components/shared/file-tabs/util.js +14 -27
  76. package/cjs/components/shared/file-tree/FileTree.js +10 -20
  77. package/cjs/components/shared/file-tree/FileTreeConfig.js +40 -46
  78. package/cjs/components/shared/file-tree/FileTreeList.js +40 -43
  79. package/cjs/components/shared/file-tree/FileTreeListItemContent.js +99 -128
  80. package/cjs/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -29
  81. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.js +96 -106
  82. package/cjs/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -10
  83. package/cjs/components/shared/file-tree/FileTreeListItemContentMenu.js +91 -133
  84. package/cjs/components/shared/file-tree/FileTreeListItems.js +137 -149
  85. package/cjs/components/shared/file-tree/FileTreeListItems.styled.js +2 -6
  86. package/cjs/components/shared/file-tree/FileTreeToolbar.styled.js +1 -5
  87. package/cjs/components/shared/file-tree/context/FileTreeContext.d.ts +1 -1
  88. package/cjs/components/shared/file-tree/context/FileTreeContext.js +79 -101
  89. package/cjs/components/shared/file-tree/file-tree-toolbar/FileTreeToolbar.js +54 -59
  90. package/cjs/components/shared/file-tree/utils/fileTreeFiles.js +20 -24
  91. package/cjs/components/shared/file-tree/utils/fileTreeGenerator.js +146 -193
  92. package/cjs/components/shared/file-tree/utils/fileTreeInput.js +0 -11
  93. package/cjs/components/shared/file-tree/utils/fileTreeItem.js +1 -1
  94. package/cjs/components/shared/file-tree/utils/fileTreePath.js +6 -5
  95. package/cjs/components/shared/file-viewer/FileViewer.js +46 -76
  96. package/cjs/components/shared/file-viewer/FileViewerCsv.js +167 -262
  97. package/cjs/components/shared/file-viewer/FileViewerImage.js +12 -16
  98. package/cjs/components/shared/file-viewer/FileViewerIpynb.js +11 -27
  99. package/cjs/components/shared/file-viewer/FileViewerNonViewable.js +47 -65
  100. package/cjs/components/shared/file-viewer/FileViewerText.js +11 -23
  101. package/cjs/components/shared/material-modal/MaterialModal.js +11 -20
  102. package/cjs/components/shared/material-modal/MaterialModal.styled.js +5 -9
  103. package/cjs/components/shared/monaco-editor/MonacoEditor.js +74 -102
  104. package/cjs/components/shared/monaco-editor/MonacoEditorLazy.js +7 -15
  105. package/cjs/components/shared/monaco-editor/MonacoEditorMobile.js +34 -49
  106. package/cjs/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +194 -249
  107. package/cjs/components/shared/monaco-editor/constants/grammars/index.js +28 -82
  108. package/cjs/components/shared/monaco-editor/constants/monaco/preferences.js +5 -5
  109. package/cjs/components/shared/monaco-editor/constants/themes/index.js +17 -49
  110. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -11
  111. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -15
  112. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -9
  113. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -34
  114. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -9
  115. package/cjs/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -6
  116. package/cjs/components/shared/monaco-editor/editor-languages/css/formatter.js +10 -33
  117. package/cjs/components/shared/monaco-editor/editor-languages/css/index.js +2 -3
  118. package/cjs/components/shared/monaco-editor/editor-languages/html/formatter.js +10 -33
  119. package/cjs/components/shared/monaco-editor/editor-languages/html/index.js +2 -3
  120. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -1
  121. package/cjs/components/shared/monaco-editor/editor-languages/typescript/formatter.js +10 -37
  122. package/cjs/components/shared/monaco-editor/editor-languages/typescript/index.js +5 -6
  123. package/cjs/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -11
  124. package/cjs/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -10
  125. package/cjs/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -12
  126. package/cjs/components/shared/monaco-editor/utils/grammar/index.js +24 -67
  127. package/cjs/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -25
  128. package/cjs/components/shared/monaco-editor/utils/grammar/textmate.js +37 -70
  129. package/cjs/components/shared/monaco-editor/utils/monacoLanguage.js +7 -8
  130. package/cjs/components/shared/monaco-editor/utils/monacoPreference.js +4 -6
  131. package/cjs/components/shared/monaco-editor/utils/prettier/config.js +2 -2
  132. package/cjs/components/shared/monaco-editor/utils/prettier/index.js +7 -27
  133. package/cjs/components/shared/monaco-editor/utils/theme/convert.js +14 -24
  134. package/cjs/components/shared/monaco-editor/utils/theme/index.js +3 -22
  135. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -77
  136. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -82
  137. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -120
  138. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +132 -155
  139. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -104
  140. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -2
  141. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -1
  142. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -2
  143. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +158 -177
  144. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -3
  145. package/cjs/components/shared/no-vnc/NoVnc.js +78 -118
  146. package/cjs/components/shared/no-vnc/NoVncLazy.js +7 -15
  147. package/cjs/components/shared/preview-container/PreviewContainer.js +13 -18
  148. package/cjs/components/shared/web-browser/WebBrowser.js +52 -74
  149. package/cjs/components/shared/xterm/Xterm.js +57 -82
  150. package/cjs/components/shared/xterm/XtermLazy.js +7 -15
  151. package/cjs/constants/arduino.js +10 -10
  152. package/cjs/constants/color.js +1 -1
  153. package/cjs/constants/shortcutKeyMap.js +1 -3
  154. package/cjs/constants/stylesheets.js +5 -7
  155. package/cjs/hooks/useArduino.js +141 -282
  156. package/cjs/hooks/useExerciseFile.js +22 -24
  157. package/cjs/hooks/useExericseShortcut.js +4 -6
  158. package/cjs/hooks/useMaterialExerciseFileUrl.js +33 -55
  159. package/cjs/hooks/useRunnerRoomWebSocket.js +27 -51
  160. package/cjs/hooks/useStdioTextConcator.js +11 -15
  161. package/cjs/hooks/useStdioWebSocket.js +28 -32
  162. package/cjs/hooks/useUsercodeEditWebSocket.js +158 -238
  163. package/cjs/hooks/useUsercodeHistory.js +63 -115
  164. package/cjs/utils/arduino.js +11 -23
  165. package/cjs/utils/exerciseFile.js +10 -8
  166. package/cjs/utils/runner.js +17 -33
  167. package/es/assets/empty.png.js +2 -1
  168. package/es/components/material-exercise/MaterialExercise.d.ts +1 -1
  169. package/es/components/material-exercise/MaterialExercise.js +75 -107
  170. package/es/components/material-exercise/MaterialExercise.styled.js +14 -14
  171. package/es/components/material-exercise/MaterialExerciseMobile.d.ts +1 -1
  172. package/es/components/material-exercise/MaterialExerciseMobile.js +7 -13
  173. package/es/components/material-exercise/context/ExerciseProvider.js +58 -63
  174. package/es/components/material-exercise/context/ExerciseProviderNoImage.js +30 -35
  175. package/es/components/material-exercise/context/context.js +1 -1
  176. package/es/components/material-exercise/context/recoil.js +290 -535
  177. package/es/components/material-exercise/context/subjects.js +4 -4
  178. package/es/components/material-exercise/context/types.d.ts +2 -2
  179. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.js +78 -95
  180. package/es/components/material-exercise/exercise-code-history/ExerciseCodeHistory.styled.js +8 -8
  181. package/es/components/material-exercise/exercise-file/ExerciseFile.js +27 -25
  182. package/es/components/material-exercise/exercise-file-editor/ExerciseFileEditor.js +149 -221
  183. package/es/components/material-exercise/exercise-file-editor/ExerciseFileReadOnlyBanner.js +13 -15
  184. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabs.js +29 -44
  185. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.d.ts +2 -1
  186. package/es/components/material-exercise/exercise-file-tabs/ExerciseFileTabsLazy.js +4 -6
  187. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/ExerciseFileTabsFileTreeButton.js +36 -48
  188. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTree.js +211 -348
  189. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.d.ts +2 -1
  190. package/es/components/material-exercise/exercise-file-tree/ExerciseFileTreeLazy.js +4 -6
  191. package/es/components/material-exercise/exercise-file-viewer/ExerciseFileViewer.js +15 -14
  192. package/es/components/material-exercise/exercise-menu/ExerciseMenu.js +12 -16
  193. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoAgentModalButton.js +11 -12
  194. package/es/components/material-exercise/exercise-menu/ExerciseMenuArduinoSettings.js +80 -119
  195. package/es/components/material-exercise/exercise-menu/ExerciseMenuDropdown.js +67 -96
  196. package/es/components/material-exercise/exercise-menu/ExerciseMenuReset.js +23 -41
  197. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.js +122 -143
  198. package/es/components/material-exercise/exercise-menu/ExerciseMenuStdioFileBrowser.styled.js +13 -13
  199. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdown.js +19 -28
  200. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.d.ts +2 -1
  201. package/es/components/material-exercise/exercise-multilang-dropdown/ExerciseMultilangDropdownLazy.js +4 -6
  202. package/es/components/material-exercise/exercise-preview/ExercisePreview.js +24 -26
  203. package/es/components/material-exercise/exercise-preview/ExercisePreviewDisplayModeButton.js +7 -14
  204. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpane.js +35 -47
  205. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEditorPerference.js +6 -10
  206. package/es/components/material-exercise/exercise-rightpane/ExerciseRightpaneEnvironment.js +78 -85
  207. package/es/components/material-exercise/exercise-room/ExerciseRoom.js +12 -21
  208. package/es/components/material-exercise/exercise-room/ExerciseRoom.styled.js +12 -14
  209. package/es/components/material-exercise/exercise-room/ExerciseRoomDetail.js +349 -498
  210. package/es/components/material-exercise/exercise-room/ExerciseRoomList.js +133 -193
  211. package/es/components/material-exercise/exercise-room/helpers/exerciseRoomPermissionStringConvertor.js +2 -2
  212. package/es/components/material-exercise/exercise-runner/ExerciseRunner.js +142 -200
  213. package/es/components/material-exercise/exercise-runner/ExerciseRunnerContext.js +1 -1
  214. package/es/components/material-exercise/exercise-runner/ExerciseRunnerController.js +16 -20
  215. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoAgentModal.js +85 -112
  216. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerArduinoStatusMessage.js +20 -30
  217. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerButtonGroup.js +82 -90
  218. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerCodeHelpRequestButton.js +52 -63
  219. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerRunningInfo.js +87 -131
  220. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusIndicator.js +2 -2
  221. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerStatusMessage.js +15 -17
  222. package/es/components/material-exercise/exercise-runner/ExerciseRunnerControllerTimer.js +23 -31
  223. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.js +250 -399
  224. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistory.styled.js +8 -8
  225. package/es/components/material-exercise/exercise-submit-history/ExerciseSubmitHistoryOutput.js +49 -68
  226. package/es/components/shared/exercise-menu-button/ExerciseMenuButton.js +24 -29
  227. package/es/components/shared/exercise-shimmer/ExerciseFileShimmer.js +38 -40
  228. package/es/components/shared/exercise-shimmer/ExerciseFileTabShimmer.js +20 -22
  229. package/es/components/shared/exercise-shimmer/ExerciseFileTabsShimmer.js +8 -10
  230. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListItemShimmer.js +22 -24
  231. package/es/components/shared/exercise-shimmer/ExerciseFileTreeListShimmer.js +9 -19
  232. package/es/components/shared/exercise-version-list/ExerciseVersionList.js +5 -6
  233. package/es/components/shared/exercise-version-list/ExerciseVersionList.styled.js +1 -1
  234. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.js +10 -10
  235. package/es/components/shared/exercise-version-list/ExerciseVersionListItem.styled.js +5 -9
  236. package/es/components/shared/file-icon/FileIcon.js +16 -19
  237. package/es/components/shared/file-tabs/FileTab.js +33 -43
  238. package/es/components/shared/file-tabs/FileTab.styled.js +15 -19
  239. package/es/components/shared/file-tabs/FileTabs.js +40 -62
  240. package/es/components/shared/file-tabs/FileTabs.styled.js +2 -2
  241. package/es/components/shared/file-tabs/util.js +14 -27
  242. package/es/components/shared/file-tree/FileTree.js +10 -16
  243. package/es/components/shared/file-tree/FileTreeConfig.js +39 -39
  244. package/es/components/shared/file-tree/FileTreeList.js +40 -38
  245. package/es/components/shared/file-tree/FileTreeListItemContent.js +99 -124
  246. package/es/components/shared/file-tree/FileTreeListItemContent.styled.js +21 -25
  247. package/es/components/shared/file-tree/FileTreeListItemContentInput.js +96 -102
  248. package/es/components/shared/file-tree/FileTreeListItemContentInput.styled.js +6 -6
  249. package/es/components/shared/file-tree/FileTreeListItemContentMenu.js +91 -129
  250. package/es/components/shared/file-tree/FileTreeListItems.js +137 -149
  251. package/es/components/shared/file-tree/FileTreeListItems.styled.js +2 -2
  252. package/es/components/shared/file-tree/FileTreeToolbar.styled.js +1 -1
  253. package/es/components/shared/file-tree/context/FileTreeContext.d.ts +1 -1
  254. package/es/components/shared/file-tree/context/FileTreeContext.js +79 -97
  255. package/es/components/shared/file-tree/file-tree-toolbar/FileTreeToolbar.js +54 -55
  256. package/es/components/shared/file-tree/utils/fileTreeFiles.js +20 -20
  257. package/es/components/shared/file-tree/utils/fileTreeGenerator.js +146 -193
  258. package/es/components/shared/file-tree/utils/fileTreeInput.js +1 -11
  259. package/es/components/shared/file-tree/utils/fileTreeItem.js +1 -1
  260. package/es/components/shared/file-tree/utils/fileTreePath.js +6 -5
  261. package/es/components/shared/file-viewer/FileViewer.js +46 -69
  262. package/es/components/shared/file-viewer/FileViewerCsv.js +167 -257
  263. package/es/components/shared/file-viewer/FileViewerImage.js +12 -12
  264. package/es/components/shared/file-viewer/FileViewerIpynb.js +11 -21
  265. package/es/components/shared/file-viewer/FileViewerNonViewable.js +47 -60
  266. package/es/components/shared/file-viewer/FileViewerText.js +11 -19
  267. package/es/components/shared/material-modal/MaterialModal.js +11 -20
  268. package/es/components/shared/material-modal/MaterialModal.styled.js +5 -5
  269. package/es/components/shared/monaco-editor/MonacoEditor.js +72 -95
  270. package/es/components/shared/monaco-editor/MonacoEditorLazy.js +7 -11
  271. package/es/components/shared/monaco-editor/MonacoEditorMobile.js +32 -43
  272. package/es/components/shared/monaco-editor/MonacoEditorPerferenceForm.js +194 -244
  273. package/es/components/shared/monaco-editor/constants/grammars/index.js +28 -82
  274. package/es/components/shared/monaco-editor/constants/monaco/preferences.js +5 -5
  275. package/es/components/shared/monaco-editor/constants/themes/index.js +17 -49
  276. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventChange.js +10 -11
  277. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventCursor.js +14 -15
  278. package/es/components/shared/monaco-editor/editor-hooks/useMonacoEventScroll.js +8 -9
  279. package/es/components/shared/monaco-editor/editor-hooks/useMonacoMarkers.js +30 -34
  280. package/es/components/shared/monaco-editor/editor-hooks/useMonacoOptions.js +7 -9
  281. package/es/components/shared/monaco-editor/editor-hooks/useMonacoTheme.js +6 -6
  282. package/es/components/shared/monaco-editor/editor-languages/css/formatter.js +10 -33
  283. package/es/components/shared/monaco-editor/editor-languages/html/formatter.js +10 -33
  284. package/es/components/shared/monaco-editor/editor-languages/typescript/dts/_helper.js +1 -1
  285. package/es/components/shared/monaco-editor/editor-languages/typescript/formatter.js +10 -37
  286. package/es/components/shared/monaco-editor/editor-languages/typescript/index.js +3 -3
  287. package/es/components/shared/monaco-editor/hooks/useEditorOptions.js +5 -11
  288. package/es/components/shared/monaco-editor/utils/emmet/abbreviationActions.js +12 -10
  289. package/es/components/shared/monaco-editor/utils/emmet/registerProvider.js +6 -12
  290. package/es/components/shared/monaco-editor/utils/grammar/index.js +24 -67
  291. package/es/components/shared/monaco-editor/utils/grammar/onigasm.js +6 -25
  292. package/es/components/shared/monaco-editor/utils/grammar/textmate.js +35 -67
  293. package/es/components/shared/monaco-editor/utils/monacoLanguage.js +5 -5
  294. package/es/components/shared/monaco-editor/utils/monacoPreference.js +4 -6
  295. package/es/components/shared/monaco-editor/utils/prettier/config.js +2 -2
  296. package/es/components/shared/monaco-editor/utils/prettier/index.js +7 -27
  297. package/es/components/shared/monaco-editor/utils/theme/convert.js +13 -19
  298. package/es/components/shared/monaco-editor/utils/theme/index.js +3 -22
  299. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursor.js +56 -77
  300. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorManager.js +68 -82
  301. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteCursorWidget.js +93 -120
  302. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelection.js +130 -152
  303. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/RemoteSelectionManager.js +92 -104
  304. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/styles.js +2 -2
  305. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/configCompat.js +6 -1
  306. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/data.js +2 -2
  307. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/emmetHelper.js +156 -171
  308. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/utils.js +3 -3
  309. package/es/components/shared/no-vnc/NoVnc.js +71 -99
  310. package/es/components/shared/no-vnc/NoVncLazy.js +7 -11
  311. package/es/components/shared/preview-container/PreviewContainer.js +14 -15
  312. package/es/components/shared/web-browser/WebBrowser.js +52 -69
  313. package/es/components/shared/xterm/Xterm.js +57 -77
  314. package/es/components/shared/xterm/XtermLazy.js +7 -11
  315. package/es/constants/arduino.js +10 -10
  316. package/es/constants/color.js +1 -1
  317. package/es/constants/shortcutKeyMap.js +1 -3
  318. package/es/constants/stylesheets.js +5 -7
  319. package/es/hooks/useArduino.js +141 -278
  320. package/es/hooks/useExerciseFile.js +22 -24
  321. package/es/hooks/useExericseShortcut.js +4 -6
  322. package/es/hooks/useMaterialExerciseFileUrl.js +34 -52
  323. package/es/hooks/useRunnerRoomWebSocket.js +27 -51
  324. package/es/hooks/useStdioTextConcator.js +11 -11
  325. package/es/hooks/useStdioWebSocket.js +28 -32
  326. package/es/hooks/useUsercodeEditWebSocket.js +157 -232
  327. package/es/hooks/useUsercodeHistory.js +63 -115
  328. package/es/utils/arduino.js +12 -24
  329. package/es/utils/exerciseFile.js +10 -8
  330. package/es/utils/runner.js +17 -33
  331. package/package.json +15 -11
  332. package/cjs/_virtual/_rollupPluginBabelHelpers.js +0 -519
  333. package/cjs/components/index.js +0 -25
  334. package/cjs/components/locales/index.js +0 -13
  335. package/cjs/components/material-exercise/context/index.js +0 -57
  336. package/cjs/components/material-exercise/exercise-code-history/index.js +0 -7
  337. package/cjs/components/material-exercise/exercise-code-history/locales/index.js +0 -13
  338. package/cjs/components/material-exercise/exercise-file/index.js +0 -7
  339. package/cjs/components/material-exercise/exercise-file-editor/index.js +0 -7
  340. package/cjs/components/material-exercise/exercise-file-editor/locales/index.js +0 -13
  341. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/index.js +0 -7
  342. package/cjs/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/locales/index.js +0 -13
  343. package/cjs/components/material-exercise/exercise-file-tabs/index.js +0 -9
  344. package/cjs/components/material-exercise/exercise-file-tabs/locales/index.js +0 -13
  345. package/cjs/components/material-exercise/exercise-file-tree/index.js +0 -9
  346. package/cjs/components/material-exercise/exercise-file-tree/locales/index.js +0 -13
  347. package/cjs/components/material-exercise/exercise-file-viewer/index.js +0 -7
  348. package/cjs/components/material-exercise/exercise-menu/index.js +0 -7
  349. package/cjs/components/material-exercise/exercise-menu/locales/index.js +0 -13
  350. package/cjs/components/material-exercise/exercise-multilang-dropdown/index.js +0 -9
  351. package/cjs/components/material-exercise/exercise-preview/index.js +0 -7
  352. package/cjs/components/material-exercise/exercise-preview/locales/index.js +0 -13
  353. package/cjs/components/material-exercise/exercise-rightpane/index.js +0 -7
  354. package/cjs/components/material-exercise/exercise-rightpane/locales/index.js +0 -13
  355. package/cjs/components/material-exercise/exercise-room/helpers/index.js +0 -7
  356. package/cjs/components/material-exercise/exercise-room/index.js +0 -7
  357. package/cjs/components/material-exercise/exercise-room/locales/index.js +0 -13
  358. package/cjs/components/material-exercise/exercise-runner/index.js +0 -7
  359. package/cjs/components/material-exercise/exercise-runner/locales/index.js +0 -13
  360. package/cjs/components/material-exercise/exercise-submit-history/index.js +0 -7
  361. package/cjs/components/material-exercise/exercise-submit-history/locales/index.js +0 -13
  362. package/cjs/components/material-exercise/index.js +0 -9
  363. package/cjs/components/shared/exercise-menu-button/index.js +0 -7
  364. package/cjs/components/shared/exercise-shimmer/index.js +0 -15
  365. package/cjs/components/shared/exercise-version-list/index.js +0 -9
  366. package/cjs/components/shared/file-icon/index.js +0 -7
  367. package/cjs/components/shared/file-tabs/index.js +0 -7
  368. package/cjs/components/shared/file-tree/context/index.js +0 -9
  369. package/cjs/components/shared/file-tree/file-tree-toolbar/index.js +0 -7
  370. package/cjs/components/shared/file-tree/file-tree-toolbar/locales/index.js +0 -13
  371. package/cjs/components/shared/file-tree/index.js +0 -7
  372. package/cjs/components/shared/file-tree/locales/index.js +0 -13
  373. package/cjs/components/shared/file-tree/utils/index.js +0 -20
  374. package/cjs/components/shared/file-viewer/index.js +0 -7
  375. package/cjs/components/shared/file-viewer/locales/index.js +0 -21
  376. package/cjs/components/shared/material-modal/index.js +0 -7
  377. package/cjs/components/shared/monaco-editor/constants/index.js +0 -13
  378. package/cjs/components/shared/monaco-editor/constants/monaco/index.js +0 -11
  379. package/cjs/components/shared/monaco-editor/editor-hooks/index.js +0 -17
  380. package/cjs/components/shared/monaco-editor/editor-languages/typescript/dts/index.js +0 -11
  381. package/cjs/components/shared/monaco-editor/hooks/index.js +0 -7
  382. package/cjs/components/shared/monaco-editor/index.js +0 -21
  383. package/cjs/components/shared/monaco-editor/locales/index.js +0 -13
  384. package/cjs/components/shared/monaco-editor/utils/emmet/index.js +0 -9
  385. package/cjs/components/shared/monaco-editor/utils/index.js +0 -9
  386. package/cjs/components/shared/monaco-editor/vendors/monaco-collab-ext/index.js +0 -12
  387. package/cjs/components/shared/monaco-editor/vendors/vscode-emmet-helper/index.js +0 -11
  388. package/cjs/components/shared/no-vnc/index.js +0 -7
  389. package/cjs/components/shared/preview-container/index.js +0 -9
  390. package/cjs/components/shared/web-browser/index.js +0 -7
  391. package/cjs/components/shared/xterm/index.js +0 -7
  392. package/cjs/components/shared/xterm/locales/index.js +0 -13
  393. package/cjs/constants/index.js +0 -7
  394. package/cjs/hooks/index.js +0 -20
  395. package/cjs/utils/index.js +0 -10
  396. package/es/_virtual/_rollupPluginBabelHelpers.js +0 -499
  397. package/es/components/index.js +0 -8
  398. package/es/components/locales/index.js +0 -4
  399. package/es/components/material-exercise/context/index.js +0 -5
  400. package/es/components/material-exercise/exercise-code-history/index.js +0 -1
  401. package/es/components/material-exercise/exercise-code-history/locales/index.js +0 -4
  402. package/es/components/material-exercise/exercise-file/index.js +0 -1
  403. package/es/components/material-exercise/exercise-file-editor/index.js +0 -1
  404. package/es/components/material-exercise/exercise-file-editor/locales/index.js +0 -4
  405. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/index.js +0 -1
  406. package/es/components/material-exercise/exercise-file-tabs/exercise-file-tabs-file-tree-button/locales/index.js +0 -4
  407. package/es/components/material-exercise/exercise-file-tabs/index.js +0 -2
  408. package/es/components/material-exercise/exercise-file-tabs/locales/index.js +0 -4
  409. package/es/components/material-exercise/exercise-file-tree/index.js +0 -2
  410. package/es/components/material-exercise/exercise-file-tree/locales/index.js +0 -4
  411. package/es/components/material-exercise/exercise-file-viewer/index.js +0 -1
  412. package/es/components/material-exercise/exercise-menu/index.js +0 -1
  413. package/es/components/material-exercise/exercise-menu/locales/index.js +0 -4
  414. package/es/components/material-exercise/exercise-multilang-dropdown/index.js +0 -2
  415. package/es/components/material-exercise/exercise-preview/index.js +0 -1
  416. package/es/components/material-exercise/exercise-preview/locales/index.js +0 -4
  417. package/es/components/material-exercise/exercise-rightpane/index.js +0 -1
  418. package/es/components/material-exercise/exercise-rightpane/locales/index.js +0 -4
  419. package/es/components/material-exercise/exercise-room/helpers/index.js +0 -1
  420. package/es/components/material-exercise/exercise-room/index.js +0 -1
  421. package/es/components/material-exercise/exercise-room/locales/index.js +0 -4
  422. package/es/components/material-exercise/exercise-runner/index.js +0 -1
  423. package/es/components/material-exercise/exercise-runner/locales/index.js +0 -4
  424. package/es/components/material-exercise/exercise-submit-history/index.js +0 -1
  425. package/es/components/material-exercise/exercise-submit-history/locales/index.js +0 -4
  426. package/es/components/material-exercise/index.js +0 -2
  427. package/es/components/shared/exercise-menu-button/index.js +0 -1
  428. package/es/components/shared/exercise-shimmer/index.js +0 -5
  429. package/es/components/shared/exercise-version-list/index.js +0 -2
  430. package/es/components/shared/file-icon/index.js +0 -1
  431. package/es/components/shared/file-tabs/index.js +0 -1
  432. package/es/components/shared/file-tree/context/index.js +0 -1
  433. package/es/components/shared/file-tree/file-tree-toolbar/index.js +0 -1
  434. package/es/components/shared/file-tree/file-tree-toolbar/locales/index.js +0 -4
  435. package/es/components/shared/file-tree/index.js +0 -1
  436. package/es/components/shared/file-tree/locales/index.js +0 -4
  437. package/es/components/shared/file-tree/utils/index.js +0 -5
  438. package/es/components/shared/file-viewer/index.js +0 -1
  439. package/es/components/shared/file-viewer/locales/index.js +0 -8
  440. package/es/components/shared/material-modal/index.js +0 -1
  441. package/es/components/shared/monaco-editor/constants/index.js +0 -2
  442. package/es/components/shared/monaco-editor/constants/monaco/index.js +0 -1
  443. package/es/components/shared/monaco-editor/editor-hooks/index.js +0 -6
  444. package/es/components/shared/monaco-editor/editor-languages/typescript/dts/index.js +0 -3
  445. package/es/components/shared/monaco-editor/hooks/index.js +0 -1
  446. package/es/components/shared/monaco-editor/index.js +0 -6
  447. package/es/components/shared/monaco-editor/locales/index.js +0 -4
  448. package/es/components/shared/monaco-editor/utils/emmet/index.js +0 -1
  449. package/es/components/shared/monaco-editor/utils/index.js +0 -2
  450. package/es/components/shared/monaco-editor/vendors/monaco-collab-ext/index.js +0 -3
  451. package/es/components/shared/monaco-editor/vendors/vscode-emmet-helper/index.js +0 -2
  452. package/es/components/shared/no-vnc/index.js +0 -1
  453. package/es/components/shared/preview-container/index.js +0 -1
  454. package/es/components/shared/web-browser/index.js +0 -1
  455. package/es/components/shared/xterm/index.js +0 -1
  456. package/es/components/shared/xterm/locales/index.js +0 -4
  457. package/es/constants/index.js +0 -1
  458. package/es/hooks/index.js +0 -7
  459. package/es/utils/index.js +0 -2
@@ -1,5 +1,3 @@
1
- import { slicedToArray as _slicedToArray, asyncToGenerator as _asyncToGenerator, regeneratorRuntime as _regeneratorRuntime } from '../../../_virtual/_rollupPluginBabelHelpers.js';
2
- import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
3
1
  import React from 'react';
4
2
  import { useCopyToClipboard, useDebounce, useUpdateEffect } from 'react-use';
5
3
  import { getOrgMaterialExerciseExerciseRoomGet, postOrgMaterialExerciseExerciseRoomEdit, postOrgMaterialExerciseExerciseRoomDefaultRoomSet, getOrgCourseUserList, postOrgMaterialExerciseExerciseRoomDelete, postOrgMaterialExerciseExerciseRoomUserDelete, postOrgMaterialExerciseExerciseRoomUserEdit } from '@elice/api-client';
@@ -19,105 +17,75 @@ import '../context/ExerciseProvider.js';
19
17
  import { exerciseRoomPermissionStringConvertor } from './helpers/exerciseRoomPermissionStringConvertor.js';
20
18
  import { StyledExerciseRoomTableWrapper, StyledExerciseRoomTable, StyledExerciseRoomThead, StyledExerciseRoomTr, StyledExerciseRoomTh, StyledExerciseRoomTbody, StyledExerciseRoomTd } from './ExerciseRoom.styled.js';
21
19
 
22
- var StyledModal = styled(Modal).withConfig({
20
+ const StyledModal = styled(Modal).withConfig({
23
21
  componentId: "sc-x9irqe-0"
24
22
  })(["& > div:first-child{.eb-button{color:", ";&:hover{color:", ";}}}& .eb-input[width='full']{*:not(button,button > *){background-color:", ";color:", ";}& > div{border:1px solid ", ";}}& .eb-select{*{background-color:", ";color:", ";}& > div{border:1px solid ", ";}& select{padding-top:6px;padding-bottom:6px;height:2rem;font-size:0.75rem;}}"], base.color.navy0, base.color.navy0, base.color.navy7, base.color.navy0, base.color.navy6, base.color.navy6, base.color.navy0, base.color.navy5);
25
- var MaterialExerciseExerciseRoomDetail = function MaterialExerciseExerciseRoomDetail(_ref) {
26
- var selectedExerciseRoomId = _ref.selectedExerciseRoomId,
27
- goToList = _ref.goToList,
28
- onHide = _ref.onHide;
23
+ const MaterialExerciseExerciseRoomDetail = ({
24
+ selectedExerciseRoomId,
25
+ goToList,
26
+ onHide
27
+ }) => {
29
28
  var _a, _b, _c, _d, _e;
30
- var intl = useRawEliceIntl();
31
- var _React$useContext = React.useContext(ExerciseContext),
32
- materialExerciseId = _React$useContext.materialExerciseId,
33
- onExerciseRoomIdChange = _React$useContext.onExerciseRoomIdChange;
34
- var materialExercise = useRecoilValue(exerciseState(materialExerciseId));
35
- var user = useRecoilValue(exerciseUserState);
36
- var _React$useState = React.useState(),
37
- _React$useState2 = _slicedToArray(_React$useState, 2),
38
- exerciseRoom = _React$useState2[0],
39
- setExerciseRoom = _React$useState2[1];
40
- var _React$useState3 = React.useState(''),
41
- _React$useState4 = _slicedToArray(_React$useState3, 2),
42
- title = _React$useState4[0],
43
- setTitle = _React$useState4[1];
44
- var _React$useState5 = React.useState(''),
45
- _React$useState6 = _slicedToArray(_React$useState5, 2),
46
- debouncedTitle = _React$useState6[0],
47
- setDebouncedTitle = _React$useState6[1];
48
- var _React$useState7 = React.useState(''),
49
- _React$useState8 = _slicedToArray(_React$useState7, 2),
50
- search = _React$useState8[0],
51
- setSearch = _React$useState8[1];
52
- var _React$useState9 = React.useState(''),
53
- _React$useState10 = _slicedToArray(_React$useState9, 2),
54
- debouncedSearch = _React$useState10[0],
55
- setDebouncedSearch = _React$useState10[1];
56
- var _React$useState11 = React.useState([]),
57
- _React$useState12 = _slicedToArray(_React$useState11, 2),
58
- exerciseRoomUserList = _React$useState12[0],
59
- setExerciseRoomUserList = _React$useState12[1];
60
- var _React$useState13 = React.useState(false),
61
- _React$useState14 = _slicedToArray(_React$useState13, 2),
62
- isLeaveDialogOpen = _React$useState14[0],
63
- setIsLeaveDialogOpen = _React$useState14[1];
64
- var _React$useState15 = React.useState(false),
65
- _React$useState16 = _slicedToArray(_React$useState15, 2),
66
- isDeleting = _React$useState16[0],
67
- setIsDeleting = _React$useState16[1];
68
- var isThisChatRoomOwner = (_b = ((_a = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.roomUsers.find(function (roomUser) {
69
- return roomUser.user.id === (user === null || user === void 0 ? void 0 : user.id);
70
- })) === null || _a === void 0 ? void 0 : _a.permission) === enums.ExerciseRoomPermission.Owner) !== null && _b !== void 0 ? _b : false;
71
- var shareLink = materialExercise ? "https://".concat(window.location.host, "/courses/").concat(materialExercise._courseId, "/lectures/").concat(materialExercise === null || materialExercise === void 0 ? void 0 : materialExercise._lectureId, "/lecturepages/").concat(materialExercise === null || materialExercise === void 0 ? void 0 : materialExercise._lecturePageId, "/projects/").concat(selectedExerciseRoomId) : '';
72
- var _useCopyToClipboard = useCopyToClipboard(),
73
- _useCopyToClipboard2 = _slicedToArray(_useCopyToClipboard, 2),
74
- copyToClipboard = _useCopyToClipboard2[1];
75
- var doGetOrgMaterialExerciseExerciseRoomGet = React.useCallback(function () {
29
+ const intl = useRawEliceIntl();
30
+ const {
31
+ materialExerciseId,
32
+ onExerciseRoomIdChange
33
+ } = React.useContext(ExerciseContext);
34
+ const materialExercise = useRecoilValue(exerciseState(materialExerciseId));
35
+ const user = useRecoilValue(exerciseUserState);
36
+ const [exerciseRoom, setExerciseRoom] = React.useState();
37
+ const [title, setTitle] = React.useState('');
38
+ const [debouncedTitle, setDebouncedTitle] = React.useState('');
39
+ const [search, setSearch] = React.useState('');
40
+ const [debouncedSearch, setDebouncedSearch] = React.useState('');
41
+ const [exerciseRoomUserList, setExerciseRoomUserList] = React.useState([]);
42
+ const [isLeaveDialogOpen, setIsLeaveDialogOpen] = React.useState(false);
43
+ const [isDeleting, setIsDeleting] = React.useState(false);
44
+ const isThisChatRoomOwner = (_b = ((_a = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.roomUsers.find(roomUser => roomUser.user.id === (user === null || user === void 0 ? void 0 : user.id))) === null || _a === void 0 ? void 0 : _a.permission) === enums.ExerciseRoomPermission.Owner) !== null && _b !== void 0 ? _b : false;
45
+ const shareLink = materialExercise ? `https://${window.location.host}/courses/${materialExercise._courseId}/lectures/${materialExercise === null || materialExercise === void 0 ? void 0 : materialExercise._lectureId}/lecturepages/${materialExercise === null || materialExercise === void 0 ? void 0 : materialExercise._lecturePageId}/projects/${selectedExerciseRoomId}` : '';
46
+ const [, copyToClipboard] = useCopyToClipboard();
47
+ const doGetOrgMaterialExerciseExerciseRoomGet = React.useCallback(() => {
76
48
  return getOrgMaterialExerciseExerciseRoomGet({
77
49
  exerciseRoomId: selectedExerciseRoomId
78
- }).then(function (res) {
50
+ }).then(res => {
79
51
  setExerciseRoom(res.exerciseRoom);
80
- var list = _.map(res.exerciseRoom.roomUsers, function (_ref2) {
81
- var _ref2$user = _ref2.user,
82
- id = _ref2$user.id,
83
- profileUrl = _ref2$user.profileUrl,
84
- fullname = _ref2$user.fullname,
85
- permission = _ref2.permission;
86
- return {
87
- id: id,
88
- profileUrl: profileUrl,
89
- fullname: fullname,
90
- permission: permission
91
- };
92
- });
52
+ const list = _.map(res.exerciseRoom.roomUsers, ({
53
+ user: {
54
+ id,
55
+ profileUrl,
56
+ fullname
57
+ },
58
+ permission
59
+ }) => ({
60
+ id,
61
+ profileUrl,
62
+ fullname,
63
+ permission
64
+ }));
93
65
  setTitle(res.exerciseRoom.title);
94
66
  setDebouncedTitle(res.exerciseRoom.title);
95
67
  setExerciseRoomUserList(list);
96
68
  }).catch(console.error);
97
69
  }, [selectedExerciseRoomId]);
98
- var doPostOrgMaterialExerciseExerciseRoomEdit = React.useCallback(function (publicPermission) {
70
+ const doPostOrgMaterialExerciseExerciseRoomEdit = React.useCallback(publicPermission => {
99
71
  if (exerciseRoom && materialExercise) {
100
72
  postOrgMaterialExerciseExerciseRoomEdit({
101
73
  materialExerciseId: materialExercise.id,
102
- publicPermission: publicPermission,
74
+ publicPermission,
103
75
  title: exerciseRoom.title,
104
76
  exerciseRoomId: selectedExerciseRoomId
105
- }).then(function () {
106
- return doGetOrgMaterialExerciseExerciseRoomGet();
107
- }).catch(console.error);
77
+ }).then(() => doGetOrgMaterialExerciseExerciseRoomGet()).catch(console.error);
108
78
  }
109
79
  }, [doGetOrgMaterialExerciseExerciseRoomGet, exerciseRoom, selectedExerciseRoomId, materialExercise]);
110
- var doPostOrgMaterialExerciseExerciseRoomDefaultRoomSet = React.useCallback(function () {
80
+ const doPostOrgMaterialExerciseExerciseRoomDefaultRoomSet = React.useCallback(() => {
111
81
  postOrgMaterialExerciseExerciseRoomDefaultRoomSet({
112
82
  exerciseRoomId: selectedExerciseRoomId
113
- }).then(function () {
114
- return doGetOrgMaterialExerciseExerciseRoomGet();
115
- }).catch(console.error);
83
+ }).then(() => doGetOrgMaterialExerciseExerciseRoomGet()).catch(console.error);
116
84
  }, [doGetOrgMaterialExerciseExerciseRoomGet, selectedExerciseRoomId]);
117
- useDebounce(function () {
85
+ useDebounce(() => {
118
86
  setDebouncedSearch(search);
119
87
  }, 300, [search]);
120
- var doGetOrgCourseUserList = React.useCallback(function () {
88
+ const doGetOrgCourseUserList = React.useCallback(() => {
121
89
  if (materialExercise) {
122
90
  return getOrgCourseUserList({
123
91
  courseId: materialExercise._courseId,
@@ -127,9 +95,9 @@ var MaterialExerciseExerciseRoomDetail = function MaterialExerciseExerciseRoomDe
127
95
  filterConditions: {
128
96
  $and: [{
129
97
  $or: [{
130
- name: "%".concat(debouncedSearch, "%")
98
+ name: `%${debouncedSearch}%`
131
99
  }, {
132
- email: "%".concat(debouncedSearch, "%")
100
+ email: `%${debouncedSearch}%`
133
101
  }]
134
102
  }, {
135
103
  $or: [{
@@ -145,109 +113,86 @@ var MaterialExerciseExerciseRoomDetail = function MaterialExerciseExerciseRoomDe
145
113
  }]
146
114
  }]
147
115
  }
148
- }).then( /*#__PURE__*/function () {
149
- var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(res) {
150
- var _yield$getOrgMaterial, exerciseRoom, list;
151
- return _regeneratorRuntime().wrap(function _callee$(_context) {
152
- while (1) switch (_context.prev = _context.next) {
153
- case 0:
154
- _context.next = 2;
155
- return getOrgMaterialExerciseExerciseRoomGet({
156
- exerciseRoomId: selectedExerciseRoomId
157
- });
158
- case 2:
159
- _yield$getOrgMaterial = _context.sent;
160
- exerciseRoom = _yield$getOrgMaterial.exerciseRoom;
161
- list = _.map(res.users, function (_ref4) {
162
- var id = _ref4.id,
163
- profileUrl = _ref4.profileUrl,
164
- fullname = _ref4.fullname;
165
- var _a, _b;
166
- return {
167
- id: id,
168
- profileUrl: profileUrl,
169
- fullname: fullname,
170
- permission: (_b = (_a = _.find(exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.roomUsers, function (roomUser) {
171
- return roomUser.user.id === id;
172
- })) === null || _a === void 0 ? void 0 : _a.permission) !== null && _b !== void 0 ? _b : enums.ExerciseRoomPermission.Nothing
173
- };
174
- });
175
- setExerciseRoomUserList(list);
176
- case 6:
177
- case "end":
178
- return _context.stop();
179
- }
180
- }, _callee);
181
- }));
182
- return function (_x) {
183
- return _ref3.apply(this, arguments);
184
- };
185
- }()).catch(console.error);
116
+ }).then(async res => {
117
+ const {
118
+ exerciseRoom
119
+ } = await getOrgMaterialExerciseExerciseRoomGet({
120
+ exerciseRoomId: selectedExerciseRoomId
121
+ });
122
+ const list = _.map(res.users, ({
123
+ id,
124
+ profileUrl,
125
+ fullname
126
+ }) => {
127
+ var _a, _b;
128
+ return {
129
+ id,
130
+ profileUrl,
131
+ fullname,
132
+ permission: (_b = (_a = _.find(exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.roomUsers, roomUser => roomUser.user.id === id)) === null || _a === void 0 ? void 0 : _a.permission) !== null && _b !== void 0 ? _b : enums.ExerciseRoomPermission.Nothing
133
+ };
134
+ });
135
+ setExerciseRoomUserList(list);
136
+ }).catch(console.error);
186
137
  }
187
138
  }, [debouncedSearch, materialExercise, selectedExerciseRoomId]);
188
- React.useEffect(function () {
139
+ React.useEffect(() => {
189
140
  if (debouncedSearch) {
190
141
  void doGetOrgCourseUserList();
191
142
  } else {
192
143
  void doGetOrgMaterialExerciseExerciseRoomGet();
193
144
  }
194
145
  }, [debouncedSearch, doGetOrgCourseUserList, doGetOrgMaterialExerciseExerciseRoomGet]);
195
- useDebounce(function () {
146
+ useDebounce(() => {
196
147
  setDebouncedTitle(title);
197
148
  }, 300, [title]);
198
- useUpdateEffect(function () {
149
+ useUpdateEffect(() => {
199
150
  if (debouncedTitle.length > 0 && materialExercise && exerciseRoom && exerciseRoom.title !== debouncedTitle) {
200
151
  postOrgMaterialExerciseExerciseRoomEdit({
201
152
  materialExerciseId: materialExercise.id,
202
153
  publicPermission: exerciseRoom.publicPermission,
203
154
  title: debouncedTitle,
204
155
  exerciseRoomId: selectedExerciseRoomId
205
- }).then(function () {
206
- return doGetOrgMaterialExerciseExerciseRoomGet();
207
- }).catch(console.error);
156
+ }).then(() => doGetOrgMaterialExerciseExerciseRoomGet()).catch(console.error);
208
157
  }
209
158
  }, [debouncedTitle]);
210
- return jsxs(StyledModal, {
159
+ return React.createElement(StyledModal, {
211
160
  theme: "dark",
212
161
  onHide: onHide,
213
162
  title: (_c = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.title) !== null && _c !== void 0 ? _c : '',
214
163
  headerIcon: eilArrowLeftwardsSingle,
215
164
  onHeaderIconClick: goToList,
216
- footerChild: exerciseRoom ? exerciseRoom.isDefaultRoom ? jsxs(Flex, {
165
+ footerChild: exerciseRoom ? exerciseRoom.isDefaultRoom ? React.createElement(Flex, {
217
166
  justify: "flex-end",
218
- align: "center",
219
- children: [jsx(Icon, {
220
- icon: eisArrowDownwardsCircle,
221
- color: base.color.primary3,
222
- style: {
223
- marginRight: '0.5rem'
224
- }
225
- }), jsx(Text, {
226
- role: "lightpurple",
227
- size: "tiny",
228
- children: intl.formatMessage({
229
- id: 'materialExerciseExerciseRoom.defaultExerciseRoomDescription'
230
- })
231
- })]
232
- }) : jsx(Flex, {
167
+ align: "center"
168
+ }, React.createElement(Icon, {
169
+ icon: eisArrowDownwardsCircle,
170
+ color: base.color.primary3,
171
+ style: {
172
+ marginRight: '0.5rem'
173
+ }
174
+ }), React.createElement(Text, {
175
+ role: "lightpurple",
176
+ size: "tiny"
177
+ }, intl.formatMessage({
178
+ id: 'materialExerciseExerciseRoom.defaultExerciseRoomDescription'
179
+ }))) : React.createElement(Flex, {
233
180
  justify: "flex-end",
234
- align: "center",
235
- children: jsx(Button, {
236
- transparent: true,
237
- role: "lightpurple",
238
- underline: true,
239
- border: false,
240
- onClick: doPostOrgMaterialExerciseExerciseRoomDefaultRoomSet,
241
- children: intl.formatMessage({
242
- id: 'materialExerciseExerciseRoom.setDefaultExerciseRoom'
243
- })
244
- })
245
- }) : undefined,
181
+ align: "center"
182
+ }, React.createElement(Button, {
183
+ transparent: true,
184
+ role: "lightpurple",
185
+ underline: true,
186
+ border: false,
187
+ onClick: doPostOrgMaterialExerciseExerciseRoomDefaultRoomSet
188
+ }, intl.formatMessage({
189
+ id: 'materialExerciseExerciseRoom.setDefaultExerciseRoom'
190
+ }))) : undefined,
246
191
  footerButtons: [{
247
192
  label: intl.formatMessage({
248
193
  id: 'materialExerciseExerciseRoom.open'
249
194
  }),
250
- onClick: function onClick() {
195
+ onClick: () => {
251
196
  if (exerciseRoom && typeof onExerciseRoomIdChange === 'function') {
252
197
  onExerciseRoomIdChange(exerciseRoom.id);
253
198
  onHide();
@@ -261,371 +206,277 @@ var MaterialExerciseExerciseRoomDetail = function MaterialExerciseExerciseRoomDe
261
206
  }),
262
207
  disabled: (_d = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.isDefaultRoom) !== null && _d !== void 0 ? _d : false,
263
208
  role: 'gray6',
264
- onClick: function onClick() {
209
+ onClick: () => {
265
210
  setIsLeaveDialogOpen(true);
266
211
  }
267
- }],
268
- children: [isLeaveDialogOpen ? jsxs(Dialog, {
269
- type: "warning",
270
- title: intl.formatMessage({
271
- id: 'materialExerciseExerciseRoom.leave.dialog.title'
272
- }),
273
- body: intl.formatMessage({
274
- id: 'materialExerciseExerciseRoom.leave.dialog.body'
275
- }),
276
- onHide: function onHide() {
277
- setIsLeaveDialogOpen(false);
278
- },
279
- children: [jsx(Dialog.ActionButton, {
280
- loading: isDeleting,
281
- onClick: function onClick() {
282
- if (isThisChatRoomOwner) {
283
- setIsDeleting(true);
284
- postOrgMaterialExerciseExerciseRoomDelete({
285
- exerciseRoomId: selectedExerciseRoomId
286
- }).then(function () {
287
- goToList();
288
- }).catch(console.error).finally(function () {
289
- setIsDeleting(false);
290
- });
291
- } else {
292
- setIsDeleting(true);
293
- postOrgMaterialExerciseExerciseRoomUserDelete({
294
- exerciseRoomId: selectedExerciseRoomId
295
- }).then(function () {
296
- goToList();
297
- }).catch(console.error).finally(function () {
298
- setIsDeleting(false);
299
- });
212
+ }]
213
+ }, isLeaveDialogOpen ? React.createElement(Dialog, {
214
+ type: "warning",
215
+ title: intl.formatMessage({
216
+ id: 'materialExerciseExerciseRoom.leave.dialog.title'
217
+ }),
218
+ body: intl.formatMessage({
219
+ id: 'materialExerciseExerciseRoom.leave.dialog.body'
220
+ }),
221
+ onHide: () => {
222
+ setIsLeaveDialogOpen(false);
223
+ }
224
+ }, React.createElement(Dialog.ActionButton, {
225
+ loading: isDeleting,
226
+ onClick: () => {
227
+ if (isThisChatRoomOwner) {
228
+ setIsDeleting(true);
229
+ postOrgMaterialExerciseExerciseRoomDelete({
230
+ exerciseRoomId: selectedExerciseRoomId
231
+ }).then(() => {
232
+ goToList();
233
+ }).catch(console.error).finally(() => {
234
+ setIsDeleting(false);
235
+ });
236
+ } else {
237
+ setIsDeleting(true);
238
+ postOrgMaterialExerciseExerciseRoomUserDelete({
239
+ exerciseRoomId: selectedExerciseRoomId
240
+ }).then(() => {
241
+ goToList();
242
+ }).catch(console.error).finally(() => {
243
+ setIsDeleting(false);
244
+ });
245
+ }
246
+ }
247
+ }, '확인'), React.createElement(Dialog.CloseButton, {
248
+ onClick: () => {
249
+ setIsLeaveDialogOpen(false);
250
+ }
251
+ }, '취소')) : null, isThisChatRoomOwner ? React.createElement(React.Fragment, null, React.createElement(Label, {
252
+ role: "white",
253
+ size: "tiny"
254
+ }, intl.formatMessage({
255
+ id: 'materialExerciseExerciseRoom.detail.title.label'
256
+ })), React.createElement(Vspace, {
257
+ height: 0.5
258
+ }), React.createElement(Input, {
259
+ size: "small",
260
+ width: "full",
261
+ value: title,
262
+ onChange: e => setTitle(e.target.value),
263
+ placeholder: intl.formatMessage({
264
+ id: 'materialExerciseExerciseRoom.detail.title.placeholder'
265
+ })
266
+ }), React.createElement(Vspace, {
267
+ height: 1.25
268
+ })) : null, isThisChatRoomOwner ? React.createElement(React.Fragment, null, React.createElement(Label, {
269
+ role: "white",
270
+ size: "tiny"
271
+ }, intl.formatMessage({
272
+ id: 'materialExerciseExerciseRoom.detail.addUsers.label'
273
+ })), React.createElement(Vspace, {
274
+ height: 0.5
275
+ }), React.createElement(Input, {
276
+ prefix: eilSearch,
277
+ size: "small",
278
+ width: "full",
279
+ value: search,
280
+ onChange: e => setSearch(e.target.value),
281
+ placeholder: intl.formatMessage({
282
+ id: 'materialExerciseExerciseRoom.detail.addUsers.placeholder'
283
+ })
284
+ }), React.createElement(Vspace, {
285
+ height: 1.25
286
+ })) : null, React.createElement(StyledExerciseRoomTableWrapper, null, React.createElement(StyledExerciseRoomTable, null, React.createElement("colgroup", null, React.createElement("col", {
287
+ span: 1,
288
+ width: "70%"
289
+ }), React.createElement("col", {
290
+ span: 1,
291
+ width: "30%"
292
+ })), React.createElement(StyledExerciseRoomThead, null, React.createElement(StyledExerciseRoomTr, null, React.createElement(StyledExerciseRoomTh, null, intl.formatMessage({
293
+ id: 'materialExerciseExerciseRoom.detail.table.head.users'
294
+ })), React.createElement(StyledExerciseRoomTh, null, intl.formatMessage({
295
+ id: 'materialExerciseExerciseRoom.detail.table.head.permission'
296
+ })))), React.createElement(StyledExerciseRoomTbody, null, exerciseRoomUserList.map(chatroomUser => {
297
+ const renderUserPermission = () => {
298
+ if ((user === null || user === void 0 ? void 0 : user.id) === chatroomUser.id || !isThisChatRoomOwner) {
299
+ return React.createElement(Text, {
300
+ bold: true,
301
+ role: "gray0",
302
+ size: "tiny",
303
+ preWrap: true,
304
+ ellipsis: true,
305
+ customStyles: {
306
+ maxWidth: '100px',
307
+ marginRight: '0.5rem'
300
308
  }
301
- },
302
- children: '확인'
303
- }), jsx(Dialog.CloseButton, {
304
- onClick: function onClick() {
305
- setIsLeaveDialogOpen(false);
306
- },
307
- children: '취소'
308
- })]
309
- }) : null, isThisChatRoomOwner ? jsxs(Fragment, {
310
- children: [jsx(Label, {
311
- role: "white",
312
- size: "tiny",
313
- children: intl.formatMessage({
314
- id: 'materialExerciseExerciseRoom.detail.title.label'
315
- })
316
- }), jsx(Vspace, {
317
- height: 0.5
318
- }), jsx(Input, {
319
- size: "small",
320
- width: "full",
321
- value: title,
322
- onChange: function onChange(e) {
323
- return setTitle(e.target.value);
324
- },
325
- placeholder: intl.formatMessage({
326
- id: 'materialExerciseExerciseRoom.detail.title.placeholder'
327
- })
328
- }), jsx(Vspace, {
329
- height: 1.25
330
- })]
331
- }) : null, isThisChatRoomOwner ? jsxs(Fragment, {
332
- children: [jsx(Label, {
333
- role: "white",
334
- size: "tiny",
335
- children: intl.formatMessage({
336
- id: 'materialExerciseExerciseRoom.detail.addUsers.label'
337
- })
338
- }), jsx(Vspace, {
339
- height: 0.5
340
- }), jsx(Input, {
341
- prefix: eilSearch,
342
- size: "small",
343
- width: "full",
344
- value: search,
345
- onChange: function onChange(e) {
346
- return setSearch(e.target.value);
347
- },
348
- placeholder: intl.formatMessage({
349
- id: 'materialExerciseExerciseRoom.detail.addUsers.placeholder'
350
- })
351
- }), jsx(Vspace, {
352
- height: 1.25
353
- })]
354
- }) : null, jsx(StyledExerciseRoomTableWrapper, {
355
- children: jsxs(StyledExerciseRoomTable, {
356
- children: [jsxs("colgroup", {
357
- children: [jsx("col", {
358
- span: 1,
359
- width: "70%"
360
- }), jsx("col", {
361
- span: 1,
362
- width: "30%"
363
- })]
364
- }), jsx(StyledExerciseRoomThead, {
365
- children: jsxs(StyledExerciseRoomTr, {
366
- children: [jsx(StyledExerciseRoomTh, {
367
- children: intl.formatMessage({
368
- id: 'materialExerciseExerciseRoom.detail.table.head.users'
369
- })
370
- }), jsx(StyledExerciseRoomTh, {
371
- children: intl.formatMessage({
372
- id: 'materialExerciseExerciseRoom.detail.table.head.permission'
373
- })
374
- })]
375
- })
376
- }), jsx(StyledExerciseRoomTbody, {
377
- children: exerciseRoomUserList.map(function (chatroomUser) {
378
- var renderUserPermission = function renderUserPermission() {
379
- if ((user === null || user === void 0 ? void 0 : user.id) === chatroomUser.id || !isThisChatRoomOwner) {
380
- return jsx(Text, {
381
- bold: true,
382
- role: "gray0",
383
- size: "tiny",
384
- preWrap: true,
385
- ellipsis: true,
386
- customStyles: {
387
- maxWidth: '100px',
388
- marginRight: '0.5rem'
389
- },
390
- children: intl.formatMessage({
391
- id: "materialExerciseExerciseRoom.exerciseRoom.publicPermission.".concat(exerciseRoomPermissionStringConvertor(chatroomUser.permission))
392
- })
393
- });
394
- } else if (chatroomUser.permission === enums.ExerciseRoomPermission.Nothing) {
395
- return jsxs(Flex, {
396
- align: "center",
397
- children: [jsx(Text, {
398
- bold: true,
399
- role: "gray0",
400
- size: "tiny",
401
- preWrap: true,
402
- ellipsis: true,
403
- customStyles: {
404
- maxWidth: '100px',
405
- marginRight: '0.5rem'
406
- },
407
- children: intl.formatMessage({
408
- id: "materialExerciseExerciseRoom.exerciseRoom.publicPermission.".concat(exerciseRoomPermissionStringConvertor(chatroomUser.permission))
409
- })
410
- }), jsx(Button, {
411
- size: "micro",
412
- role: "lightpurple",
413
- loading: false,
414
- onClick: function () {
415
- var _onClick = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
416
- return _regeneratorRuntime().wrap(function _callee2$(_context2) {
417
- while (1) switch (_context2.prev = _context2.next) {
418
- case 0:
419
- _context2.prev = 0;
420
- _context2.next = 3;
421
- return postOrgMaterialExerciseExerciseRoomUserEdit({
422
- exerciseRoomId: selectedExerciseRoomId,
423
- permission: enums.ExerciseRoomPermission.Read,
424
- userId: chatroomUser.id
425
- });
426
- case 3:
427
- if (debouncedSearch) {
428
- void doGetOrgCourseUserList();
429
- } else {
430
- void doGetOrgMaterialExerciseExerciseRoomGet();
431
- }
432
- _context2.next = 9;
433
- break;
434
- case 6:
435
- _context2.prev = 6;
436
- _context2.t0 = _context2["catch"](0);
437
- console.error(_context2.t0);
438
- case 9:
439
- case "end":
440
- return _context2.stop();
441
- }
442
- }, _callee2, null, [[0, 6]]);
443
- }));
444
- function onClick() {
445
- return _onClick.apply(this, arguments);
446
- }
447
- return onClick;
448
- }(),
449
- children: intl.formatMessage({
450
- id: 'materialExerciseExerciseRoom.detail.table.body.add'
451
- })
452
- })]
309
+ }, intl.formatMessage({
310
+ id: `materialExerciseExerciseRoom.exerciseRoom.publicPermission.${exerciseRoomPermissionStringConvertor(chatroomUser.permission)}`
311
+ }));
312
+ } else if (chatroomUser.permission === enums.ExerciseRoomPermission.Nothing) {
313
+ return React.createElement(Flex, {
314
+ align: "center"
315
+ }, React.createElement(Text, {
316
+ bold: true,
317
+ role: "gray0",
318
+ size: "tiny",
319
+ preWrap: true,
320
+ ellipsis: true,
321
+ customStyles: {
322
+ maxWidth: '100px',
323
+ marginRight: '0.5rem'
324
+ }
325
+ }, intl.formatMessage({
326
+ id: `materialExerciseExerciseRoom.exerciseRoom.publicPermission.${exerciseRoomPermissionStringConvertor(chatroomUser.permission)}`
327
+ })), React.createElement(Button, {
328
+ size: "micro",
329
+ role: "lightpurple",
330
+ loading: false,
331
+ onClick: async () => {
332
+ try {
333
+ await postOrgMaterialExerciseExerciseRoomUserEdit({
334
+ exerciseRoomId: selectedExerciseRoomId,
335
+ permission: enums.ExerciseRoomPermission.Read,
336
+ userId: chatroomUser.id
337
+ });
338
+ if (debouncedSearch) {
339
+ void doGetOrgCourseUserList();
340
+ } else {
341
+ void doGetOrgMaterialExerciseExerciseRoomGet();
342
+ }
343
+ } catch (error) {
344
+ console.error(error);
345
+ }
346
+ }
347
+ }, intl.formatMessage({
348
+ id: 'materialExerciseExerciseRoom.detail.table.body.add'
349
+ })));
350
+ } else {
351
+ return React.createElement(Select, {
352
+ size: "small",
353
+ width: "small",
354
+ value: chatroomUser.permission,
355
+ onChange: async value => {
356
+ try {
357
+ const permission = Number(value);
358
+ if (permission === enums.ExerciseRoomPermission.Nothing) {
359
+ await postOrgMaterialExerciseExerciseRoomUserDelete({
360
+ exerciseRoomId: selectedExerciseRoomId,
361
+ userId: chatroomUser.id
453
362
  });
363
+ if (debouncedSearch) {
364
+ void doGetOrgCourseUserList();
365
+ } else {
366
+ void doGetOrgMaterialExerciseExerciseRoomGet();
367
+ }
454
368
  } else {
455
- return jsxs(Select, {
456
- size: "small",
457
- width: "small",
458
- value: chatroomUser.permission,
459
- onChange: function () {
460
- var _onChange = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(value) {
461
- var permission;
462
- return _regeneratorRuntime().wrap(function _callee3$(_context3) {
463
- while (1) switch (_context3.prev = _context3.next) {
464
- case 0:
465
- _context3.prev = 0;
466
- permission = Number(value);
467
- if (!(permission === enums.ExerciseRoomPermission.Nothing)) {
468
- _context3.next = 8;
469
- break;
470
- }
471
- _context3.next = 5;
472
- return postOrgMaterialExerciseExerciseRoomUserDelete({
473
- exerciseRoomId: selectedExerciseRoomId,
474
- userId: chatroomUser.id
475
- });
476
- case 5:
477
- if (debouncedSearch) {
478
- void doGetOrgCourseUserList();
479
- } else {
480
- void doGetOrgMaterialExerciseExerciseRoomGet();
481
- }
482
- _context3.next = 11;
483
- break;
484
- case 8:
485
- _context3.next = 10;
486
- return postOrgMaterialExerciseExerciseRoomUserEdit({
487
- exerciseRoomId: selectedExerciseRoomId,
488
- permission: permission,
489
- userId: chatroomUser.id
490
- });
491
- case 10:
492
- if (debouncedSearch) {
493
- void doGetOrgCourseUserList();
494
- } else {
495
- void doGetOrgMaterialExerciseExerciseRoomGet();
496
- }
497
- case 11:
498
- _context3.next = 16;
499
- break;
500
- case 13:
501
- _context3.prev = 13;
502
- _context3.t0 = _context3["catch"](0);
503
- console.error(_context3.t0);
504
- case 16:
505
- case "end":
506
- return _context3.stop();
507
- }
508
- }, _callee3, null, [[0, 13]]);
509
- }));
510
- function onChange(_x2) {
511
- return _onChange.apply(this, arguments);
512
- }
513
- return onChange;
514
- }(),
515
- disabled: !isThisChatRoomOwner,
516
- children: [jsx("option", {
517
- value: enums.ExerciseRoomPermission.Nothing,
518
- children: intl.formatMessage({
519
- id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.nothing'
520
- })
521
- }), jsx("option", {
522
- value: enums.ExerciseRoomPermission.Read,
523
- children: intl.formatMessage({
524
- id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.read'
525
- })
526
- }), jsx("option", {
527
- value: enums.ExerciseRoomPermission.ReadWrite,
528
- children: intl.formatMessage({
529
- id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.readWrite'
530
- })
531
- })]
369
+ await postOrgMaterialExerciseExerciseRoomUserEdit({
370
+ exerciseRoomId: selectedExerciseRoomId,
371
+ permission,
372
+ userId: chatroomUser.id
532
373
  });
374
+ if (debouncedSearch) {
375
+ void doGetOrgCourseUserList();
376
+ } else {
377
+ void doGetOrgMaterialExerciseExerciseRoomGet();
378
+ }
533
379
  }
534
- };
535
- return jsxs(StyledExerciseRoomTr, {
536
- children: [jsx(StyledExerciseRoomTd, {
537
- children: jsxs(Flex, {
538
- align: "center",
539
- children: [jsx(ProfileImage, {
540
- src: chatroomUser.profileUrl || '',
541
- hasBorder: false,
542
- width: "1.5rem",
543
- height: "1.5rem"
544
- }), jsx(Text, {
545
- bold: true,
546
- size: "small",
547
- role: "white",
548
- preWrap: true,
549
- ellipsis: true,
550
- customStyles: {
551
- marginLeft: '0.5rem'
552
- },
553
- children: chatroomUser.fullname
554
- })]
555
- })
556
- }), jsx(StyledExerciseRoomTd, {
557
- children: renderUserPermission()
558
- })]
559
- }, chatroomUser.id);
560
- })
561
- })]
562
- })
563
- }), jsx(Vspace, {
564
- height: 1.25
565
- }), jsx(Label, {
566
- role: "white",
567
- size: "tiny",
568
- children: intl.formatMessage({
569
- id: 'materialExerciseExerciseRoom.detail.sharelink.label'
570
- })
571
- }), jsx(Vspace, {
572
- height: 0.5
573
- }), isThisChatRoomOwner ? jsxs(Fragment, {
574
- children: [jsxs(Select, {
575
- size: "small",
576
- width: "small",
577
- value: (_e = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.publicPermission) !== null && _e !== void 0 ? _e : enums.ExerciseRoomPermission.Nothing,
578
- onChange: function onChange(value) {
579
- doPostOrgMaterialExerciseExerciseRoomEdit(value);
580
- },
581
- disabled: false,
582
- children: [jsx("option", {
380
+ } catch (error) {
381
+ console.error(error);
382
+ }
383
+ },
384
+ disabled: !isThisChatRoomOwner
385
+ }, React.createElement("option", {
583
386
  value: enums.ExerciseRoomPermission.Nothing,
584
387
  children: intl.formatMessage({
585
388
  id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.nothing'
586
389
  })
587
- }), jsx("option", {
390
+ }), React.createElement("option", {
588
391
  value: enums.ExerciseRoomPermission.Read,
589
392
  children: intl.formatMessage({
590
393
  id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.read'
591
394
  })
592
- }), jsx("option", {
395
+ }), React.createElement("option", {
593
396
  value: enums.ExerciseRoomPermission.ReadWrite,
594
397
  children: intl.formatMessage({
595
398
  id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.readWrite'
596
399
  })
597
- })]
598
- }), jsx(Vspace, {
599
- height: 0.75
600
- })]
601
- }) : null, jsx(Input, {
400
+ }));
401
+ }
402
+ };
403
+ return React.createElement(StyledExerciseRoomTr, {
404
+ key: chatroomUser.id
405
+ }, React.createElement(StyledExerciseRoomTd, null, React.createElement(Flex, {
406
+ align: "center"
407
+ }, React.createElement(ProfileImage, {
408
+ src: chatroomUser.profileUrl || '',
409
+ hasBorder: false,
410
+ width: "1.5rem",
411
+ height: "1.5rem"
412
+ }), React.createElement(Text, {
413
+ bold: true,
602
414
  size: "small",
603
- width: "full",
604
- suffix: jsx(Button, {
605
- size: "micro",
606
- role: "lightpurple",
607
- style: {
608
- backgroundColor: "".concat(base.color.red6, " !important")
609
- },
610
- onClick: function onClick() {
611
- Notification.info(intl.formatMessage({
612
- id: 'materialExerciseExerciseRoom.detail.copy.success'
613
- }));
614
- copyToClipboard(shareLink);
615
- },
616
- children: intl.formatMessage({
617
- id: 'materialExerciseExerciseRoom.detail.copy'
618
- })
619
- }),
620
- value: materialExercise ? shareLink : '',
621
- onChange: function onChange(e) {
622
- return setSearch(e.target.value);
415
+ role: "white",
416
+ preWrap: true,
417
+ ellipsis: true,
418
+ customStyles: {
419
+ marginLeft: '0.5rem'
420
+ }
421
+ }, chatroomUser.fullname))), React.createElement(StyledExerciseRoomTd, null, renderUserPermission()));
422
+ })))), React.createElement(Vspace, {
423
+ height: 1.25
424
+ }), React.createElement(Label, {
425
+ role: "white",
426
+ size: "tiny"
427
+ }, intl.formatMessage({
428
+ id: 'materialExerciseExerciseRoom.detail.sharelink.label'
429
+ })), React.createElement(Vspace, {
430
+ height: 0.5
431
+ }), isThisChatRoomOwner ? React.createElement(React.Fragment, null, React.createElement(Select, {
432
+ size: "small",
433
+ width: "small",
434
+ value: (_e = exerciseRoom === null || exerciseRoom === void 0 ? void 0 : exerciseRoom.publicPermission) !== null && _e !== void 0 ? _e : enums.ExerciseRoomPermission.Nothing,
435
+ onChange: value => {
436
+ doPostOrgMaterialExerciseExerciseRoomEdit(value);
437
+ },
438
+ disabled: false
439
+ }, React.createElement("option", {
440
+ value: enums.ExerciseRoomPermission.Nothing,
441
+ children: intl.formatMessage({
442
+ id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.nothing'
443
+ })
444
+ }), React.createElement("option", {
445
+ value: enums.ExerciseRoomPermission.Read,
446
+ children: intl.formatMessage({
447
+ id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.read'
448
+ })
449
+ }), React.createElement("option", {
450
+ value: enums.ExerciseRoomPermission.ReadWrite,
451
+ children: intl.formatMessage({
452
+ id: 'materialExerciseExerciseRoom.exerciseRoom.publicPermission.readWrite'
453
+ })
454
+ })), React.createElement(Vspace, {
455
+ height: 0.75
456
+ })) : null, React.createElement(Input, {
457
+ size: "small",
458
+ width: "full",
459
+ suffix: React.createElement(Button, {
460
+ size: "micro",
461
+ role: "lightpurple",
462
+ style: {
463
+ backgroundColor: `${base.color.red6} !important`
623
464
  },
624
- placeholder: intl.formatMessage({
625
- id: 'materialExerciseExerciseRoom.detail.addUsers.placeholder'
626
- })
627
- })]
628
- });
465
+ onClick: () => {
466
+ Notification.info(intl.formatMessage({
467
+ id: 'materialExerciseExerciseRoom.detail.copy.success'
468
+ }));
469
+ copyToClipboard(shareLink);
470
+ }
471
+ }, intl.formatMessage({
472
+ id: 'materialExerciseExerciseRoom.detail.copy'
473
+ })),
474
+ value: materialExercise ? shareLink : '',
475
+ onChange: e => setSearch(e.target.value),
476
+ placeholder: intl.formatMessage({
477
+ id: 'materialExerciseExerciseRoom.detail.addUsers.placeholder'
478
+ })
479
+ }));
629
480
  };
630
481
 
631
482
  export { MaterialExerciseExerciseRoomDetail as default };