@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,76 +0,0 @@
1
- import React from 'react';
2
- import { CheckCircleIcon, ClockIcon, TrophyFilledIcon } from '@100mslive/react-icons';
3
- import { Box, Flex } from '../../../../Layout';
4
- import { Text } from '../../../../Text';
5
- import { getFormattedTime } from '../common/utils';
6
-
7
- const positionColorMap: Record<number, string> = { 1: '#D69516', 2: '#3E3E3E', 3: '#583B0F' };
8
-
9
- export const LeaderboardEntry = ({
10
- position,
11
- score,
12
- questionCount,
13
- correctResponses,
14
- userName,
15
- maxPossibleScore,
16
- duration,
17
- }: {
18
- position: number;
19
- score: number;
20
- questionCount: number;
21
- correctResponses: number;
22
- userName: string;
23
- maxPossibleScore: number;
24
- duration: number;
25
- }) => {
26
- return (
27
- <Flex align="center" justify="between" css={{ my: '$8' }}>
28
- <Flex align="center" css={{ gap: '$6' }}>
29
- <Flex
30
- align="center"
31
- justify="center"
32
- css={{
33
- backgroundColor: positionColorMap[position] || '',
34
- h: '$10',
35
- w: '$10',
36
- borderRadius: '$round',
37
- color: position > 3 ? '$on_surface_low' : '#FFF',
38
- fontSize: '$xs',
39
- fontWeight: '$semiBold',
40
- }}
41
- >
42
- {position}
43
- </Flex>
44
-
45
- <Box>
46
- <Text variant="sm" css={{ fontWeight: '$semiBold', color: '$on_surface_high' }}>
47
- {userName}
48
- </Text>
49
-
50
- <Text variant="sm" css={{ mt: '$1' }}>
51
- {score} / {maxPossibleScore} points
52
- </Text>
53
- </Box>
54
- </Flex>
55
-
56
- <Flex align="center" css={{ gap: '$4', color: '$on_surface_medium' }}>
57
- {position === 1 && score ? <TrophyFilledIcon height={16} width={16} /> : null}
58
- {questionCount ? (
59
- <>
60
- <CheckCircleIcon height={16} width={16} />
61
- <Text variant="xs">
62
- {correctResponses}/{questionCount}
63
- </Text>
64
- </>
65
- ) : null}
66
-
67
- {duration ? (
68
- <Flex align="center" css={{ gap: '$2', color: '$on_surface_medium' }}>
69
- <ClockIcon height={16} width={16} />
70
- <Text variant="xs">{getFormattedTime(duration)}</Text>
71
- </Flex>
72
- ) : null}
73
- </Flex>
74
- </Flex>
75
- );
76
- };
@@ -1,116 +0,0 @@
1
- import React, { useState } from 'react';
2
- import { selectPollByID, useHMSStore } from '@100mslive/react-sdk';
3
- import { ChevronLeftIcon, ChevronRightIcon, CrossIcon } from '@100mslive/react-icons';
4
- import { Box, Flex } from '../../../../Layout';
5
- import { Loading } from '../../../../Loading';
6
- import { Text } from '../../../../Text';
7
- // @ts-ignore
8
- import { Container } from '../../Streaming/Common';
9
- import { LeaderboardEntry } from './LeaderboardEntry';
10
- import { PeerParticipationSummary } from './PeerParticipationSummary';
11
- // @ts-ignore
12
- import { useSidepaneToggle } from '../../AppData/useSidepane';
13
- // @ts-ignore
14
- import { usePollViewState } from '../../AppData/useUISettings';
15
- import { useQuizSummary } from './useQuizSummary';
16
- // @ts-ignore
17
- import { StatusIndicator } from '../common/StatusIndicator';
18
- import { POLL_VIEWS } from '../../../common/constants';
19
-
20
- export const LeaderboardSummary = ({ pollID }: { pollID: string }) => {
21
- const quiz = useHMSStore(selectPollByID(pollID));
22
- const { quizLeaderboard, maxPossibleScore } = useQuizSummary(pollID);
23
- const [viewAllEntries, setViewAllEntries] = useState(false);
24
- const { setPollView } = usePollViewState();
25
- const toggleSidepane = useSidepaneToggle();
26
-
27
- if (!quiz || !quizLeaderboard)
28
- return (
29
- <Flex align="center" justify="center" css={{ size: '100%' }}>
30
- <Loading />
31
- </Flex>
32
- );
33
-
34
- const questionCount = quiz.questions?.length || 0;
35
-
36
- return (
37
- <Container rounded>
38
- <Flex direction="column" css={{ size: '100%', p: '$8' }}>
39
- <Flex justify="between" align="center" css={{ pb: '$6', borderBottom: '1px solid $border_bright', mb: '$8' }}>
40
- <Flex align="center" css={{ gap: '$4' }}>
41
- <Flex
42
- css={{ color: '$on_surface_medium', '&:hover': { color: '$on_surface_high', cursor: 'pointer' } }}
43
- onClick={() => setPollView(POLL_VIEWS.VOTE)}
44
- >
45
- <ChevronLeftIcon />
46
- </Flex>
47
- <Text variant="lg" css={{ fontWeight: '$semiBold' }}>
48
- {quiz.title}
49
- </Text>
50
- <StatusIndicator status={quiz.state} />
51
- </Flex>
52
- <Flex
53
- css={{ color: '$on_surface_medium', '&:hover': { color: '$on_surface_high', cursor: 'pointer' } }}
54
- onClick={toggleSidepane}
55
- >
56
- <CrossIcon />
57
- </Flex>
58
- </Flex>
59
- <Box css={{ overflowY: 'auto', mr: '-$4', pr: '$4' }}>
60
- {!viewAllEntries ? <PeerParticipationSummary quiz={quiz} /> : null}
61
-
62
- <Text variant="sm" css={{ fontWeight: '$semiBold', mt: '$4' }}>
63
- Leaderboard
64
- </Text>
65
- <Text variant="xs" css={{ color: '$on_surface_medium' }}>
66
- Based on score and time taken to cast the correct answer
67
- </Text>
68
- <Box
69
- css={{
70
- mt: '$8',
71
- overflowY: 'auto',
72
- flex: viewAllEntries ? '1 1 0' : 'unset',
73
- mr: viewAllEntries ? '-$6' : 'unset',
74
- px: viewAllEntries ? '0' : '$4',
75
- pr: viewAllEntries ? '$6' : '$4',
76
- backgroundColor: viewAllEntries ? '' : '$surface_default',
77
- borderRadius: '$1',
78
- }}
79
- >
80
- {quizLeaderboard?.entries &&
81
- quizLeaderboard.entries
82
- .slice(0, viewAllEntries ? undefined : 5)
83
- .map(question => (
84
- <LeaderboardEntry
85
- key={question.position}
86
- position={question.position}
87
- score={question.score}
88
- questionCount={questionCount}
89
- correctResponses={question.correctResponses}
90
- userName={question.peer.username || ''}
91
- maxPossibleScore={maxPossibleScore}
92
- duration={question.duration}
93
- />
94
- ))}
95
- {quizLeaderboard?.entries?.length > 5 && !viewAllEntries ? (
96
- <Flex
97
- align="center"
98
- justify="end"
99
- css={{
100
- w: '100%',
101
- borderTop: '1px solid $border_bright',
102
- cursor: 'pointer',
103
- color: '$on_surface_high',
104
- p: '$6 $2',
105
- }}
106
- onClick={() => setViewAllEntries(true)}
107
- >
108
- <Text variant="sm">View All</Text> <ChevronRightIcon />
109
- </Flex>
110
- ) : null}
111
- </Box>
112
- </Box>
113
- </Flex>
114
- </Container>
115
- );
116
- };
@@ -1,60 +0,0 @@
1
- import React from 'react';
2
- import { HMSPoll, selectLocalPeerID, useHMSStore } from '@100mslive/react-sdk';
3
- import { Box } from '../../../../Layout';
4
- import { Text } from '../../../../Text';
5
- import { StatisticBox } from './StatisticBox';
6
- import { useQuizSummary } from './useQuizSummary';
7
- import { getFormattedTime } from '../common/utils';
8
-
9
- export const PeerParticipationSummary = ({ quiz }: { quiz: HMSPoll }) => {
10
- const localPeerId = useHMSStore(selectLocalPeerID);
11
- const { quizLeaderboard, summary } = useQuizSummary(quiz.id);
12
- if (quiz.state !== 'stopped') {
13
- return <></>;
14
- }
15
- const isLocalPeerQuizCreator = localPeerId === quiz.startedBy;
16
- const peerEntry = quizLeaderboard?.entries.find(entry => entry.peer?.peerid === localPeerId);
17
-
18
- const boxes = isLocalPeerQuizCreator
19
- ? [
20
- {
21
- title: 'Voted',
22
- value: `${summary.totalUsers ? ((100 * summary.votedUsers) / summary.totalUsers).toFixed(0) : 0}% (${
23
- summary.votedUsers
24
- }/${summary.totalUsers})`,
25
- },
26
- {
27
- title: 'Correct Answers',
28
- value: `${summary.totalUsers ? ((100 * summary.correctUsers) / summary.totalUsers).toFixed(0) : 0}% (${
29
- summary.correctUsers
30
- }/${summary.totalUsers})`,
31
- },
32
- // Time in ms
33
- { title: 'Avg. Time Taken', value: getFormattedTime(summary.avgTime) },
34
- {
35
- title: 'Avg. Score',
36
- value: Number.isInteger(summary.avgScore) ? summary.avgScore : summary.avgScore.toFixed(2),
37
- },
38
- ]
39
- : [
40
- { title: 'Your rank', value: peerEntry?.position || '-' },
41
- { title: 'Points', value: peerEntry?.score || 0 },
42
- // Time in ms
43
- { title: 'Time Taken', value: getFormattedTime(peerEntry?.duration) },
44
- {
45
- title: 'Correct Answers',
46
- value: peerEntry?.totalResponses ? `${peerEntry?.correctResponses}/${peerEntry.totalResponses}` : '-',
47
- },
48
- ];
49
-
50
- return (
51
- <Box>
52
- <Text css={{ fontWeight: '$semiBold', my: '$8' }}>Participation Summary</Text>
53
- <Box css={{ display: 'grid', gridTemplateColumns: '1fr 1fr', gap: '$4' }}>
54
- {boxes.map(box => (
55
- <StatisticBox key={box.title} title={box.title} value={box.value} />
56
- ))}
57
- </Box>
58
- </Box>
59
- );
60
- };
@@ -1,221 +0,0 @@
1
- // @ts-check
2
- import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';
3
- import { match } from 'ts-pattern';
4
- import {
5
- HMSRoomState,
6
- selectLocalPeer,
7
- selectLocalPeerRoleName,
8
- selectRoomState,
9
- useHMSActions,
10
- useHMSStore,
11
- } from '@100mslive/react-sdk';
12
- import { CheckCircleIcon, ChevronDownIcon, CrossCircleIcon } from '@100mslive/react-icons';
13
- import { Box, Button, Flex, Text } from '../../../../';
14
- import { checkCorrectAnswer } from '../../../common/utils';
15
- import { MultipleChoiceOptions } from '../common/MultipleChoiceOptions';
16
- import { SingleChoiceOptions } from '../common/SingleChoiceOptions';
17
- import { QUESTION_TYPE } from '../../../common/constants';
18
-
19
- export const QuestionCard = ({
20
- pollID,
21
- isQuiz,
22
- startedBy,
23
- pollState,
24
- index,
25
- totalQuestions,
26
- result,
27
- type,
28
- text,
29
- options = [],
30
- answer,
31
- localPeerResponse,
32
- updateSavedResponses,
33
- rolesThatCanViewResponses,
34
- }) => {
35
- const actions = useHMSActions();
36
- const localPeer = useHMSStore(selectLocalPeer);
37
- const roomState = useHMSStore(selectRoomState);
38
- const isLocalPeerCreator = localPeer?.id === startedBy;
39
- const localPeerRoleName = useHMSStore(selectLocalPeerRoleName);
40
- const roleCanViewResponse =
41
- !rolesThatCanViewResponses ||
42
- rolesThatCanViewResponses.length === 0 ||
43
- rolesThatCanViewResponses.includes(localPeerRoleName || '');
44
- const [localPeerChoice, setLocalPeerChoice] = useState(localPeerResponse);
45
-
46
- useEffect(() => {
47
- setLocalPeerChoice(localPeerResponse);
48
- }, [localPeerResponse]);
49
-
50
- const showVoteCount =
51
- roleCanViewResponse && (localPeerChoice || (isLocalPeerCreator && pollState === 'stopped')) && !isQuiz;
52
-
53
- const isLive = pollState === 'started';
54
- const pollEnded = pollState === 'stopped';
55
- const canRespond = isLive && !localPeerChoice;
56
- const startTime = useRef(Date.now());
57
- const isCorrectAnswer = checkCorrectAnswer(answer, localPeerChoice, type);
58
-
59
- const [singleOptionAnswer, setSingleOptionAnswer] = useState();
60
- const [multipleOptionAnswer, setMultipleOptionAnswer] = useState(new Set());
61
- const [showOptions, setShowOptions] = useState(true);
62
-
63
- const respondedToQuiz = isQuiz && localPeerChoice && !localPeerChoice.skipped;
64
-
65
- const isValidVote = useMemo(() => {
66
- if (type === QUESTION_TYPE.SINGLE_CHOICE) {
67
- return singleOptionAnswer !== undefined;
68
- } else if (type === QUESTION_TYPE.MULTIPLE_CHOICE) {
69
- return multipleOptionAnswer.size > 0;
70
- }
71
- }, [singleOptionAnswer, multipleOptionAnswer, type]);
72
-
73
- const handleVote = useCallback(async () => {
74
- if (!isValidVote) {
75
- return;
76
- }
77
- const submittedResponse = {
78
- questionIndex: index,
79
- option: singleOptionAnswer,
80
- options: Array.from(multipleOptionAnswer),
81
- duration: Date.now() - startTime.current,
82
- };
83
- await actions.interactivityCenter.addResponsesToPoll(pollID, [submittedResponse]);
84
- updateSavedResponses(prev => {
85
- const prevCopy = { ...prev };
86
- prevCopy[index] = { option: singleOptionAnswer, options: Array.from(multipleOptionAnswer) };
87
- return prevCopy;
88
- });
89
- startTime.current = Date.now();
90
- }, [
91
- isValidVote,
92
- index,
93
- singleOptionAnswer,
94
- multipleOptionAnswer,
95
- actions.interactivityCenter,
96
- pollID,
97
- updateSavedResponses,
98
- ]);
99
-
100
- return (
101
- <Box
102
- css={{
103
- backgroundColor: '$surface_bright',
104
- borderRadius: '$1',
105
- p: '$md',
106
- mt: '$md',
107
- border:
108
- respondedToQuiz && !isLive
109
- ? `1px solid ${isCorrectAnswer ? '$alert_success' : '$alert_error_default'}`
110
- : 'none',
111
- }}
112
- >
113
- <Flex align="center" justify="between">
114
- <Text
115
- variant="caption"
116
- css={{
117
- color: match({ respondedToQuiz, isLive, isCorrectAnswer })
118
- .when(
119
- ({ respondedToQuiz, isLive }) => respondedToQuiz && !isLive,
120
- ({ isCorrectAnswer }) => (isCorrectAnswer ? '$alert_success' : '$alert_error_default'),
121
- )
122
- .otherwise(() => '$on_surface_low'),
123
- fontWeight: '$semiBold',
124
- display: 'flex',
125
- alignItems: 'center',
126
- gap: '$4',
127
- }}
128
- >
129
- {match({ respondedToQuiz, pollEnded, isCorrectAnswer })
130
- .when(
131
- ({ respondedToQuiz, pollEnded }) => respondedToQuiz && pollEnded,
132
- ({ isCorrectAnswer }) => {
133
- return isCorrectAnswer ? (
134
- <CheckCircleIcon height={16} width={16} />
135
- ) : (
136
- <CrossCircleIcon height={16} width={16} />
137
- );
138
- },
139
- )
140
- .otherwise(() => null)}
141
- QUESTION {index} OF {totalQuestions}: {type.toUpperCase()}
142
- </Text>
143
- </Flex>
144
-
145
- <Flex justify="between" css={{ my: '$md' }}>
146
- <Text css={{ color: '$on_surface_high' }}>{text}</Text>
147
- <Box
148
- css={{ color: '$on_surface_medium', '&:hover': { color: '$on_surface_high', cursor: 'pointer' } }}
149
- onClick={() => setShowOptions(prev => !prev)}
150
- >
151
- <ChevronDownIcon
152
- style={{ transform: showOptions ? 'rotate(180deg)' : 'rotate(0deg)', transition: 'transform 0.3s ease' }}
153
- />
154
- </Box>
155
- </Flex>
156
-
157
- <Box
158
- css={{ maxHeight: showOptions ? '$80' : '0', transition: 'max-height 0.3s ease', overflowY: 'auto', mb: '$4' }}
159
- >
160
- {type === QUESTION_TYPE.SINGLE_CHOICE ? (
161
- <SingleChoiceOptions
162
- key={index}
163
- questionIndex={index}
164
- isQuiz={isQuiz}
165
- canRespond={canRespond}
166
- correctOptionIndex={answer?.option}
167
- options={options}
168
- setAnswer={setSingleOptionAnswer}
169
- totalResponses={result?.totalResponses}
170
- showVoteCount={showVoteCount}
171
- localPeerResponse={localPeerChoice}
172
- isStopped={pollState === 'stopped'}
173
- />
174
- ) : null}
175
-
176
- {type === QUESTION_TYPE.MULTIPLE_CHOICE ? (
177
- <MultipleChoiceOptions
178
- questionIndex={index}
179
- isQuiz={isQuiz}
180
- canRespond={canRespond}
181
- correctOptionIndexes={answer?.options}
182
- options={options}
183
- selectedOptions={multipleOptionAnswer}
184
- setSelectedOptions={setMultipleOptionAnswer}
185
- totalResponses={result?.totalResponses}
186
- showVoteCount={showVoteCount}
187
- localPeerResponse={localPeerChoice}
188
- isStopped={pollState === 'stopped'}
189
- />
190
- ) : null}
191
- </Box>
192
- {isLive && (
193
- <QuestionActions
194
- disableVote={roomState !== HMSRoomState.Connected}
195
- isValidVote={isValidVote}
196
- onVote={handleVote}
197
- response={localPeerChoice}
198
- isQuiz={isQuiz}
199
- />
200
- )}
201
- </Box>
202
- );
203
- };
204
-
205
- const QuestionActions = ({ isValidVote, response, isQuiz, onVote, disableVote }) => {
206
- return (
207
- <Flex align="center" justify="end" css={{ gap: '$4', w: '100%' }}>
208
- {response ? (
209
- <Text css={{ fontWeight: '$semiBold', color: '$on_surface_medium' }}>
210
- {response.skipped ? 'Skipped' : null}
211
- {isQuiz && !response.skipped ? 'Answered' : null}
212
- {!isQuiz && !response.skipped ? 'Voted' : null}
213
- </Text>
214
- ) : (
215
- <Button css={{ p: '$xs $10', fontWeight: '$semiBold' }} disabled={!isValidVote || disableVote} onClick={onVote}>
216
- {isQuiz ? 'Answer' : 'Vote'}
217
- </Button>
218
- )}
219
- </Flex>
220
- );
221
- };
@@ -1,47 +0,0 @@
1
- import React, { Dispatch, SetStateAction } from 'react';
2
- import { HMSPoll } from '@100mslive/react-sdk';
3
- import { PeerParticipationSummary } from './PeerParticipationSummary';
4
- // @ts-ignore
5
- import { QuestionCard } from './QuestionCard';
6
-
7
- export const StandardView = ({
8
- poll,
9
- localPeerResponses,
10
- updateSavedResponses,
11
- }: {
12
- poll: HMSPoll;
13
- localPeerResponses: Record<number, number | number[] | undefined>;
14
- updateSavedResponses: Dispatch<SetStateAction<Record<any, any>>>;
15
- }) => {
16
- if (!poll?.questions) {
17
- return null;
18
- }
19
-
20
- const isQuiz = poll.type === 'quiz';
21
- const isStopped = poll.state === 'stopped';
22
-
23
- return (
24
- <>
25
- {isQuiz && isStopped ? <PeerParticipationSummary quiz={poll} /> : null}
26
- {poll.questions?.map((question, index) => (
27
- <QuestionCard
28
- pollID={poll.id}
29
- isQuiz={isQuiz}
30
- startedBy={poll.startedBy}
31
- pollState={poll.state}
32
- key={`${question.text}-${index}`}
33
- index={question.index}
34
- text={question.text}
35
- type={question.type}
36
- result={question.result}
37
- totalQuestions={poll.questions?.length || 0}
38
- options={question.options}
39
- localPeerResponse={localPeerResponses?.[question.index]}
40
- answer={question.answer}
41
- updateSavedResponses={updateSavedResponses}
42
- rolesThatCanViewResponses={poll.rolesThatCanViewResponses}
43
- />
44
- ))}
45
- </>
46
- );
47
- };
@@ -1,20 +0,0 @@
1
- import React from 'react';
2
- import { Box } from '../../../../Layout';
3
- import { Text } from '../../../../Text';
4
-
5
- export const StatisticBox = ({ title, value = 0 }: { title: string; value: string | number | undefined }) => {
6
- if (!value && !(typeof value === 'number')) {
7
- return <></>;
8
- }
9
- return (
10
- <Box css={{ p: '$8', background: '$surface_default', borderRadius: '$1', w: '100%' }}>
11
- <Text
12
- variant="tiny"
13
- css={{ textTransform: 'uppercase', color: '$on_surface_medium', fontWeight: '$semiBold', my: '$4' }}
14
- >
15
- {title}
16
- </Text>
17
- <Text css={{ fontWeight: '$semiBold' }}>{value}</Text>
18
- </Box>
19
- );
20
- };
@@ -1,55 +0,0 @@
1
- import React, { Dispatch, SetStateAction, useEffect, useState } from 'react';
2
- import { HMSPoll } from '@100mslive/react-sdk';
3
- // @ts-ignore
4
- import { QuestionCard } from './QuestionCard';
5
- // @ts-ignore
6
- import { getIndexToShow } from '../../../common/utils';
7
-
8
- export const TimedView = ({
9
- poll,
10
- localPeerResponses,
11
- updateSavedResponses,
12
- }: {
13
- poll: HMSPoll;
14
- localPeerResponses?: Record<number, number | number[] | undefined>;
15
- updateSavedResponses: Dispatch<SetStateAction<Record<any, any>>>;
16
- }) => {
17
- const [currentIndex, setCurrentIndex] = useState(getIndexToShow(localPeerResponses));
18
- const activeQuestion = poll.questions?.find(question => question.index === currentIndex);
19
- const attemptedAll = (poll.questions?.length || 0) < currentIndex;
20
-
21
- // Handles increments so only one question is shown at a time in quiz
22
- useEffect(() => {
23
- setCurrentIndex(getIndexToShow(localPeerResponses));
24
- }, [localPeerResponses]);
25
-
26
- if ((!activeQuestion && !attemptedAll) || !poll.questions?.length) {
27
- return null;
28
- }
29
-
30
- return (
31
- <>
32
- {poll.questions.map(question => {
33
- return attemptedAll || activeQuestion?.index === question.index ? (
34
- <QuestionCard
35
- key={question.index}
36
- pollID={poll.id}
37
- isQuiz={poll.type === 'quiz'}
38
- startedBy={poll.startedBy}
39
- pollState={poll.state}
40
- index={question.index}
41
- text={question.text}
42
- type={question.type}
43
- result={question?.result}
44
- totalQuestions={poll.questions?.length || 0}
45
- options={question.options}
46
- localPeerResponse={localPeerResponses?.[question.index]}
47
- answer={question.answer}
48
- rolesThatCanViewResponses={poll.rolesThatCanViewResponses}
49
- updateSavedResponses={updateSavedResponses}
50
- />
51
- ) : null;
52
- })}
53
- </>
54
- );
55
- };