@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,44 +0,0 @@
1
- import { v4 } from 'uuid';
2
-
3
- export const ToastManager = {
4
- toasts: new Map(),
5
- listeners: new Map(),
6
- addToast(toast) {
7
- const id = toast.id ? toast.id : v4();
8
- this.toasts.set(id, { ...toast, id });
9
- this.onChange();
10
- return id;
11
- },
12
-
13
- clearAllToast() {
14
- this.toasts.clear();
15
- this.onChange();
16
- },
17
-
18
- removeToast(id) {
19
- this.toasts.delete(id);
20
- this.onChange();
21
- },
22
- replaceToast(id, toast) {
23
- if (this.isActive(id)) {
24
- this.toasts.set(id, { ...this.toasts.get(id), ...toast });
25
- this.onChange();
26
- return id;
27
- } else {
28
- return this.addToast(toast);
29
- }
30
- },
31
- addListener(cb) {
32
- this.listeners.set(cb, cb);
33
- },
34
- removeListener(cb) {
35
- this.listeners.delete(cb);
36
- },
37
- isActive(id) {
38
- return this.toasts.has(id);
39
- },
40
- onChange() {
41
- const toasts = Array.from(this.toasts.values());
42
- this.listeners.forEach(listener => listener(toasts));
43
- },
44
- };
@@ -1,62 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { PeopleAddIcon } from '@100mslive/react-icons';
4
- import { Flex } from '../../../Layout';
5
- import { config as cssConfig } from '../../../Theme';
6
- import { WaitingView } from '../../layouts/WaitingView';
7
- import { InsetTile } from '../InsetTile';
8
- import { Pagination } from '../Pagination';
9
- import { Grid } from './Grid';
10
- import { LayoutProps } from './interface';
11
- // @ts-ignore: No implicit Any
12
- import { useUISettings } from '../AppData/useUISettings';
13
- import { usePagesWithTiles, useTileLayout } from '../hooks/useTileLayout';
14
- import { UI_SETTINGS } from '../../common/constants';
15
-
16
- export function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }: LayoutProps) {
17
- const isMobile = useMedia(cssConfig.media.md);
18
- let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
19
- maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
20
- const pageList = usePagesWithTiles({
21
- peers,
22
- maxTileCount,
23
- });
24
-
25
- const { ref, pagesWithTiles } = useTileLayout({
26
- pageList,
27
- maxTileCount,
28
- edgeToEdge,
29
- });
30
- const [page, setPage] = useState(0);
31
- const pageSize = pagesWithTiles[0]?.length || 0;
32
-
33
- useEffect(() => {
34
- if (pageSize > 0) {
35
- onPageSize?.(pageSize);
36
- }
37
- }, [pageSize, onPageSize]);
38
-
39
- return (
40
- <Flex direction="column" css={{ flex: '1 1 0', h: '100%', position: 'relative', minWidth: 0 }}>
41
- <Grid tiles={pagesWithTiles[page]} ref={ref} edgeToEdge={edgeToEdge} />
42
- {!edgeToEdge && (
43
- <Pagination
44
- page={page}
45
- onPageChange={page => {
46
- setPage(page);
47
- onPageChange?.(page);
48
- }}
49
- numPages={pagesWithTiles.length}
50
- />
51
- )}
52
- {pageList.length === 0 ? (
53
- <WaitingView
54
- title="You're the only one here"
55
- subtitle="Sit back and relax till others join"
56
- icon={<PeopleAddIcon width="56px" height="56px" style={{ color: 'white' }} />}
57
- />
58
- ) : null}
59
- {isInsetEnabled && <InsetTile />}
60
- </Flex>
61
- );
62
- }
@@ -1,43 +0,0 @@
1
- import React from 'react';
2
- import { TrackWithPeerAndDimensions } from '@100mslive/react-sdk';
3
- import { Box } from '../../../Layout';
4
- // @ts-ignore: No implicit Any
5
- import VideoTile from '../VideoTile';
6
- import { useVideoTileContext } from '../hooks/useVideoTileLayout';
7
-
8
- export const Grid = React.forwardRef<HTMLDivElement, { tiles: TrackWithPeerAndDimensions[]; edgeToEdge?: boolean }>(
9
- ({ tiles, edgeToEdge }, ref) => {
10
- const videoTileProps = useVideoTileContext();
11
- return (
12
- <Box
13
- ref={ref}
14
- css={{
15
- flex: '1 1 0',
16
- gap: '$4',
17
- display: 'flex',
18
- placeContent: 'center',
19
- alignItems: 'center',
20
- justifyContent: 'center',
21
- flexFlow: 'row wrap',
22
- minHeight: 0,
23
- '@lg': { gap: edgeToEdge ? 0 : '$4' },
24
- }}
25
- >
26
- {tiles?.map(tile => {
27
- return (
28
- <VideoTile
29
- key={tile.track?.id || tile.peer?.id}
30
- width={tile.width}
31
- height={tile.height}
32
- peerId={tile.peer?.id}
33
- trackId={tile.track?.id}
34
- rootCSS={{ padding: 0 }}
35
- objectFit="contain"
36
- {...videoTileProps}
37
- />
38
- );
39
- })}
40
- </Box>
41
- );
42
- },
43
- );
@@ -1,155 +0,0 @@
1
- import React, { useEffect, useMemo, useState } from 'react';
2
- import { GridVideoTileLayout } from '@100mslive/types-prebuilt/elements/video_tile_layout';
3
- import {
4
- selectLocalPeerID,
5
- selectLocalPeerRoleName,
6
- selectPeers,
7
- selectPeerScreenSharing,
8
- selectWhiteboard,
9
- useHMSStore,
10
- useHMSVanillaStore,
11
- } from '@100mslive/react-sdk';
12
- import { EqualProminence } from './EqualProminence';
13
- import { RoleProminence } from './RoleProminence';
14
- import { ScreenshareLayout } from './ScreenshareLayout';
15
- import { WhiteboardLayout } from './WhiteboardLayout';
16
- // @ts-ignore: No implicit Any
17
- import { usePinnedTrack, useSetAppDataByKey } from '../AppData/useUISettings';
18
- import { VideoTileContext } from '../hooks/useVideoTileLayout';
19
- import PeersSorter from '../../common/PeersSorter';
20
- import { APP_DATA } from '../../common/constants';
21
-
22
- export type TileCustomisationProps = {
23
- hide_participant_name_on_tile: boolean;
24
- rounded_video_tile: boolean;
25
- hide_audio_mute_on_tile: boolean;
26
- video_object_fit: 'contain' | 'cover';
27
- edge_to_edge: boolean;
28
- hide_metadata_on_tile: boolean;
29
- };
30
-
31
- export type GridLayoutProps = GridVideoTileLayout & TileCustomisationProps;
32
-
33
- export const GridLayout = ({
34
- enable_local_tile_inset: isInsetEnabled = false,
35
- prominent_roles: prominentRoles = [],
36
- enable_spotlighting_peer = false,
37
- hide_participant_name_on_tile = false,
38
- rounded_video_tile = true,
39
- hide_audio_mute_on_tile = false,
40
- video_object_fit = 'contain',
41
- edge_to_edge = false,
42
- hide_metadata_on_tile = false,
43
- }: GridLayoutProps) => {
44
- const peerSharing = useHMSStore(selectPeerScreenSharing);
45
- const whiteboard = useHMSStore(selectWhiteboard);
46
- const pinnedTrack = usePinnedTrack();
47
- const peers = useHMSStore(selectPeers);
48
- const localPeerRole = useHMSStore(selectLocalPeerRoleName);
49
- const localPeerID = useHMSStore(selectLocalPeerID);
50
-
51
- const [activeScreensharePeerId] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
52
- const isRoleProminence =
53
- (prominentRoles.length &&
54
- peers.some(
55
- peer => peer.roleName && prominentRoles.includes(peer.roleName) && (peer.videoTrack || peer.audioTrack),
56
- )) ||
57
- pinnedTrack;
58
- const updatedPeers = useMemo(() => {
59
- // remove screenshare/whiteboard peer from active speaker sorting
60
- if (activeScreensharePeerId || whiteboard?.open) {
61
- return peers.filter(peer => peer.id !== activeScreensharePeerId || peer.customerUserId !== whiteboard?.owner);
62
- }
63
- if (isInsetEnabled) {
64
- const isLocalPeerPinned = localPeerID === pinnedTrack?.peerId;
65
- // if localPeer role is prominent role, it shows up in the center or local peer is pinned, so allow it in active speaker sorting
66
- if ((localPeerRole && prominentRoles.includes(localPeerRole)) || isLocalPeerPinned) {
67
- return peers;
68
- } else {
69
- return peers.filter(peer => !peer.isLocal);
70
- }
71
- }
72
- return peers;
73
- }, [
74
- isInsetEnabled,
75
- whiteboard,
76
- activeScreensharePeerId,
77
- localPeerRole,
78
- localPeerID,
79
- prominentRoles,
80
- peers,
81
- pinnedTrack,
82
- ]);
83
- const vanillaStore = useHMSVanillaStore();
84
- const [sortedPeers, setSortedPeers] = useState(updatedPeers);
85
- const peersSorter = useMemo(() => new PeersSorter(vanillaStore), [vanillaStore]);
86
- const [pageSize, setPageSize] = useState(0);
87
- const [mainPage, setMainPage] = useState(0);
88
- const tileLayout = {
89
- enableSpotlightingPeer: enable_spotlighting_peer,
90
- hideParticipantNameOnTile: hide_participant_name_on_tile,
91
- roundedVideoTile: rounded_video_tile,
92
- hideAudioMuteOnTile: hide_audio_mute_on_tile,
93
- hideMetadataOnTile: hide_metadata_on_tile,
94
- objectFit: video_object_fit,
95
- };
96
-
97
- useEffect(() => {
98
- if (mainPage !== 0) {
99
- return;
100
- }
101
- peersSorter.setPeersAndTilesPerPage({
102
- peers: updatedPeers,
103
- tilesPerPage: pageSize,
104
- });
105
- peersSorter.onUpdate(setSortedPeers);
106
- }, [mainPage, peersSorter, updatedPeers, pageSize]);
107
-
108
- if (peerSharing) {
109
- return (
110
- <VideoTileContext.Provider value={tileLayout}>
111
- <ScreenshareLayout
112
- peers={sortedPeers}
113
- onPageSize={setPageSize}
114
- onPageChange={setMainPage}
115
- edgeToEdge={edge_to_edge}
116
- />
117
- </VideoTileContext.Provider>
118
- );
119
- } else if (whiteboard?.open) {
120
- return (
121
- <VideoTileContext.Provider value={tileLayout}>
122
- <WhiteboardLayout
123
- peers={sortedPeers}
124
- onPageSize={setPageSize}
125
- onPageChange={setMainPage}
126
- edgeToEdge={edge_to_edge}
127
- />
128
- </VideoTileContext.Provider>
129
- );
130
- } else if (isRoleProminence) {
131
- return (
132
- <VideoTileContext.Provider value={tileLayout}>
133
- <RoleProminence
134
- peers={sortedPeers}
135
- onPageSize={setPageSize}
136
- onPageChange={setMainPage}
137
- prominentRoles={prominentRoles}
138
- isInsetEnabled={isInsetEnabled}
139
- edgeToEdge={edge_to_edge}
140
- />
141
- </VideoTileContext.Provider>
142
- );
143
- }
144
- return (
145
- <VideoTileContext.Provider value={tileLayout}>
146
- <EqualProminence
147
- peers={sortedPeers}
148
- onPageSize={setPageSize}
149
- onPageChange={setMainPage}
150
- isInsetEnabled={isInsetEnabled}
151
- edgeToEdge={edge_to_edge}
152
- />
153
- </VideoTileContext.Provider>
154
- );
155
- };
@@ -1,91 +0,0 @@
1
- import React from 'react';
2
- import { TrackWithPeerAndDimensions } from '@100mslive/react-sdk';
3
- import { Box, Flex } from '../../../Layout';
4
- import { CSS } from '../../../Theme';
5
- // @ts-ignore: No implicit Any
6
- import VideoTile from '../VideoTile';
7
- import { useVideoTileContext } from '../hooks/useVideoTileLayout';
8
-
9
- const Root = ({
10
- children,
11
- edgeToEdge,
12
- hasSidebar,
13
- }: React.PropsWithChildren<{ edgeToEdge?: boolean; hasSidebar?: boolean }>) => {
14
- return (
15
- <Flex
16
- direction={hasSidebar ? 'row' : 'column'}
17
- css={{ h: '100%', flex: '1 1 0', minWidth: 0, gap: '$6', '@md': { gap: edgeToEdge ? 0 : '$6' } }}
18
- >
19
- {children}
20
- </Flex>
21
- );
22
- };
23
-
24
- const ProminentSection = ({ children, css = {} }: React.PropsWithChildren<{ css?: CSS }>) => {
25
- return (
26
- <Flex direction="column" css={{ flex: '1 1 0', gap: '$2', minHeight: 0, ...css }}>
27
- {children}
28
- </Flex>
29
- );
30
- };
31
-
32
- const SecondarySection = ({
33
- tiles,
34
- children,
35
- edgeToEdge,
36
- hasSidebar,
37
- }: React.PropsWithChildren<{ tiles: TrackWithPeerAndDimensions[]; edgeToEdge?: boolean; hasSidebar?: boolean }>) => {
38
- const tileLayoutProps = useVideoTileContext();
39
- if (!tiles?.length) {
40
- return null;
41
- }
42
- const gridStyles = hasSidebar
43
- ? {
44
- gridTemplateColumns: '1fr',
45
- gridTemplateRows: `repeat(${tiles.length}, minmax(0, 1fr))`,
46
- maxHeight: '100%',
47
- width: 240,
48
- }
49
- : {
50
- gridTemplateRows: React.Children.count(children) > 0 ? '136px auto' : '154px',
51
- gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
52
- };
53
- return (
54
- <Box
55
- css={{
56
- display: 'grid',
57
- margin: 'auto',
58
- gap: hasSidebar ? '$8' : '$2 $4',
59
- placeItems: 'center',
60
- ...gridStyles,
61
- '@md': { gap: edgeToEdge ? 0 : '$4' },
62
- }}
63
- >
64
- {tiles.map(tile => {
65
- return (
66
- <VideoTile
67
- key={tile.track?.id || tile.peer?.id}
68
- peerId={tile.peer?.id}
69
- trackId={tile.track?.id}
70
- rootCSS={{
71
- padding: 0,
72
- maxWidth: 240,
73
- aspectRatio: '16 / 9',
74
- ...(hasSidebar ? { w: '100%' } : { h: '100%' }),
75
- '@md': { aspectRatio: '1' },
76
- }}
77
- objectFit="contain"
78
- {...tileLayoutProps}
79
- />
80
- );
81
- })}
82
- {children && <Box css={{ gridColumn: hasSidebar ? 1 : `1/span ${tiles.length}` }}>{children}</Box>}
83
- </Box>
84
- );
85
- };
86
-
87
- export const ProminenceLayout = {
88
- Root,
89
- ProminentSection,
90
- SecondarySection,
91
- };
@@ -1,66 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { selectLocalPeer, useHMSStore } from '@100mslive/react-sdk';
4
- import { config as cssConfig } from '../../../Theme';
5
- import { InsetTile } from '../InsetTile';
6
- import { Pagination } from '../Pagination';
7
- import { SecondaryTiles } from '../SecondaryTiles';
8
- import { Grid } from './Grid';
9
- import { LayoutProps } from './interface';
10
- import { ProminenceLayout } from './ProminenceLayout';
11
- // @ts-ignore: No implicit Any
12
- import { useUISettings } from '../AppData/useUISettings';
13
- import { useRoleProminencePeers } from '../hooks/useRoleProminencePeers';
14
- import { usePagesWithTiles, useTileLayout } from '../hooks/useTileLayout';
15
- import { UI_SETTINGS } from '../../common/constants';
16
-
17
- export function RoleProminence({
18
- isInsetEnabled = false,
19
- prominentRoles = [],
20
- peers,
21
- onPageChange,
22
- onPageSize,
23
- edgeToEdge,
24
- }: LayoutProps) {
25
- const { prominentPeers, secondaryPeers } = useRoleProminencePeers(prominentRoles, peers, isInsetEnabled);
26
- const localPeer = useHMSStore(selectLocalPeer);
27
- const isMobile = useMedia(cssConfig.media.md);
28
- let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
29
- maxTileCount = isMobile ? 4 : maxTileCount;
30
- const pageList = usePagesWithTiles({
31
- peers: prominentPeers,
32
- maxTileCount,
33
- });
34
- const { ref, pagesWithTiles } = useTileLayout({
35
- pageList,
36
- maxTileCount,
37
- });
38
- const [page, setPage] = useState(0);
39
- const pageSize = pagesWithTiles[0]?.length || 0;
40
-
41
- useEffect(() => {
42
- if (pageSize > 0) {
43
- onPageSize?.(pageSize);
44
- }
45
- }, [pageSize, onPageSize]);
46
-
47
- return (
48
- <ProminenceLayout.Root>
49
- <ProminenceLayout.ProminentSection>
50
- <Grid ref={ref} tiles={pagesWithTiles[page]} />
51
- </ProminenceLayout.ProminentSection>
52
- {!edgeToEdge && (
53
- <Pagination
54
- page={page}
55
- onPageChange={page => {
56
- setPage(page);
57
- onPageChange?.(page);
58
- }}
59
- numPages={pagesWithTiles.length}
60
- />
61
- )}
62
- <SecondaryTiles peers={secondaryPeers} isInsetEnabled={isInsetEnabled} edgeToEdge={edgeToEdge} />
63
- {isInsetEnabled && localPeer && prominentPeers.length > 0 && !prominentPeers.includes(localPeer) && <InsetTile />}
64
- </ProminenceLayout.Root>
65
- );
66
- }
@@ -1,74 +0,0 @@
1
- import React, { useEffect, useMemo, useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { selectPeersScreenSharing, useHMSStore } from '@100mslive/react-sdk';
4
- import { config as cssConfig } from '../../../Theme';
5
- import { InsetTile } from '../InsetTile';
6
- import { Pagination } from '../Pagination';
7
- // @ts-ignore: No implicit Any
8
- import ScreenshareTile from '../ScreenshareTile';
9
- import { SecondaryTiles } from '../SecondaryTiles';
10
- import { LayoutMode } from '../Settings/LayoutSettings';
11
- import { LayoutProps } from './interface';
12
- import { ProminenceLayout } from './ProminenceLayout';
13
- // @ts-ignore: No implicit Any
14
- import { useSetAppDataByKey, useSetUiSettings } from '../AppData/useUISettings';
15
- import { APP_DATA, UI_SETTINGS } from '../../common/constants';
16
-
17
- export const ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }: LayoutProps) => {
18
- const peersSharing = useHMSStore(selectPeersScreenSharing);
19
- const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
20
- const [page, setPage] = useState(0);
21
- const [layoutMode, setLayoutMode] = useSetUiSettings(UI_SETTINGS.layoutMode);
22
- const activeSharePeer = peersSharing[page];
23
- const isMobile = useMedia(cssConfig.media.md);
24
- const hasSidebar = !isMobile && layoutMode === LayoutMode.SIDEBAR;
25
- const secondaryPeers = useMemo(() => {
26
- if (layoutMode === LayoutMode.SPOTLIGHT) {
27
- return [];
28
- }
29
- if (isMobile || layoutMode === LayoutMode.SIDEBAR) {
30
- return activeSharePeer
31
- ? [activeSharePeer, ...peers.filter(p => p.id !== activeSharePeer?.id)] //keep active sharing peer as first tile
32
- : peers;
33
- }
34
- return peers.filter(p => p.id !== activeSharePeer?.id);
35
- }, [activeSharePeer, peers, isMobile, layoutMode]);
36
-
37
- useEffect(() => {
38
- if (isMobile) {
39
- setLayoutMode(LayoutMode.GALLERY);
40
- return;
41
- }
42
- if (layoutMode === LayoutMode.SIDEBAR) {
43
- return;
44
- }
45
- setLayoutMode(LayoutMode.SIDEBAR);
46
- return () => {
47
- // reset to gallery once screenshare is stopped
48
- setLayoutMode(LayoutMode.GALLERY);
49
- };
50
- }, [isMobile]); // eslint-disable-line react-hooks/exhaustive-deps
51
- useEffect(() => {
52
- setActiveScreenSharePeer(activeSharePeer?.id);
53
- return () => {
54
- setActiveScreenSharePeer('');
55
- };
56
- }, [activeSharePeer?.id, setActiveScreenSharePeer]);
57
-
58
- return (
59
- <ProminenceLayout.Root edgeToEdge={edgeToEdge} hasSidebar={hasSidebar}>
60
- <ProminenceLayout.ProminentSection>
61
- <ScreenshareTile peerId={peersSharing[page]?.id} />
62
- {!edgeToEdge && <Pagination page={page} onPageChange={setPage} numPages={peersSharing.length} />}
63
- </ProminenceLayout.ProminentSection>
64
- <SecondaryTiles
65
- peers={secondaryPeers}
66
- onPageChange={onPageChange}
67
- onPageSize={onPageSize}
68
- edgeToEdge={edgeToEdge}
69
- hasSidebar={hasSidebar}
70
- />
71
- {layoutMode === LayoutMode.SPOTLIGHT && activeSharePeer && <InsetTile peerId={activeSharePeer?.id} />}
72
- </ProminenceLayout.Root>
73
- );
74
- };
@@ -1,93 +0,0 @@
1
- import React, { useEffect, useMemo } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { Whiteboard } from '@100mslive/hms-whiteboard';
4
- import { selectPeerByCondition, selectWhiteboard, useHMSStore, useWhiteboard } from '@100mslive/react-sdk';
5
- import { Box } from '../../../Layout';
6
- import { config as cssConfig } from '../../../Theme';
7
- import { InsetTile } from '../InsetTile';
8
- import { SecondaryTiles } from '../SecondaryTiles';
9
- import { LayoutMode } from '../Settings/LayoutSettings';
10
- import { LayoutProps } from './interface';
11
- import { ProminenceLayout } from './ProminenceLayout';
12
- // @ts-ignore: No implicit Any
13
- import { useSetUiSettings } from '../AppData/useUISettings';
14
- import { UI_SETTINGS } from '../../common/constants';
15
- // eslint-disable-next-line import/no-unresolved
16
- import '@100mslive/hms-whiteboard/index.css';
17
-
18
- const WhiteboardEmbed = () => {
19
- const isMobile = useMedia(cssConfig.media.md);
20
- const { token, endpoint, zoomToContent } = useWhiteboard(isMobile);
21
-
22
- if (!token) {
23
- return null;
24
- }
25
-
26
- return (
27
- <Box
28
- css={{
29
- mx: '$8',
30
- flex: '3 1 0',
31
- '@lg': {
32
- flex: '2 1 0',
33
- display: 'flex',
34
- alignItems: 'center',
35
- },
36
- }}
37
- >
38
- <Box css={{ size: '100%' }}>
39
- <Whiteboard token={token} endpoint={`https://${endpoint}`} zoomToContent={zoomToContent} />
40
- </Box>
41
- </Box>
42
- );
43
- };
44
-
45
- export const WhiteboardLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }: LayoutProps) => {
46
- const whiteboard = useHMSStore(selectWhiteboard);
47
- const whiteboardOwner = useHMSStore(selectPeerByCondition(peer => peer.customerUserId === whiteboard?.owner));
48
- const [layoutMode, setLayoutMode] = useSetUiSettings(UI_SETTINGS.layoutMode);
49
- const isMobile = useMedia(cssConfig.media.md);
50
- const hasSidebar = !isMobile && layoutMode === LayoutMode.SIDEBAR;
51
- const secondaryPeers = useMemo(() => {
52
- if (layoutMode === LayoutMode.SPOTLIGHT) {
53
- return [];
54
- }
55
- if (isMobile || layoutMode === LayoutMode.SIDEBAR) {
56
- return whiteboardOwner
57
- ? [whiteboardOwner, ...peers.filter(p => p.id !== whiteboardOwner?.id)] //keep active sharing peer as first tile
58
- : peers;
59
- }
60
- return peers.filter(p => p.id !== whiteboardOwner?.id);
61
- }, [whiteboardOwner, peers, isMobile, layoutMode]);
62
-
63
- useEffect(() => {
64
- if (isMobile) {
65
- setLayoutMode(LayoutMode.GALLERY);
66
- return;
67
- }
68
- if (layoutMode === LayoutMode.SIDEBAR) {
69
- return;
70
- }
71
- setLayoutMode(LayoutMode.SIDEBAR);
72
- return () => {
73
- // reset to gallery once whiteboard is stopped
74
- setLayoutMode(LayoutMode.GALLERY);
75
- };
76
- }, [isMobile]); // eslint-disable-line react-hooks/exhaustive-deps
77
-
78
- return (
79
- <ProminenceLayout.Root edgeToEdge={edgeToEdge} hasSidebar={hasSidebar}>
80
- <ProminenceLayout.ProminentSection>
81
- <WhiteboardEmbed />
82
- </ProminenceLayout.ProminentSection>
83
- <SecondaryTiles
84
- peers={secondaryPeers}
85
- onPageChange={onPageChange}
86
- onPageSize={onPageSize}
87
- edgeToEdge={edgeToEdge}
88
- hasSidebar={hasSidebar}
89
- />
90
- {layoutMode === LayoutMode.SPOTLIGHT && whiteboardOwner && <InsetTile peerId={whiteboardOwner?.id} />}
91
- </ProminenceLayout.Root>
92
- );
93
- };
@@ -1,11 +0,0 @@
1
- import { HMSPeer } from '@100mslive/react-sdk';
2
-
3
- export interface LayoutProps {
4
- isInsetEnabled?: boolean;
5
- edgeToEdge?: boolean;
6
- prominentRoles?: string[];
7
- hasSidebar?: boolean;
8
- peers: HMSPeer[];
9
- onPageChange?: (page: number) => void;
10
- onPageSize?: (size: number) => void;
11
- }