@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,210 +0,0 @@
1
- import React, { ComponentPropsWithRef, PropsWithChildren } from 'react';
2
- import { Flex } from '../Layout';
3
- import { Loading } from '../Loading';
4
- import { styled } from '../Theme';
5
- import { flexCenter } from '../utils/styles';
6
-
7
- /**
8
- * @param base bg color
9
- * @param hover hover state bg color
10
- * @param active active state bg color
11
- * @returns CSS object based on the state
12
- */
13
-
14
- const getOutlinedVariants = (
15
- base: string,
16
- hover: string,
17
- active: string,
18
- disabled: string,
19
- text: string,
20
- textDisabled: string,
21
- textHover?: string,
22
- ) => {
23
- return {
24
- bg: 'transparent',
25
- border: `solid $space$px $colors${base}`,
26
- c: text,
27
- '&[disabled]': {
28
- c: textDisabled,
29
- bg: 'transparent',
30
- border: `solid $space$px $colors${disabled}`,
31
- cursor: 'not-allowed',
32
- },
33
- '&:not([disabled]):hover': {
34
- c: textHover,
35
- border: `solid $space$px $colors${hover}`,
36
- bg: 'transparent',
37
- },
38
- '&:not([disabled]):active': {
39
- border: `solid $space$px $colors${active}`,
40
- bg: 'transparent',
41
- },
42
- '&:not([disabled]):focus-visible': {
43
- boxShadow: `0 0 0 3px $colors${base}`,
44
- },
45
- };
46
- };
47
-
48
- const getButtonVariants = (
49
- base: string,
50
- hover: string,
51
- active: string,
52
- disabled: string,
53
- text: string,
54
- textDisabled: string,
55
- textHover?: string,
56
- ) => {
57
- return {
58
- bg: base,
59
- border: `1px solid ${base}`,
60
- c: text,
61
- '&[disabled]': {
62
- c: textDisabled,
63
- cursor: 'not-allowed',
64
- bg: disabled,
65
- border: `1px solid ${disabled}`,
66
- },
67
- '&:not([disabled]):hover': {
68
- c: textHover,
69
- bg: hover,
70
- border: `1px solid ${hover}`,
71
- },
72
- '&:not([disabled]):active': {
73
- bg: active,
74
- border: `1px solid ${active}`,
75
- },
76
- '&:not([disabled]):focus-visible': {
77
- boxShadow: `0 0 0 3px $colors${hover}`,
78
- },
79
- };
80
- };
81
-
82
- const StyledButton = styled('button', {
83
- ...flexCenter,
84
- cursor: 'pointer',
85
- fontFamily: '$sans',
86
- lineHeight: 'inherit',
87
- textTransform: 'none',
88
- position: 'relative',
89
- outline: 'none',
90
- border: 'none',
91
- fs: '$md',
92
- r: '$1',
93
- backgroundColor: '$primary_default',
94
- fontWeight: '500',
95
- whiteSpace: 'nowrap',
96
- p: '$4 $8',
97
- '-webkit-appearance': 'button',
98
- '&:focus': {
99
- outline: 'none',
100
- },
101
- '&:not([disabled]):focus-visible': {
102
- boxShadow: '0 0 0 3px $colors$primary_default',
103
- },
104
- transition: 'all 0.2s ease',
105
- compoundVariants: [
106
- {
107
- variant: 'standard',
108
- outlined: true,
109
- css: getOutlinedVariants(
110
- '$secondary_default',
111
- '$secondary_bright',
112
- '$secondary_dim',
113
- '$secondary_disabled',
114
- '$on_surface_high',
115
- '$on_surface_low',
116
- ),
117
- },
118
- {
119
- variant: 'danger',
120
- outlined: true,
121
- css: getOutlinedVariants(
122
- '$alert_error_default',
123
- '$alert_error_bright',
124
- '$alert_error_dim',
125
- '$alert_error_brighter',
126
- '$on_surface_high',
127
- '$on_surface_low',
128
- '$on_surface_high',
129
- ),
130
- },
131
- {
132
- variant: 'primary',
133
- outlined: true,
134
- css: getOutlinedVariants(
135
- '$primary_default',
136
- '$primary_bright',
137
- '$primary_dim',
138
- '$primary_disabled',
139
- '$on_surface_high',
140
- '$on_surface_low',
141
- ),
142
- },
143
- ],
144
- variants: {
145
- variant: {
146
- standard: getButtonVariants(
147
- '$secondary_default',
148
- '$secondary_bright',
149
- '$secondary_dim',
150
- '$secondary_disabled',
151
- '$on_secondary_high',
152
- '$on_secondary_low',
153
- ),
154
- danger: getButtonVariants(
155
- '$alert_error_default',
156
- '$alert_error_bright',
157
- '$alert_error_dim',
158
- '$alert_error_dim',
159
- '$alert_error_brighter',
160
- '$on_primary_low',
161
- '$on_primary_high',
162
- ),
163
- primary: getButtonVariants(
164
- '$primary_default',
165
- '$primary_bright',
166
- '$primary_dim',
167
- '$primary_disabled',
168
- '$on_primary_high',
169
- '$on_primary_low',
170
- ),
171
- },
172
- outlined: {
173
- true: {},
174
- },
175
- icon: {
176
- true: {},
177
- },
178
- },
179
- defaultVariants: {
180
- variant: 'primary',
181
- },
182
- });
183
-
184
- export const Button = React.forwardRef<
185
- HTMLButtonElement,
186
- PropsWithChildren<{ loading?: boolean } & ComponentPropsWithRef<typeof StyledButton>>
187
- >(({ children, loading = false, icon, ...buttonProps }, ref) => {
188
- return (
189
- <StyledButton {...buttonProps} ref={ref}>
190
- <>
191
- {loading && (
192
- <Flex
193
- align="center"
194
- justify="center"
195
- css={{ w: '100%', position: 'absolute', left: '0', color: '$on_primary_low' }}
196
- >
197
- <Loading color="currentColor" />
198
- </Flex>
199
- )}
200
- <Flex
201
- align="center"
202
- justify="center"
203
- css={{ visibility: loading ? 'hidden' : 'visible', gap: icon ? '$4' : '0' }}
204
- >
205
- {children}
206
- </Flex>
207
- </>
208
- </StyledButton>
209
- );
210
- });
@@ -1 +0,0 @@
1
- export { Button } from './Button';
package/src/Chat/Chat.mdx DELETED
@@ -1,39 +0,0 @@
1
- ## Broadcast Message:
2
-
3
- import { Story } from '@storybook/addon-docs';
4
-
5
- This will be received by everyone in the room.
6
-
7
- ```js
8
- hmsActions.sendBroadcastMessage('hello everyone!'); // yes it's that simple 😉
9
- ```
10
-
11
- ## MVP component
12
-
13
- ```jsx
14
- const ChatExample = () => {
15
- const chats = useHMSStore(selectHMSMessages);
16
- const actions = useHMSActions();
17
- const [input, setInput] = useState('');
18
- const sendMessage = (e: React.FormEvent) => {
19
- e.preventDefault();
20
- actions.sendBroadcastMessage(input);
21
- setInput('');
22
- };
23
- return (
24
- <div>
25
- {chats.map(c => (
26
- <div>{c.message}</div>
27
- ))}
28
- <form onSubmit={sendMessage}>
29
- <input value={input} onChange={e => setInput(e.target.value)} type="text" />
30
- <button type="submit">Send</button>
31
- </form>
32
- </div>
33
- );
34
- };
35
- ```
36
-
37
- ### Demo
38
-
39
- <Story id="chat-broadcast-message--chat-story-example" />
@@ -1,39 +0,0 @@
1
- import React, { useState } from 'react';
2
- import { selectHMSMessages, useHMSActions, useHMSStore } from '@100mslive/react-sdk';
3
- import ChatDocs from './Chat.mdx';
4
-
5
- const ChatStories = {
6
- title: 'Chat/Broadcast Message',
7
- // More on argTypes: https://storybook.js.org/docs/react/api/argtypes
8
- parameters: {
9
- docs: {
10
- page: ChatDocs,
11
- },
12
- },
13
- };
14
-
15
- export default ChatStories;
16
-
17
- const ChatExample = () => {
18
- const chats = useHMSStore(selectHMSMessages);
19
- const actions = useHMSActions();
20
- const [input, setInput] = useState('');
21
- const sendMessage = (e: React.FormEvent) => {
22
- e.preventDefault();
23
- actions.sendBroadcastMessage(input);
24
- setInput('');
25
- };
26
- return (
27
- <div>
28
- {chats.map(c => (
29
- <div>{c.message}</div>
30
- ))}
31
- <form onSubmit={sendMessage}>
32
- <input value={input} onChange={e => setInput(e.target.value)} type="text" />
33
- <button type="submit">Send</button>
34
- </form>
35
- </div>
36
- );
37
- };
38
-
39
- export const ChatStoryExample = ChatExample.bind({});
@@ -1,61 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { ComponentMeta, ComponentStory } from '@storybook/react';
3
- import { CheckIcon } from '@100mslive/react-icons';
4
- import { Label } from '../Label';
5
- import { Flex } from '../Layout';
6
- import { Checkbox } from '.';
7
-
8
- export default {
9
- title: 'UI Components/Checkbox',
10
- component: CheckboxWithLabelComponent,
11
- argTypes: {
12
- onCheckedChange: { action: { type: 'clicked' } },
13
- checked: { control: { type: 'boolean' } },
14
- label: { control: { type: 'text' } },
15
- css: { control: { type: 'object' } },
16
- },
17
- args: {
18
- checked: true,
19
- label: 'Label',
20
- },
21
- } as ComponentMeta<typeof CheckboxWithLabelComponent>;
22
-
23
- type CheckboxWithLabelComponentProps = {
24
- label?: string;
25
- checked?: boolean;
26
- } & React.ComponentProps<typeof Checkbox.Root>;
27
-
28
- function CheckboxWithLabelComponent({ label, checked = true, css, onCheckedChange }: CheckboxWithLabelComponentProps) {
29
- const [internalChecked, setInternalChecked] = useState(checked);
30
-
31
- useEffect(() => {
32
- handleOnCheckedChange(checked);
33
- }, [checked]); //eslint-disable-line
34
-
35
- function handleOnCheckedChange(checked: boolean) {
36
- setInternalChecked(checked);
37
- if (onCheckedChange) {
38
- onCheckedChange(checked);
39
- }
40
- }
41
-
42
- return (
43
- <Flex align="center">
44
- <Checkbox.Root id={label} checked={internalChecked} css={css} onCheckedChange={handleOnCheckedChange}>
45
- <Checkbox.Indicator css={{ display: 'flex' }}>
46
- <CheckIcon width={16} height={16} />
47
- </Checkbox.Indicator>
48
- </Checkbox.Root>
49
- <Label htmlFor={label} css={{ ml: '$4', fontSize: '$sm', cursor: 'pointer' }}>
50
- {label}
51
- </Label>
52
- </Flex>
53
- );
54
- }
55
-
56
- const CheckboxWithLabelStory: ComponentStory<typeof CheckboxWithLabelComponent> = args => {
57
- return <CheckboxWithLabelComponent {...args} />;
58
- };
59
-
60
- export const Example = CheckboxWithLabelStory.bind({});
61
- Example.storyName = 'Checkbox';
@@ -1,35 +0,0 @@
1
- import * as CheckboxPrimitive from '@radix-ui/react-checkbox';
2
- import { styled } from '../Theme';
3
-
4
- const CheckboxRoot = styled(CheckboxPrimitive.Root, {
5
- all: 'unset',
6
- border: '1px solid $primary_default',
7
- backgroundColor: '$on_primary_high',
8
- width: '$8',
9
- height: '$8',
10
- borderRadius: '$0',
11
- display: 'flex',
12
- alignItems: 'center',
13
- justifyContent: 'center',
14
- boxShadow: 'none',
15
- outline: 'none',
16
- cursor: 'pointer',
17
- '&:focus': {
18
- boxShadow: 'none',
19
- outline: 'none',
20
- },
21
- '&[data-state="checked"]': {
22
- backgroundColor: '$primary_default',
23
- },
24
- });
25
-
26
- const CheckboxIndicator = styled(CheckboxPrimitive.Indicator, {
27
- color: '$on_primary_high',
28
- // center check svg within button box
29
- lineHeight: 0,
30
- });
31
-
32
- export const Checkbox = {
33
- Root: CheckboxRoot,
34
- Indicator: CheckboxIndicator,
35
- };
@@ -1 +0,0 @@
1
- export * from './Checkbox';
@@ -1,34 +0,0 @@
1
- import { Content, Root, Trigger } from '@radix-ui/react-collapsible';
2
- import { styled } from '../Theme';
3
- import { slideDown, slideUp } from '../utils';
4
-
5
- const CollapsibleRoot = styled(Root, {});
6
-
7
- const CollapsibleTrigger = styled(Trigger, {
8
- cursor: 'pointer',
9
- appearance: 'none !important',
10
- '&:focus': {
11
- outline: 'none',
12
- },
13
- '&:focus-visible': {
14
- boxShadow: '0 0 0 3px $colors$primary_default',
15
- },
16
- });
17
-
18
- const CollapsibleContent = styled(Content, {
19
- w: '$80',
20
- r: '$1',
21
- overflowY: 'auto',
22
- '&[data-state="open"]': {
23
- animation: `${slideDown('--radix-collapsible-content-height')} 300ms cubic-bezier(0.87, 0, 0.13, 1) forwards`,
24
- },
25
- '&[data-state="closed"]': {
26
- animation: `${slideUp('--radix-collapsible-content-height')} 300ms cubic-bezier(0.87, 0, 0.13, 1) forwards`,
27
- },
28
- });
29
-
30
- export const Collapsible = {
31
- Root: CollapsibleRoot,
32
- Trigger: CollapsibleTrigger,
33
- Content: CollapsibleContent,
34
- };
@@ -1 +0,0 @@
1
- export * from './Collapsible';
@@ -1,188 +0,0 @@
1
- /* eslint-disable react/prop-types */
2
- import React, { useCallback, useEffect, useState } from 'react';
3
- import {
4
- HMSException,
5
- selectDevices,
6
- selectLocalAudioTrackID,
7
- selectLocalMediaSettings,
8
- selectTrackAudioByID,
9
- useHMSActions,
10
- useHMSStore,
11
- } from '@100mslive/react-sdk';
12
- import { MicOnIcon, SpeakerIcon, StopIcon } from '@100mslive/react-icons';
13
- import { PermissionErrorModal } from '../Prebuilt/components/Notifications/PermissionErrorModal';
14
- import { TestContainer, TestFooter } from './components';
15
- import { Button } from '../Button';
16
- import { Box, Flex } from '../Layout';
17
- import { Progress } from '../Progress';
18
- import { Text } from '../Text';
19
- // @ts-ignore: No implicit any
20
- import { DeviceSelector } from './DeviceSelector';
21
- import { DiagnosticsStep, useDiagnostics } from './DiagnosticsContext';
22
- import { useAudioOutputTest } from '../Prebuilt/components/hooks/useAudioOutputTest';
23
- import { TEST_AUDIO_URL } from '../Prebuilt/common/constants';
24
-
25
- const SelectContainer = ({ children }: { children: React.ReactNode }) => (
26
- <Box css={{ w: 'calc(50% - 0.75rem)', '@lg': { w: '100%' } }}>{children}</Box>
27
- );
28
-
29
- const MicTest = ({ setError }: { setError: (err?: Error) => void }) => {
30
- const { hmsDiagnostics } = useDiagnostics();
31
- const devices = useHMSStore(selectDevices);
32
- const [isRecording, setIsRecording] = useState(false);
33
- const [selectedMic, setSelectedMic] = useState(devices.audioInput[0]?.deviceId || 'default');
34
- const trackID = useHMSStore(selectLocalAudioTrackID);
35
- const audioLevel = useHMSStore(selectTrackAudioByID(trackID));
36
- const { audioOutputDeviceId } = useHMSStore(selectLocalMediaSettings);
37
- const { playing, setPlaying, audioRef } = useAudioOutputTest({
38
- deviceId: audioOutputDeviceId || devices.audioOutput[0]?.deviceId,
39
- });
40
-
41
- return (
42
- <SelectContainer>
43
- <DeviceSelector
44
- title="Microphone (Input)"
45
- devices={devices.audioInput}
46
- selection={selectedMic}
47
- icon={<MicOnIcon />}
48
- onChange={(deviceId: string) => {
49
- setError(undefined);
50
- setSelectedMic(deviceId);
51
- hmsDiagnostics?.stopMicCheck();
52
- }}
53
- />
54
- <Flex css={{ gap: '$6', alignItems: 'center' }}>
55
- <Button
56
- variant="standard"
57
- icon
58
- onClick={() => {
59
- isRecording
60
- ? hmsDiagnostics?.stopMicCheck()
61
- : hmsDiagnostics
62
- ?.startMicCheck({
63
- inputDevice: selectedMic,
64
- onError: (err: Error) => {
65
- setError(err);
66
- },
67
- onStop: () => {
68
- setIsRecording(false);
69
- },
70
- })
71
- .then(() => {
72
- setIsRecording(true);
73
- });
74
- }}
75
- disabled={devices.audioInput.length === 0 || playing}
76
- >
77
- {isRecording ? <StopIcon /> : <MicOnIcon />}
78
- {isRecording ? 'Stop Recording' : 'Record'}
79
- </Button>
80
-
81
- <Button
82
- icon
83
- variant="standard"
84
- outlined={hmsDiagnostics?.getRecordedAudio() === TEST_AUDIO_URL}
85
- onClick={() => {
86
- if (audioRef.current) {
87
- audioRef.current.src = hmsDiagnostics?.getRecordedAudio() || '';
88
- audioRef.current.play();
89
- }
90
- }}
91
- disabled={playing || hmsDiagnostics?.getRecordedAudio() === TEST_AUDIO_URL}
92
- >
93
- <SpeakerIcon />
94
- {playing ? 'Playing...' : 'Playback'}
95
- </Button>
96
- <audio
97
- ref={audioRef}
98
- onEnded={() => setPlaying(false)}
99
- onPlay={() => setPlaying(true)}
100
- style={{ display: 'none' }}
101
- />
102
- </Flex>
103
-
104
- <Flex align="center" css={{ mt: '$4', maxWidth: '10rem', opacity: isRecording ? '1' : '0', gap: '$4' }}>
105
- <Text>
106
- <MicOnIcon />
107
- </Text>
108
- <Progress.Root value={audioLevel} css={{ h: '$2' }}>
109
- <Progress.Content
110
- style={{
111
- transform: `translateX(-${100 - audioLevel}%)`,
112
- transition: 'transform 0.3s',
113
- }}
114
- />
115
- </Progress.Root>
116
- </Flex>
117
- </SelectContainer>
118
- );
119
- };
120
-
121
- const SpeakerTest = () => {
122
- const actions = useHMSActions();
123
- const devices = useHMSStore(selectDevices);
124
- const { audioOutputDeviceId } = useHMSStore(selectLocalMediaSettings);
125
-
126
- if (devices.audioOutput.length === 0) {
127
- return <></>;
128
- }
129
-
130
- return (
131
- <SelectContainer>
132
- <DeviceSelector
133
- title="Speaker (Output)"
134
- devices={devices.audioOutput}
135
- selection={audioOutputDeviceId || devices.audioOutput[0]?.deviceId}
136
- icon={<SpeakerIcon />}
137
- onChange={(deviceId: string) => {
138
- actions.setAudioOutputDevice(deviceId);
139
- }}
140
- />
141
- </SelectContainer>
142
- );
143
- };
144
-
145
- export const AudioTest = () => {
146
- const { hmsDiagnostics, updateStep } = useDiagnostics();
147
- const [error, setErrorAlone] = useState<Error | undefined>();
148
-
149
- const setError = useCallback(
150
- (err?: Error) => {
151
- updateStep(DiagnosticsStep.AUDIO, { hasFailed: !!err });
152
- setErrorAlone(err);
153
- },
154
- [updateStep, setErrorAlone],
155
- );
156
-
157
- useEffect(() => {
158
- hmsDiagnostics?.requestPermission({ audio: true }).catch(error => setError(error));
159
- }, [hmsDiagnostics, setError]);
160
-
161
- return (
162
- <>
163
- <TestContainer>
164
- <Text variant="body2" css={{ c: '$on_primary_medium' }}>
165
- Record a 10 second audio clip and play it back to check that your microphone and speaker are working. If they
166
- aren't, make sure your volume is turned up, try a different speaker or microphone, or check your bluetooth
167
- settings.
168
- </Text>
169
-
170
- <Flex
171
- css={{
172
- mt: '$10',
173
- gap: '$10',
174
- '@lg': {
175
- flexDirection: 'column',
176
- gap: '$8',
177
- },
178
- }}
179
- >
180
- <MicTest setError={setError} />
181
- <SpeakerTest />
182
- </Flex>
183
- </TestContainer>
184
- <TestFooter error={error} ctaText="Does your audio sound good?" />
185
- <PermissionErrorModal error={error as HMSException} />
186
- </>
187
- );
188
- };