@100mslive/roomkit-react 0.4.3-alpha.2 → 0.4.3-alpha.4

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 (391) hide show
  1. package/dist/Prebuilt/App.d.ts +0 -1
  2. package/dist/Prebuilt/AppContext.d.ts +0 -1
  3. package/dist/index.cjs.css +194 -219
  4. package/dist/index.cjs.css.map +3 -3
  5. package/dist/index.cjs.js +8 -56
  6. package/dist/index.cjs.js.map +3 -3
  7. package/dist/index.css +194 -219
  8. package/dist/index.css.map +3 -3
  9. package/dist/index.js +8 -56
  10. package/dist/index.js.map +3 -3
  11. package/dist/meta.cjs.json +23 -41
  12. package/dist/meta.esbuild.json +23 -41
  13. package/package.json +8 -9
  14. package/src/Accordion/Accordion.tsx +0 -88
  15. package/src/Accordion/index.ts +0 -8
  16. package/src/AudioLevel/AudioLevel.tsx +0 -84
  17. package/src/AudioLevel/audio-level.png +0 -0
  18. package/src/AudioLevel/index.ts +0 -2
  19. package/src/AudioLevel/useBorderAudioLevel.tsx +0 -34
  20. package/src/Avatar/Avatar.tsx +0 -60
  21. package/src/Avatar/getAvatarBg.ts +0 -50
  22. package/src/Avatar/index.ts +0 -1
  23. package/src/Button/Button.tsx +0 -210
  24. package/src/Button/index.tsx +0 -1
  25. package/src/Checkbox/Checkbox.tsx +0 -35
  26. package/src/Checkbox/index.tsx +0 -1
  27. package/src/Collapsible/Collapsible.tsx +0 -34
  28. package/src/Collapsible/index.tsx +0 -1
  29. package/src/Diagnostics/AudioTest.tsx +0 -188
  30. package/src/Diagnostics/BrowserTest.tsx +0 -141
  31. package/src/Diagnostics/ConnectivityTest.tsx +0 -383
  32. package/src/Diagnostics/DeviceSelector.jsx +0 -71
  33. package/src/Diagnostics/Diagnostics.tsx +0 -190
  34. package/src/Diagnostics/DiagnosticsContext.ts +0 -46
  35. package/src/Diagnostics/VideoTest.tsx +0 -72
  36. package/src/Diagnostics/components.tsx +0 -70
  37. package/src/Diagnostics/index.ts +0 -1
  38. package/src/Divider/Divider.tsx +0 -45
  39. package/src/Divider/index.ts +0 -1
  40. package/src/Dropdown/Dropdown.tsx +0 -145
  41. package/src/Dropdown/index.tsx +0 -1
  42. package/src/Fieldset/Fieldset.tsx +0 -11
  43. package/src/Fieldset/index.tsx +0 -1
  44. package/src/Footer/Footer.tsx +0 -47
  45. package/src/Footer/index.tsx +0 -1
  46. package/src/IconButton/IconButton.tsx +0 -43
  47. package/src/IconButton/index.tsx +0 -1
  48. package/src/Input/Input.tsx +0 -109
  49. package/src/Input/index.tsx +0 -1
  50. package/src/Label/Label.tsx +0 -8
  51. package/src/Label/index.ts +0 -1
  52. package/src/Layout/Box.tsx +0 -3
  53. package/src/Layout/Flex.tsx +0 -76
  54. package/src/Layout/index.tsx +0 -2
  55. package/src/Link/Link.tsx +0 -54
  56. package/src/Link/index.tsx +0 -2
  57. package/src/Loading/Loading.tsx +0 -30
  58. package/src/Loading/index.ts +0 -1
  59. package/src/Modal/Dialog.tsx +0 -57
  60. package/src/Modal/DialogContent.tsx +0 -65
  61. package/src/Modal/index.ts +0 -1
  62. package/src/Pagination/StyledPagination.tsx +0 -70
  63. package/src/Pagination/index.tsx +0 -1
  64. package/src/Popover/index.tsx +0 -34
  65. package/src/Prebuilt/App.tsx +0 -323
  66. package/src/Prebuilt/AppContext.tsx +0 -34
  67. package/src/Prebuilt/AppStateContext.tsx +0 -95
  68. package/src/Prebuilt/IconButton.tsx +0 -26
  69. package/src/Prebuilt/common/PeersSorter.ts +0 -111
  70. package/src/Prebuilt/common/constants.ts +0 -151
  71. package/src/Prebuilt/common/hooks.ts +0 -257
  72. package/src/Prebuilt/common/utils.js +0 -185
  73. package/src/Prebuilt/components/AppData/AppData.tsx +0 -208
  74. package/src/Prebuilt/components/AppData/useChatState.js +0 -18
  75. package/src/Prebuilt/components/AppData/useSheet.ts +0 -33
  76. package/src/Prebuilt/components/AppData/useSidepane.js +0 -99
  77. package/src/Prebuilt/components/AppData/useSidepaneResetOnLayoutUpdate.tsx +0 -22
  78. package/src/Prebuilt/components/AppData/useUISettings.js +0 -212
  79. package/src/Prebuilt/components/AudioVideoToggle.tsx +0 -411
  80. package/src/Prebuilt/components/AuthToken.tsx +0 -148
  81. package/src/Prebuilt/components/CaptionIcon.tsx +0 -27
  82. package/src/Prebuilt/components/Chat/ArrowNavigation.tsx +0 -44
  83. package/src/Prebuilt/components/Chat/Chat.tsx +0 -190
  84. package/src/Prebuilt/components/Chat/ChatActions.tsx +0 -314
  85. package/src/Prebuilt/components/Chat/ChatBody.tsx +0 -493
  86. package/src/Prebuilt/components/Chat/ChatFooter.tsx +0 -316
  87. package/src/Prebuilt/components/Chat/ChatSelector.tsx +0 -228
  88. package/src/Prebuilt/components/Chat/ChatSelectorContainer.tsx +0 -158
  89. package/src/Prebuilt/components/Chat/ChatStates.tsx +0 -73
  90. package/src/Prebuilt/components/Chat/EmptyChat.tsx +0 -58
  91. package/src/Prebuilt/components/Chat/MwebChatOption.tsx +0 -24
  92. package/src/Prebuilt/components/Chat/PinnedMessage.tsx +0 -140
  93. package/src/Prebuilt/components/Chat/StickIndicator.tsx +0 -24
  94. package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +0 -32
  95. package/src/Prebuilt/components/Chat/useUnreadCount.ts +0 -19
  96. package/src/Prebuilt/components/Chat/utils.ts +0 -11
  97. package/src/Prebuilt/components/ChatSettings.tsx +0 -68
  98. package/src/Prebuilt/components/Chip.tsx +0 -40
  99. package/src/Prebuilt/components/ConferenceScreen.tsx +0 -205
  100. package/src/Prebuilt/components/Connection/ConnectionIndicator.tsx +0 -89
  101. package/src/Prebuilt/components/Connection/TileConnection.tsx +0 -93
  102. package/src/Prebuilt/components/Connection/connectionQualityUtils.js +0 -37
  103. package/src/Prebuilt/components/EmojiReaction.jsx +0 -100
  104. package/src/Prebuilt/components/EndCallFeedback/Feedback.tsx +0 -71
  105. package/src/Prebuilt/components/EndCallFeedback/FeedbackForm.tsx +0 -381
  106. package/src/Prebuilt/components/EndCallFeedback/ThankyouView.tsx +0 -64
  107. package/src/Prebuilt/components/ErrorBoundary.jsx +0 -102
  108. package/src/Prebuilt/components/Footer/ChatToggle.tsx +0 -53
  109. package/src/Prebuilt/components/Footer/EmojiCard.jsx +0 -34
  110. package/src/Prebuilt/components/Footer/Footer.tsx +0 -115
  111. package/src/Prebuilt/components/Footer/PaginatedParticipants.tsx +0 -124
  112. package/src/Prebuilt/components/Footer/ParticipantList.tsx +0 -478
  113. package/src/Prebuilt/components/Footer/PollsToggle.tsx +0 -37
  114. package/src/Prebuilt/components/Footer/RoleAccordion.tsx +0 -183
  115. package/src/Prebuilt/components/Footer/RoleOptions.tsx +0 -215
  116. package/src/Prebuilt/components/Footer/WhiteboardToggle.tsx +0 -52
  117. package/src/Prebuilt/components/FullPageProgress.tsx +0 -22
  118. package/src/Prebuilt/components/HMSVideo/Controls.jsx +0 -22
  119. package/src/Prebuilt/components/HMSVideo/FullscreenButton.tsx +0 -13
  120. package/src/Prebuilt/components/HMSVideo/HLSAutoplayBlockedPrompt.tsx +0 -72
  121. package/src/Prebuilt/components/HMSVideo/HLSCaptionSelector.tsx +0 -15
  122. package/src/Prebuilt/components/HMSVideo/HLSQualitySelector.tsx +0 -248
  123. package/src/Prebuilt/components/HMSVideo/HMSVideo.jsx +0 -75
  124. package/src/Prebuilt/components/HMSVideo/MwebHLSViewTitle.tsx +0 -86
  125. package/src/Prebuilt/components/HMSVideo/PlayPauseButton.tsx +0 -27
  126. package/src/Prebuilt/components/HMSVideo/PlayPauseSeekControls.tsx +0 -158
  127. package/src/Prebuilt/components/HMSVideo/PlayerContext.tsx +0 -15
  128. package/src/Prebuilt/components/HMSVideo/SeekControl.tsx +0 -22
  129. package/src/Prebuilt/components/HMSVideo/VideoProgress.tsx +0 -100
  130. package/src/Prebuilt/components/HMSVideo/VideoTime.tsx +0 -52
  131. package/src/Prebuilt/components/HMSVideo/VolumeControl.tsx +0 -70
  132. package/src/Prebuilt/components/HMSVideo/index.ts +0 -24
  133. package/src/Prebuilt/components/HMSVideo/utils.ts +0 -37
  134. package/src/Prebuilt/components/Header/Header.tsx +0 -52
  135. package/src/Prebuilt/components/Header/HeaderComponents.jsx +0 -57
  136. package/src/Prebuilt/components/Header/ParticipantFilter.jsx +0 -89
  137. package/src/Prebuilt/components/Header/RoomDetailsHeader.tsx +0 -51
  138. package/src/Prebuilt/components/Header/StreamActions.tsx +0 -297
  139. package/src/Prebuilt/components/Header/common.jsx +0 -196
  140. package/src/Prebuilt/components/Header/index.tsx +0 -1
  141. package/src/Prebuilt/components/HlsStatsOverlay.jsx +0 -89
  142. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.tsx +0 -167
  143. package/src/Prebuilt/components/Input/KeyboardInputManager.js +0 -107
  144. package/src/Prebuilt/components/InsetTile.tsx +0 -136
  145. package/src/Prebuilt/components/LayoutModeSelector.tsx +0 -112
  146. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +0 -166
  147. package/src/Prebuilt/components/Leave/EndSessionContent.tsx +0 -64
  148. package/src/Prebuilt/components/Leave/LeaveAtoms.tsx +0 -26
  149. package/src/Prebuilt/components/Leave/LeaveCard.tsx +0 -36
  150. package/src/Prebuilt/components/Leave/LeaveRoom.tsx +0 -82
  151. package/src/Prebuilt/components/Leave/LeaveSessionContent.tsx +0 -61
  152. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +0 -135
  153. package/src/Prebuilt/components/LeaveScreen.tsx +0 -71
  154. package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +0 -60
  155. package/src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx +0 -139
  156. package/src/Prebuilt/components/MoreSettings/CaptionContent.tsx +0 -143
  157. package/src/Prebuilt/components/MoreSettings/CaptionModal.tsx +0 -37
  158. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.tsx +0 -123
  159. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.tsx +0 -78
  160. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +0 -81
  161. package/src/Prebuilt/components/MoreSettings/FullScreenItem.tsx +0 -26
  162. package/src/Prebuilt/components/MoreSettings/MoreSettings.tsx +0 -29
  163. package/src/Prebuilt/components/MoreSettings/MuteAllContent.tsx +0 -81
  164. package/src/Prebuilt/components/MoreSettings/MuteAllModal.tsx +0 -72
  165. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx +0 -282
  166. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +0 -387
  167. package/src/Prebuilt/components/MoreSettings/constants.ts +0 -14
  168. package/src/Prebuilt/components/MwebLandscapePrompt.tsx +0 -81
  169. package/src/Prebuilt/components/Notifications/AutoplayBlockedModal.tsx +0 -39
  170. package/src/Prebuilt/components/Notifications/ChatNotifications.tsx +0 -34
  171. package/src/Prebuilt/components/Notifications/DeviceChangeNotifications.tsx +0 -18
  172. package/src/Prebuilt/components/Notifications/DeviceInUseError.tsx +0 -86
  173. package/src/Prebuilt/components/Notifications/ErrorNotifications.tsx +0 -56
  174. package/src/Prebuilt/components/Notifications/HLSFailureModal.tsx +0 -71
  175. package/src/Prebuilt/components/Notifications/HandRaisedNotifications.tsx +0 -78
  176. package/src/Prebuilt/components/Notifications/InitErrorModal.tsx +0 -42
  177. package/src/Prebuilt/components/Notifications/MessageNotifications.tsx +0 -24
  178. package/src/Prebuilt/components/Notifications/Notifications.tsx +0 -65
  179. package/src/Prebuilt/components/Notifications/PeerNotifications.tsx +0 -52
  180. package/src/Prebuilt/components/Notifications/PermissionErrorModal.tsx +0 -144
  181. package/src/Prebuilt/components/Notifications/PollNotificationModal.tsx +0 -71
  182. package/src/Prebuilt/components/Notifications/ReconnectNotifications.tsx +0 -33
  183. package/src/Prebuilt/components/Notifications/RoleChangeNotification.tsx +0 -24
  184. package/src/Prebuilt/components/Notifications/TrackBulkUnmuteModal.tsx +0 -61
  185. package/src/Prebuilt/components/Notifications/TrackNotifications.tsx +0 -41
  186. package/src/Prebuilt/components/Notifications/TrackUnmuteModal.tsx +0 -63
  187. package/src/Prebuilt/components/Notifications/TranscriptionNotifications.tsx +0 -58
  188. package/src/Prebuilt/components/Notifications/index.tsx +0 -1
  189. package/src/Prebuilt/components/PIP/PIPChat.tsx +0 -292
  190. package/src/Prebuilt/components/PIP/PIPChatOption.tsx +0 -18
  191. package/src/Prebuilt/components/PIP/PIPComponent.tsx +0 -90
  192. package/src/Prebuilt/components/PIP/PIPManager.ts +0 -335
  193. package/src/Prebuilt/components/PIP/PIPProvider.tsx +0 -56
  194. package/src/Prebuilt/components/PIP/PIPWindow.tsx +0 -13
  195. package/src/Prebuilt/components/PIP/SetupMediaSession.js +0 -60
  196. package/src/Prebuilt/components/PIP/context.ts +0 -10
  197. package/src/Prebuilt/components/PIP/index.jsx +0 -6
  198. package/src/Prebuilt/components/PIP/pip.test.js +0 -72
  199. package/src/Prebuilt/components/PIP/pipUtils.js +0 -183
  200. package/src/Prebuilt/components/PIP/usePIPChat.tsx +0 -105
  201. package/src/Prebuilt/components/PIP/usePIPWindow.tsx +0 -12
  202. package/src/Prebuilt/components/Pagination.tsx +0 -60
  203. package/src/Prebuilt/components/Polls/CreatePollQuiz/PollsQuizMenu.tsx +0 -248
  204. package/src/Prebuilt/components/Polls/CreateQuestions/CreateQuestions.jsx +0 -142
  205. package/src/Prebuilt/components/Polls/CreateQuestions/DeleteQuestionModal.tsx +0 -74
  206. package/src/Prebuilt/components/Polls/CreateQuestions/QuestionForm.tsx +0 -324
  207. package/src/Prebuilt/components/Polls/CreateQuestions/SavedQuestion.tsx +0 -64
  208. package/src/Prebuilt/components/Polls/Polls.tsx +0 -31
  209. package/src/Prebuilt/components/Polls/Voting/LeaderboardEntry.tsx +0 -76
  210. package/src/Prebuilt/components/Polls/Voting/LeaderboardSummary.tsx +0 -116
  211. package/src/Prebuilt/components/Polls/Voting/PeerParticipationSummary.tsx +0 -60
  212. package/src/Prebuilt/components/Polls/Voting/QuestionCard.jsx +0 -221
  213. package/src/Prebuilt/components/Polls/Voting/StandardVoting.tsx +0 -47
  214. package/src/Prebuilt/components/Polls/Voting/StatisticBox.tsx +0 -20
  215. package/src/Prebuilt/components/Polls/Voting/TimedVoting.tsx +0 -55
  216. package/src/Prebuilt/components/Polls/Voting/Voting.tsx +0 -143
  217. package/src/Prebuilt/components/Polls/Voting/useQuizSummary.tsx +0 -50
  218. package/src/Prebuilt/components/Polls/common/Line.tsx +0 -4
  219. package/src/Prebuilt/components/Polls/common/MultipleChoiceOptions.jsx +0 -115
  220. package/src/Prebuilt/components/Polls/common/OptionInputWithDelete.tsx +0 -38
  221. package/src/Prebuilt/components/Polls/common/SingleChoiceOptions.jsx +0 -140
  222. package/src/Prebuilt/components/Polls/common/StatusIndicator.tsx +0 -35
  223. package/src/Prebuilt/components/Polls/common/VoteCount.tsx +0 -15
  224. package/src/Prebuilt/components/Polls/common/VoteProgress.tsx +0 -18
  225. package/src/Prebuilt/components/Polls/common/constants.ts +0 -5
  226. package/src/Prebuilt/components/Polls/common/utils.ts +0 -22
  227. package/src/Prebuilt/components/Preview/PreviewForm.tsx +0 -94
  228. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +0 -292
  229. package/src/Prebuilt/components/Preview/PreviewScreen.tsx +0 -38
  230. package/src/Prebuilt/components/PreviousRoleInMetadata.tsx +0 -20
  231. package/src/Prebuilt/components/RaiseHand.tsx +0 -30
  232. package/src/Prebuilt/components/RemoveParticipant.tsx +0 -35
  233. package/src/Prebuilt/components/RoleChangeModal.tsx +0 -188
  234. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +0 -75
  235. package/src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx +0 -94
  236. package/src/Prebuilt/components/RoomDetails/Duration.tsx +0 -26
  237. package/src/Prebuilt/components/RoomDetails/RoomDetailsPane.tsx +0 -63
  238. package/src/Prebuilt/components/RoomDetails/RoomDetailsRow.tsx +0 -23
  239. package/src/Prebuilt/components/RoomDetails/RoomDetailsSheet.tsx +0 -45
  240. package/src/Prebuilt/components/ScreenShareToggle.jsx +0 -58
  241. package/src/Prebuilt/components/ScreenshareDisplay.tsx +0 -39
  242. package/src/Prebuilt/components/ScreenshareTile.tsx +0 -134
  243. package/src/Prebuilt/components/SecondaryTiles.tsx +0 -81
  244. package/src/Prebuilt/components/Settings/DeviceSettings.jsx +0 -208
  245. package/src/Prebuilt/components/Settings/LayoutSettings.tsx +0 -74
  246. package/src/Prebuilt/components/Settings/NotificationSettings.tsx +0 -66
  247. package/src/Prebuilt/components/Settings/SettingsModal.jsx +0 -301
  248. package/src/Prebuilt/components/Settings/StartRecording.jsx +0 -101
  249. package/src/Prebuilt/components/Settings/SwitchWithLabel.tsx +0 -53
  250. package/src/Prebuilt/components/Settings/common.ts +0 -16
  251. package/src/Prebuilt/components/ShareMenuIcon.jsx +0 -27
  252. package/src/Prebuilt/components/SidePaneTabs.tsx +0 -214
  253. package/src/Prebuilt/components/StatsForNerds.jsx +0 -373
  254. package/src/Prebuilt/components/Streaming/Common.jsx +0 -143
  255. package/src/Prebuilt/components/Streaming/ResolutionInput.jsx +0 -88
  256. package/src/Prebuilt/components/TileMenu/TileMenu.tsx +0 -148
  257. package/src/Prebuilt/components/TileMenu/TileMenuContent.tsx +0 -393
  258. package/src/Prebuilt/components/TileMenu/utils.ts +0 -7
  259. package/src/Prebuilt/components/Toast/Toast.jsx +0 -17
  260. package/src/Prebuilt/components/Toast/ToastBatcher.js +0 -64
  261. package/src/Prebuilt/components/Toast/ToastConfig.jsx +0 -177
  262. package/src/Prebuilt/components/Toast/ToastContainer.jsx +0 -30
  263. package/src/Prebuilt/components/Toast/ToastManager.js +0 -44
  264. package/src/Prebuilt/components/VideoLayouts/EqualProminence.tsx +0 -62
  265. package/src/Prebuilt/components/VideoLayouts/Grid.tsx +0 -43
  266. package/src/Prebuilt/components/VideoLayouts/GridLayout.tsx +0 -155
  267. package/src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx +0 -91
  268. package/src/Prebuilt/components/VideoLayouts/RoleProminence.tsx +0 -66
  269. package/src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx +0 -74
  270. package/src/Prebuilt/components/VideoLayouts/WhiteboardLayout.tsx +0 -93
  271. package/src/Prebuilt/components/VideoLayouts/interface.ts +0 -11
  272. package/src/Prebuilt/components/VideoTile.tsx +0 -203
  273. package/src/Prebuilt/components/VirtualBackground/VBCollection.tsx +0 -52
  274. package/src/Prebuilt/components/VirtualBackground/VBHandler.tsx +0 -130
  275. package/src/Prebuilt/components/VirtualBackground/VBOption.tsx +0 -57
  276. package/src/Prebuilt/components/VirtualBackground/VBPicker.tsx +0 -252
  277. package/src/Prebuilt/components/VirtualBackground/VBToggle.tsx +0 -50
  278. package/src/Prebuilt/components/hooks/useAudioOutputTest.tsx +0 -20
  279. package/src/Prebuilt/components/hooks/useAutoStartStreaming.tsx +0 -70
  280. package/src/Prebuilt/components/hooks/useChatBlacklist.ts +0 -29
  281. package/src/Prebuilt/components/hooks/useCloseScreenshareWhiteboard.tsx +0 -17
  282. package/src/Prebuilt/components/hooks/useDropdownList.ts +0 -24
  283. package/src/Prebuilt/components/hooks/useDropdownSelection.jsx +0 -3
  284. package/src/Prebuilt/components/hooks/useFullscreen.ts +0 -46
  285. package/src/Prebuilt/components/hooks/useGroupOnStageActions.tsx +0 -54
  286. package/src/Prebuilt/components/hooks/useMetadata.tsx +0 -56
  287. package/src/Prebuilt/components/hooks/usePeerOnStageActions.tsx +0 -49
  288. package/src/Prebuilt/components/hooks/usePinnedBy.tsx +0 -22
  289. package/src/Prebuilt/components/hooks/usePinnedMessages.ts +0 -78
  290. package/src/Prebuilt/components/hooks/usePlaylist.js +0 -25
  291. package/src/Prebuilt/components/hooks/usePlaylistMusic.js +0 -35
  292. package/src/Prebuilt/components/hooks/useRedirectToLeave.tsx +0 -23
  293. package/src/Prebuilt/components/hooks/useRoleProminencePeers.tsx +0 -39
  294. package/src/Prebuilt/components/hooks/useScreenshareAudio.js +0 -28
  295. package/src/Prebuilt/components/hooks/useTileLayout.tsx +0 -128
  296. package/src/Prebuilt/components/hooks/useUnreadPollQuizPresent.tsx +0 -17
  297. package/src/Prebuilt/components/hooks/useUserPreferences.jsx +0 -26
  298. package/src/Prebuilt/components/hooks/useVideoTileLayout.ts +0 -26
  299. package/src/Prebuilt/components/init/Init.jsx +0 -31
  300. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +0 -42
  301. package/src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx +0 -31
  302. package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +0 -32
  303. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +0 -211
  304. package/src/Prebuilt/components/pdfAnnotator/submitPdf.jsx +0 -48
  305. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +0 -71
  306. package/src/Prebuilt/components/peerTileUtils.tsx +0 -42
  307. package/src/Prebuilt/images/android-perm-1.png +0 -0
  308. package/src/Prebuilt/images/empty-chat.svg +0 -12
  309. package/src/Prebuilt/images/ios-perm-0.png +0 -0
  310. package/src/Prebuilt/images/pdf-share.png +0 -0
  311. package/src/Prebuilt/images/rtmp.png +0 -0
  312. package/src/Prebuilt/images/screen-share.png +0 -0
  313. package/src/Prebuilt/images/transaction_error.svg +0 -12
  314. package/src/Prebuilt/index.ts +0 -1
  315. package/src/Prebuilt/layouts/EmbedView.jsx +0 -94
  316. package/src/Prebuilt/layouts/HLSView.jsx +0 -794
  317. package/src/Prebuilt/layouts/PDFView.jsx +0 -67
  318. package/src/Prebuilt/layouts/Sheet.tsx +0 -14
  319. package/src/Prebuilt/layouts/SidePane.tsx +0 -241
  320. package/src/Prebuilt/layouts/VideoStreamingSection.tsx +0 -164
  321. package/src/Prebuilt/layouts/WaitingView.tsx +0 -52
  322. package/src/Prebuilt/plugins/CaptionsViewer.tsx +0 -261
  323. package/src/Prebuilt/plugins/FlyingEmoji.jsx +0 -154
  324. package/src/Prebuilt/plugins/RemoteStopScreenshare.jsx +0 -18
  325. package/src/Prebuilt/plugins/transcription/Transcriber.js +0 -216
  326. package/src/Prebuilt/plugins/transcription/TranscriptionButton.jsx +0 -138
  327. package/src/Prebuilt/plugins/transcription/index.jsx +0 -1
  328. package/src/Prebuilt/primitives/DialogContent.jsx +0 -285
  329. package/src/Prebuilt/primitives/DropdownTrigger.jsx +0 -46
  330. package/src/Prebuilt/provider/roomLayoutProvider/constants/index.ts +0 -60
  331. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +0 -88
  332. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useInsetEnabled.ts +0 -10
  333. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useRoomLayoutScreen.ts +0 -112
  334. package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +0 -53
  335. package/src/Prebuilt/services/FeatureFlags.jsx +0 -46
  336. package/src/Progress/index.tsx +0 -17
  337. package/src/QRCode/QRCode.tsx +0 -6
  338. package/src/QRCode/index.tsx +0 -1
  339. package/src/RadioGroup/RadioGroup.tsx +0 -33
  340. package/src/RadioGroup/index.tsx +0 -1
  341. package/src/ReactSelect/ReactSelect.tsx +0 -97
  342. package/src/ReactSelect/index.ts +0 -1
  343. package/src/Select/Select.tsx +0 -63
  344. package/src/Select/index.ts +0 -1
  345. package/src/Sheet/Sheet.tsx +0 -122
  346. package/src/Sheet/index.ts +0 -1
  347. package/src/Slider/Slider.tsx +0 -70
  348. package/src/Slider/index.ts +0 -1
  349. package/src/Stats/Stats.tsx +0 -243
  350. package/src/Stats/StyledStats.tsx +0 -57
  351. package/src/Stats/formatBytes.ts +0 -19
  352. package/src/Stats/index.tsx +0 -2
  353. package/src/Stats/useQoE.ts +0 -79
  354. package/src/Switch/Switch.tsx +0 -52
  355. package/src/Switch/index.ts +0 -1
  356. package/src/Tabs/Tabs.tsx +0 -41
  357. package/src/Tabs/index.tsx +0 -1
  358. package/src/Text/Text.tsx +0 -149
  359. package/src/Text/index.tsx +0 -1
  360. package/src/TextArea/TextArea.tsx +0 -30
  361. package/src/TextArea/index.tsx +0 -1
  362. package/src/Theme/ThemeProvider.tsx +0 -98
  363. package/src/Theme/base.config.ts +0 -236
  364. package/src/Theme/index.tsx +0 -2
  365. package/src/Theme/stitches.config.ts +0 -88
  366. package/src/Theme/useSSR.tsx +0 -24
  367. package/src/TileMenu/StyledMenuTile.tsx +0 -105
  368. package/src/TileMenu/TileMenu.tsx +0 -98
  369. package/src/TileMenu/index.tsx +0 -1
  370. package/src/Toast/Toast.tsx +0 -170
  371. package/src/Toast/index.tsx +0 -1
  372. package/src/Tooltip/Tooltip.tsx +0 -79
  373. package/src/Tooltip/index.ts +0 -1
  374. package/src/Video/Video.tsx +0 -61
  375. package/src/Video/index.tsx +0 -1
  376. package/src/VideoList/StyledVideoList.tsx +0 -39
  377. package/src/VideoList/index.tsx +0 -2
  378. package/src/VideoList/videoListUtils.tsx +0 -20
  379. package/src/VideoTile/StyledVideoTile.tsx +0 -146
  380. package/src/VideoTile/index.tsx +0 -1
  381. package/src/context/DialogContext.tsx +0 -13
  382. package/src/fixtures/chats.ts +0 -25
  383. package/src/fixtures/peers.ts +0 -27
  384. package/src/fixtures/tracks.ts +0 -11
  385. package/src/hooks/useDialogContainerSelector.tsx +0 -7
  386. package/src/index.ts +0 -41
  387. package/src/store/SetupFakeStore.ts +0 -33
  388. package/src/store/StorybookSDK.ts +0 -231
  389. package/src/utils/animations.ts +0 -114
  390. package/src/utils/index.ts +0 -2
  391. package/src/utils/styles.ts +0 -22
@@ -1,142 +0,0 @@
1
- // @ts-check
2
- import React, { useMemo, useState } from 'react';
3
- import { v4 as uuid } from 'uuid';
4
- import { selectPollByID, useHMSActions, useHMSStore, useRecordingStreaming } from '@100mslive/react-sdk';
5
- import { AddCircleIcon } from '@100mslive/react-icons';
6
- import { Button, Flex, Text } from '../../../../';
7
- import { Container, ContentHeader } from '../../Streaming/Common';
8
- import { isValidQuestion, QuestionForm } from './QuestionForm';
9
- import { SavedQuestion } from './SavedQuestion';
10
- import { usePollViewToggle } from '../../AppData/useSidepane';
11
- import { usePollViewState } from '../../AppData/useUISettings';
12
- import { POLL_VIEWS } from '../../../common/constants';
13
-
14
- const getEditableFormat = questions => {
15
- const editableQuestions = questions.map(question => {
16
- return { ...question, saved: true, draftID: uuid() };
17
- });
18
- return editableQuestions;
19
- };
20
-
21
- export function CreateQuestions() {
22
- const actions = useHMSActions();
23
- const { isHLSRunning } = useRecordingStreaming();
24
- const togglePollView = usePollViewToggle();
25
- const { pollInView: id, setPollView } = usePollViewState();
26
- const interaction = useHMSStore(selectPollByID(id));
27
- const [questions, setQuestions] = useState(
28
- interaction.questions?.length ? getEditableFormat(interaction.questions) : [{ draftID: uuid() }],
29
- );
30
-
31
- const isValidPoll = useMemo(() => questions.length > 0 && questions.every(isValidQuestion), [questions]);
32
-
33
- const launchPoll = async () => {
34
- await actions.interactivityCenter.startPoll(id);
35
- await sendTimedMetadata(id);
36
- setPollView(POLL_VIEWS.VOTE);
37
- };
38
-
39
- const sendTimedMetadata = async poll_id => {
40
- // send hls timedmetadata when it is running
41
- if (poll_id && isHLSRunning) {
42
- try {
43
- await actions.sendHLSTimedMetadata([
44
- {
45
- payload: `poll:${poll_id}`,
46
- duration: 100,
47
- },
48
- ]);
49
- } catch (e) {
50
- console.error(e);
51
- }
52
- }
53
- };
54
-
55
- const headingTitle = interaction?.type
56
- ? interaction?.type?.[0]?.toUpperCase() + interaction?.type?.slice(1)
57
- : 'Polls and Quizzes';
58
- const isQuiz = interaction?.type === 'quiz';
59
- return (
60
- <Container rounded>
61
- <ContentHeader
62
- content={headingTitle}
63
- onClose={togglePollView}
64
- onBack={() => setPollView(POLL_VIEWS.CREATE_POLL_QUIZ)}
65
- />
66
- <Flex direction="column" css={{ p: '$10', overflowY: 'auto' }}>
67
- <Flex direction="column">
68
- {questions.map((question, index) => (
69
- <QuestionCard
70
- key={question.draftID}
71
- question={question}
72
- index={index}
73
- length={questions.length}
74
- onSave={async questionParams => {
75
- const updatedQuestions = [...questions.slice(0, index), questionParams, ...questions.slice(index + 1)];
76
- setQuestions(updatedQuestions);
77
- const validQuestions = updatedQuestions.filter(question => isValidQuestion(question));
78
- await actions.interactivityCenter.addQuestionsToPoll(id, validQuestions);
79
- }}
80
- isQuiz={isQuiz}
81
- removeQuestion={async questionID => {
82
- const updatedQuestions = questions.filter(questionFromSet => questionID !== questionFromSet?.draftID);
83
- setQuestions(updatedQuestions);
84
- const validQuestions = updatedQuestions.filter(question => isValidQuestion(question));
85
- await actions.interactivityCenter.addQuestionsToPoll(id, validQuestions);
86
- }}
87
- convertToDraft={questionID =>
88
- setQuestions(prev => {
89
- const copyOfQuestions = [...prev];
90
- copyOfQuestions.forEach(question => {
91
- if (questionID && question.draftID === questionID) {
92
- question.saved = false;
93
- }
94
- });
95
- return copyOfQuestions;
96
- })
97
- }
98
- />
99
- ))}
100
- </Flex>
101
- <Flex
102
- css={{
103
- c: '$on_surface_low',
104
- my: '$sm',
105
- cursor: 'pointer',
106
- '&:hover': { c: '$on_surface_medium' },
107
- }}
108
- onClick={() => setQuestions([...questions, { draftID: uuid() }])}
109
- >
110
- <AddCircleIcon />
111
- <Text variant="body1" css={{ ml: '$md', c: '$inherit' }}>
112
- Add another question
113
- </Text>
114
- </Flex>
115
- <Flex css={{ w: '100%' }} justify="end">
116
- <Button disabled={!isValidPoll} onClick={async () => launchPoll()}>
117
- Launch {interaction?.type}
118
- </Button>
119
- </Flex>
120
- </Flex>
121
- </Container>
122
- );
123
- }
124
-
125
- const QuestionCard = ({ question, onSave, index, length, removeQuestion, isQuiz, convertToDraft }) => {
126
- return (
127
- <Flex direction="column" css={{ p: '$md', bg: '$surface_default', r: '$1', mb: '$sm' }}>
128
- {question.saved ? (
129
- <SavedQuestion question={question} index={index} length={length} convertToDraft={convertToDraft} />
130
- ) : (
131
- <QuestionForm
132
- question={question}
133
- removeQuestion={() => removeQuestion(question.draftID)}
134
- onSave={params => onSave(params)}
135
- index={index}
136
- length={length}
137
- isQuiz={isQuiz}
138
- />
139
- )}
140
- </Flex>
141
- );
142
- };
@@ -1,74 +0,0 @@
1
- import React from 'react';
2
- import { AlertTriangleIcon, CrossIcon } from '@100mslive/react-icons';
3
- import { Button } from '../../../../Button';
4
- import { Box, Flex } from '../../../../Layout';
5
- import { Dialog } from '../../../../Modal';
6
- import { Text } from '../../../../Text';
7
-
8
- export const DeleteQuestionModal = ({
9
- open,
10
- setOpen,
11
- removeQuestion,
12
- }: {
13
- open: boolean;
14
- setOpen: React.Dispatch<React.SetStateAction<boolean>>;
15
- removeQuestion: () => void;
16
- }) => {
17
- return (
18
- <Dialog.Root open={open}>
19
- <Dialog.Overlay />
20
- <Dialog.Portal>
21
- <Dialog.Content css={{ p: '$10' }}>
22
- <Box>
23
- <Flex
24
- css={{
25
- color: '$alert_error_default',
26
- display: 'flex',
27
- alignItems: 'center',
28
- }}
29
- >
30
- <AlertTriangleIcon style={{ marginRight: '0.5rem' }} />
31
- <Text variant="lg" css={{ color: 'inherit', fontWeight: '$semiBold' }}>
32
- Delete Question?
33
- </Text>
34
-
35
- <Box
36
- css={{
37
- ml: 'auto',
38
- color: '$on_surface_medium',
39
- '&:hover': { color: '$on_surface_high', cursor: 'pointer' },
40
- }}
41
- onClick={() => setOpen(false)}
42
- >
43
- <CrossIcon />
44
- </Box>
45
- </Flex>
46
- <Text variant="sm" css={{ color: '$on_surface_medium', mb: '$8', mt: '$4' }}>
47
- The question will be deleted. You can't undo this action.
48
- </Text>
49
- <Flex css={{ w: '100%', mt: '$12', gap: '$md' }}>
50
- <Button
51
- variant="standard"
52
- outlined
53
- onClick={() => setOpen(false)}
54
- css={{ w: '100%', fontSize: '$md', fontWeight: '$semiBold' }}
55
- >
56
- Cancel
57
- </Button>
58
- <Button
59
- css={{ w: '100%', fontSize: '$md', fontWeight: '$semiBold' }}
60
- variant="danger"
61
- onClick={() => {
62
- removeQuestion();
63
- setOpen(false);
64
- }}
65
- >
66
- Delete
67
- </Button>
68
- </Flex>
69
- </Box>
70
- </Dialog.Content>
71
- </Dialog.Portal>
72
- </Dialog.Root>
73
- );
74
- };
@@ -1,324 +0,0 @@
1
- // @ts-check
2
- import React, { useCallback, useRef, useState } from 'react';
3
- import {
4
- HMSPollQuestionCreateParams,
5
- HMSPollQuestionOptionCreateParams,
6
- HMSPollQuestionType,
7
- } from '@100mslive/react-sdk';
8
- import { AddCircleIcon, TrashIcon } from '@100mslive/react-icons';
9
- // import { Button, Dropdown, Flex, IconButton, Input, Switch, Text, TextArea, Tooltip } from '../../../..';
10
- import { Button, Dropdown, Flex, IconButton, Input, Text, TextArea, Tooltip } from '../../../..';
11
- // @ts-ignore
12
- import { DialogDropdownTrigger } from '../../../primitives/DropdownTrigger';
13
- // @ts-ignore
14
- import { DeleteQuestionModal } from './DeleteQuestionModal';
15
- // @ts-ignore
16
- import { useDropdownSelection } from '../../hooks/useDropdownSelection';
17
- // @ts-ignore
18
- import { isValidTextInput } from '../../../common/utils';
19
- import { Line } from '../common/Line';
20
- // @ts-ignore
21
- import { MultipleChoiceOptionInputs } from '../common/MultipleChoiceOptions';
22
- // @ts-ignore
23
- import { SingleChoiceOptionInputs } from '../common/SingleChoiceOptions';
24
- import { QUESTION_TYPE, QUESTION_TYPE_TITLE } from '../../../common/constants';
25
-
26
- export const QuestionForm = ({
27
- question,
28
- index,
29
- length,
30
- onSave,
31
- removeQuestion,
32
- isQuiz,
33
- }: {
34
- question: HMSPollQuestionCreateParams & { draftID: number };
35
- index: number;
36
- length: number;
37
- onSave: (optionParams: HMSPollQuestionCreateParams & { draftID: number; saved: boolean }) => void;
38
- removeQuestion: () => void;
39
- isQuiz: boolean;
40
- }) => {
41
- const ref = useRef(null);
42
- const selectionBg = useDropdownSelection();
43
- const [openDelete, setOpenDelete] = useState(false);
44
- const [open, setOpen] = useState(false);
45
- const [type, setType] = useState<HMSPollQuestionType>(question.type || QUESTION_TYPE.SINGLE_CHOICE);
46
- const [text, setText] = useState(question.text);
47
- const [weight, setWeight] = useState(isQuiz ? 10 : 1);
48
- const [options, setOptions] = useState(
49
- question?.options || [
50
- { text: '', isCorrectAnswer: false },
51
- { text: '', isCorrectAnswer: false },
52
- ],
53
- );
54
- // const [skippable, setSkippable] = useState(false);
55
- const isValid = isValidQuestion({
56
- text,
57
- type,
58
- options,
59
- weight,
60
- isQuiz,
61
- });
62
-
63
- const handleOptionTextChange = useCallback(
64
- (index: number, text: string) => {
65
- setOptions(options => [...options.slice(0, index), { ...options[index], text }, ...options.slice(index + 1)]);
66
- },
67
- [setOptions],
68
- );
69
-
70
- const removeOption = useCallback(
71
- (index: number) =>
72
- setOptions(options => {
73
- const newOptions = [...options];
74
- newOptions.splice(index, 1);
75
- return newOptions;
76
- }),
77
- [setOptions],
78
- );
79
-
80
- const selectSingleChoiceAnswer = useCallback(
81
- (answerIndex: number) => {
82
- if (!isQuiz) {
83
- return;
84
- }
85
- setOptions(options =>
86
- options.map((option, index) => ({
87
- ...option,
88
- isCorrectAnswer: index === answerIndex,
89
- })),
90
- );
91
- },
92
- [setOptions, isQuiz],
93
- );
94
-
95
- const selectMultipleChoiceAnswer = useCallback(
96
- (checked: boolean, index: number) => {
97
- if (!isQuiz) {
98
- return;
99
- }
100
- setOptions(options => [
101
- ...options.slice(0, index),
102
- { ...options[index], isCorrectAnswer: checked },
103
- ...options.slice(index + 1),
104
- ]);
105
- },
106
- [setOptions, isQuiz],
107
- );
108
-
109
- return (
110
- <>
111
- <Text variant="overline" css={{ c: '$on_surface_low', textTransform: 'uppercase' }}>
112
- Question {index + 1} of {length}
113
- </Text>
114
- <Text variant="body2" css={{ mt: '$4', mb: '$md' }}>
115
- Question Type
116
- </Text>
117
- <Dropdown.Root open={open} onOpenChange={setOpen}>
118
- <DialogDropdownTrigger
119
- ref={ref}
120
- // @ts-ignore
121
- title={QUESTION_TYPE_TITLE[type]}
122
- css={{
123
- backgroundColor: '$surface_bright',
124
- border: '1px solid $border_bright',
125
- }}
126
- open={open}
127
- />
128
- <Dropdown.Portal>
129
- {/* @ts-ignore */}
130
- <Dropdown.Content align="start" sideOffset={8} css={{ w: ref.current?.clientWidth, zIndex: 1000 }}>
131
- {Object.keys(QUESTION_TYPE_TITLE).map(value => {
132
- return (
133
- <Dropdown.Item
134
- key={value}
135
- // @ts-ignore
136
- onSelect={() => setType(value)}
137
- css={{
138
- px: '$9',
139
- bg: type === value ? selectionBg : undefined,
140
- }}
141
- >
142
- {/* @ts-ignore */}
143
- {QUESTION_TYPE_TITLE[value]}
144
- </Dropdown.Item>
145
- );
146
- })}
147
- </Dropdown.Content>
148
- </Dropdown.Portal>
149
- </Dropdown.Root>
150
- <TextArea
151
- maxLength={1024}
152
- placeholder="Ask a question"
153
- css={{
154
- mt: '$md',
155
- backgroundColor: '$surface_bright',
156
- border: '1px solid $border_bright',
157
- minHeight: '$14',
158
- resize: 'vertical',
159
- maxHeight: '$32',
160
- }}
161
- value={text}
162
- onChange={event => setText(event.target.value.trimStart())}
163
- />
164
- <Text variant="xs" css={{ color: '$on_surface_medium', textAlign: 'end', mt: '$4' }}>
165
- {text?.length || 0}/1024
166
- </Text>
167
- <Line />
168
- {/* @ts-ignore */}
169
- {type === QUESTION_TYPE.SINGLE_CHOICE || type === QUESTION_TYPE.MULTIPLE_CHOICE ? (
170
- <>
171
- <Text variant="body2" css={{ mb: '$6', c: '$on_surface_medium' }}>
172
- Options
173
- </Text>
174
-
175
- {isQuiz && (
176
- <Text variant="xs" css={{ c: '$on_surface_medium', mb: '$md' }}>
177
- {type === QUESTION_TYPE.SINGLE_CHOICE
178
- ? 'Use the radio buttons to indicate the correct answer'
179
- : 'Use the checkboxes to indicate the correct answer(s)'}
180
- </Text>
181
- )}
182
-
183
- {type === QUESTION_TYPE.SINGLE_CHOICE && (
184
- <SingleChoiceOptionInputs
185
- isQuiz={isQuiz}
186
- options={options}
187
- selectAnswer={selectSingleChoiceAnswer}
188
- handleOptionTextChange={handleOptionTextChange}
189
- removeOption={removeOption}
190
- />
191
- )}
192
-
193
- {type === QUESTION_TYPE.MULTIPLE_CHOICE && (
194
- <MultipleChoiceOptionInputs
195
- isQuiz={isQuiz}
196
- options={options}
197
- selectAnswer={selectMultipleChoiceAnswer}
198
- handleOptionTextChange={handleOptionTextChange}
199
- removeOption={removeOption}
200
- />
201
- )}
202
-
203
- {options?.length < 20 && (
204
- <Flex
205
- css={{
206
- c: '$on_surface_medium',
207
- cursor: 'pointer',
208
- '&:hover': { c: '$on_surface_high' },
209
- }}
210
- onClick={() => setOptions([...options, { text: '', isCorrectAnswer: false }])}
211
- >
212
- <AddCircleIcon style={{ position: 'relative', left: '-2px' }} />
213
-
214
- <Text
215
- variant="sm"
216
- css={{
217
- ml: '$4',
218
- c: 'inherit',
219
- }}
220
- >
221
- Add an option
222
- </Text>
223
- </Flex>
224
- )}
225
- <Line />
226
- {isQuiz ? (
227
- <>
228
- <Flex justify="between" align="center" css={{ gap: '$6', w: '100%' }}>
229
- <Text variant="sm" css={{ color: '$on_surface_medium' }}>
230
- Point Weightage
231
- </Text>
232
- <Input
233
- type="number"
234
- value={weight}
235
- min={1}
236
- max={999}
237
- onChange={e => setWeight(Math.min(Number(e.target.value), 999))}
238
- css={{
239
- backgroundColor: '$surface_bright',
240
- border: '1px solid $border_bright',
241
- maxWidth: '$20',
242
- }}
243
- />
244
- </Flex>
245
- {/* <Flex justify="between" css={{ mt: '$md', gap: '$6', w: '100%' }}>
246
- <Text variant="sm" css={{ color: '$on_surface_medium' }}>
247
- Allow to skip
248
- </Text>
249
- <Switch defaultChecked={skippable} onCheckedChange={checked => setSkippable(checked)} />
250
- </Flex> */}
251
- </>
252
- ) : null}
253
- </>
254
- ) : null}
255
-
256
- <Flex justify="end" align="center" css={{ mt: '$12', gap: '$8' }}>
257
- <IconButton css={{ border: '1px solid $border_bright' }}>
258
- <TrashIcon onClick={() => setOpenDelete(!open)} />
259
- </IconButton>
260
- <Tooltip
261
- disabled={isValid}
262
- title={
263
- options.length < 2
264
- ? 'At least two options must be added'
265
- : `Please fill all the fields ${isQuiz ? 'and mark the correct answer(s)' : ''} to continue`
266
- }
267
- boxCss={{ maxWidth: '$40' }}
268
- >
269
- <Button
270
- variant="standard"
271
- disabled={!isValid}
272
- onClick={() => {
273
- onSave({
274
- saved: true,
275
- text,
276
- type,
277
- options,
278
- skippable: false,
279
- draftID: question.draftID,
280
- weight,
281
- });
282
- }}
283
- >
284
- Save
285
- </Button>
286
- </Tooltip>
287
- </Flex>
288
-
289
- <DeleteQuestionModal open={openDelete} setOpen={setOpenDelete} removeQuestion={removeQuestion} />
290
- </>
291
- );
292
- };
293
-
294
- export const isValidQuestion = ({
295
- text,
296
- type,
297
- options,
298
- weight,
299
- isQuiz = false,
300
- }: {
301
- text: string;
302
- type: string;
303
- options: HMSPollQuestionOptionCreateParams[];
304
- weight: number;
305
- isQuiz?: boolean;
306
- }) => {
307
- if (!isValidTextInput(text) || !type) {
308
- return false;
309
- }
310
-
311
- const everyOptionHasText = options.length > 1 && options.every(option => option && isValidTextInput(option.text, 1));
312
- const hasCorrectAnswer = options.some(option => option.isCorrectAnswer);
313
-
314
- if (!isQuiz) {
315
- return everyOptionHasText;
316
- }
317
-
318
- // The minimum acceptable value of weight is 1
319
- if (isQuiz && weight < 1) {
320
- return false;
321
- }
322
-
323
- return everyOptionHasText && hasCorrectAnswer;
324
- };
@@ -1,64 +0,0 @@
1
- import React, { useMemo } from 'react';
2
- import { HMSPollQuestion } from '@100mslive/react-sdk';
3
- import { CheckCircleIcon } from '@100mslive/react-icons';
4
- import { Button, Flex, Text } from '../../../../';
5
- import { QUESTION_TYPE_TITLE } from '../../../common/constants';
6
-
7
- export const SavedQuestion = ({
8
- question,
9
- index,
10
- length,
11
- convertToDraft,
12
- }: {
13
- question: HMSPollQuestion & { draftID: number };
14
- index: number;
15
- length: number;
16
- convertToDraft: (draftID: number) => void;
17
- }) => {
18
- const answerArray = useMemo(() => {
19
- const updatedAnswerArray = [];
20
- const { option, options } = question?.answer ?? {};
21
- if (option) {
22
- updatedAnswerArray.push(option);
23
- }
24
- if (options) {
25
- updatedAnswerArray.push(...options);
26
- }
27
- return updatedAnswerArray;
28
- }, [question?.answer]);
29
-
30
- return (
31
- <>
32
- <Text variant="overline" css={{ c: '$on_surface_low', textTransform: 'uppercase' }}>
33
- {/* @ts-ignore */}
34
- Question {index + 1} of {length}: {QUESTION_TYPE_TITLE[question.type]}
35
- </Text>
36
- <Text variant="body2" css={{ mt: '$4', mb: '$md' }}>
37
- {question.text}
38
- </Text>
39
- {question.options?.map((option, index) => (
40
- <Flex key={`${option.text}-${index}`} css={{ alignItems: 'center', my: '$xs' }}>
41
- <Text variant="body2" css={{ c: '$on_surface_medium' }}>
42
- {option.text}
43
- </Text>
44
- {/* @ts-ignore */}
45
- {(answerArray.includes(index + 1) || option.isCorrectAnswer) && (
46
- <Flex css={{ color: '$alert_success', mx: '$xs' }}>
47
- <CheckCircleIcon height={24} width={24} />
48
- </Flex>
49
- )}
50
- </Flex>
51
- ))}
52
- {question.skippable ? (
53
- <Text variant="sm" css={{ color: '$on_surface_low', my: '$md' }}>
54
- Not required to answer
55
- </Text>
56
- ) : null}
57
- <Flex justify="end" css={{ w: '100%', alignItems: 'center' }}>
58
- <Button variant="standard" css={{ fontWeight: '$semiBold' }} onClick={() => convertToDraft(question.draftID)}>
59
- Edit
60
- </Button>
61
- </Flex>
62
- </>
63
- );
64
- };
@@ -1,31 +0,0 @@
1
- import React from 'react';
2
- // @ts-ignore: No implicit Any
3
- import { PollsQuizMenu } from './CreatePollQuiz/PollsQuizMenu';
4
- // @ts-ignore: No implicit Any
5
- import { CreateQuestions } from './CreateQuestions/CreateQuestions';
6
- import { LeaderboardSummary } from './Voting/LeaderboardSummary';
7
- // @ts-ignore: No implicit Any
8
- import { Voting } from './Voting/Voting';
9
- // @ts-ignore: No implicit Any
10
- import { usePollViewToggle } from '../AppData/useSidepane';
11
- // @ts-ignore: No implicit Any
12
- import { usePollViewState } from '../AppData/useUISettings';
13
- // @ts-ignore: No implicit Any
14
- import { POLL_VIEWS } from '../../common/constants';
15
-
16
- export const Polls = () => {
17
- const togglePollView = usePollViewToggle();
18
- const { pollInView: pollID, view } = usePollViewState();
19
-
20
- if (view === POLL_VIEWS.CREATE_POLL_QUIZ) {
21
- return <PollsQuizMenu />;
22
- } else if (view === POLL_VIEWS.CREATE_QUESTIONS) {
23
- return <CreateQuestions />;
24
- } else if (view === POLL_VIEWS.VOTE) {
25
- return <Voting toggleVoting={togglePollView} id={pollID} />;
26
- } else if (view === POLL_VIEWS.RESULTS) {
27
- return <LeaderboardSummary pollID={pollID} />;
28
- } else {
29
- return null;
30
- }
31
- };