@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,134 +0,0 @@
1
- import React, { useRef, useState } from 'react';
2
- import { useFullscreen, useMedia } from 'react-use';
3
- import screenfull from 'screenfull';
4
- import {
5
- selectLocalPeerID,
6
- selectPeerByID,
7
- selectScreenShareAudioByPeerID,
8
- selectScreenShareByPeerID,
9
- useHMSStore,
10
- } from '@100mslive/react-sdk';
11
- import { ExpandIcon, ShrinkIcon } from '@100mslive/react-icons';
12
- import TileMenu from './TileMenu/TileMenu';
13
- import { Box } from '../../Layout';
14
- import { VideoTileStats } from '../../Stats';
15
- import { config as cssConfig, useTheme } from '../../Theme';
16
- import { Video } from '../../Video';
17
- import { StyledVideoTile } from '../../VideoTile';
18
- import { LayoutModeSelector } from './LayoutModeSelector';
19
- import { getVideoTileLabel } from './peerTileUtils';
20
- import { ScreenshareDisplay } from './ScreenshareDisplay';
21
- // @ts-ignore: No implicit Any
22
- import { useUISettings } from './AppData/useUISettings';
23
- import { UI_SETTINGS } from '../common/constants';
24
-
25
- const labelStyles = {
26
- position: 'unset',
27
- width: '100%',
28
- textAlign: 'center',
29
- c: '$on_surface_high',
30
- transform: 'none',
31
- flexShrink: 0,
32
- };
33
-
34
- const Tile = ({ peerId, width = '100%', height = '100%' }: { peerId: string; width?: string; height?: string }) => {
35
- const isLocal = useHMSStore(selectLocalPeerID) === peerId;
36
- const track = useHMSStore(selectScreenShareByPeerID(peerId));
37
- const { theme } = useTheme();
38
- const peer = useHMSStore(selectPeerByID(peerId));
39
- const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
40
- const [isMouseHovered, setIsMouseHovered] = useState(false);
41
- const isMobile = useMedia(cssConfig.media.md);
42
- const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
43
- const fullscreenRef = useRef<HTMLDivElement | null>(null);
44
- // fullscreen is for desired state
45
- const [fullscreen, setFullscreen] = useState(false);
46
- // isFullscreen is for true state
47
- const isFullscreen = useFullscreen(fullscreenRef, fullscreen, {
48
- onClose: () => setFullscreen(false),
49
- });
50
- const isFullScreenSupported = screenfull.isEnabled;
51
- const audioTrack = useHMSStore(selectScreenShareAudioByPeerID(peer?.id));
52
-
53
- if (isLocal && track?.displaySurface && !['browser', 'window', 'application'].includes(track.displaySurface)) {
54
- return <ScreenshareDisplay />;
55
- }
56
-
57
- if (!peer) {
58
- return null;
59
- }
60
-
61
- const label = getVideoTileLabel({
62
- peerName: peer?.name,
63
- isLocal: false,
64
- videoTrack: track,
65
- audioTrack,
66
- });
67
-
68
- return (
69
- <StyledVideoTile.Root
70
- css={{
71
- width,
72
- height,
73
- p: 0,
74
- minHeight: 0,
75
- }}
76
- data-testid="screenshare_tile"
77
- >
78
- <StyledVideoTile.Container
79
- transparentBg
80
- ref={fullscreenRef}
81
- css={{ flexDirection: 'column', gap: '$2' }}
82
- onMouseEnter={() => setIsMouseHovered(true)}
83
- onMouseLeave={() => {
84
- setIsMouseHovered(false);
85
- }}
86
- >
87
- {showStatsOnTiles ? (
88
- <VideoTileStats audioTrackID={audioTrack?.id} videoTrackID={track?.id} peerID={peerId} isLocal={isLocal} />
89
- ) : null}
90
- {isFullScreenSupported && isMouseHovered ? (
91
- <StyledVideoTile.FullScreenButton
92
- css={{ bg: `${theme.colors.background_dim.value}A3` }}
93
- onClick={() => setFullscreen(!fullscreen)}
94
- >
95
- {isFullscreen ? <ShrinkIcon /> : <ExpandIcon />}
96
- </StyledVideoTile.FullScreenButton>
97
- ) : null}
98
- {!isMobile && isMouseHovered && !isFullscreen && (
99
- <Box
100
- css={{
101
- position: 'absolute',
102
- top: '$2',
103
- r: '$1',
104
- h: '$14',
105
- right: isFullScreenSupported ? '$17' : '$2',
106
- zIndex: 5,
107
- bg: `${theme.colors.background_dim.value}A3`,
108
- }}
109
- >
110
- <LayoutModeSelector />
111
- </Box>
112
- )}
113
-
114
- {track ? (
115
- <Video screenShare={true} mirror={false} attach={!isAudioOnly} trackId={track.id} css={{ minHeight: 0 }} />
116
- ) : null}
117
- <StyledVideoTile.Info css={labelStyles}>{label}</StyledVideoTile.Info>
118
- {isMouseHovered && !peer.isLocal ? (
119
- <TileMenu
120
- isScreenshare
121
- peerID={peer.id}
122
- audioTrackID={audioTrack?.id}
123
- videoTrackID={track?.id}
124
- enableSpotlightingPeer={false}
125
- />
126
- ) : null}
127
- </StyledVideoTile.Container>
128
- </StyledVideoTile.Root>
129
- );
130
- };
131
-
132
- const ScreenshareTile = React.memo(Tile);
133
-
134
- export default ScreenshareTile;
@@ -1,81 +0,0 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { selectAppData, selectSessionStore, selectTrackByID, useHMSStore } from '@100mslive/react-sdk';
4
- import { LayoutProps } from './VideoLayouts/interface';
5
- import { ProminenceLayout } from './VideoLayouts/ProminenceLayout';
6
- import { config as cssConfig } from '../../Theme';
7
- import { Pagination } from './Pagination';
8
- import { usePagesWithTiles } from './hooks/useTileLayout';
9
- import { APP_DATA, SESSION_STORE_KEY } from '../common/constants';
10
-
11
- export const SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge, hasSidebar }: LayoutProps) => {
12
- const isMobile = useMedia(cssConfig.media.md);
13
- const maxTileCount = isMobile ? 2 : 4;
14
- const [page, setPage] = useState(0);
15
- const pinnedTrackId = useHMSStore(selectAppData(APP_DATA.pinnedTrackId));
16
- const spotlightPeerId = useHMSStore(selectSessionStore(SESSION_STORE_KEY.SPOTLIGHT));
17
- const activeScreensharePeerId = useHMSStore(selectAppData(APP_DATA.activeScreensharePeerId));
18
- const pinnedPeer = useHMSStore(selectTrackByID(pinnedTrackId))?.peerId;
19
- const pageChangedAfterPinning = useRef(false);
20
- const pagesWithTiles = usePagesWithTiles({
21
- peers:
22
- spotlightPeerId || pinnedPeer
23
- ? [...peers].sort((p1, p2) => {
24
- if (activeScreensharePeerId === p1.id) {
25
- return -1;
26
- }
27
- if (activeScreensharePeerId === p2.id) {
28
- return 1;
29
- }
30
- const peerIdList = [pinnedPeer, spotlightPeerId];
31
- // put active screenshare peer, pinned peer, spotlight peer at first
32
- if (peerIdList.includes(p1.id)) {
33
- return -1;
34
- }
35
- if (peerIdList.includes(p2.id)) {
36
- return 1;
37
- }
38
- return 0;
39
- })
40
- : peers,
41
- maxTileCount,
42
- });
43
- const pageSize = pagesWithTiles[0]?.length || 0;
44
-
45
- // Handles final peer leaving from the last page
46
- useEffect(() => {
47
- if (peers.length > 0 && !pagesWithTiles[page]?.length) {
48
- setPage(Math.max(0, page - 1));
49
- }
50
- }, [peers, page, pagesWithTiles]);
51
-
52
- useEffect(() => {
53
- if (pageSize > 0) {
54
- onPageSize?.(pageSize);
55
- }
56
- }, [pageSize, onPageSize]);
57
-
58
- useEffect(() => {
59
- if ((pinnedPeer || spotlightPeerId) && page !== 0 && !pageChangedAfterPinning.current) {
60
- setPage(0);
61
- pageChangedAfterPinning.current = true;
62
- } else if (!pinnedPeer && !spotlightPeerId) {
63
- pageChangedAfterPinning.current = false;
64
- }
65
- }, [pinnedPeer, spotlightPeerId, page]);
66
-
67
- return (
68
- <ProminenceLayout.SecondarySection tiles={pagesWithTiles[page]} edgeToEdge={edgeToEdge} hasSidebar={hasSidebar}>
69
- {!edgeToEdge && (
70
- <Pagination
71
- page={page}
72
- onPageChange={page => {
73
- setPage(page);
74
- onPageChange?.(page);
75
- }}
76
- numPages={pagesWithTiles.length}
77
- />
78
- )}
79
- </ProminenceLayout.SecondarySection>
80
- );
81
- };
@@ -1,208 +0,0 @@
1
- import React, { Fragment, useRef, useState } from 'react';
2
- import {
3
- DeviceType,
4
- selectIsLocalVideoEnabled,
5
- selectLocalVideoTrackID,
6
- selectVideoTrackByID,
7
- useDevices,
8
- useHMSStore,
9
- } from '@100mslive/react-sdk';
10
- import { MicOnIcon, SpeakerIcon, VideoOnIcon } from '@100mslive/react-icons';
11
- import { Box, Button, Dropdown, Flex, StyledVideoTile, Text, Video } from '../../../';
12
- import { DialogDropdownTrigger } from '../../primitives/DropdownTrigger';
13
- import { useUISettings } from '../AppData/useUISettings';
14
- import { useAudioOutputTest } from '../hooks/useAudioOutputTest';
15
- import { useDropdownSelection } from '../hooks/useDropdownSelection';
16
- import { settingOverflow } from './common';
17
- import { TEST_AUDIO_URL, UI_SETTINGS } from '../../common/constants';
18
-
19
- /**
20
- * wrap the button on click of whom settings should open, this component will take care of the rest,
21
- * it'll give the user options to change input/output device as well as check speaker.
22
- * There is also another controlled way of using this by passing in open and onOpenChange.
23
- */
24
- const Settings = ({ setHide }) => {
25
- const { allDevices, selectedDeviceIDs, updateDevice } = useDevices();
26
- const { videoInput, audioInput, audioOutput } = allDevices;
27
- const videoTrackId = useHMSStore(selectLocalVideoTrackID);
28
- const isVideoOn = useHMSStore(selectIsLocalVideoEnabled);
29
- // don't show speaker selector where the API is not supported, and use
30
- // a generic word("Audio") for Mic. In some cases(Chrome Android for example) this changes both mic and speaker keeping them in sync.
31
- const shouldShowAudioOutput = 'setSinkId' in HTMLMediaElement.prototype;
32
- const mirrorLocalVideo = useUISettings(UI_SETTINGS.mirrorLocalVideo);
33
- const trackSelector = selectVideoTrackByID(videoTrackId);
34
- const track = useHMSStore(trackSelector);
35
-
36
- /**
37
- * Chromium browsers return an audioOutput with empty label when no permissions are given
38
- */
39
- const audioOutputFiltered = audioOutput?.filter(item => !!item.label) ?? [];
40
-
41
- if (!videoInput?.length && !audioInput?.length && !audioOutputFiltered?.length) {
42
- setHide(true);
43
- }
44
-
45
- return (
46
- <Box className={settingOverflow()}>
47
- {videoInput?.length ? (
48
- <Fragment>
49
- {isVideoOn && (
50
- <StyledVideoTile.Container
51
- css={{
52
- w: '90%',
53
- px: '$10',
54
- height: '$48',
55
- bg: 'transparent',
56
- m: '$10 auto',
57
- }}
58
- >
59
- <Video trackId={videoTrackId} mirror={track?.facingMode !== 'environment' && mirrorLocalVideo} />
60
- </StyledVideoTile.Container>
61
- )}
62
- <DeviceSelector
63
- title="Video"
64
- devices={videoInput}
65
- icon={<VideoOnIcon />}
66
- selection={selectedDeviceIDs.videoInput}
67
- onChange={deviceId =>
68
- updateDevice({
69
- deviceId,
70
- deviceType: DeviceType.videoInput,
71
- })
72
- }
73
- />
74
- </Fragment>
75
- ) : null}
76
-
77
- {audioInput?.length ? (
78
- <DeviceSelector
79
- title={shouldShowAudioOutput ? 'Microphone' : 'Audio'}
80
- icon={<MicOnIcon />}
81
- devices={audioInput}
82
- selection={selectedDeviceIDs.audioInput}
83
- onChange={deviceId =>
84
- updateDevice({
85
- deviceId,
86
- deviceType: DeviceType.audioInput,
87
- })
88
- }
89
- />
90
- ) : null}
91
-
92
- {audioOutputFiltered?.length && shouldShowAudioOutput ? (
93
- <DeviceSelector
94
- title="Speaker"
95
- icon={<SpeakerIcon />}
96
- devices={audioOutput}
97
- selection={selectedDeviceIDs.audioOutput}
98
- onChange={deviceId =>
99
- updateDevice({
100
- deviceId,
101
- deviceType: DeviceType.audioOutput,
102
- })
103
- }
104
- >
105
- <TestAudio id={selectedDeviceIDs.audioOutput} />
106
- </DeviceSelector>
107
- ) : null}
108
- </Box>
109
- );
110
- };
111
-
112
- const DeviceSelector = ({ title, devices, selection, onChange, icon, children = null }) => {
113
- const [open, setOpen] = useState(false);
114
- const selectionBg = useDropdownSelection();
115
- const ref = useRef(null);
116
-
117
- return (
118
- <Box css={{ mb: '$10' }}>
119
- <Text css={{ mb: '$4' }}>{title}</Text>
120
- <Flex
121
- align="center"
122
- css={{
123
- gap: '$4',
124
- '@md': {
125
- flexDirection: children ? 'column' : 'row',
126
- alignItems: children ? 'start' : 'center',
127
- },
128
- }}
129
- >
130
- <Box
131
- css={{
132
- position: 'relative',
133
- flex: '1 1 0',
134
- minWidth: 0,
135
- w: '100%',
136
- maxWidth: '100%',
137
- '@md': {
138
- mb: children ? '$8' : 0,
139
- },
140
- }}
141
- >
142
- <Dropdown.Root open={open} onOpenChange={setOpen}>
143
- <DialogDropdownTrigger
144
- ref={ref}
145
- icon={icon}
146
- title={devices.find(({ deviceId }) => deviceId === selection)?.label || 'Select device from list'}
147
- open={open}
148
- />
149
- <Dropdown.Portal>
150
- <Dropdown.Content align="start" sideOffset={8} css={{ w: ref.current?.clientWidth, zIndex: 1001 }}>
151
- {devices.map(device => {
152
- return (
153
- <Dropdown.Item
154
- key={device.label}
155
- onSelect={() => onChange(device.deviceId)}
156
- css={{
157
- px: '$9',
158
- bg: device.deviceId === selection ? selectionBg : undefined,
159
- }}
160
- >
161
- {device.label}
162
- </Dropdown.Item>
163
- );
164
- })}
165
- </Dropdown.Content>
166
- </Dropdown.Portal>
167
- </Dropdown.Root>
168
- </Box>
169
- {children}
170
- </Flex>
171
- </Box>
172
- );
173
- };
174
-
175
- const TestAudio = ({ id }) => {
176
- const { playing, setPlaying, audioRef } = useAudioOutputTest({ deviceId: id });
177
- return (
178
- <>
179
- <Button
180
- variant="standard"
181
- css={{
182
- flexShrink: 0,
183
- p: '$6 $9',
184
- '@md': {
185
- w: '100%',
186
- },
187
- }}
188
- onClick={() => audioRef.current?.play()}
189
- disabled={playing}
190
- >
191
- <SpeakerIcon />
192
- &nbsp;Test{' '}
193
- <Text as="span" css={{ display: 'none', '@md': { display: 'inline' } }}>
194
- &nbsp; speaker
195
- </Text>
196
- </Button>
197
- <audio
198
- ref={audioRef}
199
- src={TEST_AUDIO_URL}
200
- onEnded={() => setPlaying(false)}
201
- onPlay={() => setPlaying(true)}
202
- css={{ display: 'none' }}
203
- />
204
- </>
205
- );
206
- };
207
-
208
- export default Settings;
@@ -1,74 +0,0 @@
1
- import React, { useCallback } from 'react';
2
- import { selectIsLocalScreenShared, selectIsLocalVideoEnabled, useHMSActions, useHMSStore } from '@100mslive/react-sdk';
3
- import { GalleryIcon, PersonRectangleIcon, SidebarIcon } from '@100mslive/react-icons';
4
- import { Box, Flex, Slider, Text } from '../../..';
5
- import SwitchWithLabel from './SwitchWithLabel';
6
- // @ts-ignore: No implicit Any
7
- import { useSetUiSettings } from '../AppData/useUISettings';
8
- import { settingOverflow } from './common';
9
- import { UI_SETTINGS } from '../../common/constants';
10
-
11
- export const LayoutMode = {
12
- SIDEBAR: 'Sidebar',
13
- GALLERY: 'Gallery',
14
- SPOTLIGHT: 'Spotlight',
15
- };
16
-
17
- export type LayoutModeKeys = keyof typeof LayoutMode;
18
-
19
- export const LayoutModeIconMapping = {
20
- [LayoutMode.GALLERY]: <GalleryIcon />,
21
- [LayoutMode.SIDEBAR]: <SidebarIcon />,
22
- [LayoutMode.SPOTLIGHT]: <PersonRectangleIcon />,
23
- };
24
-
25
- export const LayoutSettings = () => {
26
- const hmsActions = useHMSActions();
27
- const isLocalVideoEnabled = useHMSStore(selectIsLocalVideoEnabled);
28
- const isLocalScreenShared = useHMSStore(selectIsLocalScreenShared);
29
- const [{ isAudioOnly, maxTileCount, mirrorLocalVideo }, setUISettings] = useSetUiSettings();
30
- const toggleIsAudioOnly = useCallback(
31
- async (isAudioOnlyModeOn?: boolean) => {
32
- if (isAudioOnlyModeOn) {
33
- // turn off video and screen share if user switches to audio only mode
34
- isLocalVideoEnabled && (await hmsActions.setLocalVideoEnabled(false));
35
- isLocalScreenShared && (await hmsActions.setScreenShareEnabled(false));
36
- }
37
- setUISettings({ [UI_SETTINGS.isAudioOnly]: isAudioOnlyModeOn });
38
- },
39
- [hmsActions, isLocalVideoEnabled, isLocalScreenShared, setUISettings],
40
- );
41
-
42
- return (
43
- <Box className={settingOverflow()}>
44
- <Flex align="center" css={{ w: '100%', my: '$2', py: '$8', '@md': { display: 'none' } }}>
45
- <Text variant="md" css={{ fontWeight: '$semiBold' }}>
46
- Tiles In View({maxTileCount})
47
- </Text>
48
- <Flex justify="end" css={{ flex: '1 1 0' }}>
49
- <Slider
50
- step={1}
51
- value={[maxTileCount]}
52
- min={1}
53
- max={49}
54
- onValueChange={e => {
55
- setUISettings({ [UI_SETTINGS.maxTileCount]: e[0] });
56
- }}
57
- css={{ w: '70%' }}
58
- />
59
- </Flex>
60
- </Flex>
61
- <SwitchWithLabel label="Audio Only Mode" id="audioOnlyMode" checked={isAudioOnly} onChange={toggleIsAudioOnly} />
62
- <SwitchWithLabel
63
- label="Mirror Local Video"
64
- id="mirrorMode"
65
- checked={mirrorLocalVideo}
66
- onChange={value => {
67
- setUISettings({
68
- [UI_SETTINGS.mirrorLocalVideo]: value,
69
- });
70
- }}
71
- />
72
- </Box>
73
- );
74
- };
@@ -1,66 +0,0 @@
1
- import React from 'react';
2
- import { AlertOctagonIcon, HandIcon, PeopleAddIcon, PeopleRemoveIcon } from '@100mslive/react-icons';
3
- import { Box } from '../../..';
4
- import SwitchWithLabel from './SwitchWithLabel';
5
- // @ts-ignore: No implicit Any
6
- import { useSetSubscribedNotifications, useSubscribedNotifications } from '../AppData/useUISettings';
7
- import { settingOverflow } from './common';
8
- import { SUBSCRIBED_NOTIFICATIONS } from '../../common/constants';
9
-
10
- const NotificationItem = ({
11
- type,
12
- label,
13
- icon,
14
- checked,
15
- }: {
16
- type: string;
17
- label: string;
18
- icon: React.ReactNode;
19
- checked: boolean;
20
- }) => {
21
- const [, setSubscribedNotifications] = useSetSubscribedNotifications(type);
22
- return (
23
- <SwitchWithLabel
24
- label={label}
25
- id={type}
26
- icon={icon}
27
- checked={checked}
28
- onChange={value => {
29
- setSubscribedNotifications(value);
30
- }}
31
- />
32
- );
33
- };
34
-
35
- export const NotificationSettings = () => {
36
- const subscribedNotifications = useSubscribedNotifications();
37
-
38
- return (
39
- <Box className={settingOverflow()}>
40
- <NotificationItem
41
- label="Peer Joined"
42
- type={SUBSCRIBED_NOTIFICATIONS.PEER_JOINED}
43
- icon={<PeopleAddIcon />}
44
- checked={subscribedNotifications.PEER_JOINED}
45
- />
46
- <NotificationItem
47
- label="Peer Leave"
48
- type={SUBSCRIBED_NOTIFICATIONS.PEER_LEFT}
49
- icon={<PeopleRemoveIcon />}
50
- checked={subscribedNotifications.PEER_LEFT}
51
- />
52
- <NotificationItem
53
- label="Hand Raised"
54
- type={SUBSCRIBED_NOTIFICATIONS.METADATA_UPDATED}
55
- icon={<HandIcon />}
56
- checked={subscribedNotifications.METADATA_UPDATED}
57
- />
58
- <NotificationItem
59
- label="Error"
60
- type={SUBSCRIBED_NOTIFICATIONS.ERROR}
61
- icon={<AlertOctagonIcon />}
62
- checked={subscribedNotifications.ERROR}
63
- />
64
- </Box>
65
- );
66
- };