@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,393 +0,0 @@
1
- import React, { Fragment } from 'react';
2
- import { useMedia } from 'react-use';
3
- import {
4
- HMSException,
5
- HMSSimulcastLayerDefinition,
6
- HMSTrackID,
7
- HMSVideoTrack,
8
- selectAvailableRoleNames,
9
- selectPermissions,
10
- selectSessionStore,
11
- selectTrackByID,
12
- useCustomEvent,
13
- useHMSActions,
14
- useHMSStore,
15
- useRemoteAVToggle,
16
- } from '@100mslive/react-sdk';
17
- import {
18
- MicOffIcon,
19
- MicOnIcon,
20
- PencilIcon,
21
- PersonSettingsIcon,
22
- PinIcon,
23
- RemoveUserIcon,
24
- ShareScreenIcon,
25
- ShrinkIcon,
26
- SpeakerIcon,
27
- StarIcon,
28
- VideoOffIcon,
29
- VideoOnIcon,
30
- } from '@100mslive/react-icons';
31
- import { Box, Flex } from '../../../Layout';
32
- import { Slider } from '../../../Slider';
33
- import { Text } from '../../../Text';
34
- import { config as cssConfig } from '../../../Theme';
35
- import { StyledMenuTile } from '../../../TileMenu';
36
- import { useHMSPrebuiltContext } from '../../AppContext';
37
- // @ts-ignore
38
- import { ToastManager } from '../Toast/ToastManager';
39
- // @ts-ignore
40
- import { useSetAppDataByKey } from '../AppData/useUISettings';
41
- // @ts-ignore
42
- import { useDropdownSelection } from '../hooks/useDropdownSelection';
43
- import { getDragClassName } from './utils';
44
- import { APP_DATA, isIOS, REMOTE_STOP_SCREENSHARE_TYPE, SESSION_STORE_KEY } from '../../common/constants';
45
-
46
- export const isSameTile = ({
47
- trackId,
48
- videoTrackID,
49
- audioTrackID,
50
- }: {
51
- trackId: HMSTrackID;
52
- videoTrackID?: string;
53
- audioTrackID?: string;
54
- }) => !!trackId && ((!!videoTrackID && videoTrackID === trackId) || (!!audioTrackID && audioTrackID === trackId));
55
-
56
- const spacingCSS = { '@md': { my: '$8', fontWeight: '$semiBold', fontSize: 'sm' } };
57
-
58
- const SpotlightActions = ({
59
- peerId,
60
- onSpotLightClick = () => {
61
- return;
62
- },
63
- }: {
64
- peerId: string;
65
- onSpotLightClick: () => void;
66
- }) => {
67
- const hmsActions = useHMSActions();
68
- const spotlightPeerId = useHMSStore(selectSessionStore(SESSION_STORE_KEY.SPOTLIGHT));
69
- const isTileSpotlighted = spotlightPeerId === peerId;
70
- const dragClassName = getDragClassName();
71
-
72
- const setSpotlightPeerId = (peerIdToSpotlight?: string) =>
73
- hmsActions.sessionStore
74
- .set(SESSION_STORE_KEY.SPOTLIGHT, peerIdToSpotlight)
75
- .catch((err: HMSException) => ToastManager.addToast({ title: err.description }));
76
-
77
- return (
78
- <StyledMenuTile.ItemButton
79
- className={dragClassName}
80
- css={spacingCSS}
81
- onClick={() => {
82
- if (isTileSpotlighted) {
83
- setSpotlightPeerId();
84
- } else {
85
- setSpotlightPeerId(peerId);
86
- }
87
- onSpotLightClick();
88
- }}
89
- >
90
- <StarIcon height={20} width={20} />
91
- <span>{isTileSpotlighted ? 'Remove from Spotlight' : 'Spotlight Tile for everyone'}</span>
92
- </StyledMenuTile.ItemButton>
93
- );
94
- };
95
-
96
- const PinActions = ({ audioTrackID, videoTrackID }: { videoTrackID: string; audioTrackID: string }) => {
97
- const [pinnedTrackId, setPinnedTrackId] = useSetAppDataByKey(APP_DATA.pinnedTrackId);
98
- const dragClassName = getDragClassName();
99
-
100
- const isTilePinned = isSameTile({
101
- trackId: pinnedTrackId,
102
- videoTrackID,
103
- audioTrackID,
104
- });
105
-
106
- return (
107
- <>
108
- <StyledMenuTile.ItemButton
109
- className={dragClassName}
110
- css={spacingCSS}
111
- onClick={() => (isTilePinned ? setPinnedTrackId() : setPinnedTrackId(videoTrackID || audioTrackID))}
112
- >
113
- <PinIcon height={20} width={20} />
114
- <span>{isTilePinned ? 'Unpin' : 'Pin'} Tile for myself</span>
115
- </StyledMenuTile.ItemButton>
116
- </>
117
- );
118
- };
119
-
120
- const MinimiseInset = () => {
121
- const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
122
- const dragClassName = getDragClassName();
123
-
124
- return (
125
- <>
126
- <StyledMenuTile.ItemButton className={dragClassName} css={spacingCSS} onClick={() => setMinimised(!minimised)}>
127
- <ShrinkIcon height={20} width={20} />
128
- <span>{minimised ? 'Show' : 'Minimise'} your video</span>
129
- </StyledMenuTile.ItemButton>
130
- </>
131
- );
132
- };
133
-
134
- const SimulcastLayers = ({ trackId }: { trackId: HMSTrackID }) => {
135
- const track: HMSVideoTrack = useHMSStore(selectTrackByID(trackId)) as HMSVideoTrack;
136
- const actions = useHMSActions();
137
- const bg = useDropdownSelection();
138
- if (!track?.layerDefinitions?.length || track.degraded || !track.enabled) {
139
- return null;
140
- }
141
- const currentLayer = track.layerDefinitions.find((layer: HMSSimulcastLayerDefinition) => layer.layer === track.layer);
142
- const dragClassName = getDragClassName();
143
- return (
144
- <Fragment>
145
- <StyledMenuTile.ItemButton className={dragClassName} css={{ color: '$on_surface_medium', cursor: 'default' }}>
146
- Select maximum resolution
147
- </StyledMenuTile.ItemButton>
148
- {track.layerDefinitions.map((layer: HMSSimulcastLayerDefinition) => {
149
- return (
150
- <StyledMenuTile.ItemButton
151
- className={dragClassName}
152
- key={layer.layer}
153
- onClick={async () => {
154
- await actions.setPreferredLayer(trackId, layer.layer);
155
- }}
156
- css={{
157
- justifyContent: 'space-between',
158
- bg: track.preferredLayer === layer.layer ? bg : undefined,
159
- '&:hover': {
160
- bg: track.preferredLayer === layer.layer ? bg : undefined,
161
- },
162
- }}
163
- >
164
- <Text
165
- as="span"
166
- css={{
167
- textTransform: 'capitalize',
168
- mr: '$2',
169
- fontWeight: track.preferredLayer === layer.layer ? '$semiBold' : '$regular',
170
- color: track.preferredLayer === layer.layer ? '$on_primary_high' : '$on_surface_high',
171
- }}
172
- >
173
- {layer.layer}
174
- </Text>
175
- <Text
176
- as="span"
177
- variant="xs"
178
- css={{
179
- color: track.preferredLayer === layer.layer ? '$on_primary_high' : '$on_surface_high',
180
- }}
181
- >
182
- {layer.resolution.width}x{layer.resolution.height}
183
- </Text>
184
- </StyledMenuTile.ItemButton>
185
- );
186
- })}
187
- <StyledMenuTile.ItemButton className={dragClassName}>
188
- <Text as="span" variant="xs" css={{ color: '$on_surface_medium' }}>
189
- Currently streaming:
190
- <Text
191
- as="span"
192
- variant="xs"
193
- css={{
194
- fontWeight: '$semiBold',
195
- textTransform: 'capitalize',
196
- color: '$on_surface_medium',
197
- ml: '$2',
198
- }}
199
- >
200
- {currentLayer ? (
201
- <>
202
- {track.layer} ({currentLayer.resolution.width}x{currentLayer.resolution.height})
203
- </>
204
- ) : (
205
- '-'
206
- )}
207
- </Text>
208
- </Text>
209
- </StyledMenuTile.ItemButton>
210
- </Fragment>
211
- );
212
- };
213
-
214
- export const TileMenuContent = ({
215
- videoTrackID,
216
- audioTrackID,
217
- isLocal,
218
- isScreenshare,
219
- showSpotlight,
220
- showPinAction,
221
- peerID,
222
- canMinimise,
223
- closeSheetOnClick = () => {
224
- return;
225
- },
226
- openNameChangeModal = () => {
227
- return;
228
- },
229
- openRoleChangeModal = () => {
230
- return;
231
- },
232
- }: {
233
- videoTrackID: string;
234
- audioTrackID: string;
235
- isLocal: boolean;
236
- isScreenshare: boolean;
237
- showSpotlight: boolean;
238
- showPinAction: boolean;
239
- peerID: string;
240
- canMinimise?: boolean;
241
- closeSheetOnClick?: () => void;
242
- openNameChangeModal?: () => void;
243
- openRoleChangeModal?: () => void;
244
- }) => {
245
- const actions = useHMSActions();
246
- const dragClassName = getDragClassName();
247
- const permissions = useHMSStore(selectPermissions);
248
- const canChangeRole = !!permissions?.changeRole;
249
- const removeOthers = !!permissions?.removeOthers;
250
- const { userName } = useHMSPrebuiltContext();
251
- const roles = useHMSStore(selectAvailableRoleNames);
252
-
253
- const { isAudioEnabled, isVideoEnabled, setVolume, toggleAudio, toggleVideo, volume } = useRemoteAVToggle(
254
- audioTrackID,
255
- videoTrackID,
256
- );
257
-
258
- const { sendEvent } = useCustomEvent({
259
- type: REMOTE_STOP_SCREENSHARE_TYPE,
260
- });
261
-
262
- const isMobile = useMedia(cssConfig.media.md);
263
-
264
- if (isLocal) {
265
- return showPinAction || canMinimise || !userName || showSpotlight ? (
266
- <>
267
- {showPinAction && <PinActions audioTrackID={audioTrackID} videoTrackID={videoTrackID} />}
268
- {showSpotlight && <SpotlightActions peerId={peerID} onSpotLightClick={() => closeSheetOnClick()} />}
269
- {canMinimise && <MinimiseInset />}
270
- {!userName && (
271
- <StyledMenuTile.ItemButton
272
- className={dragClassName}
273
- onClick={() => {
274
- openNameChangeModal();
275
- closeSheetOnClick();
276
- }}
277
- >
278
- <PencilIcon height={20} width={20} />
279
- <Text variant="sm" css={{ '@md': { fontWeight: '$semiBold' }, c: '$on_surface_high' }}>
280
- Change Name
281
- </Text>
282
- </StyledMenuTile.ItemButton>
283
- )}
284
- </>
285
- ) : null;
286
- }
287
-
288
- return (
289
- <>
290
- {toggleVideo ? (
291
- <StyledMenuTile.ItemButton
292
- className={dragClassName}
293
- css={spacingCSS}
294
- onClick={() => {
295
- toggleVideo();
296
- closeSheetOnClick();
297
- }}
298
- data-testid={isVideoEnabled ? 'mute_video_participant_btn' : 'unmute_video_participant_btn'}
299
- >
300
- {isVideoEnabled ? <VideoOnIcon height={20} width={20} /> : <VideoOffIcon height={20} width={20} />}
301
- <span>{isVideoEnabled ? 'Mute Video' : 'Request to Unmute Video'}</span>
302
- </StyledMenuTile.ItemButton>
303
- ) : null}
304
-
305
- {toggleAudio ? (
306
- <StyledMenuTile.ItemButton
307
- css={spacingCSS}
308
- className={dragClassName}
309
- onClick={() => {
310
- toggleAudio();
311
- closeSheetOnClick();
312
- }}
313
- data-testid={isAudioEnabled ? 'mute_audio_participant_btn' : 'unmute_audio_participant_btn'}
314
- >
315
- {isAudioEnabled ? <MicOnIcon height={20} width={20} /> : <MicOffIcon height={20} width={20} />}
316
- <span>{isAudioEnabled ? 'Mute Audio' : 'Request to Unmute Audio'}</span>
317
- </StyledMenuTile.ItemButton>
318
- ) : null}
319
-
320
- {!isScreenshare && canChangeRole && roles.length > 1 ? (
321
- <StyledMenuTile.ItemButton
322
- className={dragClassName}
323
- css={spacingCSS}
324
- onClick={() => {
325
- openRoleChangeModal();
326
- closeSheetOnClick();
327
- }}
328
- data-testid="change_role_btn"
329
- >
330
- <PersonSettingsIcon height={20} width={20} />
331
- <span>Switch Role</span>
332
- </StyledMenuTile.ItemButton>
333
- ) : null}
334
-
335
- {!isIOS && audioTrackID ? (
336
- <StyledMenuTile.VolumeItem data-testid="participant_volume_slider" css={{ ...spacingCSS, mb: '$0' }}>
337
- <Flex align="center" gap={1}>
338
- <SpeakerIcon height={20} width={20} />
339
- <Box as="span" css={{ ml: '$4' }}>
340
- Volume ({volume})
341
- </Box>
342
- </Flex>
343
- <Slider
344
- css={{ my: '0.5rem' }}
345
- step={5}
346
- value={[typeof volume === 'number' ? volume : 100]}
347
- onValueChange={e => setVolume?.(e[0])}
348
- />
349
- </StyledMenuTile.VolumeItem>
350
- ) : null}
351
-
352
- {showPinAction && (
353
- <>
354
- <PinActions audioTrackID={audioTrackID} videoTrackID={videoTrackID} />
355
- {showSpotlight && <SpotlightActions peerId={peerID} onSpotLightClick={() => closeSheetOnClick()} />}
356
- </>
357
- )}
358
-
359
- {isMobile ? null : <SimulcastLayers trackId={videoTrackID} />}
360
-
361
- {removeOthers ? (
362
- <StyledMenuTile.RemoveItem
363
- css={{ ...spacingCSS, borderTop: 'none' }}
364
- onClick={async () => {
365
- try {
366
- await actions.removePeer(peerID, '');
367
- } catch (error) {
368
- // TODO: Toast here
369
- }
370
- closeSheetOnClick();
371
- }}
372
- data-testid="remove_participant_btn"
373
- >
374
- <RemoveUserIcon height={20} width={20} />
375
- <span>Remove Participant</span>
376
- </StyledMenuTile.RemoveItem>
377
- ) : null}
378
-
379
- {removeOthers && isScreenshare ? (
380
- <StyledMenuTile.RemoveItem
381
- onClick={() => {
382
- sendEvent({});
383
- closeSheetOnClick();
384
- }}
385
- css={spacingCSS}
386
- >
387
- <ShareScreenIcon height={20} width={20} />
388
- <span>Stop Screenshare</span>
389
- </StyledMenuTile.RemoveItem>
390
- ) : null}
391
- </>
392
- );
393
- };
@@ -1,7 +0,0 @@
1
- /**
2
- * Add __cancel-drag-event for the menu to open on touch devices on the draggdable element
3
- *
4
- */
5
- export const getDragClassName = () => {
6
- return navigator?.maxTouchPoints > 0 ? '__cancel-drag-event' : '';
7
- };
@@ -1,17 +0,0 @@
1
- import React from 'react';
2
- import { Toast as ToastPrimitive } from '../../../Toast';
3
-
4
- export const Toast = ({ title, description, close = true, open, duration, onOpenChange, icon, ...props }) => {
5
- return (
6
- <ToastPrimitive.HMSToast
7
- title={title}
8
- description={description}
9
- open={open}
10
- isClosable={close}
11
- onOpenChange={onOpenChange}
12
- duration={!close ? 600000 : duration}
13
- icon={icon}
14
- {...props}
15
- />
16
- );
17
- };
@@ -1,64 +0,0 @@
1
- import { ToastConfig } from './ToastConfig';
2
- import { ToastManager } from './ToastManager';
3
-
4
- export const ToastBatcher = {
5
- toastsType: new Map(),
6
- toastCache: {},
7
- showToastInternal({ notification, duration, type }) {
8
- let notificationType = type;
9
- if (!type) {
10
- notificationType = notification.type;
11
- }
12
- const toastType = this.toastsType.has(notificationType);
13
- if (toastType) {
14
- let { notifications } = this.toastsType.get(notificationType);
15
- const { id } = this.toastsType.get(notificationType);
16
- notifications.push(notification);
17
- const toastObject = ToastConfig[notificationType].multiple(notifications);
18
- const toastId = ToastManager.replaceToast(id, {
19
- ...toastObject,
20
- duration: duration,
21
- });
22
- this.toastsType.set(notificationType, {
23
- id: toastId,
24
- notifications: notifications,
25
- duration: duration,
26
- });
27
- } else {
28
- const toastObject = ToastConfig[notificationType].single(notification);
29
- const toastId = ToastManager.addToast({
30
- ...toastObject,
31
- duration: duration,
32
- });
33
- let notifications = [];
34
- notifications.push(notification);
35
- this.toastsType.set(notificationType, {
36
- id: toastId,
37
- notifications: [...notifications],
38
- duration: duration,
39
- });
40
- }
41
- },
42
- showToast({ notification, duration = 3000, type }) {
43
- try {
44
- if (!this.toastCache[notification.id]) {
45
- this.showToastInternal({ notification, duration, type });
46
- }
47
- this.toastCache[notification.id] = true;
48
- if (Object.keys(this.toastCache).length > 100) {
49
- this.toastCache = {};
50
- }
51
- } catch (err) {
52
- console.debug('Notifications', err);
53
- }
54
- },
55
- syncUItoast(toastsDisplaying) {
56
- for (const [toastType, toastInfo] of this.toastsType.entries()) {
57
- if (!toastsDisplaying.find(toast => toast.id === toastInfo.id)) {
58
- this.toastsType.delete(toastType);
59
- }
60
- }
61
- },
62
- };
63
-
64
- ToastManager.addListener(ToastBatcher.syncUItoast.bind(ToastBatcher));
@@ -1,177 +0,0 @@
1
- import React, { useCallback } from 'react';
2
- import { selectPeerByID, useHMSActions, useHMSStore } from '@100mslive/react-sdk';
3
- import {
4
- ChatUnreadIcon,
5
- ConnectivityIcon,
6
- HandIcon,
7
- PeopleAddIcon,
8
- PeopleRemoveIcon,
9
- PoorConnectivityIcon,
10
- } from '@100mslive/react-icons';
11
- import { Button } from '../../../Button';
12
- import { useRoomLayout } from '../../provider/roomLayoutProvider';
13
- import { useIsSidepaneTypeOpen, useSidepaneToggle } from '../AppData/useSidepane';
14
- import { SIDE_PANE_OPTIONS } from '../../common/constants';
15
-
16
- const ChatAction = React.forwardRef((_, ref) => {
17
- const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
18
- const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
19
-
20
- if (isChatOpen) {
21
- return null;
22
- }
23
-
24
- return (
25
- <Button outlined as="div" variant="standard" css={{ w: 'max-content' }} onClick={toggleChat} ref={ref}>
26
- Open Chat
27
- </Button>
28
- );
29
- });
30
-
31
- const HandRaiseAction = React.forwardRef(({ id = '', isSingleHandRaise = true }, ref) => {
32
- const hmsActions = useHMSActions();
33
- const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
34
- const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
35
- const peer = useHMSStore(selectPeerByID(id));
36
- const layout = useRoomLayout();
37
- const {
38
- bring_to_stage_label,
39
- on_stage_role,
40
- off_stage_roles = [],
41
- skip_preview_for_role_change = false,
42
- } = layout?.screens?.conferencing?.default?.elements.on_stage_exp || {};
43
-
44
- const onClickHandler = useCallback(async () => {
45
- if (isSingleHandRaise) {
46
- hmsActions.changeRoleOfPeer(id, on_stage_role, skip_preview_for_role_change);
47
- if (skip_preview_for_role_change) {
48
- await hmsActions.lowerRemotePeerHand(id);
49
- }
50
- } else {
51
- !isParticipantsOpen && toggleSidepane();
52
- }
53
- }, [
54
- hmsActions,
55
- id,
56
- isParticipantsOpen,
57
- isSingleHandRaise,
58
- on_stage_role,
59
- toggleSidepane,
60
- skip_preview_for_role_change,
61
- ]);
62
-
63
- // show nothing if handRaise is single and peer role is not hls
64
- if (isSingleHandRaise && (!peer || !off_stage_roles.includes(peer.roleName))) {
65
- return null;
66
- }
67
- return (
68
- <Button outlined as="div" variant="standard" css={{ w: 'max-content' }} onClick={onClickHandler} ref={ref}>
69
- {isSingleHandRaise ? bring_to_stage_label : 'View'}
70
- </Button>
71
- );
72
- });
73
-
74
- export const ToastConfig = {
75
- PEER_JOINED: {
76
- single: function (notification) {
77
- return {
78
- title: `${notification.data?.name} joined`,
79
- icon: <PeopleAddIcon />,
80
- };
81
- },
82
- multiple: function (notifications) {
83
- return {
84
- title: `${notifications[notifications.length - 1].data.name} and ${notifications.length - 1} others joined`,
85
- icon: <PeopleAddIcon />,
86
- };
87
- },
88
- },
89
- PEER_LEFT: {
90
- single: function (notification) {
91
- return {
92
- title: `${notification.data?.name} left`,
93
- icon: <PeopleRemoveIcon />,
94
- };
95
- },
96
- multiple: function (notifications) {
97
- return {
98
- title: `${notifications[notifications.length - 1].data.name} and ${notifications.length - 1} others left`,
99
- icon: <PeopleRemoveIcon />,
100
- };
101
- },
102
- },
103
- RAISE_HAND: {
104
- single: notification => {
105
- return {
106
- title: `${notification.data?.name} raised hand`,
107
- icon: <HandIcon />,
108
- };
109
- },
110
- multiple: notifications => {
111
- const count = new Set(notifications.map(notification => notification.data?.id)).size;
112
- return {
113
- title: `${notifications[notifications.length - 1].data?.name} ${
114
- count > 1 ? `and ${count} others` : ''
115
- } raised hand`,
116
- icon: <HandIcon />,
117
- };
118
- },
119
- },
120
- RAISE_HAND_HLS: {
121
- single: notification => {
122
- return {
123
- title: `${notification.data?.name} raised hand`,
124
- icon: <HandIcon />,
125
- action: <HandRaiseAction id={notification.data?.id} />,
126
- };
127
- },
128
- multiple: notifications => {
129
- const count = new Set(notifications.map(notification => notification.data?.id)).size;
130
- return {
131
- title: `${notifications[notifications.length - 1].data?.name} ${
132
- count > 1 ? `and ${count} others` : ''
133
- } raised hand`,
134
- icon: <HandIcon />,
135
- action: <HandRaiseAction isSingleHandRaise={false} />,
136
- };
137
- },
138
- },
139
- NEW_MESSAGE: {
140
- single: notification => {
141
- return {
142
- title: `New message from ${notification.data?.senderName}`,
143
- icon: <ChatUnreadIcon />,
144
- action: <ChatAction />,
145
- };
146
- },
147
- multiple: notifications => {
148
- return {
149
- title: `${notifications.length} new messages`,
150
- icon: <ChatUnreadIcon />,
151
- action: <ChatAction />,
152
- };
153
- },
154
- },
155
- RECONNECTED: {
156
- single: online => {
157
- return {
158
- title: `You are now ${online ? 'online' : 'connected'}`,
159
- icon: <ConnectivityIcon />,
160
- variant: 'success',
161
- duration: 3000,
162
- };
163
- },
164
- },
165
- RECONNECTING: {
166
- single: message => {
167
- return {
168
- title: `You are offline for now. while we try to reconnect, please check
169
- your internet connection. ${message}.
170
- `,
171
- icon: <PoorConnectivityIcon />,
172
- variant: 'warning',
173
- duration: 30000,
174
- };
175
- },
176
- },
177
- };
@@ -1,30 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { selectIsConnectedToRoom, useHMSStore } from '@100mslive/react-sdk';
3
- import { Toast as ToastPrimitive } from '../../../Toast';
4
- import { Toast } from './Toast';
5
- import { ToastManager } from './ToastManager';
6
- import { MAX_TOASTS } from '../../common/constants';
7
-
8
- export const ToastContainer = () => {
9
- const isConnected = useHMSStore(selectIsConnectedToRoom);
10
- const [toasts, setToast] = useState([]);
11
- useEffect(() => {
12
- ToastManager.addListener(setToast);
13
- return () => {
14
- ToastManager.removeListener(setToast);
15
- };
16
- }, []);
17
- return (
18
- <ToastPrimitive.Provider swipeDirection="left" duration={3000}>
19
- {toasts.slice(0, MAX_TOASTS).map(toast => {
20
- return <Toast key={toast.id} {...toast} onOpenChange={value => !value && ToastManager.removeToast(toast.id)} />;
21
- })}
22
- <ToastPrimitive.Viewport
23
- css={{
24
- position: 'absolute',
25
- ...(!isConnected ? {} : { bottom: '$24' }),
26
- }}
27
- />
28
- </ToastPrimitive.Provider>
29
- );
30
- };