@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,282 +0,0 @@
1
- import React, { Fragment, useState } from 'react';
2
- import { HMSHLSPlayer } from '@100mslive/hls-player';
3
- import {
4
- ConferencingScreen,
5
- DefaultConferencingScreen_Elements,
6
- HLSLiveStreamingScreen_Elements,
7
- } from '@100mslive/types-prebuilt';
8
- import { match } from 'ts-pattern';
9
- import {
10
- HMSTranscriptionMode,
11
- selectAppData,
12
- selectIsTranscriptionAllowedByMode,
13
- selectIsTranscriptionEnabled,
14
- selectLocalPeerID,
15
- useHMSActions,
16
- useHMSStore,
17
- } from '@100mslive/react-sdk';
18
- import {
19
- BrbIcon,
20
- CheckIcon,
21
- HamburgerMenuIcon,
22
- InfoIcon,
23
- OpenCaptionIcon,
24
- PipIcon,
25
- SettingsIcon,
26
- } from '@100mslive/react-icons';
27
- import { Checkbox, Dropdown, Flex, Switch, Text, Tooltip } from '../../../..';
28
- import IconButton from '../../../IconButton';
29
- // @ts-ignore: No implicit any
30
- import { PIP } from '../../PIP';
31
- import { PIPChat } from '../../PIP/PIPChat';
32
- // @ts-ignore: No implicit any
33
- import { PIPChatOption } from '../../PIP/PIPChatOption';
34
- import { PictureInPicture } from '../../PIP/PIPManager';
35
- import { PIPWindow } from '../../PIP/PIPWindow';
36
- // @ts-ignore: No implicit any
37
- import { RoleChangeModal } from '../../RoleChangeModal';
38
- // @ts-ignore: No implicit any
39
- import SettingsModal from '../../Settings/SettingsModal';
40
- // @ts-ignore: No implicit any
41
- import StartRecording from '../../Settings/StartRecording';
42
- // @ts-ignore: No implicit any
43
- import { StatsForNerds } from '../../StatsForNerds';
44
- // @ts-ignore: No implicit any
45
- import { BulkRoleChangeModal } from '../BulkRoleChangeModal';
46
- import { CaptionModal } from '../CaptionModal';
47
- // @ts-ignore: No implicit any
48
- import { FullScreenItem } from '../FullScreenItem';
49
- import { MuteAllModal } from '../MuteAllModal';
50
- // @ts-ignore: No implicit any
51
- import { useIsSidepaneTypeOpen, useSidepaneToggle } from '../../AppData/useSidepane';
52
- // @ts-ignore: No implicit any
53
- import { useDropdownList } from '../../hooks/useDropdownList';
54
- import { useMyMetadata } from '../../hooks/useMetadata';
55
- // @ts-ignore: No implicit any
56
- import { usePIPChat } from '../../PIP/usePIPChat';
57
- // @ts-ignore: No implicit any
58
- import { APP_DATA, isMacOS, SIDE_PANE_OPTIONS } from '../../../common/constants';
59
-
60
- const MODALS = {
61
- CHANGE_NAME: 'changeName',
62
- SELF_ROLE_CHANGE: 'selfRoleChange',
63
- MORE_SETTINGS: 'moreSettings',
64
- START_RECORDING: 'startRecording',
65
- DEVICE_SETTINGS: 'deviceSettings',
66
- STATS_FOR_NERDS: 'statsForNerds',
67
- BULK_ROLE_CHANGE: 'bulkRoleChange',
68
- MUTE_ALL: 'muteAll',
69
- EMBED_URL: 'embedUrl',
70
- CAPTION: 'caption',
71
- };
72
-
73
- export const DesktopOptions = ({
74
- elements,
75
- screenType,
76
- }: {
77
- elements: DefaultConferencingScreen_Elements & HLSLiveStreamingScreen_Elements;
78
- screenType: keyof ConferencingScreen;
79
- }) => {
80
- const localPeerId = useHMSStore(selectLocalPeerID);
81
- const hmsActions = useHMSActions();
82
- const enablHlsStats = useHMSStore(selectAppData(APP_DATA.hlsStats));
83
- const [openModals, setOpenModals] = useState(new Set());
84
- const { isBRBOn, toggleBRB } = useMyMetadata();
85
- const isPipOn = PictureInPicture.isOn();
86
- const isBRBEnabled = !!elements?.brb;
87
- const isTranscriptionAllowed = useHMSStore(selectIsTranscriptionAllowedByMode(HMSTranscriptionMode.CAPTION));
88
- const isTranscriptionEnabled = useHMSStore(selectIsTranscriptionEnabled);
89
- const { isSupported, pipWindow, requestPipWindow } = usePIPChat();
90
- const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
91
- const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
92
- // Hide if pip chat is already open
93
- const showPipChatOption = !!elements?.chat && isSupported && !pipWindow;
94
-
95
- useDropdownList({ open: openModals.size > 0, name: 'MoreSettings' });
96
-
97
- const updateState = (modalName: string, value: boolean) => {
98
- setOpenModals(modals => {
99
- const copy = new Set(modals);
100
- if (value) {
101
- // avoiding extra set state trigger which removes currently open dialog by clearing set.
102
- copy.clear();
103
- copy.add(modalName);
104
- } else {
105
- copy.delete(modalName);
106
- }
107
- return copy;
108
- });
109
- };
110
-
111
- return (
112
- <Fragment>
113
- {isSupported && pipWindow ? (
114
- <PIPWindow pipWindow={pipWindow}>
115
- <PIPChat />
116
- </PIPWindow>
117
- ) : null}
118
- <Dropdown.Root
119
- open={openModals.has(MODALS.MORE_SETTINGS)}
120
- onOpenChange={value => updateState(MODALS.MORE_SETTINGS, value)}
121
- modal={false}
122
- >
123
- <Tooltip title="More options">
124
- <Dropdown.Trigger asChild data-testid="more_settings_btn">
125
- <IconButton>
126
- <HamburgerMenuIcon />
127
- </IconButton>
128
- </Dropdown.Trigger>
129
- </Tooltip>
130
-
131
- <Dropdown.Content
132
- sideOffset={5}
133
- onCloseAutoFocus={e => {
134
- e.preventDefault();
135
- }}
136
- align="end"
137
- css={{
138
- py: '$0',
139
- maxHeight: 'unset',
140
- '@md': { w: '$64' },
141
- "div[role='separator']:first-child": {
142
- display: 'none',
143
- },
144
- }}
145
- >
146
- {isBRBEnabled && screenType !== 'hls_live_streaming' ? (
147
- <Dropdown.Item onClick={toggleBRB} data-testid="brb_btn">
148
- <BrbIcon />
149
- <Text variant="sm" css={{ ml: '$4', color: '$on_surface_high' }}>
150
- Be Right Back
151
- </Text>
152
- <Flex justify="end" css={{ color: '$on_surface_high', flexGrow: '1' }}>
153
- {isBRBOn ? <CheckIcon /> : null}
154
- </Flex>
155
- </Dropdown.Item>
156
- ) : null}
157
- {isTranscriptionAllowed ? (
158
- <Dropdown.Item
159
- data-testid="closed_caption_admin"
160
- onClick={() => {
161
- updateState(MODALS.CAPTION, true);
162
- }}
163
- >
164
- <OpenCaptionIcon />
165
- <Flex direction="column" css={{ flexGrow: '1' }}>
166
- <Text variant="sm" css={{ ml: '$4', color: '$on_surface_high' }}>
167
- Closed Captions
168
- </Text>
169
- <Text variant="caption" css={{ ml: '$4', color: '$on_surface_medium' }}>
170
- {isTranscriptionEnabled ? 'Enabled' : 'Disabled'}
171
- </Text>
172
- </Flex>
173
- <Switch id="closed_caption_start_stop" checked={isTranscriptionEnabled} disabled={false} />
174
- </Dropdown.Item>
175
- ) : null}
176
- {screenType !== 'hls_live_streaming' ? (
177
- <Dropdown.Item css={{ p: 0, '&:empty': { display: 'none' } }}>
178
- <PIP
179
- content={
180
- <Flex css={{ w: '100%', h: '100%', p: '$8' }}>
181
- <PipIcon />
182
- <Text variant="sm" css={{ ml: '$4' }}>
183
- {isPipOn ? 'Disable' : 'Enable'} Picture-in-Picture
184
- </Text>
185
- </Flex>
186
- }
187
- />
188
- </Dropdown.Item>
189
- ) : null}
190
-
191
- <PIPChatOption
192
- showPIPChat={showPipChatOption}
193
- openChat={async () => {
194
- isChatOpen && toggleChat();
195
- await requestPipWindow(350, 500);
196
- }}
197
- />
198
- <FullScreenItem />
199
- <Dropdown.ItemSeparator css={{ mx: 0 }} />
200
- <Dropdown.Item onClick={() => updateState(MODALS.DEVICE_SETTINGS, true)} data-testid="device_settings_btn">
201
- <SettingsIcon />
202
- <Text variant="sm" css={{ ml: '$4' }}>
203
- Settings
204
- </Text>
205
- </Dropdown.Item>
206
- {match({ screenType, isSupported: HMSHLSPlayer.isSupported() })
207
- .with({ screenType: 'hls_live_streaming', isSupported: false }, () => null)
208
- .with({ screenType: 'hls_live_streaming', isSupported: true }, () => {
209
- return (
210
- <Dropdown.Item
211
- onClick={() => hmsActions.setAppData(APP_DATA.hlsStats, !enablHlsStats)}
212
- data-testid="hls_stats"
213
- >
214
- <Checkbox.Root
215
- css={{ margin: '$2' }}
216
- checked={enablHlsStats}
217
- onCheckedChange={() => hmsActions.setAppData(APP_DATA.hlsStats, !enablHlsStats)}
218
- >
219
- <Checkbox.Indicator>
220
- <CheckIcon width={16} height={16} />
221
- </Checkbox.Indicator>
222
- </Checkbox.Root>
223
- <Flex justify="between" css={{ width: '100%' }}>
224
- <Text variant="sm" css={{ ml: '$4' }}>
225
- Show HLS Stats
226
- </Text>
227
-
228
- <Text variant="sm" css={{ ml: '$4' }}>
229
- {`${isMacOS ? '⌘' : 'ctrl'} + ]`}
230
- </Text>
231
- </Flex>
232
- </Dropdown.Item>
233
- );
234
- })
235
- .otherwise(() => (
236
- <Dropdown.Item
237
- onClick={() => updateState(MODALS.STATS_FOR_NERDS, true)}
238
- data-testid="stats_for_nerds_btn"
239
- >
240
- <InfoIcon />
241
- <Text variant="sm" css={{ ml: '$4' }}>
242
- Stats for Nerds
243
- </Text>
244
- </Dropdown.Item>
245
- ))}
246
- </Dropdown.Content>
247
- </Dropdown.Root>
248
- {openModals.has(MODALS.BULK_ROLE_CHANGE) && (
249
- <BulkRoleChangeModal onOpenChange={(value: boolean) => updateState(MODALS.BULK_ROLE_CHANGE, value)} />
250
- )}
251
- {openModals.has(MODALS.MUTE_ALL) && (
252
- <MuteAllModal onOpenChange={(value: boolean) => updateState(MODALS.MUTE_ALL, value)} />
253
- )}
254
-
255
- {openModals.has(MODALS.START_RECORDING) && (
256
- <StartRecording open onOpenChange={(value: boolean) => updateState(MODALS.START_RECORDING, value)} />
257
- )}
258
- {openModals.has(MODALS.DEVICE_SETTINGS) && (
259
- <SettingsModal
260
- open
261
- onOpenChange={(value: boolean) => updateState(MODALS.DEVICE_SETTINGS, value)}
262
- screenType={screenType}
263
- />
264
- )}
265
- {openModals.has(MODALS.STATS_FOR_NERDS) && (
266
- <StatsForNerds open onOpenChange={(value: boolean) => updateState(MODALS.STATS_FOR_NERDS, value)} />
267
- )}
268
- {openModals.has(MODALS.SELF_ROLE_CHANGE) && (
269
- <RoleChangeModal
270
- peerId={localPeerId}
271
- onOpenChange={(value: boolean) => updateState(MODALS.SELF_ROLE_CHANGE, value)}
272
- />
273
- )}
274
- {openModals.has(MODALS.CAPTION) && (
275
- <CaptionModal onOpenChange={(value: boolean) => updateState(MODALS.CAPTION, value)} />
276
- )}
277
- {/* {openModals.has(MODALS.EMBED_URL) && (
278
- <EmbedUrlModal onOpenChange={value => updateState(MODALS.EMBED_URL, value)} />
279
- )} */}
280
- </Fragment>
281
- );
282
- };
@@ -1,387 +0,0 @@
1
- import React, { useRef, useState } from 'react';
2
- import { useClickAway } from 'react-use';
3
- import { ConferencingScreen, DefaultConferencingScreen_Elements } from '@100mslive/types-prebuilt';
4
- import { match } from 'ts-pattern';
5
- import {
6
- HMSTranscriptionMode,
7
- selectIsConnectedToRoom,
8
- selectIsLocalVideoEnabled,
9
- selectIsTranscriptionAllowedByMode,
10
- selectIsTranscriptionEnabled,
11
- selectPeerCount,
12
- selectPermissions,
13
- useHMSActions,
14
- useHMSStore,
15
- useRecordingStreaming,
16
- } from '@100mslive/react-sdk';
17
- import {
18
- BrbIcon,
19
- ClosedCaptionIcon,
20
- CrossIcon,
21
- EmojiIcon,
22
- HamburgerMenuIcon,
23
- HandIcon,
24
- HandRaiseSlashedIcon,
25
- InfoIcon,
26
- OpenCaptionIcon,
27
- PeopleIcon,
28
- QuizActiveIcon,
29
- QuizIcon,
30
- RecordIcon,
31
- SettingsIcon,
32
- VirtualBackgroundIcon,
33
- } from '@100mslive/react-icons';
34
- import { Box, Loading, Tooltip } from '../../../..';
35
- import { Sheet } from '../../../../Sheet';
36
- // @ts-ignore: No implicit any
37
- import IconButton from '../../../IconButton';
38
- import { NoiseCancellation } from '../../AudioVideoToggle';
39
- // @ts-ignore: No implicit any
40
- import { EmojiReaction } from '../../EmojiReaction';
41
- // @ts-ignore: No implicit any
42
- import { StopRecordingInSheet } from '../../Header/StreamActions';
43
- // @ts-ignore: No implicit any
44
- import SettingsModal from '../../Settings/SettingsModal';
45
- // @ts-ignore: No implicit any
46
- import { StatsForNerds } from '../../StatsForNerds';
47
- // @ts-ignore: No implicit any
48
- import { ToastManager } from '../../Toast/ToastManager';
49
- // @ts-ignore: No implicit any
50
- import { ActionTile } from '../ActionTile';
51
- import { CaptionModal } from '../CaptionModal';
52
- // @ts-ignore: No implicit any
53
- import { ChangeNameModal } from '../ChangeNameModal';
54
- // @ts-ignore: No implicit any
55
- import { MuteAllModal } from '../MuteAllModal';
56
- import { useRoomLayoutHeader } from '../../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
57
- import { useSheetToggle } from '../../AppData/useSheet';
58
- // @ts-ignore: No implicit any
59
- import { usePollViewToggle, useSidepaneToggle } from '../../AppData/useSidepane';
60
- // @ts-ignore: No implicit Any
61
- import { useSetIsCaptionEnabled, useShowPolls } from '../../AppData/useUISettings';
62
- // @ts-ignore: No implicit any
63
- import { useDropdownList } from '../../hooks/useDropdownList';
64
- import { useMyMetadata } from '../../hooks/useMetadata';
65
- import { useUnreadPollQuizPresent } from '../../hooks/useUnreadPollQuizPresent';
66
- import { useLandscapeHLSStream, useMobileHLSStream, useRecordingHandler } from '../../../common/hooks';
67
- // @ts-ignore: No implicit any
68
- import { getFormattedCount } from '../../../common/utils';
69
- // @ts-ignore: No implicit any
70
- import { SHEET_OPTIONS, SIDE_PANE_OPTIONS } from '../../../common/constants';
71
-
72
- const MODALS = {
73
- CHANGE_NAME: 'changeName',
74
- SELF_ROLE_CHANGE: 'selfRoleChange',
75
- MORE_SETTINGS: 'moreSettings',
76
- START_RECORDING: 'startRecording',
77
- DEVICE_SETTINGS: 'deviceSettings',
78
- STATS_FOR_NERDS: 'statsForNerds',
79
- BULK_ROLE_CHANGE: 'bulkRoleChange',
80
- MUTE_ALL: 'muteAll',
81
- EMBED_URL: 'embedUrl',
82
- CAPTION: 'caption',
83
- };
84
-
85
- export const MwebOptions = ({
86
- elements,
87
- screenType,
88
- }: {
89
- elements: DefaultConferencingScreen_Elements;
90
- screenType: keyof ConferencingScreen;
91
- }) => {
92
- const hmsActions = useHMSActions();
93
- const permissions = useHMSStore(selectPermissions);
94
- const isConnected = useHMSStore(selectIsConnectedToRoom);
95
- const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming();
96
- const [openModals, setOpenModals] = useState(new Set());
97
- const [openOptionsSheet, setOpenOptionsSheet] = useState(false);
98
- const [openSettingsSheet, setOpenSettingsSheet] = useState(false);
99
- const [openStatsForNerdsSheet, setOpenStatsForNerdsSheet] = useState(false);
100
- const [showEmojiCard, setShowEmojiCard] = useState(false);
101
- const [showRecordingOn, setShowRecordingOn] = useState(false);
102
- const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
103
- const { showPolls } = useShowPolls();
104
- const togglePollView = usePollViewToggle();
105
- const peerCount = useHMSStore(selectPeerCount);
106
- const emojiCardRef = useRef(null);
107
- const { isBRBOn, toggleBRB, isHandRaised, toggleHandRaise } = useMyMetadata();
108
- const { unreadPollQuiz, setUnreadPollQuiz } = useUnreadPollQuizPresent();
109
- const { title, description } = useRoomLayoutHeader();
110
- const toggleDetailsSheet = useSheetToggle(SHEET_OPTIONS.ROOM_DETAILS);
111
- const isMobileHLSStream = useMobileHLSStream();
112
- const isLandscapeHLSStream = useLandscapeHLSStream();
113
- const toggleVB = useSidepaneToggle(SIDE_PANE_OPTIONS.VB);
114
- const isLocalVideoEnabled = useHMSStore(selectIsLocalVideoEnabled);
115
- const { startRecording, isRecordingLoading } = useRecordingHandler();
116
- const isTranscriptionAllowed = useHMSStore(selectIsTranscriptionAllowedByMode(HMSTranscriptionMode.CAPTION));
117
- const isTranscriptionEnabled = useHMSStore(selectIsTranscriptionEnabled);
118
-
119
- const [isCaptionEnabled] = useSetIsCaptionEnabled();
120
- useDropdownList({ open: openModals.size > 0 || openOptionsSheet || openSettingsSheet, name: 'MoreSettings' });
121
-
122
- const updateState = (modalName: string, value: boolean) => {
123
- setOpenModals(modals => {
124
- const copy = new Set(modals);
125
- if (value) {
126
- copy.add(modalName);
127
- } else {
128
- copy.delete(modalName);
129
- }
130
- return copy;
131
- });
132
- };
133
-
134
- useClickAway(emojiCardRef, () => setShowEmojiCard(false));
135
-
136
- return (
137
- <>
138
- <Sheet.Root open={openOptionsSheet} onOpenChange={setOpenOptionsSheet}>
139
- <Tooltip title="More options">
140
- <Sheet.Trigger asChild data-testid="more_settings_btn">
141
- <IconButton css={{ bg: isMobileHLSStream || isLandscapeHLSStream ? '$surface_default' : '' }}>
142
- <HamburgerMenuIcon />
143
- </IconButton>
144
- </Sheet.Trigger>
145
- </Tooltip>
146
- <Sheet.Content css={{ bg: '$surface_dim', pb: '$14' }}>
147
- <Sheet.Title
148
- css={{
149
- display: 'flex',
150
- color: '$on_surface_high',
151
- w: '100%',
152
- justifyContent: 'space-between',
153
- fontSize: '$md',
154
- mt: '$8',
155
- px: '$10',
156
- pb: '$8',
157
- borderBottom: '1px solid $border_default',
158
- mb: '$8',
159
- alignItems: 'center',
160
- }}
161
- >
162
- Options
163
- <Sheet.Close>
164
- <Box css={{ color: '$on_surface_high' }}>
165
- <CrossIcon />
166
- </Box>
167
- </Sheet.Close>
168
- </Sheet.Title>
169
- <Box
170
- css={{
171
- display: 'grid',
172
- gridTemplateColumns: '1fr 1fr 1fr',
173
- gridTemplateRows: 'auto',
174
- gridColumnGap: '$6',
175
- gridRowGap: '$8',
176
- px: '$9',
177
- }}
178
- >
179
- {elements?.participant_list && (
180
- <ActionTile.Root
181
- onClick={() => {
182
- toggleParticipants();
183
- setOpenOptionsSheet(false);
184
- }}
185
- >
186
- <ActionTile.Count>{getFormattedCount(peerCount)}</ActionTile.Count>
187
- <PeopleIcon />
188
- <ActionTile.Title>Participants</ActionTile.Title>
189
- </ActionTile.Root>
190
- )}
191
-
192
- {elements.hand_raise ? (
193
- <ActionTile.Root
194
- active={isHandRaised}
195
- onClick={() => {
196
- toggleHandRaise();
197
- setOpenOptionsSheet(false);
198
- }}
199
- >
200
- {isHandRaised ? <HandRaiseSlashedIcon /> : <HandIcon />}
201
- <ActionTile.Title>{isHandRaised ? 'Lower' : 'Raise'} Hand</ActionTile.Title>
202
- </ActionTile.Root>
203
- ) : null}
204
- <NoiseCancellation setOpenOptionsSheet={setOpenOptionsSheet} actionTile />
205
- {isTranscriptionAllowed ? (
206
- <ActionTile.Root
207
- onClick={() => {
208
- setOpenOptionsSheet(false);
209
- updateState(MODALS.CAPTION, true);
210
- }}
211
- >
212
- {isTranscriptionEnabled && isCaptionEnabled ? <ClosedCaptionIcon /> : <OpenCaptionIcon />}
213
- <ActionTile.Title>Closed Caption</ActionTile.Title>
214
- </ActionTile.Root>
215
- ) : null}
216
- {isLocalVideoEnabled && !!elements?.virtual_background ? (
217
- <ActionTile.Root
218
- onClick={() => {
219
- toggleVB();
220
- setOpenOptionsSheet(false);
221
- }}
222
- >
223
- <VirtualBackgroundIcon />
224
- <ActionTile.Title>Virtual Background</ActionTile.Title>
225
- </ActionTile.Root>
226
- ) : null}
227
-
228
- {elements?.emoji_reactions && !(isLandscapeHLSStream || isMobileHLSStream) && (
229
- <ActionTile.Root
230
- onClick={() => {
231
- setShowEmojiCard(true);
232
- setOpenOptionsSheet(false);
233
- }}
234
- >
235
- <EmojiIcon />
236
- <ActionTile.Title>Emoji Reactions</ActionTile.Title>
237
- </ActionTile.Root>
238
- )}
239
-
240
- {showPolls && (
241
- <ActionTile.Root
242
- onClick={() => {
243
- togglePollView();
244
- setOpenOptionsSheet(false);
245
- setUnreadPollQuiz(false);
246
- }}
247
- >
248
- {unreadPollQuiz ? <QuizActiveIcon /> : <QuizIcon />}
249
- <ActionTile.Title>Polls and Quizzes</ActionTile.Title>
250
- </ActionTile.Root>
251
- )}
252
-
253
- {elements?.brb && (
254
- <ActionTile.Root
255
- active={isBRBOn}
256
- onClick={() => {
257
- toggleBRB();
258
- setOpenOptionsSheet(false);
259
- }}
260
- >
261
- <BrbIcon />
262
- <ActionTile.Title>Be Right Back</ActionTile.Title>
263
- </ActionTile.Root>
264
- )}
265
-
266
- <ActionTile.Root
267
- onClick={() => {
268
- setOpenSettingsSheet(true);
269
- setOpenOptionsSheet(false);
270
- }}
271
- >
272
- <SettingsIcon />
273
- <ActionTile.Title>Settings</ActionTile.Title>
274
- </ActionTile.Root>
275
- <ActionTile.Root
276
- onClick={() => {
277
- setOpenStatsForNerdsSheet(true);
278
- setOpenOptionsSheet(false);
279
- }}
280
- >
281
- <InfoIcon />
282
- <ActionTile.Title>Stats For Nerds</ActionTile.Title>
283
- </ActionTile.Root>
284
- {isConnected && permissions?.browserRecording ? (
285
- <ActionTile.Root
286
- disabled={isHLSRunning}
287
- onClick={async () => {
288
- if (isRecordingLoading) {
289
- return;
290
- }
291
- if (isBrowserRecordingOn || isStreamingOn) {
292
- setOpenOptionsSheet(false);
293
- setShowRecordingOn(true);
294
- } else {
295
- // start recording
296
- await startRecording();
297
- setOpenOptionsSheet(false);
298
- }
299
- if (isHLSRunning) {
300
- setOpenOptionsSheet(false);
301
- }
302
- }}
303
- >
304
- {isRecordingLoading ? <Loading /> : <RecordIcon />}
305
- <ActionTile.Title>
306
- {match({ isBrowserRecordingOn, isRecordingLoading })
307
- .with({ isBrowserRecordingOn: true, isRecordingLoading: false }, () => 'Recording On')
308
- .with({ isRecordingLoading: true }, () => 'Starting Recording')
309
- .with({ isRecordingLoading: false }, () => 'Start Recording')
310
- .otherwise(() => null)}
311
- </ActionTile.Title>
312
- </ActionTile.Root>
313
- ) : null}
314
-
315
- {title || description ? (
316
- <ActionTile.Root
317
- onClick={() => {
318
- setOpenOptionsSheet(false);
319
- toggleDetailsSheet();
320
- }}
321
- >
322
- <InfoIcon />
323
- <ActionTile.Title>About Session</ActionTile.Title>
324
- </ActionTile.Root>
325
- ) : null}
326
- </Box>
327
- </Sheet.Content>
328
- </Sheet.Root>
329
- <SettingsModal open={openSettingsSheet} onOpenChange={setOpenSettingsSheet} screenType={screenType} />
330
-
331
- {openStatsForNerdsSheet && (
332
- <StatsForNerds open={openStatsForNerdsSheet} onOpenChange={setOpenStatsForNerdsSheet} />
333
- )}
334
-
335
- {openModals.has(MODALS.MUTE_ALL) && (
336
- <MuteAllModal onOpenChange={(value: boolean) => updateState(MODALS.MUTE_ALL, value)} isMobile />
337
- )}
338
- {openModals.has(MODALS.CHANGE_NAME) && (
339
- <ChangeNameModal
340
- onOpenChange={(value: boolean) => updateState(MODALS.CHANGE_NAME, value)}
341
- openParentSheet={() => setOpenOptionsSheet(true)}
342
- />
343
- )}
344
- {openModals.has(MODALS.CAPTION) && (
345
- <CaptionModal onOpenChange={(value: boolean) => updateState(MODALS.CAPTION, value)} />
346
- )}
347
- {showEmojiCard && (
348
- <Box
349
- ref={emojiCardRef}
350
- css={{
351
- maxWidth: '100%',
352
- w: '100%',
353
- position: 'absolute',
354
- left: 0,
355
- right: 0,
356
- bottom: '$18',
357
- bg: '$surface_default',
358
- zIndex: '10',
359
- p: '$8',
360
- pb: 0,
361
- r: '$1',
362
- mx: '$4',
363
- }}
364
- >
365
- <EmojiReaction showCard />
366
- </Box>
367
- )}
368
- {showRecordingOn && (
369
- <StopRecordingInSheet
370
- onClose={() => setShowRecordingOn(false)}
371
- onStopRecording={async () => {
372
- try {
373
- await hmsActions.stopRTMPAndRecording();
374
- setShowRecordingOn(false);
375
- } catch (error) {
376
- ToastManager.addToast({
377
- // @ts-ignore
378
- title: error.message,
379
- variant: 'error',
380
- });
381
- }
382
- }}
383
- />
384
- )}
385
- </>
386
- );
387
- };
@@ -1,14 +0,0 @@
1
- export const trackSourceOptions = [
2
- { label: 'All Track Sources', value: '' },
3
- { label: 'regular', value: 'regular' },
4
- { label: 'screen', value: 'screen' },
5
- { label: 'audioplaylist', value: 'audioplaylist' },
6
- { label: 'videoplaylist', value: 'videoplaylist' },
7
- ];
8
- export const trackTypeOptions = [
9
- { label: 'All Track Types', value: '' },
10
- { label: 'audio', value: 'audio' },
11
- { label: 'video', value: 'video' },
12
- ];
13
-
14
- export const DEFAULT_TILES_IN_VIEW = { MWEB: 4, DESKTOP: 9 };