@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,478 +0,0 @@
1
- import React, { Fragment, useCallback, useState } from 'react';
2
- import { useDebounce, useMedia } from 'react-use';
3
- import {
4
- HMSPeer,
5
- HMSPeerType,
6
- HMSRoleName,
7
- selectAvailableRoleNames,
8
- selectHandRaisedPeers,
9
- selectHasPeerHandRaised,
10
- selectIsLargeRoom,
11
- selectIsPeerAudioEnabled,
12
- selectLocalPeerID,
13
- selectPeerCount,
14
- selectPermissions,
15
- useHMSStore,
16
- } from '@100mslive/react-sdk';
17
- import {
18
- AddIcon,
19
- CallIcon,
20
- ChangeRoleIcon,
21
- CrossIcon,
22
- HandIcon,
23
- MicOffIcon,
24
- PeopleIcon,
25
- PersonSettingsIcon,
26
- SearchIcon,
27
- VerticalMenuIcon,
28
- } from '@100mslive/react-icons';
29
- import { Accordion, Box, Button, config as cssConfig, Dropdown, Flex, Input, Text, textEllipsis } from '../../..';
30
- // @ts-ignore: No implicit Any
31
- import IconButton from '../../IconButton';
32
- import { ConnectionIndicator } from '../Connection/ConnectionIndicator';
33
- import { RemoveParticipant } from '../RemoveParticipant';
34
- import { RoleChangeModal } from '../RoleChangeModal';
35
- import { RoleAccordion } from './RoleAccordion';
36
- import { useRoomLayoutConferencingScreen } from '../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
37
- // @ts-ignore: No implicit Any
38
- import { useIsSidepaneTypeOpen, useSidepaneToggle } from '../AppData/useSidepane';
39
- import { useSidepaneResetOnLayoutUpdate } from '../AppData/useSidepaneResetOnLayoutUpdate';
40
- import { usePeerOnStageActions } from '../hooks/usePeerOnStageActions';
41
- import { useParticipants } from '../../common/hooks';
42
- // @ts-ignore: No implicit Any
43
- import { getFormattedCount } from '../../common/utils';
44
- import { SIDE_PANE_OPTIONS } from '../../common/constants';
45
-
46
- export const ParticipantList = ({
47
- offStageRoles = [],
48
- onActive,
49
- }: {
50
- offStageRoles: HMSRoleName[];
51
- onActive: (role: string) => void;
52
- }) => {
53
- const [filter, setFilter] = useState<{ search?: string } | undefined>();
54
- const { participants, isConnected, peerCount } = useParticipants(filter);
55
- const isLargeRoom = useHMSStore(selectIsLargeRoom);
56
- const peersOrderedByRoles: Record<string, HMSPeer[]> = {};
57
-
58
- const handRaisedPeers = useHMSStore(selectHandRaisedPeers);
59
-
60
- participants.forEach(participant => {
61
- if (participant.roleName) {
62
- if (peersOrderedByRoles[participant.roleName] === undefined) {
63
- peersOrderedByRoles[participant.roleName] = [];
64
- }
65
- peersOrderedByRoles[participant.roleName].push(participant);
66
- }
67
- });
68
-
69
- // prefill off_stage roles of large rooms to load more peers
70
- if (isLargeRoom) {
71
- offStageRoles.forEach(role => {
72
- if (!peersOrderedByRoles[role]) {
73
- peersOrderedByRoles[role] = [];
74
- }
75
- });
76
- }
77
-
78
- useSidepaneResetOnLayoutUpdate('participant_list', SIDE_PANE_OPTIONS.PARTICIPANTS);
79
-
80
- const onSearch = useCallback((value: string) => {
81
- setFilter(filterValue => {
82
- if (!filterValue) {
83
- filterValue = {};
84
- }
85
- filterValue.search = value.toLowerCase();
86
- return { ...filterValue };
87
- });
88
- }, []);
89
-
90
- if (peerCount === 0) {
91
- return null;
92
- }
93
-
94
- return (
95
- <Fragment>
96
- <Flex
97
- direction="column"
98
- css={{
99
- size: '100%',
100
- gap: '$4',
101
- }}
102
- >
103
- {!filter?.search && participants.length === 0 ? null : <ParticipantSearch onSearch={onSearch} inSidePane />}
104
- <VirtualizedParticipants
105
- peersOrderedByRoles={peersOrderedByRoles}
106
- handRaisedList={handRaisedPeers}
107
- isConnected={!!isConnected}
108
- filter={filter}
109
- offStageRoles={offStageRoles}
110
- isLargeRoom={isLargeRoom}
111
- onActive={onActive}
112
- >
113
- {participants.length === 0 ? (
114
- <Flex
115
- align="center"
116
- justify="center"
117
- className="emptyParticipants"
118
- css={{ w: '100%', p: '$8 0', display: 'none' }}
119
- >
120
- <Text variant="sm">{!filter ? 'No participants' : 'No matching participants'}</Text>
121
- </Flex>
122
- ) : null}
123
- </VirtualizedParticipants>
124
- </Flex>
125
- </Fragment>
126
- );
127
- };
128
-
129
- export const ParticipantCount = () => {
130
- const peerCount = useHMSStore(selectPeerCount);
131
- const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
132
- const isPeerListOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
133
-
134
- if (peerCount === 0) {
135
- return null;
136
- }
137
- return (
138
- <IconButton
139
- css={{
140
- w: 'auto',
141
- p: '$4',
142
- h: 'auto',
143
- bg: isPeerListOpen ? '$surface_brighter' : '',
144
- }}
145
- onClick={() => {
146
- if (peerCount > 0) {
147
- toggleSidepane();
148
- }
149
- }}
150
- data-testid="participant_list"
151
- >
152
- <PeopleIcon />
153
- <Text variant="sm" css={{ mx: '$4', c: 'inherit' }}>
154
- {getFormattedCount(peerCount)}
155
- </Text>
156
- </IconButton>
157
- );
158
- };
159
-
160
- export const Participant = ({
161
- peer,
162
- isConnected,
163
- isHandRaisedAccordion,
164
- style,
165
- }: {
166
- peer: HMSPeer;
167
- isConnected: boolean;
168
- isHandRaisedAccordion?: boolean;
169
- style: React.CSSProperties;
170
- }) => {
171
- const localPeerId = useHMSStore(selectLocalPeerID);
172
- return (
173
- <Flex
174
- key={peer.id}
175
- css={{
176
- w: '100%',
177
- p: '$4 $8',
178
- pr: '$6',
179
- h: '$16',
180
- '&:hover .participant_item': { display: 'flex' },
181
- }}
182
- align="center"
183
- justify="between"
184
- data-testid={'participant_' + peer.name}
185
- style={style}
186
- >
187
- <Text
188
- variant="sm"
189
- css={{ ...textEllipsis('100%'), flex: '1 1 0', mr: '$8', fontWeight: '$semiBold', color: '$on_surface_high' }}
190
- >
191
- {peer.name} {localPeerId === peer.id ? '(You)' : ''}
192
- </Text>
193
- {isConnected && peer.roleName ? (
194
- <ParticipantActions
195
- peerId={peer.id}
196
- peerType={peer.type}
197
- role={peer.roleName}
198
- isHandRaisedAccordion={isHandRaisedAccordion}
199
- />
200
- ) : null}
201
- </Flex>
202
- );
203
- };
204
-
205
- const VirtualizedParticipants = ({
206
- peersOrderedByRoles = {},
207
- isConnected,
208
- filter,
209
- handRaisedList = [],
210
- offStageRoles,
211
- isLargeRoom,
212
- onActive,
213
- children,
214
- }: {
215
- peersOrderedByRoles: Record<string, HMSPeer[]>;
216
- isConnected: boolean;
217
- filter: undefined | { search?: string };
218
- handRaisedList: HMSPeer[];
219
- offStageRoles: HMSRoleName[];
220
- isLargeRoom: boolean;
221
- onActive: (role: string) => void;
222
- children: React.ReactNode;
223
- }) => {
224
- return (
225
- <Flex
226
- direction="column"
227
- css={{
228
- gap: '$8',
229
- overflowY: 'auto',
230
- overflowX: 'hidden',
231
- pr: '$10',
232
- mr: '-$10',
233
- flex: '1 1 0',
234
- '& > div:empty ~ .emptyParticipants': {
235
- display: 'flex',
236
- },
237
- }}
238
- >
239
- <Accordion.Root type={isLargeRoom ? 'single' : 'multiple'} collapsible>
240
- {handRaisedList.length > 0 ? (
241
- <RoleAccordion
242
- peerList={handRaisedList}
243
- roleName="Hand Raised"
244
- filter={filter}
245
- isConnected={isConnected}
246
- isHandRaisedAccordion
247
- offStageRoles={offStageRoles}
248
- />
249
- ) : null}
250
- {Object.keys(peersOrderedByRoles).map(role => (
251
- <RoleAccordion
252
- key={role}
253
- peerList={peersOrderedByRoles[role]}
254
- roleName={role}
255
- isConnected={isConnected}
256
- filter={filter}
257
- offStageRoles={offStageRoles}
258
- onActive={onActive}
259
- />
260
- ))}
261
- </Accordion.Root>
262
- {children}
263
- </Flex>
264
- );
265
- };
266
-
267
- /**
268
- * shows settings to change for a participant like changing their role
269
- */
270
- const ParticipantActions = React.memo(
271
- ({
272
- peerId,
273
- peerType,
274
- role,
275
- isHandRaisedAccordion,
276
- }: {
277
- peerId: string;
278
- role: string;
279
- isHandRaisedAccordion?: boolean;
280
- peerType: HMSPeerType;
281
- }) => {
282
- const isHandRaised = useHMSStore(selectHasPeerHandRaised(peerId));
283
- const canChangeRole = useHMSStore(selectPermissions)?.changeRole;
284
- const canRemoveOthers = useHMSStore(selectPermissions)?.removeOthers;
285
- const { elements } = useRoomLayoutConferencingScreen();
286
- const { on_stage_exp } = elements || {};
287
- const shouldShowMoreActions = (on_stage_exp && canChangeRole) || canRemoveOthers;
288
- const isAudioMuted = !useHMSStore(selectIsPeerAudioEnabled(peerId));
289
-
290
- return (
291
- <Flex
292
- align="center"
293
- css={{
294
- flexShrink: 0,
295
- gap: '$8',
296
- }}
297
- >
298
- {isHandRaisedAccordion ? (
299
- <HandRaisedAccordionParticipantActions peerId={peerId} role={role} />
300
- ) : (
301
- <>
302
- <ConnectionIndicator peerId={peerId} />
303
- {peerType === HMSPeerType.SIP && (
304
- <Flex
305
- align="center"
306
- justify="center"
307
- css={{ p: '$1', c: '$on_surface_high', bg: '$surface_bright', borderRadius: '$round' }}
308
- >
309
- <CallIcon width={19} height={19} />
310
- </Flex>
311
- )}
312
- {isHandRaised && (
313
- <Flex
314
- align="center"
315
- justify="center"
316
- css={{ p: '$1', c: '$on_surface_high', bg: '$surface_bright', borderRadius: '$round' }}
317
- >
318
- <HandIcon height={19} width={19} />
319
- </Flex>
320
- )}
321
- {isAudioMuted ? (
322
- <Flex
323
- align="center"
324
- justify="center"
325
- css={{ p: '$2', c: '$on_surface_high', bg: '$surface_bright', borderRadius: '$round' }}
326
- >
327
- <MicOffIcon height={19} width={19} />
328
- </Flex>
329
- ) : null}
330
-
331
- {shouldShowMoreActions ? <ParticipantMoreActions peerId={peerId} role={role} /> : null}
332
- </>
333
- )}
334
- </Flex>
335
- );
336
- },
337
- );
338
-
339
- const quickActionStyle = { p: '$1', borderRadius: '$round' };
340
- const HandRaisedAccordionParticipantActions = ({ peerId, role }: { peerId: string; role: string }) => {
341
- const { handleStageAction, lowerPeerHand, shouldShowStageRoleChange, isInStage } = usePeerOnStageActions({
342
- peerId,
343
- role,
344
- });
345
- if (!shouldShowStageRoleChange) {
346
- return null;
347
- }
348
- return (
349
- <>
350
- <Button variant="standard" css={quickActionStyle} onClick={lowerPeerHand}>
351
- <CrossIcon height={18} width={18} />
352
- </Button>
353
- {!isInStage && (
354
- <Button variant="primary" onClick={handleStageAction} css={quickActionStyle}>
355
- <AddIcon height={18} width={18} />
356
- </Button>
357
- )}
358
- </>
359
- );
360
- };
361
-
362
- const ParticipantMoreActions = ({ peerId, role }: { peerId: string; role: string }) => {
363
- const {
364
- open,
365
- setOpen,
366
- bring_to_stage_label,
367
- remove_from_stage_label,
368
- handleStageAction,
369
- isInStage,
370
- shouldShowStageRoleChange,
371
- } = usePeerOnStageActions({ peerId, role });
372
- const canChangeRole = !!useHMSStore(selectPermissions)?.changeRole;
373
- const [openRoleChangeModal, setOpenRoleChangeModal] = useState(false);
374
- const roles = useHMSStore(selectAvailableRoleNames);
375
-
376
- return (
377
- <>
378
- <Dropdown.Root open={open} onOpenChange={value => setOpen(value)} modal={false}>
379
- <Dropdown.Trigger
380
- asChild
381
- data-testid="participant_more_actions"
382
- className="participant_item"
383
- css={{
384
- p: '$1',
385
- r: '$0',
386
- c: '$on_surface_high',
387
- display: open ? 'flex' : 'none',
388
- '&:hover': {
389
- bg: '$surface_bright',
390
- },
391
- '@md': {
392
- display: 'flex',
393
- },
394
- }}
395
- tabIndex={0}
396
- >
397
- <Box css={{ my: 'auto' }}>
398
- <VerticalMenuIcon />
399
- </Box>
400
- </Dropdown.Trigger>
401
- <Dropdown.Portal>
402
- <Dropdown.Content align="end" sideOffset={8} css={{ w: '$64', bg: '$surface_default' }}>
403
- {shouldShowStageRoleChange ? (
404
- <Dropdown.Item css={{ bg: '$surface_default' }} onClick={() => handleStageAction()}>
405
- <ChangeRoleIcon />
406
- <Text variant="sm" css={{ ml: '$4', fontWeight: '$semiBold', c: '$on_surface_high' }}>
407
- {isInStage ? remove_from_stage_label : bring_to_stage_label}
408
- </Text>
409
- </Dropdown.Item>
410
- ) : null}
411
-
412
- {canChangeRole && roles.length > 1 ? (
413
- <Dropdown.Item css={{ bg: '$surface_default' }} onClick={() => setOpenRoleChangeModal(true)}>
414
- <PersonSettingsIcon />
415
- <Text variant="sm" css={{ ml: '$4', fontWeight: '$semiBold', c: '$on_surface_high' }}>
416
- Switch Role
417
- </Text>
418
- </Dropdown.Item>
419
- ) : null}
420
- <RemoveParticipant peerId={peerId} />
421
- </Dropdown.Content>
422
- </Dropdown.Portal>
423
- </Dropdown.Root>
424
- {openRoleChangeModal && <RoleChangeModal peerId={peerId} onOpenChange={setOpenRoleChangeModal} />}
425
- </>
426
- );
427
- };
428
-
429
- export const ParticipantSearch = ({
430
- onSearch,
431
- placeholder = 'Search for participants',
432
- inSidePane = false,
433
- }: {
434
- inSidePane?: boolean;
435
- placeholder?: string;
436
- onSearch: (val: string) => void;
437
- }) => {
438
- const [value, setValue] = React.useState('');
439
- const isMobile = useMedia(cssConfig.media.md);
440
-
441
- useDebounce(
442
- () => {
443
- onSearch(value);
444
- },
445
- 300,
446
- [value, onSearch],
447
- );
448
-
449
- return (
450
- <Flex
451
- align="center"
452
- css={{
453
- p: isMobile ? '0' : '$2 0',
454
- mb: '$2',
455
- position: 'relative',
456
- color: '$on_surface_medium',
457
- mt: inSidePane ? '$4' : '',
458
- }}
459
- onClick={e => e.stopPropagation()}
460
- >
461
- <SearchIcon style={{ position: 'absolute', left: '0.5rem' }} />
462
- <Input
463
- type="text"
464
- placeholder={placeholder}
465
- css={{ w: '100%', p: '$6', pl: '$14', bg: inSidePane ? '$surface_default' : '$surface_dim' }}
466
- value={value}
467
- onKeyDown={event => {
468
- event.stopPropagation();
469
- }}
470
- onChange={event => {
471
- setValue(event.currentTarget.value);
472
- }}
473
- autoComplete="off"
474
- aria-autocomplete="none"
475
- />
476
- </Flex>
477
- );
478
- };
@@ -1,37 +0,0 @@
1
- import React, { useEffect } from 'react';
2
- import { QuizActiveIcon, QuizIcon } from '@100mslive/react-icons';
3
- import { Tooltip } from '../../..';
4
- // @ts-ignore: No implicit Any
5
- import IconButton from '../../IconButton';
6
- // @ts-ignore: No implicit Any
7
- import { useIsSidepaneTypeOpen, usePollViewToggle } from '../AppData/useSidepane';
8
- import { useUnreadPollQuizPresent } from '../hooks/useUnreadPollQuizPresent';
9
- // @ts-ignore: No implicit Any
10
- import { SIDE_PANE_OPTIONS } from '../../common/constants';
11
-
12
- export const PollsToggle = () => {
13
- const isPollsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.POLLS);
14
- const togglePollView = usePollViewToggle();
15
- const { unreadPollQuiz, setUnreadPollQuiz } = useUnreadPollQuizPresent();
16
-
17
- useEffect(() => {
18
- if (unreadPollQuiz && isPollsOpen) {
19
- setUnreadPollQuiz(false);
20
- }
21
- }, [isPollsOpen, unreadPollQuiz, setUnreadPollQuiz]);
22
-
23
- return (
24
- <Tooltip key="polls" title={`${isPollsOpen ? 'Close' : 'Open'} polls and quizzes`}>
25
- <IconButton
26
- onClick={() => {
27
- togglePollView();
28
- setUnreadPollQuiz(false);
29
- }}
30
- css={{ bg: isPollsOpen ? '$surface_brighter' : '' }}
31
- data-testid="polls_btn"
32
- >
33
- {unreadPollQuiz ? <QuizActiveIcon /> : <QuizIcon />}
34
- </IconButton>
35
- </Tooltip>
36
- );
37
- };
@@ -1,183 +0,0 @@
1
- import React, { useEffect } from 'react';
2
- import { useMeasure } from 'react-use';
3
- import { FixedSizeList } from 'react-window';
4
- import { HMSPeer, selectIsLargeRoom, useHMSStore, usePaginatedParticipants } from '@100mslive/react-sdk';
5
- import { AddIcon, ChevronRightIcon, CrossIcon } from '@100mslive/react-icons';
6
- import { Accordion } from '../../../Accordion';
7
- import { Button } from '../../../Button';
8
- import { HorizontalDivider } from '../../../Divider';
9
- import { Flex } from '../../../Layout';
10
- import { Text } from '../../../Text';
11
- import { Participant } from './ParticipantList';
12
- import { RoleOptions } from './RoleOptions';
13
- import { useGroupOnStageActions } from '../hooks/useGroupOnStageActions';
14
- // @ts-ignore: No implicit Any
15
- import { getFormattedCount } from '../../common/utils';
16
-
17
- export const ROW_HEIGHT = 50;
18
- const ITER_TIMER = 5000;
19
-
20
- export interface ItemData {
21
- peerList: HMSPeer[];
22
- isHandRaisedAccordion?: boolean;
23
- isConnected: boolean;
24
- }
25
-
26
- export function itemKey(index: number, data: ItemData) {
27
- return data.peerList[index]?.id;
28
- }
29
-
30
- export const VirtualizedParticipantItem = React.memo(
31
- ({ index, data, style }: { index: number; data: ItemData; style: React.CSSProperties }) => {
32
- return (
33
- <Participant
34
- key={data.peerList[index].id}
35
- peer={data.peerList[index]}
36
- isHandRaisedAccordion={data.isHandRaisedAccordion}
37
- isConnected={data.isConnected}
38
- style={style}
39
- />
40
- );
41
- },
42
- );
43
-
44
- export const RoleAccordion = ({
45
- peerList = [],
46
- roleName,
47
- isConnected,
48
- filter,
49
- isHandRaisedAccordion = false,
50
- offStageRoles,
51
- onActive,
52
- }: ItemData & {
53
- roleName: string;
54
- isHandRaisedAccordion?: boolean;
55
- filter?: { search?: string };
56
- offStageRoles: string[];
57
- onActive?: (role: string) => void;
58
- }) => {
59
- const [ref, { width }] = useMeasure<HTMLDivElement>();
60
- const isLargeRoom = useHMSStore(selectIsLargeRoom);
61
- const { peers, total, loadPeers } = usePaginatedParticipants({ role: roleName, limit: 10 });
62
- const isOffStageRole = roleName && offStageRoles.includes(roleName);
63
- let peersInAccordion = peerList;
64
- // for large rooms, peer list would be empty
65
- if (isOffStageRole && isLargeRoom) {
66
- peersInAccordion = peers;
67
- if (filter?.search) {
68
- peersInAccordion = peersInAccordion.filter(peer => peer.name.toLowerCase().includes(filter.search || ''));
69
- }
70
- }
71
- const { bringAllToStage, bring_to_stage_label, canBringToStage, lowerAllHands } = useGroupOnStageActions({
72
- peers: peersInAccordion,
73
- });
74
-
75
- useEffect(() => {
76
- if (!isOffStageRole || !isLargeRoom) {
77
- return;
78
- }
79
- loadPeers();
80
- const interval = setInterval(() => {
81
- loadPeers();
82
- }, ITER_TIMER);
83
- return () => clearInterval(interval);
84
- }, [isOffStageRole, isLargeRoom]); //eslint-disable-line
85
-
86
- if (peersInAccordion.length === 0 || (isHandRaisedAccordion && filter?.search)) {
87
- return null;
88
- }
89
-
90
- const height = ROW_HEIGHT * peersInAccordion.length;
91
- const hasNext = total > peersInAccordion.length && !filter?.search;
92
-
93
- return (
94
- <Accordion.Item value={roleName} css={{ '&:hover .role_actions': { visibility: 'visible' }, mb: '$8' }} ref={ref}>
95
- <Accordion.Header
96
- chevronID={`role_accordion_btn_${roleName}`}
97
- iconStyles={{ c: '$on_surface_high' }}
98
- css={{
99
- textTransform: 'capitalize',
100
- p: '$6 $8',
101
- fontSize: '$sm',
102
- fontWeight: '$semiBold',
103
- c: '$on_surface_medium',
104
- borderRadius: '$1',
105
- border: '1px solid $border_default',
106
- '&[data-state="open"]': {
107
- borderBottomLeftRadius: 0,
108
- borderBottomRightRadius: 0,
109
- },
110
- }}
111
- >
112
- <Flex justify="between" align="center" css={{ flexGrow: 1, pr: '$6' }}>
113
- <Text
114
- variant="sm"
115
- css={{ fontWeight: '$semiBold', textTransform: 'capitalize', color: '$on_surface_medium' }}
116
- >
117
- {roleName} {`(${getFormattedCount(isLargeRoom && isOffStageRole ? total : peerList.length)})`}
118
- </Text>
119
- <RoleOptions roleName={roleName} peerList={peersInAccordion} />
120
- </Flex>
121
- </Accordion.Header>
122
- <Accordion.Content contentStyles={{ border: '1px solid $border_default', borderTop: 'none' }}>
123
- <FixedSizeList
124
- itemSize={ROW_HEIGHT}
125
- itemData={{
126
- peerList: isHandRaisedAccordion
127
- ? peersInAccordion.sort((a, b) => {
128
- try {
129
- const aHandRaisedAt = JSON.parse(a.metadata || '{}').handRaisedAt;
130
- const bHandRaisedAt = JSON.parse(b.metadata || '{}').handRaisedAt;
131
- return aHandRaisedAt - bHandRaisedAt;
132
- } catch (err) {
133
- return 0;
134
- }
135
- })
136
- : peersInAccordion,
137
- isConnected,
138
- isHandRaisedAccordion,
139
- }}
140
- itemKey={itemKey}
141
- itemCount={peersInAccordion.length}
142
- width={width}
143
- height={height}
144
- >
145
- {VirtualizedParticipantItem}
146
- </FixedSizeList>
147
- {offStageRoles?.includes(roleName) && hasNext ? (
148
- <Flex
149
- align="center"
150
- justify="end"
151
- css={{
152
- gap: '$1',
153
- cursor: 'pointer',
154
- color: '$on_surface_high',
155
- p: '$6',
156
- borderTop: '1px solid $border_default',
157
- }}
158
- onClick={() => onActive?.(roleName)}
159
- >
160
- <Text variant="sm" css={{ color: 'inherit' }}>
161
- View All
162
- </Text>
163
- <ChevronRightIcon />
164
- </Flex>
165
- ) : null}
166
- {isHandRaisedAccordion && canBringToStage && (
167
- <>
168
- <HorizontalDivider />
169
- <Flex css={{ w: '100%', p: '$6', gap: '$4' }} justify="center">
170
- <Button variant="standard" onClick={lowerAllHands} icon css={{ pl: '$2' }}>
171
- <CrossIcon /> Lower all hands
172
- </Button>
173
-
174
- <Button onClick={bringAllToStage} icon css={{ pl: '$2' }}>
175
- <AddIcon /> {bring_to_stage_label}
176
- </Button>
177
- </Flex>
178
- </>
179
- )}
180
- </Accordion.Content>
181
- </Accordion.Item>
182
- );
183
- };