@100mslive/roomkit-react 0.4.3-alpha.0 → 0.4.3-alpha.10

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 (442) hide show
  1. package/dist/index.cjs.css +214 -223
  2. package/dist/index.cjs.css.map +3 -3
  3. package/dist/index.cjs.js +489 -727
  4. package/dist/index.cjs.js.map +4 -4
  5. package/dist/index.css +214 -223
  6. package/dist/index.css.map +3 -3
  7. package/dist/index.js +501 -739
  8. package/dist/index.js.map +4 -4
  9. package/dist/meta.cjs.json +93 -149
  10. package/dist/meta.esbuild.json +92 -148
  11. package/package.json +10 -24
  12. package/src/Accordion/Accordion.stories.tsx +0 -50
  13. package/src/Accordion/Accordion.tsx +0 -88
  14. package/src/Accordion/index.ts +0 -8
  15. package/src/AudioLevel/AudioLevel.tsx +0 -84
  16. package/src/AudioLevel/audio-level.png +0 -0
  17. package/src/AudioLevel/index.ts +0 -2
  18. package/src/AudioLevel/useBorderAudioLevel.tsx +0 -34
  19. package/src/Avatar/Avatar.stories.tsx +0 -33
  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.mdx +0 -43
  24. package/src/Button/Button.stories.tsx +0 -52
  25. package/src/Button/Button.tsx +0 -210
  26. package/src/Button/index.tsx +0 -1
  27. package/src/Chat/Chat.mdx +0 -39
  28. package/src/Chat/Chat.stories.tsx +0 -39
  29. package/src/Checkbox/Checkbox.stories.tsx +0 -61
  30. package/src/Checkbox/Checkbox.tsx +0 -35
  31. package/src/Checkbox/index.tsx +0 -1
  32. package/src/Collapsible/Collapsible.tsx +0 -34
  33. package/src/Collapsible/index.tsx +0 -1
  34. package/src/Diagnostics/AudioTest.tsx +0 -188
  35. package/src/Diagnostics/BrowserTest.tsx +0 -141
  36. package/src/Diagnostics/ConnectivityTest.tsx +0 -383
  37. package/src/Diagnostics/DeviceSelector.jsx +0 -71
  38. package/src/Diagnostics/Diagnostics.tsx +0 -190
  39. package/src/Diagnostics/DiagnosticsContext.ts +0 -46
  40. package/src/Diagnostics/VideoTest.tsx +0 -72
  41. package/src/Diagnostics/components.tsx +0 -70
  42. package/src/Diagnostics/index.ts +0 -1
  43. package/src/Divider/Divider.tsx +0 -45
  44. package/src/Divider/HorizontalDivider.stories.tsx +0 -34
  45. package/src/Divider/VerticalDivider.stories.tsx +0 -40
  46. package/src/Divider/index.ts +0 -1
  47. package/src/Dropdown/Dropdown.stories.tsx +0 -94
  48. package/src/Dropdown/Dropdown.tsx +0 -145
  49. package/src/Dropdown/index.tsx +0 -1
  50. package/src/Fieldset/Fieldset.stories.tsx +0 -29
  51. package/src/Fieldset/Fieldset.tsx +0 -11
  52. package/src/Fieldset/index.tsx +0 -1
  53. package/src/Footer/Footer.stories.tsx +0 -61
  54. package/src/Footer/Footer.tsx +0 -47
  55. package/src/Footer/index.tsx +0 -1
  56. package/src/IconButton/IconButton.tsx +0 -43
  57. package/src/IconButton/index.tsx +0 -1
  58. package/src/Icons/Icons.stories.mdx +0 -10
  59. package/src/Icons/IconsList.jsx +0 -17
  60. package/src/Input/Input.stories.tsx +0 -25
  61. package/src/Input/Input.tsx +0 -109
  62. package/src/Input/PasswordInput.stories.tsx +0 -53
  63. package/src/Input/index.tsx +0 -1
  64. package/src/Introduction/Integrating.stories.mdx +0 -100
  65. package/src/Introduction/Introduction.stories.mdx +0 -9
  66. package/src/Label/Label.tsx +0 -8
  67. package/src/Label/index.ts +0 -1
  68. package/src/Layout/Box.tsx +0 -3
  69. package/src/Layout/Flex.tsx +0 -76
  70. package/src/Layout/index.tsx +0 -2
  71. package/src/Link/Link.stories.tsx +0 -18
  72. package/src/Link/Link.tsx +0 -54
  73. package/src/Link/index.tsx +0 -2
  74. package/src/Loading/Loading.mdx +0 -15
  75. package/src/Loading/Loading.stories.tsx +0 -37
  76. package/src/Loading/Loading.tsx +0 -30
  77. package/src/Loading/index.ts +0 -1
  78. package/src/Modal/Dialog.mdx +0 -19
  79. package/src/Modal/Dialog.stories.tsx +0 -68
  80. package/src/Modal/Dialog.tsx +0 -57
  81. package/src/Modal/DialogContent.tsx +0 -65
  82. package/src/Modal/index.ts +0 -1
  83. package/src/Pagination/StyledPagination.stories.tsx +0 -80
  84. package/src/Pagination/StyledPagination.tsx +0 -70
  85. package/src/Pagination/index.tsx +0 -1
  86. package/src/Popover/Popover.mdx +0 -9
  87. package/src/Popover/Popover.stories.tsx +0 -95
  88. package/src/Popover/index.tsx +0 -34
  89. package/src/Prebuilt/App.tsx +0 -318
  90. package/src/Prebuilt/AppContext.tsx +0 -33
  91. package/src/Prebuilt/AppStateContext.tsx +0 -95
  92. package/src/Prebuilt/IconButton.tsx +0 -26
  93. package/src/Prebuilt/Prebuilt.stories.tsx +0 -46
  94. package/src/Prebuilt/common/PeersSorter.ts +0 -111
  95. package/src/Prebuilt/common/constants.ts +0 -151
  96. package/src/Prebuilt/common/hooks.ts +0 -257
  97. package/src/Prebuilt/common/utils.js +0 -185
  98. package/src/Prebuilt/components/AppData/AppData.tsx +0 -208
  99. package/src/Prebuilt/components/AppData/useChatState.js +0 -18
  100. package/src/Prebuilt/components/AppData/useSheet.ts +0 -33
  101. package/src/Prebuilt/components/AppData/useSidepane.js +0 -99
  102. package/src/Prebuilt/components/AppData/useSidepaneResetOnLayoutUpdate.tsx +0 -22
  103. package/src/Prebuilt/components/AppData/useUISettings.js +0 -212
  104. package/src/Prebuilt/components/AudioVideoToggle.tsx +0 -411
  105. package/src/Prebuilt/components/AuthToken.tsx +0 -148
  106. package/src/Prebuilt/components/CaptionIcon.tsx +0 -27
  107. package/src/Prebuilt/components/Chat/ArrowNavigation.tsx +0 -44
  108. package/src/Prebuilt/components/Chat/Chat.tsx +0 -190
  109. package/src/Prebuilt/components/Chat/ChatActions.tsx +0 -314
  110. package/src/Prebuilt/components/Chat/ChatBody.tsx +0 -493
  111. package/src/Prebuilt/components/Chat/ChatFooter.tsx +0 -316
  112. package/src/Prebuilt/components/Chat/ChatSelector.tsx +0 -228
  113. package/src/Prebuilt/components/Chat/ChatSelectorContainer.tsx +0 -158
  114. package/src/Prebuilt/components/Chat/ChatStates.tsx +0 -73
  115. package/src/Prebuilt/components/Chat/EmptyChat.tsx +0 -58
  116. package/src/Prebuilt/components/Chat/MwebChatOption.tsx +0 -24
  117. package/src/Prebuilt/components/Chat/PinnedMessage.tsx +0 -140
  118. package/src/Prebuilt/components/Chat/StickIndicator.tsx +0 -24
  119. package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +0 -32
  120. package/src/Prebuilt/components/Chat/useUnreadCount.ts +0 -19
  121. package/src/Prebuilt/components/Chat/utils.ts +0 -11
  122. package/src/Prebuilt/components/ChatSettings.tsx +0 -68
  123. package/src/Prebuilt/components/Chip.tsx +0 -40
  124. package/src/Prebuilt/components/ConferenceScreen.tsx +0 -205
  125. package/src/Prebuilt/components/Connection/ConnectionIndicator.tsx +0 -89
  126. package/src/Prebuilt/components/Connection/TileConnection.tsx +0 -93
  127. package/src/Prebuilt/components/Connection/connectionQualityUtils.js +0 -37
  128. package/src/Prebuilt/components/EmojiReaction.jsx +0 -100
  129. package/src/Prebuilt/components/EndCallFeedback/Feedback.tsx +0 -71
  130. package/src/Prebuilt/components/EndCallFeedback/FeedbackForm.tsx +0 -381
  131. package/src/Prebuilt/components/EndCallFeedback/ThankyouView.tsx +0 -64
  132. package/src/Prebuilt/components/ErrorBoundary.jsx +0 -102
  133. package/src/Prebuilt/components/Footer/ChatToggle.tsx +0 -53
  134. package/src/Prebuilt/components/Footer/EmojiCard.jsx +0 -34
  135. package/src/Prebuilt/components/Footer/Footer.tsx +0 -115
  136. package/src/Prebuilt/components/Footer/PaginatedParticipants.tsx +0 -124
  137. package/src/Prebuilt/components/Footer/ParticipantList.tsx +0 -478
  138. package/src/Prebuilt/components/Footer/PollsToggle.tsx +0 -37
  139. package/src/Prebuilt/components/Footer/RoleAccordion.tsx +0 -183
  140. package/src/Prebuilt/components/Footer/RoleOptions.tsx +0 -215
  141. package/src/Prebuilt/components/Footer/WhiteboardToggle.tsx +0 -52
  142. package/src/Prebuilt/components/FullPageProgress.tsx +0 -22
  143. package/src/Prebuilt/components/HMSVideo/Controls.jsx +0 -22
  144. package/src/Prebuilt/components/HMSVideo/FullscreenButton.tsx +0 -13
  145. package/src/Prebuilt/components/HMSVideo/HLSAutoplayBlockedPrompt.tsx +0 -72
  146. package/src/Prebuilt/components/HMSVideo/HLSCaptionSelector.tsx +0 -15
  147. package/src/Prebuilt/components/HMSVideo/HLSQualitySelector.tsx +0 -248
  148. package/src/Prebuilt/components/HMSVideo/HMSVideo.jsx +0 -75
  149. package/src/Prebuilt/components/HMSVideo/MwebHLSViewTitle.tsx +0 -86
  150. package/src/Prebuilt/components/HMSVideo/PlayPauseButton.tsx +0 -27
  151. package/src/Prebuilt/components/HMSVideo/PlayPauseSeekControls.tsx +0 -158
  152. package/src/Prebuilt/components/HMSVideo/PlayerContext.tsx +0 -15
  153. package/src/Prebuilt/components/HMSVideo/SeekControl.tsx +0 -22
  154. package/src/Prebuilt/components/HMSVideo/VideoProgress.tsx +0 -100
  155. package/src/Prebuilt/components/HMSVideo/VideoTime.tsx +0 -52
  156. package/src/Prebuilt/components/HMSVideo/VolumeControl.tsx +0 -70
  157. package/src/Prebuilt/components/HMSVideo/index.ts +0 -24
  158. package/src/Prebuilt/components/HMSVideo/utils.ts +0 -37
  159. package/src/Prebuilt/components/Header/Header.tsx +0 -52
  160. package/src/Prebuilt/components/Header/HeaderComponents.jsx +0 -57
  161. package/src/Prebuilt/components/Header/ParticipantFilter.jsx +0 -89
  162. package/src/Prebuilt/components/Header/RoomDetailsHeader.tsx +0 -51
  163. package/src/Prebuilt/components/Header/StreamActions.tsx +0 -297
  164. package/src/Prebuilt/components/Header/common.jsx +0 -196
  165. package/src/Prebuilt/components/Header/index.tsx +0 -1
  166. package/src/Prebuilt/components/HlsStatsOverlay.jsx +0 -89
  167. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.stories.tsx +0 -40
  168. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.tsx +0 -167
  169. package/src/Prebuilt/components/Input/KeyboardInputManager.js +0 -107
  170. package/src/Prebuilt/components/InsetTile.tsx +0 -136
  171. package/src/Prebuilt/components/LayoutModeSelector.tsx +0 -112
  172. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +0 -166
  173. package/src/Prebuilt/components/Leave/EndSessionContent.tsx +0 -64
  174. package/src/Prebuilt/components/Leave/LeaveAtoms.tsx +0 -26
  175. package/src/Prebuilt/components/Leave/LeaveCard.tsx +0 -36
  176. package/src/Prebuilt/components/Leave/LeaveRoom.tsx +0 -82
  177. package/src/Prebuilt/components/Leave/LeaveSessionContent.tsx +0 -61
  178. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +0 -135
  179. package/src/Prebuilt/components/LeaveScreen.tsx +0 -71
  180. package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +0 -60
  181. package/src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx +0 -139
  182. package/src/Prebuilt/components/MoreSettings/CaptionContent.tsx +0 -143
  183. package/src/Prebuilt/components/MoreSettings/CaptionModal.tsx +0 -37
  184. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.tsx +0 -123
  185. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.tsx +0 -78
  186. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +0 -81
  187. package/src/Prebuilt/components/MoreSettings/FullScreenItem.tsx +0 -26
  188. package/src/Prebuilt/components/MoreSettings/MoreSettings.tsx +0 -29
  189. package/src/Prebuilt/components/MoreSettings/MuteAllContent.tsx +0 -81
  190. package/src/Prebuilt/components/MoreSettings/MuteAllModal.tsx +0 -72
  191. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx +0 -282
  192. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +0 -387
  193. package/src/Prebuilt/components/MoreSettings/constants.ts +0 -14
  194. package/src/Prebuilt/components/MwebLandscapePrompt.tsx +0 -81
  195. package/src/Prebuilt/components/Notifications/AutoplayBlockedModal.tsx +0 -39
  196. package/src/Prebuilt/components/Notifications/ChatNotifications.tsx +0 -34
  197. package/src/Prebuilt/components/Notifications/DeviceChangeNotifications.tsx +0 -18
  198. package/src/Prebuilt/components/Notifications/DeviceInUseError.tsx +0 -86
  199. package/src/Prebuilt/components/Notifications/ErrorNotifications.tsx +0 -56
  200. package/src/Prebuilt/components/Notifications/HLSFailureModal.tsx +0 -71
  201. package/src/Prebuilt/components/Notifications/HandRaisedNotifications.tsx +0 -78
  202. package/src/Prebuilt/components/Notifications/InitErrorModal.tsx +0 -42
  203. package/src/Prebuilt/components/Notifications/MessageNotifications.tsx +0 -24
  204. package/src/Prebuilt/components/Notifications/Notifications.tsx +0 -65
  205. package/src/Prebuilt/components/Notifications/PeerNotifications.tsx +0 -52
  206. package/src/Prebuilt/components/Notifications/PermissionErrorModal.tsx +0 -144
  207. package/src/Prebuilt/components/Notifications/PollNotificationModal.tsx +0 -71
  208. package/src/Prebuilt/components/Notifications/ReconnectNotifications.tsx +0 -33
  209. package/src/Prebuilt/components/Notifications/RoleChangeNotification.tsx +0 -24
  210. package/src/Prebuilt/components/Notifications/TrackBulkUnmuteModal.tsx +0 -61
  211. package/src/Prebuilt/components/Notifications/TrackNotifications.tsx +0 -41
  212. package/src/Prebuilt/components/Notifications/TrackUnmuteModal.tsx +0 -63
  213. package/src/Prebuilt/components/Notifications/TranscriptionNotifications.tsx +0 -58
  214. package/src/Prebuilt/components/Notifications/index.tsx +0 -1
  215. package/src/Prebuilt/components/PIP/PIPChat.tsx +0 -292
  216. package/src/Prebuilt/components/PIP/PIPChatOption.tsx +0 -18
  217. package/src/Prebuilt/components/PIP/PIPComponent.tsx +0 -90
  218. package/src/Prebuilt/components/PIP/PIPManager.ts +0 -335
  219. package/src/Prebuilt/components/PIP/PIPProvider.tsx +0 -56
  220. package/src/Prebuilt/components/PIP/PIPWindow.tsx +0 -13
  221. package/src/Prebuilt/components/PIP/SetupMediaSession.js +0 -60
  222. package/src/Prebuilt/components/PIP/context.ts +0 -10
  223. package/src/Prebuilt/components/PIP/index.jsx +0 -6
  224. package/src/Prebuilt/components/PIP/pip.test.js +0 -72
  225. package/src/Prebuilt/components/PIP/pipUtils.js +0 -183
  226. package/src/Prebuilt/components/PIP/usePIPChat.tsx +0 -105
  227. package/src/Prebuilt/components/PIP/usePIPWindow.tsx +0 -12
  228. package/src/Prebuilt/components/Pagination.tsx +0 -60
  229. package/src/Prebuilt/components/Polls/CreatePollQuiz/PollsQuizMenu.tsx +0 -248
  230. package/src/Prebuilt/components/Polls/CreateQuestions/CreateQuestions.jsx +0 -142
  231. package/src/Prebuilt/components/Polls/CreateQuestions/DeleteQuestionModal.tsx +0 -74
  232. package/src/Prebuilt/components/Polls/CreateQuestions/QuestionForm.tsx +0 -324
  233. package/src/Prebuilt/components/Polls/CreateQuestions/SavedQuestion.tsx +0 -64
  234. package/src/Prebuilt/components/Polls/Polls.tsx +0 -31
  235. package/src/Prebuilt/components/Polls/Voting/LeaderboardEntry.tsx +0 -76
  236. package/src/Prebuilt/components/Polls/Voting/LeaderboardSummary.tsx +0 -116
  237. package/src/Prebuilt/components/Polls/Voting/PeerParticipationSummary.tsx +0 -60
  238. package/src/Prebuilt/components/Polls/Voting/QuestionCard.jsx +0 -221
  239. package/src/Prebuilt/components/Polls/Voting/StandardVoting.tsx +0 -47
  240. package/src/Prebuilt/components/Polls/Voting/StatisticBox.tsx +0 -20
  241. package/src/Prebuilt/components/Polls/Voting/TimedVoting.tsx +0 -55
  242. package/src/Prebuilt/components/Polls/Voting/Voting.tsx +0 -143
  243. package/src/Prebuilt/components/Polls/Voting/useQuizSummary.tsx +0 -50
  244. package/src/Prebuilt/components/Polls/common/Line.tsx +0 -4
  245. package/src/Prebuilt/components/Polls/common/MultipleChoiceOptions.jsx +0 -115
  246. package/src/Prebuilt/components/Polls/common/OptionInputWithDelete.tsx +0 -38
  247. package/src/Prebuilt/components/Polls/common/SingleChoiceOptions.jsx +0 -140
  248. package/src/Prebuilt/components/Polls/common/StatusIndicator.tsx +0 -35
  249. package/src/Prebuilt/components/Polls/common/VoteCount.tsx +0 -15
  250. package/src/Prebuilt/components/Polls/common/VoteProgress.tsx +0 -18
  251. package/src/Prebuilt/components/Polls/common/constants.ts +0 -5
  252. package/src/Prebuilt/components/Polls/common/utils.ts +0 -22
  253. package/src/Prebuilt/components/Preview/PreviewForm.tsx +0 -94
  254. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +0 -292
  255. package/src/Prebuilt/components/Preview/PreviewScreen.tsx +0 -38
  256. package/src/Prebuilt/components/PreviousRoleInMetadata.tsx +0 -20
  257. package/src/Prebuilt/components/RaiseHand.tsx +0 -30
  258. package/src/Prebuilt/components/RemoveParticipant.tsx +0 -35
  259. package/src/Prebuilt/components/RoleChangeModal.tsx +0 -188
  260. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +0 -75
  261. package/src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx +0 -94
  262. package/src/Prebuilt/components/RoomDetails/Duration.tsx +0 -26
  263. package/src/Prebuilt/components/RoomDetails/RoomDetailsPane.tsx +0 -63
  264. package/src/Prebuilt/components/RoomDetails/RoomDetailsRow.tsx +0 -23
  265. package/src/Prebuilt/components/RoomDetails/RoomDetailsSheet.tsx +0 -45
  266. package/src/Prebuilt/components/ScreenShareToggle.jsx +0 -58
  267. package/src/Prebuilt/components/ScreenshareDisplay.tsx +0 -39
  268. package/src/Prebuilt/components/ScreenshareTile.tsx +0 -134
  269. package/src/Prebuilt/components/SecondaryTiles.tsx +0 -81
  270. package/src/Prebuilt/components/Settings/DeviceSettings.jsx +0 -208
  271. package/src/Prebuilt/components/Settings/LayoutSettings.tsx +0 -74
  272. package/src/Prebuilt/components/Settings/NotificationSettings.tsx +0 -66
  273. package/src/Prebuilt/components/Settings/SettingsModal.jsx +0 -301
  274. package/src/Prebuilt/components/Settings/StartRecording.jsx +0 -101
  275. package/src/Prebuilt/components/Settings/SwitchWithLabel.tsx +0 -53
  276. package/src/Prebuilt/components/Settings/common.ts +0 -16
  277. package/src/Prebuilt/components/ShareMenuIcon.jsx +0 -27
  278. package/src/Prebuilt/components/SidePaneTabs.tsx +0 -214
  279. package/src/Prebuilt/components/StatsForNerds.jsx +0 -373
  280. package/src/Prebuilt/components/Streaming/Common.jsx +0 -143
  281. package/src/Prebuilt/components/Streaming/ResolutionInput.jsx +0 -88
  282. package/src/Prebuilt/components/TileMenu/TileMenu.tsx +0 -148
  283. package/src/Prebuilt/components/TileMenu/TileMenuContent.tsx +0 -393
  284. package/src/Prebuilt/components/TileMenu/utils.ts +0 -7
  285. package/src/Prebuilt/components/Toast/Toast.jsx +0 -17
  286. package/src/Prebuilt/components/Toast/ToastBatcher.js +0 -64
  287. package/src/Prebuilt/components/Toast/ToastConfig.jsx +0 -177
  288. package/src/Prebuilt/components/Toast/ToastContainer.jsx +0 -30
  289. package/src/Prebuilt/components/Toast/ToastManager.js +0 -44
  290. package/src/Prebuilt/components/VideoLayouts/EqualProminence.tsx +0 -62
  291. package/src/Prebuilt/components/VideoLayouts/Grid.tsx +0 -43
  292. package/src/Prebuilt/components/VideoLayouts/GridLayout.tsx +0 -155
  293. package/src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx +0 -91
  294. package/src/Prebuilt/components/VideoLayouts/RoleProminence.tsx +0 -66
  295. package/src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx +0 -74
  296. package/src/Prebuilt/components/VideoLayouts/WhiteboardLayout.tsx +0 -93
  297. package/src/Prebuilt/components/VideoLayouts/interface.ts +0 -11
  298. package/src/Prebuilt/components/VideoTile.tsx +0 -203
  299. package/src/Prebuilt/components/VirtualBackground/VBCollection.tsx +0 -52
  300. package/src/Prebuilt/components/VirtualBackground/VBHandler.tsx +0 -130
  301. package/src/Prebuilt/components/VirtualBackground/VBOption.tsx +0 -57
  302. package/src/Prebuilt/components/VirtualBackground/VBPicker.tsx +0 -252
  303. package/src/Prebuilt/components/VirtualBackground/VBToggle.tsx +0 -50
  304. package/src/Prebuilt/components/hooks/useAudioOutputTest.tsx +0 -20
  305. package/src/Prebuilt/components/hooks/useAutoStartStreaming.tsx +0 -70
  306. package/src/Prebuilt/components/hooks/useChatBlacklist.ts +0 -29
  307. package/src/Prebuilt/components/hooks/useCloseScreenshareWhiteboard.tsx +0 -17
  308. package/src/Prebuilt/components/hooks/useDropdownList.ts +0 -24
  309. package/src/Prebuilt/components/hooks/useDropdownSelection.jsx +0 -3
  310. package/src/Prebuilt/components/hooks/useFullscreen.ts +0 -46
  311. package/src/Prebuilt/components/hooks/useGroupOnStageActions.tsx +0 -54
  312. package/src/Prebuilt/components/hooks/useMetadata.tsx +0 -56
  313. package/src/Prebuilt/components/hooks/usePeerOnStageActions.tsx +0 -49
  314. package/src/Prebuilt/components/hooks/usePinnedBy.tsx +0 -22
  315. package/src/Prebuilt/components/hooks/usePinnedMessages.ts +0 -78
  316. package/src/Prebuilt/components/hooks/usePlaylist.js +0 -25
  317. package/src/Prebuilt/components/hooks/usePlaylistMusic.js +0 -35
  318. package/src/Prebuilt/components/hooks/useRedirectToLeave.tsx +0 -23
  319. package/src/Prebuilt/components/hooks/useRoleProminencePeers.tsx +0 -39
  320. package/src/Prebuilt/components/hooks/useScreenshareAudio.js +0 -28
  321. package/src/Prebuilt/components/hooks/useTileLayout.tsx +0 -128
  322. package/src/Prebuilt/components/hooks/useUnreadPollQuizPresent.tsx +0 -17
  323. package/src/Prebuilt/components/hooks/useUserPreferences.jsx +0 -26
  324. package/src/Prebuilt/components/hooks/useVideoTileLayout.ts +0 -26
  325. package/src/Prebuilt/components/init/Init.jsx +0 -31
  326. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +0 -42
  327. package/src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx +0 -31
  328. package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +0 -32
  329. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +0 -211
  330. package/src/Prebuilt/components/pdfAnnotator/submitPdf.jsx +0 -48
  331. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +0 -71
  332. package/src/Prebuilt/components/peerTileUtils.tsx +0 -42
  333. package/src/Prebuilt/images/android-perm-1.png +0 -0
  334. package/src/Prebuilt/images/empty-chat.svg +0 -12
  335. package/src/Prebuilt/images/ios-perm-0.png +0 -0
  336. package/src/Prebuilt/images/pdf-share.png +0 -0
  337. package/src/Prebuilt/images/rtmp.png +0 -0
  338. package/src/Prebuilt/images/screen-share.png +0 -0
  339. package/src/Prebuilt/images/transaction_error.svg +0 -12
  340. package/src/Prebuilt/index.ts +0 -1
  341. package/src/Prebuilt/layouts/EmbedView.jsx +0 -94
  342. package/src/Prebuilt/layouts/HLSView.jsx +0 -747
  343. package/src/Prebuilt/layouts/PDFView.jsx +0 -67
  344. package/src/Prebuilt/layouts/Sheet.tsx +0 -14
  345. package/src/Prebuilt/layouts/SidePane.tsx +0 -241
  346. package/src/Prebuilt/layouts/VideoStreamingSection.tsx +0 -164
  347. package/src/Prebuilt/layouts/WaitingView.tsx +0 -52
  348. package/src/Prebuilt/plugins/CaptionsViewer.tsx +0 -261
  349. package/src/Prebuilt/plugins/FlyingEmoji.jsx +0 -154
  350. package/src/Prebuilt/plugins/RemoteStopScreenshare.jsx +0 -18
  351. package/src/Prebuilt/plugins/transcription/Transcriber.js +0 -216
  352. package/src/Prebuilt/plugins/transcription/TranscriptionButton.jsx +0 -138
  353. package/src/Prebuilt/plugins/transcription/index.jsx +0 -1
  354. package/src/Prebuilt/primitives/DialogContent.jsx +0 -285
  355. package/src/Prebuilt/primitives/DropdownTrigger.jsx +0 -46
  356. package/src/Prebuilt/provider/roomLayoutProvider/constants/index.ts +0 -60
  357. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +0 -88
  358. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useInsetEnabled.ts +0 -10
  359. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useRoomLayoutScreen.ts +0 -112
  360. package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +0 -53
  361. package/src/Prebuilt/services/FeatureFlags.jsx +0 -46
  362. package/src/Progress/index.tsx +0 -17
  363. package/src/QRCode/QRCode.mdx +0 -9
  364. package/src/QRCode/QRCode.stories.tsx +0 -29
  365. package/src/QRCode/QRCode.tsx +0 -6
  366. package/src/QRCode/index.tsx +0 -1
  367. package/src/RadioGroup/RadioGroup.stories.tsx +0 -32
  368. package/src/RadioGroup/RadioGroup.tsx +0 -33
  369. package/src/RadioGroup/index.tsx +0 -1
  370. package/src/ReactSelect/ReactSelect.stories.tsx +0 -83
  371. package/src/ReactSelect/ReactSelect.tsx +0 -97
  372. package/src/ReactSelect/index.ts +0 -1
  373. package/src/Select/Select.stories.tsx +0 -33
  374. package/src/Select/Select.tsx +0 -63
  375. package/src/Select/index.ts +0 -1
  376. package/src/Sheet/Sheet.mdx +0 -19
  377. package/src/Sheet/Sheet.stories.tsx +0 -103
  378. package/src/Sheet/Sheet.tsx +0 -122
  379. package/src/Sheet/index.ts +0 -1
  380. package/src/Slider/Slider.stories.tsx +0 -21
  381. package/src/Slider/Slider.tsx +0 -70
  382. package/src/Slider/index.ts +0 -1
  383. package/src/Stats/Stats.tsx +0 -243
  384. package/src/Stats/StyledStats.tsx +0 -57
  385. package/src/Stats/formatBytes.ts +0 -19
  386. package/src/Stats/index.tsx +0 -2
  387. package/src/Stats/useQoE.ts +0 -79
  388. package/src/Switch/Switch.mdx +0 -11
  389. package/src/Switch/Switch.stories.tsx +0 -46
  390. package/src/Switch/Switch.tsx +0 -52
  391. package/src/Switch/index.ts +0 -1
  392. package/src/Tabs/Tabs.stories.tsx +0 -77
  393. package/src/Tabs/Tabs.tsx +0 -41
  394. package/src/Tabs/index.tsx +0 -1
  395. package/src/Text/Text.stories.tsx +0 -21
  396. package/src/Text/Text.tsx +0 -149
  397. package/src/Text/index.tsx +0 -1
  398. package/src/TextArea/TextArea.tsx +0 -30
  399. package/src/TextArea/index.tsx +0 -1
  400. package/src/Theme/Theme.stories.mdx +0 -8
  401. package/src/Theme/ThemeProvider.tsx +0 -98
  402. package/src/Theme/ThemeStory.jsx +0 -56
  403. package/src/Theme/base.config.ts +0 -236
  404. package/src/Theme/index.tsx +0 -2
  405. package/src/Theme/stitches.config.ts +0 -88
  406. package/src/Theme/useSSR.tsx +0 -24
  407. package/src/TileMenu/StyledMenuTile.tsx +0 -105
  408. package/src/TileMenu/TileMenu.tsx +0 -98
  409. package/src/TileMenu/index.tsx +0 -1
  410. package/src/Toast/AppToast.stories.tsx +0 -56
  411. package/src/Toast/Toast.mdx +0 -19
  412. package/src/Toast/Toast.stories.tsx +0 -57
  413. package/src/Toast/Toast.tsx +0 -170
  414. package/src/Toast/index.tsx +0 -1
  415. package/src/Tooltip/Tooltip.stories.tsx +0 -62
  416. package/src/Tooltip/Tooltip.tsx +0 -79
  417. package/src/Tooltip/index.ts +0 -1
  418. package/src/Video/UseVideo.mdx +0 -22
  419. package/src/Video/UseVideo.stories.tsx +0 -26
  420. package/src/Video/Video.mdx +0 -24
  421. package/src/Video/Video.stories.tsx +0 -27
  422. package/src/Video/Video.tsx +0 -61
  423. package/src/Video/index.tsx +0 -1
  424. package/src/VideoList/StyledVideoList.tsx +0 -39
  425. package/src/VideoList/VideoList.stories.tsx +0 -92
  426. package/src/VideoList/index.tsx +0 -2
  427. package/src/VideoList/videoListUtils.tsx +0 -20
  428. package/src/VideoTile/StyledVideoTile.tsx +0 -146
  429. package/src/VideoTile/VideoTile.mdx +0 -28
  430. package/src/VideoTile/VideoTile.stories.tsx +0 -32
  431. package/src/VideoTile/index.tsx +0 -1
  432. package/src/context/DialogContext.tsx +0 -13
  433. package/src/fixtures/chats.ts +0 -25
  434. package/src/fixtures/peers.ts +0 -27
  435. package/src/fixtures/tracks.ts +0 -11
  436. package/src/hooks/useDialogContainerSelector.tsx +0 -7
  437. package/src/index.ts +0 -41
  438. package/src/store/SetupFakeStore.ts +0 -33
  439. package/src/store/StorybookSDK.ts +0 -231
  440. package/src/utils/animations.ts +0 -114
  441. package/src/utils/index.ts +0 -2
  442. package/src/utils/styles.ts +0 -22
@@ -1,136 +0,0 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import Draggable from 'react-draggable';
3
- import { useMedia } from 'react-use';
4
- import {
5
- selectIsAllowedToPublish,
6
- selectLocalPeer,
7
- selectPeerByID,
8
- selectVideoTrackByID,
9
- useHMSStore,
10
- } from '@100mslive/react-sdk';
11
- import { ExpandIcon } from '@100mslive/react-icons';
12
- import { Box, Flex } from '../../Layout';
13
- import { Text } from '../../Text';
14
- import { config as cssConfig } from '../../Theme';
15
- // @ts-ignore: No implicit Any
16
- import IconButton from '../IconButton';
17
- // @ts-ignore: No implicit Any
18
- import { AudioVideoToggle } from './AudioVideoToggle';
19
- // @ts-ignore: No implicit Any
20
- import VideoTile from './VideoTile';
21
- // @ts-ignore: No implicit Any
22
- import { useSetAppDataByKey } from './AppData/useUISettings';
23
- import { useVideoTileContext } from './hooks/useVideoTileLayout';
24
- // @ts-ignore: No implicit Any
25
- import { APP_DATA } from '../common/constants';
26
-
27
- const MinimisedTile = ({ setMinimised }: { setMinimised: (value: boolean) => void }) => {
28
- return (
29
- <Flex align="center" css={{ gap: '$6', r: '$1', bg: '$surface_default', p: '$4', color: '$on_surface_high' }}>
30
- <AudioVideoToggle hideOptions={true} />
31
- <Text>You</Text>
32
- <IconButton
33
- className="__cancel-drag-event"
34
- onClick={() => setMinimised(false)}
35
- css={{ bg: 'transparent', border: 'transparent' }}
36
- >
37
- <ExpandIcon />
38
- </IconButton>
39
- </Flex>
40
- );
41
- };
42
-
43
- const insetHeightPx = 180;
44
- const insetMaxWidthPx = 240;
45
- const defaultMobileAspectRatio = 9 / 16;
46
- const desktopAspectRatio = 1 / defaultMobileAspectRatio;
47
-
48
- export const InsetTile = ({ peerId }: { peerId?: string }) => {
49
- const isMobile = useMedia(cssConfig.media.md);
50
- const isLandscape = useMedia(cssConfig.media.ls);
51
- const selector = peerId ? selectPeerByID(peerId) : selectLocalPeer;
52
- const peer = useHMSStore(selector);
53
- const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
54
- const videoTrack = useHMSStore(selectVideoTrackByID(peer?.videoTrack));
55
- const isAllowedToPublish = useHMSStore(selectIsAllowedToPublish);
56
- const videoTileProps = useVideoTileContext();
57
- let aspectRatio = isMobile ? defaultMobileAspectRatio : desktopAspectRatio;
58
- if (videoTrack?.width && videoTrack?.height && !isMobile) {
59
- aspectRatio = videoTrack.width / videoTrack.height;
60
- }
61
- let height = insetHeightPx;
62
- let width = height * aspectRatio;
63
- // Convert to 16/9 in landscape mode with a max width of 240
64
- if (isLandscape && width > insetMaxWidthPx) {
65
- width = 240;
66
- height = width / aspectRatio;
67
- }
68
-
69
- const nodeRef = useRef<HTMLDivElement>(null);
70
-
71
- useEffect(() => {
72
- const node = nodeRef.current;
73
- if (!node || !window.ResizeObserver) {
74
- return;
75
- }
76
- const resizeObserver = new ResizeObserver(entries => {
77
- entries.forEach(entry => {
78
- if (entry.target === node.parentElement) {
79
- // reset to original position on resize
80
- node.style.transform = `translate(0,0)`;
81
- }
82
- });
83
- });
84
- node.parentElement && resizeObserver.observe(node.parentElement);
85
- return () => {
86
- node?.parentElement && resizeObserver?.unobserve(node.parentElement);
87
- resizeObserver?.disconnect();
88
- };
89
- }, []);
90
-
91
- if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
92
- return null;
93
- }
94
-
95
- return (
96
- <Draggable bounds="parent" nodeRef={nodeRef} cancel=".__cancel-drag-event">
97
- <Box
98
- ref={nodeRef}
99
- css={{
100
- position: 'absolute',
101
- bottom: 0,
102
- right: 0,
103
- zIndex: 10,
104
- boxShadow: '0 0 8px 0 rgba(0,0,0,0.3)',
105
- r: '$2',
106
- ...(!minimised
107
- ? {
108
- aspectRatio: `${aspectRatio}`,
109
- h: height,
110
- }
111
- : {}),
112
- }}
113
- >
114
- {minimised ? (
115
- <MinimisedTile setMinimised={setMinimised} />
116
- ) : (
117
- <VideoTile
118
- peerId={peer?.id}
119
- trackId={peer?.videoTrack}
120
- rootCSS={{
121
- size: '100%',
122
- padding: 0,
123
- }}
124
- width={width}
125
- height={height}
126
- containerCSS={{ background: '$surface_default' }}
127
- canMinimise
128
- isDragabble
129
- {...videoTileProps}
130
- hideParticipantNameOnTile
131
- />
132
- )}
133
- </Box>
134
- </Draggable>
135
- );
136
- };
@@ -1,112 +0,0 @@
1
- import React, { useCallback, useState } from 'react';
2
- import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from '@100mslive/react-icons';
3
- import { LayoutMode, LayoutModeIconMapping, LayoutModeKeys } from './Settings/LayoutSettings';
4
- import { Flex } from '../../Layout';
5
- import { Popover } from '../../Popover';
6
- import { Text } from '../../Text';
7
- // @ts-ignore: No implicit Any
8
- import { useSetUiSettings } from '../components/AppData/useUISettings';
9
- import { UI_SETTINGS } from '../common/constants';
10
-
11
- export const LayoutModeSelector = () => {
12
- const [open, setOpen] = useState(false);
13
- const [layoutMode, setLayoutMode] = useSetUiSettings(UI_SETTINGS.layoutMode);
14
- const updateLayoutMode = useCallback(
15
- (value: string) => {
16
- setLayoutMode(value);
17
- setOpen(false);
18
- },
19
- [setLayoutMode, setOpen],
20
- );
21
- return (
22
- <Popover.Root open={open} onOpenChange={setOpen}>
23
- <Popover.Trigger asChild>
24
- <Flex
25
- align="center"
26
- css={{
27
- gap: '$4',
28
- color: open ? '$on_surface_low' : '$on_surface_medium',
29
- r: '$1',
30
- p: '$2 $4',
31
- height: '100%',
32
- }}
33
- >
34
- <Flex
35
- align="center"
36
- justify="center"
37
- css={{
38
- color: 'inherit',
39
- '& > svg': {
40
- w: '$9',
41
- h: '$9',
42
- },
43
- }}
44
- >
45
- {LayoutModeIconMapping[layoutMode as LayoutModeKeys]}
46
- </Flex>
47
- <Text variant="caption" css={{ color: 'inherit', lineHeight: '$sm' }}>
48
- {layoutMode}
49
- </Text>
50
- {open ? <ChevronUpIcon width={16} height={16} /> : <ChevronDownIcon width={16} height={16} />}
51
- </Flex>
52
- </Popover.Trigger>
53
- <Popover.Content
54
- css={{
55
- w: '10.75rem',
56
- r: '$1',
57
- py: '$4',
58
- px: 0,
59
- backgroundColor: '$surface_default',
60
- overflowY: 'auto',
61
- boxShadow: '0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23)',
62
- fontFamily: '$sans',
63
- color: '$on_surface_high',
64
- }}
65
- side="bottom"
66
- sideOffset={8}
67
- align="end"
68
- >
69
- {Object.keys(LayoutMode).map(key => {
70
- const value = LayoutMode[key as LayoutModeKeys];
71
- return (
72
- <Flex
73
- key={key}
74
- onClick={() => updateLayoutMode(value)}
75
- align="center"
76
- css={{
77
- gap: '$4',
78
- borderBottom: '1px solid $border_bright',
79
- p: '$8',
80
- '&:hover': {
81
- cursor: 'pointer',
82
- bg: '$surface_bright',
83
- },
84
- '&:focus-visible': {
85
- bg: '$surface_bright',
86
- },
87
- }}
88
- >
89
- <Flex
90
- align="center"
91
- justify="center"
92
- css={{
93
- color: '$on_surface_medium',
94
- '& > svg': {
95
- w: '$9',
96
- h: '$9',
97
- },
98
- }}
99
- >
100
- {LayoutModeIconMapping[value]}
101
- </Flex>
102
- <Text variant="caption" css={{ lineHeight: '$sm' }}>
103
- {value}
104
- </Text>
105
- {value === layoutMode ? <CheckIcon width={20} height={20} style={{ marginLeft: 'auto' }} /> : null}
106
- </Flex>
107
- );
108
- })}
109
- </Popover.Content>
110
- </Popover.Root>
111
- );
112
- };
@@ -1,166 +0,0 @@
1
- import React, { Fragment, useState } from 'react';
2
- import { ConferencingScreen } from '@100mslive/types-prebuilt';
3
- import { selectIsConnectedToRoom, selectPermissions, useHMSStore, useRecordingStreaming } from '@100mslive/react-sdk';
4
- import { ExitIcon, StopIcon, VerticalMenuIcon } from '@100mslive/react-icons';
5
- import { Dropdown } from '../../../Dropdown';
6
- import { Box, Flex } from '../../../Layout';
7
- import { Dialog } from '../../../Modal';
8
- import { Tooltip } from '../../../Tooltip';
9
- import { EndSessionContent } from './EndSessionContent';
10
- import { LeaveIconButton, MenuTriggerButton } from './LeaveAtoms';
11
- import { LeaveCard } from './LeaveCard';
12
- import { LeaveSessionContent } from './LeaveSessionContent';
13
- // @ts-ignore: No implicit Any
14
- import { useDropdownList } from '../hooks/useDropdownList';
15
-
16
- export const DesktopLeaveRoom = ({
17
- leaveRoom,
18
- screenType,
19
- endRoom,
20
- container,
21
- }: {
22
- leaveRoom: (options?: { endStream?: boolean; sendReason?: boolean }) => Promise<void>;
23
- screenType: keyof ConferencingScreen;
24
- endRoom: () => Promise<void>;
25
- container?: HTMLElement;
26
- }) => {
27
- const [open, setOpen] = useState(false);
28
- const [showLeaveRoomAlert, setShowLeaveRoomAlert] = useState(false);
29
- const [showEndStreamAlert, setShowEndStreamAlert] = useState(false);
30
- const isConnected = useHMSStore(selectIsConnectedToRoom);
31
- const permissions = useHMSStore(selectPermissions);
32
- const { isStreamingOn } = useRecordingStreaming();
33
- const showStream = screenType !== 'hls_live_streaming' && isStreamingOn && permissions?.hlsStreaming;
34
- const showLeaveOptions = (permissions?.hlsStreaming && isStreamingOn) || permissions?.endRoom;
35
-
36
- useDropdownList({ open: open || showEndStreamAlert || showLeaveRoomAlert, name: 'LeaveRoom' });
37
-
38
- if (!permissions || !isConnected) {
39
- return null;
40
- }
41
-
42
- return (
43
- <Fragment>
44
- {showLeaveOptions ? (
45
- <Flex>
46
- <LeaveIconButton
47
- key="LeaveRoom"
48
- data-testid="leave_room_btn"
49
- css={{
50
- borderTopRightRadius: 0,
51
- borderBottomRightRadius: 0,
52
- }}
53
- onClick={() => setShowLeaveRoomAlert(true)}
54
- >
55
- <Tooltip title="Leave Room">
56
- <Box>
57
- <ExitIcon style={{ transform: 'rotate(180deg)' }} />
58
- </Box>
59
- </Tooltip>
60
- </LeaveIconButton>
61
- <Dropdown.Root open={open} onOpenChange={setOpen} modal={false}>
62
- <Dropdown.Trigger
63
- asChild
64
- css={{
65
- '&[data-state="open"]': {
66
- bg: '$alert_error_dim',
67
- },
68
- }}
69
- >
70
- <MenuTriggerButton data-testid="leave_end_dropdown_trigger">
71
- <VerticalMenuIcon />
72
- </MenuTriggerButton>
73
- </Dropdown.Trigger>
74
- <Dropdown.Portal container={container}>
75
- <Dropdown.Content css={{ p: 0, w: '$100' }} alignOffset={-50} sideOffset={10}>
76
- <Dropdown.Item
77
- css={{
78
- bg: '$surface_dim',
79
- color: '$on_surface_medium',
80
- '&:hover': { bg: '$surface_default', color: '$on_surface_high' },
81
- p: '0',
82
- }}
83
- data-testid="just_leave_btn"
84
- >
85
- <LeaveCard
86
- title={showStream ? 'Leave Stream' : 'Leave Session'}
87
- subtitle={`Others will continue after you leave. You can join the ${
88
- showStream ? 'stream' : 'session'
89
- } again.`}
90
- bg=""
91
- titleColor="$on_surface_high"
92
- icon={<ExitIcon height={24} width={24} style={{ transform: 'rotate(180deg)' }} />}
93
- onClick={async () => await leaveRoom({ sendReason: true })}
94
- css={{ p: '$8 $4' }}
95
- />
96
- </Dropdown.Item>
97
-
98
- <Dropdown.Item
99
- css={{
100
- bg: '$alert_error_dim',
101
- color: '$alert_error_bright',
102
- '&:hover': { bg: '$alert_error_dim', color: '$alert_error_brighter' },
103
- p: '0',
104
- }}
105
- data-testid="end_room_btn"
106
- >
107
- <LeaveCard
108
- title={showStream ? 'End Stream' : 'End Session'}
109
- subtitle={`The ${
110
- showStream ? 'stream' : 'session'
111
- } will end for everyone. You can't undo this action.`}
112
- bg=""
113
- titleColor="$alert_error_brighter"
114
- icon={<StopIcon height={24} width={24} />}
115
- onClick={() => {
116
- setOpen(false);
117
- setShowEndStreamAlert(true);
118
- }}
119
- css={{ p: '$8 $4' }}
120
- />
121
- </Dropdown.Item>
122
- </Dropdown.Content>
123
- </Dropdown.Portal>
124
- </Dropdown.Root>
125
- </Flex>
126
- ) : (
127
- <LeaveIconButton
128
- onClick={() => {
129
- setShowLeaveRoomAlert(true);
130
- }}
131
- key="LeaveRoom"
132
- data-testid="leave_room_btn"
133
- >
134
- <Tooltip title="Leave Room">
135
- <Box>
136
- <ExitIcon style={{ transform: 'rotate(180deg)' }} />
137
- </Box>
138
- </Tooltip>
139
- </LeaveIconButton>
140
- )}
141
-
142
- <Dialog.Root open={showEndStreamAlert} modal={false}>
143
- <Dialog.Portal>
144
- <Dialog.Overlay />
145
- <Dialog.Content css={{ w: 'min(420px, 90%)', p: '$8', bg: '$surface_dim' }}>
146
- <EndSessionContent
147
- setShowEndStreamAlert={setShowEndStreamAlert}
148
- leaveRoom={isStreamingOn ? () => leaveRoom({ endStream: true }) : endRoom}
149
- isStreamingOn={isStreamingOn}
150
- isModal
151
- />
152
- </Dialog.Content>
153
- </Dialog.Portal>
154
- </Dialog.Root>
155
-
156
- <Dialog.Root open={showLeaveRoomAlert} modal={false}>
157
- <Dialog.Portal>
158
- <Dialog.Overlay />
159
- <Dialog.Content css={{ w: 'min(420px, 90%)', p: '$8', bg: '$surface_dim' }}>
160
- <LeaveSessionContent setShowLeaveRoomAlert={setShowLeaveRoomAlert} leaveRoom={leaveRoom} isModal />
161
- </Dialog.Content>
162
- </Dialog.Portal>
163
- </Dialog.Root>
164
- </Fragment>
165
- );
166
- };
@@ -1,64 +0,0 @@
1
- import React from 'react';
2
- import { AlertTriangleIcon, CrossIcon } from '@100mslive/react-icons';
3
- import { Button } from '../../../Button';
4
- import { Box, Flex } from '../../../Layout';
5
- import { Text } from '../../../Text';
6
-
7
- export const EndSessionContent = ({
8
- setShowEndStreamAlert,
9
- leaveRoom,
10
- isModal = false,
11
- isStreamingOn = false,
12
- }: {
13
- setShowEndStreamAlert: (value: boolean) => void;
14
- leaveRoom: (options?: { endStream?: boolean }) => Promise<void>;
15
- isModal?: boolean;
16
- isStreamingOn: boolean;
17
- }) => {
18
- return (
19
- <Box>
20
- <Flex
21
- css={{
22
- color: '$alert_error_default',
23
- display: 'flex',
24
- alignItems: 'center',
25
- }}
26
- >
27
- <AlertTriangleIcon style={{ marginRight: '0.5rem' }} />
28
- <Text variant="lg" css={{ color: 'inherit', fontWeight: '$semiBold' }}>
29
- End {isStreamingOn ? 'Stream' : 'Session'}
30
- </Text>
31
- {isModal ? null : (
32
- <Box css={{ color: '$on_surface_high', ml: 'auto' }} onClick={() => setShowEndStreamAlert(false)}>
33
- <CrossIcon />
34
- </Box>
35
- )}
36
- </Flex>
37
- <Text variant="sm" css={{ color: '$on_surface_medium', mb: '$8', mt: '$4' }}>
38
- The {isStreamingOn ? 'stream' : 'session'} will end for everyone. You can't undo this action.
39
- </Text>
40
- <Flex align="center" justify="between" css={{ w: '100%', gap: '$8' }}>
41
- <Button
42
- outlined
43
- variant="standard"
44
- css={{ w: '100%', '@md': { display: 'none' } }}
45
- onClick={() => setShowEndStreamAlert(false)}
46
- >
47
- Cancel
48
- </Button>
49
- <Button
50
- variant="danger"
51
- css={{ w: '100%' }}
52
- onClick={async () => {
53
- await leaveRoom({ endStream: true });
54
- setShowEndStreamAlert(false);
55
- }}
56
- id="stopStream"
57
- data-testid="stop_stream_btn"
58
- >
59
- End {isStreamingOn ? 'Stream' : 'Session'}
60
- </Button>
61
- </Flex>
62
- </Box>
63
- );
64
- };
@@ -1,26 +0,0 @@
1
- import { IconButton } from '../../../IconButton';
2
- import { styled } from '../../../Theme';
3
-
4
- export const LeaveIconButton = styled(IconButton, {
5
- color: '$on_primary_high',
6
- h: '$14',
7
- px: '$4',
8
- r: '$1',
9
- bg: '$alert_error_default',
10
- '&:not([disabled]):hover': {
11
- bg: '$alert_error_bright',
12
- },
13
- '&:not([disabled]):active': {
14
- bg: '$alert_error_default',
15
- },
16
- '@md': {
17
- mx: 0,
18
- },
19
- });
20
-
21
- export const MenuTriggerButton = styled(LeaveIconButton, {
22
- borderLeft: '1px solid $alert_error_dim',
23
- borderTopLeftRadius: 0,
24
- borderBottomLeftRadius: 0,
25
- px: '$2',
26
- });
@@ -1,36 +0,0 @@
1
- import React from 'react';
2
- import { Box, Flex } from '../../../Layout';
3
- import { Text } from '../../../Text';
4
- import { CSS } from '../../../Theme';
5
-
6
- export const LeaveCard = ({
7
- icon,
8
- title,
9
- subtitle,
10
- onClick,
11
- bg,
12
- titleColor,
13
- css = {},
14
- }: {
15
- icon: React.JSX.Element;
16
- title: string;
17
- subtitle: string;
18
- onClick: () => void;
19
- titleColor: string;
20
- bg: string;
21
- css?: CSS;
22
- }) => {
23
- return (
24
- <Flex css={{ p: '$10', flexGrow: 1, gap: '$8', bg, ...css }} onClick={onClick}>
25
- <Box css={{ color: titleColor }}>{icon}</Box>
26
- <Box css={{ gap: '$2' }}>
27
- <Text variant="lg" css={{ color: titleColor }}>
28
- {title}
29
- </Text>
30
- <Text variant="sm" css={{ c: 'inherit' }}>
31
- {subtitle}
32
- </Text>
33
- </Box>
34
- </Flex>
35
- );
36
- };
@@ -1,82 +0,0 @@
1
- import React from 'react';
2
- import { useMedia } from 'react-use';
3
- import { ConferencingScreen } from '@100mslive/types-prebuilt';
4
- import {
5
- HMSPeer,
6
- HMSRole,
7
- selectHLSState,
8
- selectIsConnectedToRoom,
9
- selectPeersByCondition,
10
- selectPermissions,
11
- selectRolesMap,
12
- useHMSActions,
13
- useHMSStore,
14
- } from '@100mslive/react-sdk';
15
- import { config as cssConfig } from '../../../Theme';
16
- // @ts-ignore: No implicit Any
17
- import { ToastManager } from '../Toast/ToastManager';
18
- import { DesktopLeaveRoom } from './DesktopLeaveRoom';
19
- import { MwebLeaveRoom } from './MwebLeaveRoom';
20
- import { useLandscapeHLSStream, useMobileHLSStream } from '../../common/hooks';
21
-
22
- export const LeaveRoom = ({
23
- screenType,
24
- container,
25
- }: {
26
- screenType: keyof ConferencingScreen;
27
- container?: HTMLElement;
28
- }) => {
29
- const isConnected = useHMSStore(selectIsConnectedToRoom);
30
- const permissions = useHMSStore(selectPermissions);
31
- const isMobile = useMedia(cssConfig.media.md);
32
- const rolesMap: Record<string, HMSRole> = useHMSStore(selectRolesMap);
33
- const streamingPermissionRoles = Object.keys(rolesMap).filter(roleName => {
34
- const roleObj = rolesMap[roleName];
35
- return roleObj.permissions.hlsStreaming;
36
- });
37
- const peersWithStreamingRights = useHMSStore(
38
- selectPeersByCondition((peer: HMSPeer) => streamingPermissionRoles.includes(peer.roleName || '')),
39
- );
40
- const hlsState = useHMSStore(selectHLSState);
41
- const hmsActions = useHMSActions();
42
- const isMobileHLSStream = useMobileHLSStream();
43
- const isLandscapeHLSStream = useLandscapeHLSStream();
44
-
45
- const stopStream = async (stop_reason = '') => {
46
- try {
47
- if (permissions?.hlsStreaming) {
48
- console.log('Stopping HLS stream');
49
- await hmsActions.stopHLSStreaming({ stop_reason });
50
- ToastManager.addToast({ title: 'Stopping the stream' });
51
- }
52
- } catch (e) {
53
- console.error('Error stopping stream', e);
54
- ToastManager.addToast({ title: 'Error in stopping the stream', type: 'error' });
55
- }
56
- };
57
-
58
- const endRoom = async () => {
59
- await hmsActions.endRoom(false, 'End Room');
60
- };
61
-
62
- const leaveRoom = async (
63
- options: { endStream?: boolean; sendReason?: boolean } = { endStream: false, sendReason: false },
64
- ) => {
65
- if (options.endStream || (hlsState.running && peersWithStreamingRights.length === 1)) {
66
- await stopStream(options.sendReason ? 'last publisher left' : '');
67
- }
68
- await hmsActions.leave();
69
- };
70
-
71
- if (!permissions || !isConnected) {
72
- return null;
73
- }
74
- if (isMobileHLSStream || isLandscapeHLSStream) {
75
- return <MwebLeaveRoom leaveRoom={leaveRoom} endRoom={endRoom} container={container} />;
76
- }
77
- return isMobile ? (
78
- <MwebLeaveRoom leaveRoom={leaveRoom} endRoom={endRoom} container={container} />
79
- ) : (
80
- <DesktopLeaveRoom leaveRoom={leaveRoom} screenType={screenType} endRoom={endRoom} container={container} />
81
- );
82
- };
@@ -1,61 +0,0 @@
1
- import React from 'react';
2
- import { AlertTriangleIcon, CrossIcon } from '@100mslive/react-icons';
3
- import { Button } from '../../../Button';
4
- import { Box, Flex } from '../../../Layout';
5
- import { Text } from '../../../Text';
6
-
7
- export const LeaveSessionContent = ({
8
- setShowLeaveRoomAlert,
9
- leaveRoom,
10
- isModal = false,
11
- }: {
12
- setShowLeaveRoomAlert: (value: boolean) => void;
13
- leaveRoom: (options?: { endStream?: boolean; sendReason?: boolean }) => Promise<void>;
14
- isModal?: boolean;
15
- }) => {
16
- return (
17
- <Box>
18
- <Flex
19
- css={{
20
- color: '$alert_error_default',
21
- display: 'flex',
22
- alignItems: 'center',
23
- }}
24
- >
25
- <AlertTriangleIcon style={{ marginRight: '0.5rem' }} />
26
- <Text variant="lg" css={{ color: 'inherit', fontWeight: '$semiBold' }}>
27
- Leave
28
- </Text>
29
- {isModal ? null : (
30
- <Box css={{ color: '$on_surface_high', ml: 'auto' }} onClick={() => setShowLeaveRoomAlert(false)}>
31
- <CrossIcon />
32
- </Box>
33
- )}
34
- </Flex>
35
- <Text variant="sm" css={{ color: '$on_surface_low', mb: '$8', mt: '$4' }}>
36
- Others will continue after you leave. You can join the session again.
37
- </Text>
38
- <Flex align="center" justify="between" css={{ w: '100%', gap: '$8' }}>
39
- <Button
40
- outlined
41
- variant="standard"
42
- css={{ w: '100%', '@md': { display: 'none' } }}
43
- onClick={() => setShowLeaveRoomAlert(false)}
44
- >
45
- Cancel
46
- </Button>
47
- <Button
48
- variant="danger"
49
- css={{ w: '100%' }}
50
- onClick={async () => {
51
- await leaveRoom({ sendReason: true });
52
- }}
53
- id="leaveRoom"
54
- data-testid="leave_room"
55
- >
56
- Leave Session
57
- </Button>
58
- </Flex>
59
- </Box>
60
- );
61
- };