@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,61 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import {
3
- HMSChangeMultiTrackStateRequest,
4
- HMSNotificationTypes,
5
- useHMSActions,
6
- useHMSNotifications,
7
- } from '@100mslive/react-sdk';
8
- import { MicOnIcon } from '@100mslive/react-icons';
9
- // @ts-ignore: No implicit Any
10
- import { RequestDialog } from '../../primitives/DialogContent';
11
-
12
- const notificationTypes = [
13
- HMSNotificationTypes.CHANGE_MULTI_TRACK_STATE_REQUEST,
14
- HMSNotificationTypes.ROOM_ENDED,
15
- HMSNotificationTypes.REMOVED_FROM_ROOM,
16
- ];
17
-
18
- export const TrackBulkUnmuteModal = () => {
19
- const hmsActions = useHMSActions();
20
- const [muteNotification, setMuteNotification] = useState<HMSChangeMultiTrackStateRequest | null>(null);
21
- const notification = useHMSNotifications(notificationTypes);
22
-
23
- useEffect(() => {
24
- switch (notification?.type) {
25
- case HMSNotificationTypes.REMOVED_FROM_ROOM:
26
- case HMSNotificationTypes.ROOM_ENDED:
27
- setMuteNotification(null);
28
- break;
29
- case HMSNotificationTypes.CHANGE_MULTI_TRACK_STATE_REQUEST:
30
- if (notification?.data.enabled) {
31
- setMuteNotification(notification.data);
32
- }
33
- break;
34
- default:
35
- return;
36
- }
37
- }, [notification]);
38
-
39
- if (!muteNotification) {
40
- return null;
41
- }
42
-
43
- const { requestedBy: peer, tracks, enabled } = muteNotification;
44
-
45
- const types = new Set(tracks.map(track => track.type));
46
-
47
- return (
48
- <RequestDialog
49
- title="Unmute request"
50
- body={`${peer?.name} is requesting you to unmute your ${Array.from(types).join(',')}`}
51
- onOpenChange={(value: boolean) => !value && setMuteNotification(null)}
52
- onAction={() => {
53
- tracks.forEach(track => {
54
- hmsActions.setEnabledTrack(track.id, enabled);
55
- });
56
- setMuteNotification(null);
57
- }}
58
- Icon={MicOnIcon}
59
- />
60
- );
61
- };
@@ -1,41 +0,0 @@
1
- import { useEffect } from 'react';
2
- import { HMSNotificationTypes, useHMSNotifications } from '@100mslive/react-sdk';
3
- // @ts-ignore: No implicit Any
4
- import { ToastManager } from '../Toast/ToastManager';
5
-
6
- const notificationTypes = [
7
- HMSNotificationTypes.TRACK_ADDED,
8
- HMSNotificationTypes.TRACK_REMOVED,
9
- HMSNotificationTypes.TRACK_MUTED,
10
- HMSNotificationTypes.TRACK_UNMUTED,
11
- HMSNotificationTypes.CHANGE_TRACK_STATE_REQUEST,
12
- ];
13
-
14
- export const TrackNotifications = () => {
15
- const notification = useHMSNotifications(notificationTypes);
16
- useEffect(() => {
17
- if (notification) {
18
- switch (notification.type) {
19
- case HMSNotificationTypes.TRACK_ADDED:
20
- case HMSNotificationTypes.TRACK_REMOVED:
21
- case HMSNotificationTypes.TRACK_MUTED:
22
- case HMSNotificationTypes.TRACK_UNMUTED:
23
- console.debug(`[${notification.type}]`, notification);
24
- break;
25
- case HMSNotificationTypes.CHANGE_TRACK_STATE_REQUEST:
26
- {
27
- const track = notification.data?.track;
28
- if (!notification.data.enabled) {
29
- ToastManager.addToast({
30
- title: `Your ${track.source} ${track.type} was muted by
31
- ${notification.data.requestedBy?.name}.`,
32
- });
33
- }
34
- }
35
- break;
36
- }
37
- }
38
- }, [notification]);
39
-
40
- return null;
41
- };
@@ -1,63 +0,0 @@
1
- import React, { useEffect, useState } from 'react';
2
- import {
3
- HMSChangeTrackStateRequest,
4
- HMSNotificationTypes,
5
- useHMSActions,
6
- useHMSNotifications,
7
- } from '@100mslive/react-sdk';
8
- import { MicOnIcon } from '@100mslive/react-icons';
9
- // @ts-ignore: No implicit Any
10
- import { RequestDialog } from '../../primitives/DialogContent';
11
- // @ts-ignore: No implicit Any
12
- import { ToastManager } from '../Toast/ToastManager';
13
-
14
- const notificationTypes = [
15
- HMSNotificationTypes.CHANGE_TRACK_STATE_REQUEST,
16
- HMSNotificationTypes.ROOM_ENDED,
17
- HMSNotificationTypes.REMOVED_FROM_ROOM,
18
- ];
19
-
20
- export const TrackUnmuteModal = () => {
21
- const hmsActions = useHMSActions();
22
- const notification = useHMSNotifications(notificationTypes);
23
- const [muteNotification, setMuteNotification] = useState<HMSChangeTrackStateRequest | null>(null);
24
-
25
- useEffect(() => {
26
- switch (notification?.type) {
27
- case HMSNotificationTypes.REMOVED_FROM_ROOM:
28
- case HMSNotificationTypes.ROOM_ENDED:
29
- ToastManager.addToast({
30
- title: `${notification.message}.
31
- ${notification.data.reason && `Reason: ${notification.data.reason}`}`,
32
- });
33
- setMuteNotification(null);
34
- break;
35
- case HMSNotificationTypes.CHANGE_TRACK_STATE_REQUEST:
36
- if (notification?.data.enabled) {
37
- setMuteNotification(notification.data);
38
- }
39
- break;
40
- default:
41
- return;
42
- }
43
- }, [notification]);
44
-
45
- if (!muteNotification) {
46
- return null;
47
- }
48
-
49
- const { requestedBy: peer, track, enabled } = muteNotification;
50
-
51
- return (
52
- <RequestDialog
53
- title={`Unmute your ${track.type}?`}
54
- onOpenChange={(value: boolean) => !value && setMuteNotification(null)}
55
- body={`${peer?.name} is requesting you to unmute your ${track?.type}.`}
56
- onAction={() => {
57
- hmsActions.setEnabledTrack(track.id, enabled);
58
- setMuteNotification(null);
59
- }}
60
- Icon={MicOnIcon}
61
- />
62
- );
63
- };
@@ -1,58 +0,0 @@
1
- import React, { useEffect } from 'react';
2
- import { match } from 'ts-pattern';
3
- import { HMSNotificationTypes, HMSTranscriptionState, useHMSNotifications } from '@100mslive/react-sdk';
4
- import { AlertTriangleIcon, ClosedCaptionIcon, OpenCaptionIcon } from '@100mslive/react-icons';
5
- // @ts-ignore: No implicit Any
6
- import { ToastManager } from '../Toast/ToastManager';
7
- // @ts-ignore: No implicit Any
8
- import { useSetAppDataByKey } from '../AppData/useUISettings';
9
- import { CAPTION_TOAST } from '../../common/constants';
10
-
11
- export const TranscriptionNotifications = () => {
12
- const notification = useHMSNotifications(HMSNotificationTypes.TRANSCRIPTION_STATE_UPDATED);
13
- const [toastId, setToastId] = useSetAppDataByKey(CAPTION_TOAST.captionToast);
14
-
15
- useEffect(() => {
16
- if (!notification?.data) {
17
- return;
18
- }
19
-
20
- console.debug(`[${notification.type}]`, notification);
21
- const transcriptionStates = notification.data;
22
- if (transcriptionStates.length > 0) {
23
- let id = '';
24
- match({ state: transcriptionStates[0].state, error: transcriptionStates[0].error })
25
- .when(
26
- ({ error }) => !!error,
27
- () => {
28
- id = ToastManager.replaceToast(toastId, {
29
- title: `Failed to enable Closed Caption`,
30
- variant: 'error',
31
- icon: <AlertTriangleIcon style={{ marginRight: '0.5rem' }} />,
32
- });
33
- },
34
- )
35
- .with({ state: HMSTranscriptionState.STARTED }, () => {
36
- id = ToastManager.replaceToast(toastId, {
37
- title: `Closed Captioning enabled for everyone`,
38
- variant: 'standard',
39
- duration: 2000,
40
- icon: <ClosedCaptionIcon style={{ marginRight: '0.5rem' }} />,
41
- });
42
- })
43
- .with({ state: HMSTranscriptionState.STOPPED }, () => {
44
- id = ToastManager.replaceToast(toastId, {
45
- title: `Closed Captioning disabled for everyone`,
46
- variant: 'standard',
47
- duration: 2000,
48
- icon: <OpenCaptionIcon style={{ marginRight: '0.5rem' }} />,
49
- });
50
- })
51
- .otherwise(() => null);
52
- setToastId(id);
53
- }
54
- // eslint-disable-next-line react-hooks/exhaustive-deps
55
- }, [notification, setToastId]);
56
-
57
- return null;
58
- };
@@ -1 +0,0 @@
1
- export { Notifications } from './Notifications';
@@ -1,292 +0,0 @@
1
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
2
- import {
3
- selectHMSMessages,
4
- selectLocalPeerID,
5
- selectPeerNameByID,
6
- selectSessionStore,
7
- selectUnreadHMSMessagesCount,
8
- useHMSStore,
9
- } from '@100mslive/react-sdk';
10
- import { SendIcon } from '@100mslive/react-icons';
11
- import { Box, Flex } from '../../../Layout';
12
- import { Text } from '../../../Text';
13
- import { TextArea } from '../../../TextArea';
14
- import { Tooltip } from '../../../Tooltip';
15
- import IconButton from '../../IconButton';
16
- import { AnnotisedMessage } from '../Chat/ChatBody';
17
- import { useRoomLayoutConferencingScreen } from '../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
18
- import { useIsPeerBlacklisted } from '../hooks/useChatBlacklist';
19
- import { CHAT_MESSAGE_LIMIT, formatTime } from '../Chat/utils';
20
- import { SESSION_STORE_KEY } from '../../common/constants';
21
-
22
- export const PIPChat = () => {
23
- const messages = useHMSStore(selectHMSMessages);
24
- const localPeerID = useHMSStore(selectLocalPeerID);
25
- const count = useHMSStore(selectUnreadHMSMessagesCount);
26
- const [unreadMessageCount, setUnreadMessageCount] = useState(0);
27
-
28
- const getSenderName = useCallback(
29
- (senderName: string, senderID?: string) => {
30
- const slicedName = senderName.length > 10 ? senderName.slice(0, 10) + '...' : senderName;
31
- return slicedName + (senderID === localPeerID ? ' (You)' : '');
32
- },
33
- [localPeerID],
34
- );
35
-
36
- useEffect(() => {
37
- const timeoutId = setTimeout(() => {
38
- setUnreadMessageCount(count);
39
- }, 100);
40
- return () => clearTimeout(timeoutId);
41
- }, [count]);
42
-
43
- const blacklistedMessageIDs = useHMSStore(selectSessionStore(SESSION_STORE_KEY.CHAT_MESSAGE_BLACKLIST));
44
- const filteredMessages = useMemo(() => {
45
- const blacklistedMessageIDSet = new Set(blacklistedMessageIDs || []);
46
- return messages?.filter(message => message.type === 'chat' && !blacklistedMessageIDSet.has(message.id)) || [];
47
- }, [blacklistedMessageIDs, messages]);
48
- const { enabled: isChatEnabled = true, updatedBy: chatStateUpdatedBy = '' } =
49
- useHMSStore(selectSessionStore(SESSION_STORE_KEY.CHAT_STATE)) || {};
50
- const isLocalPeerBlacklisted = useIsPeerBlacklisted({ local: true });
51
- const { elements } = useRoomLayoutConferencingScreen();
52
- const message_placeholder = elements?.chat?.message_placeholder || 'Send a message';
53
- const canSendChatMessages =
54
- !!elements?.chat?.public_chat_enabled ||
55
- !!elements?.chat?.roles_whitelist?.length ||
56
- !!elements?.chat?.private_chat_enabled;
57
-
58
- const getChatStatus = useCallback(() => {
59
- if (isLocalPeerBlacklisted) return "You've been blocked from sending messages";
60
- if (!isChatEnabled)
61
- return `Chat has been paused by ${
62
- chatStateUpdatedBy.peerId === localPeerID ? 'you' : chatStateUpdatedBy?.userName
63
- }`;
64
- return message_placeholder;
65
- }, [
66
- chatStateUpdatedBy.peerId,
67
- chatStateUpdatedBy?.userName,
68
- isChatEnabled,
69
- isLocalPeerBlacklisted,
70
- localPeerID,
71
- message_placeholder,
72
- ]);
73
-
74
- return (
75
- <div style={{ height: '100vh' }}>
76
- <Box
77
- id="chat-container"
78
- css={{
79
- bg: '$surface_dim',
80
- overflowY: 'auto',
81
- // Subtracting height of footer
82
- h: canSendChatMessages ? 'calc(100% - 87px)' : '100%',
83
- position: 'relative',
84
- }}
85
- >
86
- {unreadMessageCount ? (
87
- <Box
88
- id="new-message-notif"
89
- style={{
90
- position: 'fixed',
91
- bottom: '76px',
92
- right: '4px',
93
- }}
94
- >
95
- <Text
96
- variant="xs"
97
- css={{ cursor: 'pointer' }}
98
- style={{ color: 'white', background: 'gray', padding: '4px', borderRadius: '4px' }}
99
- >
100
- {unreadMessageCount === 1 ? 'New message' : `${unreadMessageCount} new messages`}
101
- </Text>
102
- </Box>
103
- ) : (
104
- ''
105
- )}
106
- {filteredMessages.length === 0 ? (
107
- <div
108
- style={{
109
- display: 'flex',
110
- flexDirection: 'column',
111
- height: '100%',
112
- width: '100%',
113
- alignItems: 'center',
114
- justifyContent: 'center',
115
- }}
116
- >
117
- <Text variant="h5" css={{ mt: '$8', c: '$on_surface_high' }}>
118
- {canSendChatMessages ? 'Start a conversation' : 'No messages yet'}
119
- </Text>
120
- {canSendChatMessages ? (
121
- <Text variant="sm" style={{ maxWidth: '80%', textAlign: 'center', marginTop: '4px' }}>
122
- There are no messages here yet. Start a conversation by sending a message.
123
- </Text>
124
- ) : (
125
- ''
126
- )}
127
- </div>
128
- ) : (
129
- filteredMessages.map(message => (
130
- <Box className="pip-message" key={message.id} id={message.id} style={{ padding: '8px 0.75rem' }}>
131
- <Flex style={{ width: '100%', alignItems: 'center', justifyContent: 'between' }}>
132
- <Text
133
- style={{ display: 'flex', justifyContent: 'between', width: '100%', alignItems: 'center' }}
134
- css={{
135
- color: '$on_surface_high',
136
- fontWeight: '$semiBold',
137
- }}
138
- >
139
- <Flex style={{ flexGrow: 1, gap: '2px', alignItems: 'center' }}>
140
- {message.senderName === 'You' || !message.senderName ? (
141
- <Text as="span" variant="sub2" css={{ color: '$on_surface_high', fontWeight: '$semiBold' }}>
142
- {message.senderName || 'Anonymous'}
143
- </Text>
144
- ) : (
145
- <Tooltip title={message.senderName} side="top" align="start">
146
- <Text as="span" variant="sub2" css={{ color: '$on_surface_high', fontWeight: '$semiBold' }}>
147
- {getSenderName(message.senderName, message?.sender)}
148
- </Text>
149
- </Tooltip>
150
- )}
151
- <MessageTitle
152
- localPeerID={localPeerID}
153
- recipientPeer={message.recipientPeer}
154
- recipientRoles={message.recipientRoles}
155
- />
156
- </Flex>
157
-
158
- <Text
159
- variant="xs"
160
- css={{
161
- color: '$on_surface_medium',
162
- flexShrink: 0,
163
- p: '$2',
164
- whitespace: 'nowrap',
165
- }}
166
- >
167
- {formatTime(message.time)}
168
- </Text>
169
- </Text>
170
- </Flex>
171
- <Text
172
- variant="sm"
173
- css={{
174
- w: '100%',
175
- mt: '$2',
176
- wordBreak: 'break-word',
177
- whiteSpace: 'pre-wrap',
178
- userSelect: 'all',
179
- color: '$on_surface_high',
180
- }}
181
- >
182
- <AnnotisedMessage message={message.message} />
183
- </Text>
184
- </Box>
185
- ))
186
- )}
187
- <div id="marker" style={{ height: filteredMessages.length ? '1px' : 0 }} />
188
- </Box>
189
- {canSendChatMessages && (
190
- <Box css={{ bg: '$surface_dim' }}>
191
- <Flex css={{ px: '$4', pb: '3px', gap: '$2', alignItems: 'center' }}>
192
- <Text variant="caption">To:</Text>
193
- <Flex css={{ bg: '$primary_bright', color: '$on_primary_high', r: '$2' }}>
194
- <select
195
- id="selector"
196
- style={{
197
- background: 'inherit',
198
- color: 'inherit',
199
- border: 'none',
200
- outline: 'none',
201
- borderRadius: '4px',
202
- padding: '0 2px',
203
- }}
204
- defaultValue={elements.chat?.public_chat_enabled ? 'Everyone' : elements.chat?.roles_whitelist?.[0]}
205
- >
206
- {elements.chat?.roles_whitelist?.map(role => (
207
- <option key={role} value={role}>
208
- {role}
209
- </option>
210
- ))}
211
- {elements.chat?.public_chat_enabled ? <option value="Everyone">Everyone</option> : ''}
212
- </select>
213
- </Flex>
214
- </Flex>
215
- <Flex
216
- align="center"
217
- css={{
218
- bg: '$surface_default',
219
- minHeight: '$16',
220
- width: '100%',
221
- py: '$6',
222
- pl: '$4',
223
- boxSizing: 'border-box',
224
- gap: '$2',
225
- r: '$2',
226
- }}
227
- >
228
- <TextArea
229
- id="chat-input"
230
- maxLength={CHAT_MESSAGE_LIMIT}
231
- disabled={!isChatEnabled || isLocalPeerBlacklisted}
232
- rows={1}
233
- css={{
234
- w: '100%',
235
- c: '$on_surface_high',
236
- p: '0.75rem 0.75rem !important',
237
- border: 'none',
238
- resize: 'none',
239
- }}
240
- placeholder={getChatStatus()}
241
- required
242
- autoComplete="off"
243
- aria-autocomplete="none"
244
- />
245
-
246
- <IconButton
247
- id="send-btn"
248
- disabled={!isChatEnabled || isLocalPeerBlacklisted}
249
- title={getChatStatus()}
250
- css={{
251
- ml: 'auto',
252
- height: 'max-content',
253
- mr: '$4',
254
- '&:hover': { c: '$on_surface_medium' },
255
- }}
256
- data-testid="send_msg_btn"
257
- >
258
- <SendIcon />
259
- </IconButton>
260
- </Flex>
261
- </Box>
262
- )}
263
- </div>
264
- );
265
- };
266
-
267
- const MessageTitle = ({
268
- recipientPeer,
269
- recipientRoles,
270
- localPeerID,
271
- }: {
272
- recipientPeer?: string;
273
- recipientRoles?: string[];
274
- localPeerID: string;
275
- }) => {
276
- const peerName = useHMSStore(selectPeerNameByID(recipientPeer));
277
-
278
- return (
279
- <>
280
- {recipientRoles ? (
281
- <Text as="span" variant="sub2" css={{ color: '$on_surface_high', fontWeight: '$semiBold' }}>
282
- to {recipientRoles} (Group)
283
- </Text>
284
- ) : null}
285
- {recipientPeer ? (
286
- <Text as="span" variant="sub2" css={{ color: '$on_surface_high', fontWeight: '$semiBold' }}>
287
- to {recipientPeer === localPeerID ? 'You' : peerName} (DM)
288
- </Text>
289
- ) : null}
290
- </>
291
- );
292
- };
@@ -1,18 +0,0 @@
1
- import React from 'react';
2
- import { ExternalLinkIcon } from '@100mslive/react-icons';
3
- import { Dropdown } from '../../../Dropdown';
4
- import { Text } from '../../../Text';
5
-
6
- export const PIPChatOption = ({ openChat, showPIPChat }: { openChat: () => void; showPIPChat: boolean }) => {
7
- if (!showPIPChat) {
8
- return <></>;
9
- }
10
- return (
11
- <Dropdown.Item onClick={openChat} data-testid="pip_chat_btn">
12
- <ExternalLinkIcon />
13
- <Text variant="sm" css={{ ml: '$4', color: '$on_surface_high' }}>
14
- Pop out Chat
15
- </Text>
16
- </Dropdown.Item>
17
- );
18
- };
@@ -1,90 +0,0 @@
1
- import React, { useCallback, useEffect, useState } from 'react';
2
- import { selectPeers, selectTracksMap, useHMSActions, useHMSVanillaStore } from '@100mslive/react-sdk';
3
- import { PipIcon } from '@100mslive/react-icons';
4
- import { Flex, Tooltip } from '../../..';
5
- import IconButton from '../../IconButton';
6
- import { PictureInPicture } from './PIPManager';
7
- // @ts-ignore: No implicit Any
8
- import { MediaSession } from './SetupMediaSession';
9
- // @ts-ignore: No implicit Any
10
- import { usePinnedTrack } from '../AppData/useUISettings';
11
-
12
- /**
13
- * shows a button which when clicked shows some videos in PIP, clicking
14
- * again turns it off.
15
- */
16
- const PIPComponent = ({ content = null }) => {
17
- const [isPipOn, setIsPipOn] = useState(PictureInPicture.isOn());
18
- const hmsActions = useHMSActions();
19
- const store = useHMSVanillaStore();
20
-
21
- const onPipToggle = useCallback(() => {
22
- if (!isPipOn) {
23
- PictureInPicture.start(hmsActions, setIsPipOn).catch(err => console.error('error in starting pip', err));
24
- MediaSession.setup(hmsActions, store);
25
- } else {
26
- PictureInPicture.stop().catch(err => console.error('error in stopping pip', err));
27
- }
28
- }, [hmsActions, isPipOn, store]);
29
-
30
- if (!PictureInPicture.isSupported()) {
31
- return null;
32
- }
33
- return (
34
- <>
35
- {content ? (
36
- <Flex css={{ w: '100%' }} onClick={() => onPipToggle()} data-testid="pip_btn">
37
- {content}
38
- </Flex>
39
- ) : (
40
- <Tooltip title={`${isPipOn ? 'Deactivate' : 'Activate'} picture in picture view`}>
41
- <IconButton active={!isPipOn} key="pip" onClick={() => onPipToggle()} data-testid="pip_btn">
42
- <PipIcon />
43
- </IconButton>
44
- </Tooltip>
45
- )}
46
- </>
47
- );
48
- };
49
-
50
- /**
51
- * this is a separate component so it can be conditionally rendered and
52
- * the subscriptions to store are done only if required.
53
- */
54
- export const ActivatedPIP = () => {
55
- const store = useHMSVanillaStore();
56
- const pinnedTrack = usePinnedTrack();
57
-
58
- useEffect(() => {
59
- function subscribeToStore() {
60
- return store.subscribe(tracksMap => {
61
- let pipPeers = store.getState(selectPeers);
62
- if (pinnedTrack) {
63
- pipPeers = pipPeers.filter(peer => pinnedTrack.peerId === peer.id);
64
- }
65
- PictureInPicture.updatePeersAndTracks(pipPeers, tracksMap).catch(err => {
66
- console.error('error in updating pip', err);
67
- });
68
- }, selectTracksMap);
69
- }
70
- let unsubscribe: (() => void) | undefined = PictureInPicture.isOn() ? subscribeToStore() : undefined;
71
- PictureInPicture.listenToStateChange(isOn => {
72
- if (isOn) {
73
- if (!unsubscribe) {
74
- unsubscribe = subscribeToStore();
75
- }
76
- } else {
77
- unsubscribe?.();
78
- unsubscribe = undefined;
79
- }
80
- });
81
- return () => {
82
- unsubscribe?.();
83
- unsubscribe = undefined;
84
- };
85
- }, [pinnedTrack, store]);
86
-
87
- return <></>;
88
- };
89
-
90
- export default PIPComponent;