@100mslive/roomkit-react 0.4.3-alpha.2 → 0.4.3-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (391) hide show
  1. package/dist/Prebuilt/App.d.ts +0 -1
  2. package/dist/Prebuilt/AppContext.d.ts +0 -1
  3. package/dist/index.cjs.css +194 -219
  4. package/dist/index.cjs.css.map +3 -3
  5. package/dist/index.cjs.js +8 -56
  6. package/dist/index.cjs.js.map +3 -3
  7. package/dist/index.css +194 -219
  8. package/dist/index.css.map +3 -3
  9. package/dist/index.js +8 -56
  10. package/dist/index.js.map +3 -3
  11. package/dist/meta.cjs.json +23 -41
  12. package/dist/meta.esbuild.json +23 -41
  13. package/package.json +8 -9
  14. package/src/Accordion/Accordion.tsx +0 -88
  15. package/src/Accordion/index.ts +0 -8
  16. package/src/AudioLevel/AudioLevel.tsx +0 -84
  17. package/src/AudioLevel/audio-level.png +0 -0
  18. package/src/AudioLevel/index.ts +0 -2
  19. package/src/AudioLevel/useBorderAudioLevel.tsx +0 -34
  20. package/src/Avatar/Avatar.tsx +0 -60
  21. package/src/Avatar/getAvatarBg.ts +0 -50
  22. package/src/Avatar/index.ts +0 -1
  23. package/src/Button/Button.tsx +0 -210
  24. package/src/Button/index.tsx +0 -1
  25. package/src/Checkbox/Checkbox.tsx +0 -35
  26. package/src/Checkbox/index.tsx +0 -1
  27. package/src/Collapsible/Collapsible.tsx +0 -34
  28. package/src/Collapsible/index.tsx +0 -1
  29. package/src/Diagnostics/AudioTest.tsx +0 -188
  30. package/src/Diagnostics/BrowserTest.tsx +0 -141
  31. package/src/Diagnostics/ConnectivityTest.tsx +0 -383
  32. package/src/Diagnostics/DeviceSelector.jsx +0 -71
  33. package/src/Diagnostics/Diagnostics.tsx +0 -190
  34. package/src/Diagnostics/DiagnosticsContext.ts +0 -46
  35. package/src/Diagnostics/VideoTest.tsx +0 -72
  36. package/src/Diagnostics/components.tsx +0 -70
  37. package/src/Diagnostics/index.ts +0 -1
  38. package/src/Divider/Divider.tsx +0 -45
  39. package/src/Divider/index.ts +0 -1
  40. package/src/Dropdown/Dropdown.tsx +0 -145
  41. package/src/Dropdown/index.tsx +0 -1
  42. package/src/Fieldset/Fieldset.tsx +0 -11
  43. package/src/Fieldset/index.tsx +0 -1
  44. package/src/Footer/Footer.tsx +0 -47
  45. package/src/Footer/index.tsx +0 -1
  46. package/src/IconButton/IconButton.tsx +0 -43
  47. package/src/IconButton/index.tsx +0 -1
  48. package/src/Input/Input.tsx +0 -109
  49. package/src/Input/index.tsx +0 -1
  50. package/src/Label/Label.tsx +0 -8
  51. package/src/Label/index.ts +0 -1
  52. package/src/Layout/Box.tsx +0 -3
  53. package/src/Layout/Flex.tsx +0 -76
  54. package/src/Layout/index.tsx +0 -2
  55. package/src/Link/Link.tsx +0 -54
  56. package/src/Link/index.tsx +0 -2
  57. package/src/Loading/Loading.tsx +0 -30
  58. package/src/Loading/index.ts +0 -1
  59. package/src/Modal/Dialog.tsx +0 -57
  60. package/src/Modal/DialogContent.tsx +0 -65
  61. package/src/Modal/index.ts +0 -1
  62. package/src/Pagination/StyledPagination.tsx +0 -70
  63. package/src/Pagination/index.tsx +0 -1
  64. package/src/Popover/index.tsx +0 -34
  65. package/src/Prebuilt/App.tsx +0 -323
  66. package/src/Prebuilt/AppContext.tsx +0 -34
  67. package/src/Prebuilt/AppStateContext.tsx +0 -95
  68. package/src/Prebuilt/IconButton.tsx +0 -26
  69. package/src/Prebuilt/common/PeersSorter.ts +0 -111
  70. package/src/Prebuilt/common/constants.ts +0 -151
  71. package/src/Prebuilt/common/hooks.ts +0 -257
  72. package/src/Prebuilt/common/utils.js +0 -185
  73. package/src/Prebuilt/components/AppData/AppData.tsx +0 -208
  74. package/src/Prebuilt/components/AppData/useChatState.js +0 -18
  75. package/src/Prebuilt/components/AppData/useSheet.ts +0 -33
  76. package/src/Prebuilt/components/AppData/useSidepane.js +0 -99
  77. package/src/Prebuilt/components/AppData/useSidepaneResetOnLayoutUpdate.tsx +0 -22
  78. package/src/Prebuilt/components/AppData/useUISettings.js +0 -212
  79. package/src/Prebuilt/components/AudioVideoToggle.tsx +0 -411
  80. package/src/Prebuilt/components/AuthToken.tsx +0 -148
  81. package/src/Prebuilt/components/CaptionIcon.tsx +0 -27
  82. package/src/Prebuilt/components/Chat/ArrowNavigation.tsx +0 -44
  83. package/src/Prebuilt/components/Chat/Chat.tsx +0 -190
  84. package/src/Prebuilt/components/Chat/ChatActions.tsx +0 -314
  85. package/src/Prebuilt/components/Chat/ChatBody.tsx +0 -493
  86. package/src/Prebuilt/components/Chat/ChatFooter.tsx +0 -316
  87. package/src/Prebuilt/components/Chat/ChatSelector.tsx +0 -228
  88. package/src/Prebuilt/components/Chat/ChatSelectorContainer.tsx +0 -158
  89. package/src/Prebuilt/components/Chat/ChatStates.tsx +0 -73
  90. package/src/Prebuilt/components/Chat/EmptyChat.tsx +0 -58
  91. package/src/Prebuilt/components/Chat/MwebChatOption.tsx +0 -24
  92. package/src/Prebuilt/components/Chat/PinnedMessage.tsx +0 -140
  93. package/src/Prebuilt/components/Chat/StickIndicator.tsx +0 -24
  94. package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +0 -32
  95. package/src/Prebuilt/components/Chat/useUnreadCount.ts +0 -19
  96. package/src/Prebuilt/components/Chat/utils.ts +0 -11
  97. package/src/Prebuilt/components/ChatSettings.tsx +0 -68
  98. package/src/Prebuilt/components/Chip.tsx +0 -40
  99. package/src/Prebuilt/components/ConferenceScreen.tsx +0 -205
  100. package/src/Prebuilt/components/Connection/ConnectionIndicator.tsx +0 -89
  101. package/src/Prebuilt/components/Connection/TileConnection.tsx +0 -93
  102. package/src/Prebuilt/components/Connection/connectionQualityUtils.js +0 -37
  103. package/src/Prebuilt/components/EmojiReaction.jsx +0 -100
  104. package/src/Prebuilt/components/EndCallFeedback/Feedback.tsx +0 -71
  105. package/src/Prebuilt/components/EndCallFeedback/FeedbackForm.tsx +0 -381
  106. package/src/Prebuilt/components/EndCallFeedback/ThankyouView.tsx +0 -64
  107. package/src/Prebuilt/components/ErrorBoundary.jsx +0 -102
  108. package/src/Prebuilt/components/Footer/ChatToggle.tsx +0 -53
  109. package/src/Prebuilt/components/Footer/EmojiCard.jsx +0 -34
  110. package/src/Prebuilt/components/Footer/Footer.tsx +0 -115
  111. package/src/Prebuilt/components/Footer/PaginatedParticipants.tsx +0 -124
  112. package/src/Prebuilt/components/Footer/ParticipantList.tsx +0 -478
  113. package/src/Prebuilt/components/Footer/PollsToggle.tsx +0 -37
  114. package/src/Prebuilt/components/Footer/RoleAccordion.tsx +0 -183
  115. package/src/Prebuilt/components/Footer/RoleOptions.tsx +0 -215
  116. package/src/Prebuilt/components/Footer/WhiteboardToggle.tsx +0 -52
  117. package/src/Prebuilt/components/FullPageProgress.tsx +0 -22
  118. package/src/Prebuilt/components/HMSVideo/Controls.jsx +0 -22
  119. package/src/Prebuilt/components/HMSVideo/FullscreenButton.tsx +0 -13
  120. package/src/Prebuilt/components/HMSVideo/HLSAutoplayBlockedPrompt.tsx +0 -72
  121. package/src/Prebuilt/components/HMSVideo/HLSCaptionSelector.tsx +0 -15
  122. package/src/Prebuilt/components/HMSVideo/HLSQualitySelector.tsx +0 -248
  123. package/src/Prebuilt/components/HMSVideo/HMSVideo.jsx +0 -75
  124. package/src/Prebuilt/components/HMSVideo/MwebHLSViewTitle.tsx +0 -86
  125. package/src/Prebuilt/components/HMSVideo/PlayPauseButton.tsx +0 -27
  126. package/src/Prebuilt/components/HMSVideo/PlayPauseSeekControls.tsx +0 -158
  127. package/src/Prebuilt/components/HMSVideo/PlayerContext.tsx +0 -15
  128. package/src/Prebuilt/components/HMSVideo/SeekControl.tsx +0 -22
  129. package/src/Prebuilt/components/HMSVideo/VideoProgress.tsx +0 -100
  130. package/src/Prebuilt/components/HMSVideo/VideoTime.tsx +0 -52
  131. package/src/Prebuilt/components/HMSVideo/VolumeControl.tsx +0 -70
  132. package/src/Prebuilt/components/HMSVideo/index.ts +0 -24
  133. package/src/Prebuilt/components/HMSVideo/utils.ts +0 -37
  134. package/src/Prebuilt/components/Header/Header.tsx +0 -52
  135. package/src/Prebuilt/components/Header/HeaderComponents.jsx +0 -57
  136. package/src/Prebuilt/components/Header/ParticipantFilter.jsx +0 -89
  137. package/src/Prebuilt/components/Header/RoomDetailsHeader.tsx +0 -51
  138. package/src/Prebuilt/components/Header/StreamActions.tsx +0 -297
  139. package/src/Prebuilt/components/Header/common.jsx +0 -196
  140. package/src/Prebuilt/components/Header/index.tsx +0 -1
  141. package/src/Prebuilt/components/HlsStatsOverlay.jsx +0 -89
  142. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.tsx +0 -167
  143. package/src/Prebuilt/components/Input/KeyboardInputManager.js +0 -107
  144. package/src/Prebuilt/components/InsetTile.tsx +0 -136
  145. package/src/Prebuilt/components/LayoutModeSelector.tsx +0 -112
  146. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +0 -166
  147. package/src/Prebuilt/components/Leave/EndSessionContent.tsx +0 -64
  148. package/src/Prebuilt/components/Leave/LeaveAtoms.tsx +0 -26
  149. package/src/Prebuilt/components/Leave/LeaveCard.tsx +0 -36
  150. package/src/Prebuilt/components/Leave/LeaveRoom.tsx +0 -82
  151. package/src/Prebuilt/components/Leave/LeaveSessionContent.tsx +0 -61
  152. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +0 -135
  153. package/src/Prebuilt/components/LeaveScreen.tsx +0 -71
  154. package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +0 -60
  155. package/src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx +0 -139
  156. package/src/Prebuilt/components/MoreSettings/CaptionContent.tsx +0 -143
  157. package/src/Prebuilt/components/MoreSettings/CaptionModal.tsx +0 -37
  158. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.tsx +0 -123
  159. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.tsx +0 -78
  160. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +0 -81
  161. package/src/Prebuilt/components/MoreSettings/FullScreenItem.tsx +0 -26
  162. package/src/Prebuilt/components/MoreSettings/MoreSettings.tsx +0 -29
  163. package/src/Prebuilt/components/MoreSettings/MuteAllContent.tsx +0 -81
  164. package/src/Prebuilt/components/MoreSettings/MuteAllModal.tsx +0 -72
  165. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx +0 -282
  166. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +0 -387
  167. package/src/Prebuilt/components/MoreSettings/constants.ts +0 -14
  168. package/src/Prebuilt/components/MwebLandscapePrompt.tsx +0 -81
  169. package/src/Prebuilt/components/Notifications/AutoplayBlockedModal.tsx +0 -39
  170. package/src/Prebuilt/components/Notifications/ChatNotifications.tsx +0 -34
  171. package/src/Prebuilt/components/Notifications/DeviceChangeNotifications.tsx +0 -18
  172. package/src/Prebuilt/components/Notifications/DeviceInUseError.tsx +0 -86
  173. package/src/Prebuilt/components/Notifications/ErrorNotifications.tsx +0 -56
  174. package/src/Prebuilt/components/Notifications/HLSFailureModal.tsx +0 -71
  175. package/src/Prebuilt/components/Notifications/HandRaisedNotifications.tsx +0 -78
  176. package/src/Prebuilt/components/Notifications/InitErrorModal.tsx +0 -42
  177. package/src/Prebuilt/components/Notifications/MessageNotifications.tsx +0 -24
  178. package/src/Prebuilt/components/Notifications/Notifications.tsx +0 -65
  179. package/src/Prebuilt/components/Notifications/PeerNotifications.tsx +0 -52
  180. package/src/Prebuilt/components/Notifications/PermissionErrorModal.tsx +0 -144
  181. package/src/Prebuilt/components/Notifications/PollNotificationModal.tsx +0 -71
  182. package/src/Prebuilt/components/Notifications/ReconnectNotifications.tsx +0 -33
  183. package/src/Prebuilt/components/Notifications/RoleChangeNotification.tsx +0 -24
  184. package/src/Prebuilt/components/Notifications/TrackBulkUnmuteModal.tsx +0 -61
  185. package/src/Prebuilt/components/Notifications/TrackNotifications.tsx +0 -41
  186. package/src/Prebuilt/components/Notifications/TrackUnmuteModal.tsx +0 -63
  187. package/src/Prebuilt/components/Notifications/TranscriptionNotifications.tsx +0 -58
  188. package/src/Prebuilt/components/Notifications/index.tsx +0 -1
  189. package/src/Prebuilt/components/PIP/PIPChat.tsx +0 -292
  190. package/src/Prebuilt/components/PIP/PIPChatOption.tsx +0 -18
  191. package/src/Prebuilt/components/PIP/PIPComponent.tsx +0 -90
  192. package/src/Prebuilt/components/PIP/PIPManager.ts +0 -335
  193. package/src/Prebuilt/components/PIP/PIPProvider.tsx +0 -56
  194. package/src/Prebuilt/components/PIP/PIPWindow.tsx +0 -13
  195. package/src/Prebuilt/components/PIP/SetupMediaSession.js +0 -60
  196. package/src/Prebuilt/components/PIP/context.ts +0 -10
  197. package/src/Prebuilt/components/PIP/index.jsx +0 -6
  198. package/src/Prebuilt/components/PIP/pip.test.js +0 -72
  199. package/src/Prebuilt/components/PIP/pipUtils.js +0 -183
  200. package/src/Prebuilt/components/PIP/usePIPChat.tsx +0 -105
  201. package/src/Prebuilt/components/PIP/usePIPWindow.tsx +0 -12
  202. package/src/Prebuilt/components/Pagination.tsx +0 -60
  203. package/src/Prebuilt/components/Polls/CreatePollQuiz/PollsQuizMenu.tsx +0 -248
  204. package/src/Prebuilt/components/Polls/CreateQuestions/CreateQuestions.jsx +0 -142
  205. package/src/Prebuilt/components/Polls/CreateQuestions/DeleteQuestionModal.tsx +0 -74
  206. package/src/Prebuilt/components/Polls/CreateQuestions/QuestionForm.tsx +0 -324
  207. package/src/Prebuilt/components/Polls/CreateQuestions/SavedQuestion.tsx +0 -64
  208. package/src/Prebuilt/components/Polls/Polls.tsx +0 -31
  209. package/src/Prebuilt/components/Polls/Voting/LeaderboardEntry.tsx +0 -76
  210. package/src/Prebuilt/components/Polls/Voting/LeaderboardSummary.tsx +0 -116
  211. package/src/Prebuilt/components/Polls/Voting/PeerParticipationSummary.tsx +0 -60
  212. package/src/Prebuilt/components/Polls/Voting/QuestionCard.jsx +0 -221
  213. package/src/Prebuilt/components/Polls/Voting/StandardVoting.tsx +0 -47
  214. package/src/Prebuilt/components/Polls/Voting/StatisticBox.tsx +0 -20
  215. package/src/Prebuilt/components/Polls/Voting/TimedVoting.tsx +0 -55
  216. package/src/Prebuilt/components/Polls/Voting/Voting.tsx +0 -143
  217. package/src/Prebuilt/components/Polls/Voting/useQuizSummary.tsx +0 -50
  218. package/src/Prebuilt/components/Polls/common/Line.tsx +0 -4
  219. package/src/Prebuilt/components/Polls/common/MultipleChoiceOptions.jsx +0 -115
  220. package/src/Prebuilt/components/Polls/common/OptionInputWithDelete.tsx +0 -38
  221. package/src/Prebuilt/components/Polls/common/SingleChoiceOptions.jsx +0 -140
  222. package/src/Prebuilt/components/Polls/common/StatusIndicator.tsx +0 -35
  223. package/src/Prebuilt/components/Polls/common/VoteCount.tsx +0 -15
  224. package/src/Prebuilt/components/Polls/common/VoteProgress.tsx +0 -18
  225. package/src/Prebuilt/components/Polls/common/constants.ts +0 -5
  226. package/src/Prebuilt/components/Polls/common/utils.ts +0 -22
  227. package/src/Prebuilt/components/Preview/PreviewForm.tsx +0 -94
  228. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +0 -292
  229. package/src/Prebuilt/components/Preview/PreviewScreen.tsx +0 -38
  230. package/src/Prebuilt/components/PreviousRoleInMetadata.tsx +0 -20
  231. package/src/Prebuilt/components/RaiseHand.tsx +0 -30
  232. package/src/Prebuilt/components/RemoveParticipant.tsx +0 -35
  233. package/src/Prebuilt/components/RoleChangeModal.tsx +0 -188
  234. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +0 -75
  235. package/src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx +0 -94
  236. package/src/Prebuilt/components/RoomDetails/Duration.tsx +0 -26
  237. package/src/Prebuilt/components/RoomDetails/RoomDetailsPane.tsx +0 -63
  238. package/src/Prebuilt/components/RoomDetails/RoomDetailsRow.tsx +0 -23
  239. package/src/Prebuilt/components/RoomDetails/RoomDetailsSheet.tsx +0 -45
  240. package/src/Prebuilt/components/ScreenShareToggle.jsx +0 -58
  241. package/src/Prebuilt/components/ScreenshareDisplay.tsx +0 -39
  242. package/src/Prebuilt/components/ScreenshareTile.tsx +0 -134
  243. package/src/Prebuilt/components/SecondaryTiles.tsx +0 -81
  244. package/src/Prebuilt/components/Settings/DeviceSettings.jsx +0 -208
  245. package/src/Prebuilt/components/Settings/LayoutSettings.tsx +0 -74
  246. package/src/Prebuilt/components/Settings/NotificationSettings.tsx +0 -66
  247. package/src/Prebuilt/components/Settings/SettingsModal.jsx +0 -301
  248. package/src/Prebuilt/components/Settings/StartRecording.jsx +0 -101
  249. package/src/Prebuilt/components/Settings/SwitchWithLabel.tsx +0 -53
  250. package/src/Prebuilt/components/Settings/common.ts +0 -16
  251. package/src/Prebuilt/components/ShareMenuIcon.jsx +0 -27
  252. package/src/Prebuilt/components/SidePaneTabs.tsx +0 -214
  253. package/src/Prebuilt/components/StatsForNerds.jsx +0 -373
  254. package/src/Prebuilt/components/Streaming/Common.jsx +0 -143
  255. package/src/Prebuilt/components/Streaming/ResolutionInput.jsx +0 -88
  256. package/src/Prebuilt/components/TileMenu/TileMenu.tsx +0 -148
  257. package/src/Prebuilt/components/TileMenu/TileMenuContent.tsx +0 -393
  258. package/src/Prebuilt/components/TileMenu/utils.ts +0 -7
  259. package/src/Prebuilt/components/Toast/Toast.jsx +0 -17
  260. package/src/Prebuilt/components/Toast/ToastBatcher.js +0 -64
  261. package/src/Prebuilt/components/Toast/ToastConfig.jsx +0 -177
  262. package/src/Prebuilt/components/Toast/ToastContainer.jsx +0 -30
  263. package/src/Prebuilt/components/Toast/ToastManager.js +0 -44
  264. package/src/Prebuilt/components/VideoLayouts/EqualProminence.tsx +0 -62
  265. package/src/Prebuilt/components/VideoLayouts/Grid.tsx +0 -43
  266. package/src/Prebuilt/components/VideoLayouts/GridLayout.tsx +0 -155
  267. package/src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx +0 -91
  268. package/src/Prebuilt/components/VideoLayouts/RoleProminence.tsx +0 -66
  269. package/src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx +0 -74
  270. package/src/Prebuilt/components/VideoLayouts/WhiteboardLayout.tsx +0 -93
  271. package/src/Prebuilt/components/VideoLayouts/interface.ts +0 -11
  272. package/src/Prebuilt/components/VideoTile.tsx +0 -203
  273. package/src/Prebuilt/components/VirtualBackground/VBCollection.tsx +0 -52
  274. package/src/Prebuilt/components/VirtualBackground/VBHandler.tsx +0 -130
  275. package/src/Prebuilt/components/VirtualBackground/VBOption.tsx +0 -57
  276. package/src/Prebuilt/components/VirtualBackground/VBPicker.tsx +0 -252
  277. package/src/Prebuilt/components/VirtualBackground/VBToggle.tsx +0 -50
  278. package/src/Prebuilt/components/hooks/useAudioOutputTest.tsx +0 -20
  279. package/src/Prebuilt/components/hooks/useAutoStartStreaming.tsx +0 -70
  280. package/src/Prebuilt/components/hooks/useChatBlacklist.ts +0 -29
  281. package/src/Prebuilt/components/hooks/useCloseScreenshareWhiteboard.tsx +0 -17
  282. package/src/Prebuilt/components/hooks/useDropdownList.ts +0 -24
  283. package/src/Prebuilt/components/hooks/useDropdownSelection.jsx +0 -3
  284. package/src/Prebuilt/components/hooks/useFullscreen.ts +0 -46
  285. package/src/Prebuilt/components/hooks/useGroupOnStageActions.tsx +0 -54
  286. package/src/Prebuilt/components/hooks/useMetadata.tsx +0 -56
  287. package/src/Prebuilt/components/hooks/usePeerOnStageActions.tsx +0 -49
  288. package/src/Prebuilt/components/hooks/usePinnedBy.tsx +0 -22
  289. package/src/Prebuilt/components/hooks/usePinnedMessages.ts +0 -78
  290. package/src/Prebuilt/components/hooks/usePlaylist.js +0 -25
  291. package/src/Prebuilt/components/hooks/usePlaylistMusic.js +0 -35
  292. package/src/Prebuilt/components/hooks/useRedirectToLeave.tsx +0 -23
  293. package/src/Prebuilt/components/hooks/useRoleProminencePeers.tsx +0 -39
  294. package/src/Prebuilt/components/hooks/useScreenshareAudio.js +0 -28
  295. package/src/Prebuilt/components/hooks/useTileLayout.tsx +0 -128
  296. package/src/Prebuilt/components/hooks/useUnreadPollQuizPresent.tsx +0 -17
  297. package/src/Prebuilt/components/hooks/useUserPreferences.jsx +0 -26
  298. package/src/Prebuilt/components/hooks/useVideoTileLayout.ts +0 -26
  299. package/src/Prebuilt/components/init/Init.jsx +0 -31
  300. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +0 -42
  301. package/src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx +0 -31
  302. package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +0 -32
  303. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +0 -211
  304. package/src/Prebuilt/components/pdfAnnotator/submitPdf.jsx +0 -48
  305. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +0 -71
  306. package/src/Prebuilt/components/peerTileUtils.tsx +0 -42
  307. package/src/Prebuilt/images/android-perm-1.png +0 -0
  308. package/src/Prebuilt/images/empty-chat.svg +0 -12
  309. package/src/Prebuilt/images/ios-perm-0.png +0 -0
  310. package/src/Prebuilt/images/pdf-share.png +0 -0
  311. package/src/Prebuilt/images/rtmp.png +0 -0
  312. package/src/Prebuilt/images/screen-share.png +0 -0
  313. package/src/Prebuilt/images/transaction_error.svg +0 -12
  314. package/src/Prebuilt/index.ts +0 -1
  315. package/src/Prebuilt/layouts/EmbedView.jsx +0 -94
  316. package/src/Prebuilt/layouts/HLSView.jsx +0 -794
  317. package/src/Prebuilt/layouts/PDFView.jsx +0 -67
  318. package/src/Prebuilt/layouts/Sheet.tsx +0 -14
  319. package/src/Prebuilt/layouts/SidePane.tsx +0 -241
  320. package/src/Prebuilt/layouts/VideoStreamingSection.tsx +0 -164
  321. package/src/Prebuilt/layouts/WaitingView.tsx +0 -52
  322. package/src/Prebuilt/plugins/CaptionsViewer.tsx +0 -261
  323. package/src/Prebuilt/plugins/FlyingEmoji.jsx +0 -154
  324. package/src/Prebuilt/plugins/RemoteStopScreenshare.jsx +0 -18
  325. package/src/Prebuilt/plugins/transcription/Transcriber.js +0 -216
  326. package/src/Prebuilt/plugins/transcription/TranscriptionButton.jsx +0 -138
  327. package/src/Prebuilt/plugins/transcription/index.jsx +0 -1
  328. package/src/Prebuilt/primitives/DialogContent.jsx +0 -285
  329. package/src/Prebuilt/primitives/DropdownTrigger.jsx +0 -46
  330. package/src/Prebuilt/provider/roomLayoutProvider/constants/index.ts +0 -60
  331. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +0 -88
  332. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useInsetEnabled.ts +0 -10
  333. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useRoomLayoutScreen.ts +0 -112
  334. package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +0 -53
  335. package/src/Prebuilt/services/FeatureFlags.jsx +0 -46
  336. package/src/Progress/index.tsx +0 -17
  337. package/src/QRCode/QRCode.tsx +0 -6
  338. package/src/QRCode/index.tsx +0 -1
  339. package/src/RadioGroup/RadioGroup.tsx +0 -33
  340. package/src/RadioGroup/index.tsx +0 -1
  341. package/src/ReactSelect/ReactSelect.tsx +0 -97
  342. package/src/ReactSelect/index.ts +0 -1
  343. package/src/Select/Select.tsx +0 -63
  344. package/src/Select/index.ts +0 -1
  345. package/src/Sheet/Sheet.tsx +0 -122
  346. package/src/Sheet/index.ts +0 -1
  347. package/src/Slider/Slider.tsx +0 -70
  348. package/src/Slider/index.ts +0 -1
  349. package/src/Stats/Stats.tsx +0 -243
  350. package/src/Stats/StyledStats.tsx +0 -57
  351. package/src/Stats/formatBytes.ts +0 -19
  352. package/src/Stats/index.tsx +0 -2
  353. package/src/Stats/useQoE.ts +0 -79
  354. package/src/Switch/Switch.tsx +0 -52
  355. package/src/Switch/index.ts +0 -1
  356. package/src/Tabs/Tabs.tsx +0 -41
  357. package/src/Tabs/index.tsx +0 -1
  358. package/src/Text/Text.tsx +0 -149
  359. package/src/Text/index.tsx +0 -1
  360. package/src/TextArea/TextArea.tsx +0 -30
  361. package/src/TextArea/index.tsx +0 -1
  362. package/src/Theme/ThemeProvider.tsx +0 -98
  363. package/src/Theme/base.config.ts +0 -236
  364. package/src/Theme/index.tsx +0 -2
  365. package/src/Theme/stitches.config.ts +0 -88
  366. package/src/Theme/useSSR.tsx +0 -24
  367. package/src/TileMenu/StyledMenuTile.tsx +0 -105
  368. package/src/TileMenu/TileMenu.tsx +0 -98
  369. package/src/TileMenu/index.tsx +0 -1
  370. package/src/Toast/Toast.tsx +0 -170
  371. package/src/Toast/index.tsx +0 -1
  372. package/src/Tooltip/Tooltip.tsx +0 -79
  373. package/src/Tooltip/index.ts +0 -1
  374. package/src/Video/Video.tsx +0 -61
  375. package/src/Video/index.tsx +0 -1
  376. package/src/VideoList/StyledVideoList.tsx +0 -39
  377. package/src/VideoList/index.tsx +0 -2
  378. package/src/VideoList/videoListUtils.tsx +0 -20
  379. package/src/VideoTile/StyledVideoTile.tsx +0 -146
  380. package/src/VideoTile/index.tsx +0 -1
  381. package/src/context/DialogContext.tsx +0 -13
  382. package/src/fixtures/chats.ts +0 -25
  383. package/src/fixtures/peers.ts +0 -27
  384. package/src/fixtures/tracks.ts +0 -11
  385. package/src/hooks/useDialogContainerSelector.tsx +0 -7
  386. package/src/index.ts +0 -41
  387. package/src/store/SetupFakeStore.ts +0 -33
  388. package/src/store/StorybookSDK.ts +0 -231
  389. package/src/utils/animations.ts +0 -114
  390. package/src/utils/index.ts +0 -2
  391. package/src/utils/styles.ts +0 -22
@@ -1,261 +0,0 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import Draggable, { ControlPosition } from 'react-draggable';
3
- import { useMedia } from 'react-use';
4
- import {
5
- HMSTranscript,
6
- selectIsTranscriptionEnabled,
7
- selectPeerNameByID,
8
- useHMSStore,
9
- useTranscript,
10
- } from '@100mslive/react-sdk';
11
- import { Box, Flex } from '../../Layout';
12
- import { Text } from '../../Text';
13
- import { config } from '../../Theme';
14
- // @ts-ignore: No implicit Any
15
- import { useIsSidepaneTypeOpen } from '../components/AppData/useSidepane';
16
- // @ts-ignore: No implicit Any
17
- import { useIsCaptionEnabled } from '../components/AppData/useUISettings';
18
- import { useRoomLayoutConferencingScreen } from '../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
19
- import { SIDE_PANE_OPTIONS } from '../common/constants';
20
- interface CaptionQueueData extends HMSTranscript {
21
- transcriptQueue: SimpleQueue;
22
- }
23
-
24
- interface TranscriptData extends HMSTranscript {
25
- timeout?: NodeJS.Timeout | undefined;
26
- }
27
- class SimpleQueue {
28
- private storage: TranscriptData[] = [];
29
- constructor(private capacity: number = 3, private MAX_STORAGE_TIME: number = 5000) {}
30
- enqueue(data: TranscriptData): void {
31
- if (!data.transcript.trim()) {
32
- return;
33
- }
34
- if (this.size() === this.capacity && this.storage[this.size() - 1].final) {
35
- this.dequeue(this.storage[this.size() - 1]);
36
- }
37
- if (this.size() === 0) {
38
- this.storage.push(data);
39
- this.addTimeout(this.storage[this.size() - 1], data.final);
40
- return;
41
- }
42
- if (this.size() > 0 && this.storage[this.size() - 1]?.final === true) {
43
- this.storage.push(data);
44
- this.addTimeout(this.storage[this.size() - 1], data.final);
45
- return;
46
- }
47
- this.storage[this.size() - 1].transcript = data.transcript;
48
- this.storage[this.size() - 1].final = data.final;
49
- this.storage[this.size() - 1].end = data.end;
50
- this.addTimeout(this.storage[this.size() - 1], data.final);
51
- }
52
- addTimeout(item: TranscriptData, isFinal: boolean) {
53
- if (!isFinal) {
54
- return;
55
- }
56
- item.timeout = setTimeout(() => {
57
- this.dequeue(item);
58
- }, this.MAX_STORAGE_TIME);
59
- }
60
- dequeue(item: TranscriptData): TranscriptData | undefined {
61
- const index = this.storage.indexOf(item);
62
- if (index === -1) {
63
- return undefined;
64
- }
65
- const removedItem = this.storage.splice(index, 1);
66
- if (removedItem.length <= 0) {
67
- return undefined;
68
- }
69
- this.clearTimeout(removedItem[0]);
70
- return item;
71
- }
72
- clearTimeout(item: TranscriptData) {
73
- if (!item.timeout) {
74
- return;
75
- }
76
- clearTimeout(item.timeout);
77
- }
78
- peek(): TranscriptData | undefined {
79
- if (this.size() <= 0) {
80
- return undefined;
81
- }
82
- return this.storage[0];
83
- }
84
- getTranscription(): string {
85
- let script = '';
86
- this.storage.forEach((value: TranscriptData) => (script += value.transcript + ' '));
87
- return script;
88
- }
89
- reset() {
90
- this.storage.length = 0;
91
- }
92
- size(): number {
93
- return this.storage.length;
94
- }
95
- }
96
- class Queue {
97
- private storage: Record<string, CaptionQueueData> = {};
98
- constructor(private capacity: number = 3) {}
99
-
100
- enqueue(data: HMSTranscript): void {
101
- if (this.size() === this.capacity) {
102
- this.dequeue();
103
- }
104
- if (!this.storage[data.peer_id]) {
105
- this.storage[data.peer_id] = {
106
- peer_id: data.peer_id,
107
- transcript: data.transcript,
108
- final: data.final,
109
- transcriptQueue: new SimpleQueue(),
110
- start: data.start,
111
- end: data.end,
112
- };
113
- this.storage[data.peer_id].transcriptQueue.enqueue(data as TranscriptData);
114
- return;
115
- }
116
- this.storage[data.peer_id].transcriptQueue.enqueue(data as TranscriptData);
117
- }
118
- dequeue(): CaptionQueueData {
119
- const key: string = Object.keys(this.storage).shift() || '';
120
- const captionData = this.storage[key];
121
- captionData.transcriptQueue.reset();
122
- delete this.storage[key];
123
- return captionData;
124
- }
125
-
126
- peek(): CaptionQueueData | undefined {
127
- if (this.size() <= 0) return undefined;
128
- const key: string = Object.keys(this.storage).shift() || '';
129
- return this.storage[key];
130
- }
131
-
132
- findPeerData(): { [key: string]: string }[] {
133
- const keys = Object.keys(this.storage);
134
- const data = keys.map((key: string) => {
135
- const data = this.storage[key];
136
- const word = data.transcriptQueue.getTranscription();
137
- return { [key]: word };
138
- });
139
- return data;
140
- }
141
- size(): number {
142
- return Object.keys(this.storage).length;
143
- }
144
- }
145
-
146
- class CaptionMaintainerQueue {
147
- captionData: Queue;
148
- constructor() {
149
- this.captionData = new Queue();
150
- }
151
- push(data: HMSTranscript[] = []) {
152
- data.forEach((value: HMSTranscript) => {
153
- this.captionData.enqueue(value);
154
- });
155
- }
156
- }
157
- const TranscriptView = ({ peer_id, data }: { peer_id: string; data: string }) => {
158
- const peerName = useHMSStore(selectPeerNameByID(peer_id)) || 'Participant';
159
- data = data.trim();
160
- if (!data) return null;
161
- return (
162
- <Text
163
- variant="body2"
164
- css={{
165
- fontWeight: '$normal',
166
- color: 'inherit',
167
- }}
168
- >
169
- <b>{peerName}: </b>
170
- {data}
171
- </Text>
172
- );
173
- };
174
-
175
- export const CaptionsViewer = ({
176
- defaultPosition,
177
- setDefaultPosition,
178
- }: {
179
- defaultPosition: ControlPosition;
180
- setDefaultPosition: (position: ControlPosition) => void;
181
- }) => {
182
- const { elements, screenType } = useRoomLayoutConferencingScreen();
183
- const isMobile = useMedia(config.media.md);
184
- const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
185
-
186
- const showCaptionAtTop = elements?.chat?.is_overlay && isChatOpen && isMobile;
187
-
188
- const [captionQueue] = useState<CaptionMaintainerQueue>(new CaptionMaintainerQueue());
189
- const [currentData, setCurrentData] = useState<{ [key: string]: string }[]>([]);
190
-
191
- const isCaptionEnabled = useIsCaptionEnabled();
192
-
193
- const isTranscriptionEnabled = useHMSStore(selectIsTranscriptionEnabled);
194
-
195
- const nodeRef = useRef<HTMLDivElement>(null);
196
-
197
- useEffect(() => {
198
- const timeInterval = setInterval(() => {
199
- if (!captionQueue) {
200
- return;
201
- }
202
- const data = captionQueue.captionData?.findPeerData();
203
- setCurrentData(data);
204
- }, 1000);
205
- return () => clearInterval(timeInterval);
206
- }, [captionQueue]);
207
-
208
- useTranscript({
209
- onTranscript: (data: HMSTranscript[]) => {
210
- captionQueue && captionQueue.push(data as HMSTranscript[]);
211
- },
212
- });
213
- const dataToShow = currentData.filter((data: { [key: string]: string }) => {
214
- const key = Object.keys(data)[0];
215
- if (data[key]) {
216
- return true;
217
- }
218
- return false;
219
- });
220
- if (dataToShow.length <= 0 || screenType === 'hls_live_streaming' || !isCaptionEnabled || !isTranscriptionEnabled) {
221
- return null;
222
- }
223
- return (
224
- <Draggable
225
- bounds="parent"
226
- nodeRef={nodeRef}
227
- defaultPosition={defaultPosition}
228
- onStop={(_, data) => {
229
- setDefaultPosition({ x: data.lastX, y: data.lastY });
230
- }}
231
- >
232
- <Box
233
- ref={nodeRef}
234
- css={{
235
- position: 'absolute',
236
- w: isMobile ? '100%' : '40%',
237
- bottom: showCaptionAtTop ? '' : '0',
238
- top: showCaptionAtTop ? '0' : '',
239
- left: isMobile ? 0 : '50%',
240
- transform: isMobile ? '' : 'translateX(-50%)',
241
- background: '#000000A3',
242
- overflow: 'clip',
243
- zIndex: 10,
244
- color: '$on_primary_high',
245
- height: 'fit-content',
246
- r: '$1',
247
- p: '$6',
248
- transition: 'bottom 0.3s ease-in-out',
249
- '&:empty': { display: 'none' },
250
- }}
251
- >
252
- <Flex direction="column">
253
- {dataToShow.map((data: { [key: string]: string }, index: number) => {
254
- const key = Object.keys(data)[0];
255
- return <TranscriptView key={index} peer_id={key} data={data[key]} />;
256
- })}
257
- </Flex>
258
- </Box>
259
- </Draggable>
260
- );
261
- };
@@ -1,154 +0,0 @@
1
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import {
4
- selectIsLargeRoom,
5
- selectLocalPeerID,
6
- selectPeerNameByID,
7
- useCustomEvent,
8
- useHMSActions,
9
- useHMSStore,
10
- useHMSVanillaStore,
11
- } from '@100mslive/react-sdk';
12
- import { Box, Flex } from '../../Layout';
13
- import { Text } from '../../Text';
14
- import { config as cssConfig, keyframes } from '../../Theme';
15
- import { EMOJI_REACTION_TYPE } from '../common/constants';
16
-
17
- let emojiCount = 1;
18
-
19
- const flyAndFade = keyframes({
20
- '20%': { opacity: 1 },
21
- '100%': { bottom: '60%', opacity: 0 },
22
- });
23
-
24
- const wiggleLeftRight = keyframes({
25
- '0%': { marginLeft: '-50px' },
26
- '100%': { marginLeft: '50px' },
27
- });
28
-
29
- const wiggleRightLeft = keyframes({
30
- '0%': { marginLeft: '50px' },
31
- '100%': { marginLeft: '-50px' },
32
- });
33
-
34
- const getStartingPoints = isMobile => {
35
- let arr = [];
36
- const min = 5;
37
- const max = isMobile ? 30 : 20;
38
- const inc = isMobile ? 8 : 5;
39
- for (let i = min; i <= max; i += inc) {
40
- arr.push(i);
41
- }
42
- return arr;
43
- };
44
-
45
- export function FlyingEmoji() {
46
- const localPeerId = useHMSStore(selectLocalPeerID);
47
- const vanillaStore = useHMSVanillaStore();
48
- const hmsActions = useHMSActions();
49
- const [emojis, setEmojis] = useState([]);
50
- const isMobile = useMedia(cssConfig.media.md);
51
- const isLargeRoom = useHMSStore(selectIsLargeRoom);
52
-
53
- const startingPoints = useMemo(() => getStartingPoints(isMobile), [isMobile]);
54
-
55
- const showFlyingEmoji = useCallback(
56
- async ({ emojiId, senderId }) => {
57
- if (!emojiId || !senderId || document.hidden) {
58
- return;
59
- }
60
- let senderPeerName = vanillaStore.getState(selectPeerNameByID(senderId));
61
- if (!senderPeerName && isLargeRoom) {
62
- const sender = await hmsActions.getPeer(senderId);
63
- senderPeerName = sender?.name;
64
- }
65
- const nameToShow = localPeerId === senderId ? 'You' : senderPeerName;
66
- const startingPoint = startingPoints[emojiCount % startingPoints.length];
67
- const id = emojiCount++;
68
-
69
- setEmojis(emojis => {
70
- return [
71
- ...emojis,
72
- {
73
- id: id,
74
- emojiId: emojiId,
75
- senderName: nameToShow,
76
- startingPoint: `${startingPoint}%`,
77
- wiggleType: Math.random() < 0.5 ? 0 : 1,
78
- },
79
- ];
80
- });
81
- },
82
- [vanillaStore, isLargeRoom, localPeerId, startingPoints, hmsActions],
83
- );
84
-
85
- useCustomEvent({
86
- type: EMOJI_REACTION_TYPE,
87
- onEvent: showFlyingEmoji,
88
- });
89
-
90
- useEffect(() => {
91
- window.showFlyingEmoji = showFlyingEmoji;
92
- }, [showFlyingEmoji]);
93
-
94
- return (
95
- <Box
96
- css={{
97
- position: 'absolute',
98
- top: 0,
99
- bottom: 0,
100
- left: 0,
101
- right: 0,
102
- overflow: 'hidden',
103
- pointerEvents: 'none',
104
- userSelect: 'none',
105
- zIndex: 999,
106
- }}
107
- >
108
- {emojis.map(emoji => {
109
- return (
110
- <Flex
111
- key={emoji.id}
112
- css={{
113
- left: emoji.startingPoint,
114
- flexDirection: 'column',
115
- alignItems: 'center',
116
- position: 'absolute',
117
- bottom: 0,
118
- animation: `${flyAndFade()} 5s forwards, ${
119
- emoji.wiggleType === 0 ? wiggleLeftRight() : wiggleRightLeft()
120
- } 1s ease-in-out infinite alternate`,
121
- }}
122
- onAnimationEnd={() => setEmojis(emojis.filter(item => item.id !== emoji.id))}
123
- >
124
- <Box>
125
- <em-emoji id={emoji.emojiId} size="48px" set="apple" />
126
- </Box>
127
- {emoji.senderName ? (
128
- <Box
129
- css={{
130
- width: 'fit-content',
131
- padding: '$2 $4',
132
- background: '$surface_bright',
133
- borderRadius: '$1',
134
- }}
135
- >
136
- <Text
137
- css={{
138
- fontSize: '$space$6',
139
- lineHeight: '$xs',
140
- color: '$on_surface_high',
141
- }}
142
- >
143
- {emoji.senderName}
144
- </Text>
145
- </Box>
146
- ) : (
147
- ''
148
- )}
149
- </Flex>
150
- );
151
- })}
152
- </Box>
153
- );
154
- }
@@ -1,18 +0,0 @@
1
- import React, { useCallback } from 'react';
2
- import { useCustomEvent, useHMSActions } from '@100mslive/react-sdk';
3
- import { REMOTE_STOP_SCREENSHARE_TYPE } from '../common/constants';
4
-
5
- export function RemoteStopScreenshare() {
6
- const actions = useHMSActions();
7
-
8
- const onRemoteStopScreenshare = useCallback(async () => {
9
- await actions.setScreenShareEnabled(false);
10
- }, [actions]);
11
-
12
- useCustomEvent({
13
- type: REMOTE_STOP_SCREENSHARE_TYPE,
14
- onEvent: onRemoteStopScreenshare,
15
- });
16
-
17
- return <></>;
18
- }
@@ -1,216 +0,0 @@
1
- import RecordRTC, { StereoAudioRecorder } from 'recordrtc';
2
- import { selectIsLocalAudioEnabled, selectLocalPeerName } from '@100mslive/react-sdk';
3
-
4
- export class Transcriber {
5
- constructor({ hmsStore, setTranscriptAndSpeakingPeer, setIsTranscriptionEnabled }) {
6
- this.hmsStore = hmsStore;
7
- this.enabled = false;
8
- this.audioSocket = null; // this is the socket that will be used to send audio to the STT server
9
- this.setTranscriptAndSpeakingPeer = setTranscriptAndSpeakingPeer;
10
- this.setIsTranscriptionEnabled = setIsTranscriptionEnabled;
11
- this.sttTuningConfig = {
12
- timeSlice: 250,
13
- desiredSampRate: 8000,
14
- numberOfAudioChannels: 1,
15
- bufferSize: 256,
16
- };
17
- this.resetTextTimer = null; // used to reset the transcript after some time, if no new update comes
18
- this.localPeerName = hmsStore.getState(selectLocalPeerName);
19
- this.observingLocalPeerTrack = false;
20
- this.trackIdBeingObserved = null;
21
- this.recordRTCInstance = null;
22
- this.unsubscribes = [];
23
- }
24
-
25
- async toggleTranscriptionState() {
26
- await this.enableTranscription(!this.enabled);
27
- }
28
-
29
- async enableTranscription(enable) {
30
- if (enable === this.enabled) {
31
- return;
32
- }
33
- console.log('transcription enabled', enable);
34
- if (enable) {
35
- this.enabled = true;
36
- await this.setIsTranscriptionEnabled(true);
37
- await this.listen();
38
- } else {
39
- this.enabled = false;
40
- await this.setIsTranscriptionEnabled(false);
41
- this.cleanup();
42
- }
43
- }
44
-
45
- setTranscriptAndPeerWithExpiry(transcript, peerName) {
46
- if (!transcript) {
47
- return;
48
- }
49
- this.setTranscriptAndSpeakingPeer(transcript, `[${peerName}]`);
50
- // reset after some time if no new update comes
51
- clearTimeout(this.resetTextTimer);
52
- this.resetTextTimer = setTimeout(() => {
53
- this.resetTranscriptAndPeer();
54
- }, 5000);
55
- }
56
-
57
- resetTranscriptAndPeer() {
58
- this.setTranscriptAndSpeakingPeer('', '');
59
- clearTimeout(this.resetTextTimer);
60
- }
61
-
62
- async listen(retryCount = 0) {
63
- if (retryCount > 5) {
64
- console.error('transcription', 'Max retry count reached!!', retryCount);
65
- this.cleanup();
66
- return;
67
- }
68
- try {
69
- let url = process.env.REACT_APP_DYNAMIC_STT_TOKEN_GENERATION_ENDPOINT;
70
- let res = await fetch(url);
71
- let body = await res.json();
72
- const authToken = body.token;
73
-
74
- if (authToken) {
75
- this.audioSocket = await new WebSocket(
76
- `wss://api.assemblyai.com/v2/realtime/ws?sample_rate=${this.sttTuningConfig.desiredSampRate}&token=${authToken}`,
77
- );
78
- this.resetTranscriptAndPeer();
79
- this.audioSocket.onmessage = message => {
80
- try {
81
- const res = JSON.parse(message.data);
82
- if (res.text && this.enabled) {
83
- //Limiting the transcript size based on it's charecter length.
84
- let messageText =
85
- res.text.length >= 80
86
- ? res.text
87
- .split(' ')
88
- .slice(Math.max(res.text.split(' ').length - 10, 1))
89
- .join(' ')
90
- : res.text;
91
- if (messageText) {
92
- this.setTranscriptAndPeerWithExpiry(messageText, this.localPeerName);
93
- }
94
- }
95
- } catch (err) {
96
- console.error('transcription', err);
97
- }
98
- };
99
-
100
- this.audioSocket.onerror = event => {
101
- console.error('transcription', event);
102
- this.audioSocket.close();
103
- };
104
-
105
- this.audioSocket.onclose = event => {
106
- try {
107
- console.log(event);
108
- this.audioSocket = null;
109
- if (this.enabled && event.code !== 4001) {
110
- this.listen(retryCount++);
111
- }
112
- } catch (err) {
113
- console.error('transcription', err);
114
- }
115
- };
116
-
117
- this.audioSocket.onopen = () => {
118
- this.observeLocalPeerTrack();
119
- };
120
- } else {
121
- console.error('Unable to fetch dynamic token!!');
122
- }
123
- } catch (err) {
124
- console.error('transcription', err);
125
- }
126
- }
127
-
128
- async observeLocalPeerTrack() {
129
- try {
130
- if (this.observingLocalPeerTrack) {
131
- return;
132
- }
133
- this.observingLocalPeerTrack = true;
134
- console.log('transcription - observing local peer track');
135
- let unsub = this.hmsStore.subscribe(this.getAndObserveStream, selectIsLocalAudioEnabled);
136
- this.unsubscribes.push(unsub);
137
- this.getAndObserveStream(); // call it once to start observing initially
138
- } catch (err) {
139
- console.error('transcription - observing local peer track', err);
140
- }
141
- }
142
-
143
- /**
144
- * This method is used to get the local peer's stream and observe it for changes.
145
- * @returns {Promise<void>}
146
- */
147
- getAndObserveStream = async () => {
148
- // a hacky way to get the local peer's stream till we have a better way
149
- const localPeer = window.__hms.sdk.getLocalPeer();
150
- const mediaTrack = localPeer.audioTrack.nativeTrack;
151
- if (!mediaTrack || mediaTrack.id === this.trackIdBeingObserved) {
152
- return;
153
- }
154
- this.trackIdBeingObserved = mediaTrack.id;
155
- console.log('transcription - observing local peer track', mediaTrack.id);
156
- try {
157
- if (this.recordRTCInstance) {
158
- console.log('transcription - destroying earlier instance');
159
- this.recordRTCInstance.destroy();
160
- }
161
- this.recordRTCInstance = null;
162
- } catch (err) {
163
- console.error('transcription - in destroying earlier instance', err);
164
- }
165
- const stream = new MediaStream([mediaTrack]);
166
- await this.observeStream(stream);
167
- };
168
-
169
- async observeStream(stream) {
170
- this.recordRTCInstance = new RecordRTC(stream, {
171
- ...this.sttTuningConfig,
172
- type: 'audio',
173
- mimeType: 'audio/webm;codecs=pcm',
174
- recorderType: StereoAudioRecorder,
175
- ondataavailable: blob => {
176
- const reader = new FileReader();
177
- reader.onload = () => {
178
- const base64data = reader.result;
179
- if (this.audioSocket && this.enabled && this.audioSocket.readyState && this.audioSocket.readyState === 1) {
180
- try {
181
- this.audioSocket.send(JSON.stringify({ audio_data: base64data.split('base64,')[1] }));
182
- } catch (err) {
183
- console.error('transcription', err);
184
- }
185
- }
186
- };
187
- reader.readAsDataURL(blob);
188
- },
189
- });
190
- this.recordRTCInstance.startRecording();
191
- }
192
-
193
- cleanup() {
194
- console.log('transcription - cleanup');
195
- if (this.audioSocket) {
196
- try {
197
- this.audioSocket.close();
198
- this.audioSocket = null;
199
- } catch (err) {
200
- console.error("transcription cleanup - couldn't close socket", err);
201
- }
202
- }
203
- if (this.recordRTCInstance) {
204
- try {
205
- this.recordRTCInstance.destroy();
206
- this.recordRTCInstance = null;
207
- } catch (err) {
208
- console.error("transcription cleanup - couldn't stop recording", err);
209
- }
210
- }
211
- for (const unsub of this.unsubscribes) {
212
- unsub();
213
- }
214
- this.resetTranscriptAndPeer();
215
- }
216
- }