@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,205 +0,0 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import { DefaultConferencingScreen_Elements } from '@100mslive/types-prebuilt';
3
- import { v4 as uuid } from 'uuid';
4
- import {
5
- HMSRoomState,
6
- selectIsConnectedToRoom,
7
- selectRoomState,
8
- useAwayNotifications,
9
- useHMSActions,
10
- useHMSStore,
11
- } from '@100mslive/react-sdk';
12
- import { Footer } from './Footer/Footer';
13
- import { MoreSettings } from './MoreSettings/MoreSettings';
14
- import { HLSFailureModal } from './Notifications/HLSFailureModal';
15
- // @ts-ignore: No implicit Any
16
- import { ActivatedPIP } from './PIP/PIPComponent';
17
- // @ts-ignore: No implicit Any
18
- import { PictureInPicture } from './PIP/PIPManager';
19
- import { RoleChangeRequestModal } from './RoleChangeRequest/RoleChangeRequestModal';
20
- import { Box, Flex } from '../../Layout';
21
- import { useHMSPrebuiltContext } from '../AppContext';
22
- import { VideoStreamingSection } from '../layouts/VideoStreamingSection';
23
- // @ts-ignore: No implicit Any
24
- import { EmojiReaction } from './EmojiReaction';
25
- import FullPageProgress from './FullPageProgress';
26
- import { Header } from './Header';
27
- import { PreviousRoleInMetadata } from './PreviousRoleInMetadata';
28
- import { RaiseHand } from './RaiseHand';
29
- import {
30
- useRoomLayoutConferencingScreen,
31
- useRoomLayoutPreviewScreen,
32
- } from '../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
33
- // @ts-ignore: No implicit Any
34
- import { useAuthToken, useSetAppDataByKey } from './AppData/useUISettings';
35
- import { useLandscapeHLSStream, useMobileHLSStream } from '../common/hooks';
36
- import { APP_DATA } from '../common/constants';
37
-
38
- export const ConferenceScreen = () => {
39
- const { userName, endpoints, onJoin: onJoinFunc } = useHMSPrebuiltContext();
40
- const screenProps = useRoomLayoutConferencingScreen();
41
- const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
42
- const roomState = useHMSStore(selectRoomState);
43
- const isConnectedToRoom = useHMSStore(selectIsConnectedToRoom);
44
- const hmsActions = useHMSActions();
45
-
46
- const authTokenInAppData = useAuthToken();
47
- const headerRef = useRef<HTMLDivElement | null>(null);
48
- const footerRef = useRef<HTMLDivElement | null>(null);
49
-
50
- const [isHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
51
- const { requestPermission } = useAwayNotifications();
52
-
53
- // using it in hls stream to show action button when chat is disabled
54
- const showChat = !!screenProps.elements?.chat;
55
- const autoRoomJoined = useRef(isPreviewScreenEnabled);
56
- const isMobileHLSStream = useMobileHLSStream();
57
- const isLandscapeHLSStream = useLandscapeHLSStream();
58
- const isMwebHLSStream = isMobileHLSStream || isLandscapeHLSStream;
59
-
60
- useEffect(() => {
61
- if (
62
- authTokenInAppData &&
63
- !isConnectedToRoom &&
64
- !isPreviewScreenEnabled &&
65
- roomState !== HMSRoomState.Connecting &&
66
- !autoRoomJoined.current
67
- ) {
68
- hmsActions
69
- .join({
70
- userName: userName || uuid(),
71
- authToken: authTokenInAppData,
72
- initEndpoint: endpoints?.init,
73
- rememberDeviceSelection: true,
74
- settings: {
75
- isAudioMuted: !isPreviewScreenEnabled,
76
- isVideoMuted: !isPreviewScreenEnabled,
77
- speakerAutoSelectionBlacklist: ['Yeti Stereo Microphone'],
78
- },
79
- })
80
- .then(() => requestPermission())
81
- .catch(console.error);
82
- autoRoomJoined.current = true;
83
- }
84
- }, [
85
- authTokenInAppData,
86
- endpoints?.init,
87
- hmsActions,
88
- isConnectedToRoom,
89
- isPreviewScreenEnabled,
90
- roomState,
91
- userName,
92
- requestPermission,
93
- ]);
94
-
95
- useEffect(() => {
96
- onJoinFunc?.();
97
- return () => {
98
- PictureInPicture.stop().catch((error: unknown) => console.error('stopping pip', (error as Error).message));
99
- };
100
- }, [onJoinFunc]);
101
-
102
- if (!isConnectedToRoom && ![HMSRoomState.Reconnecting, HMSRoomState.Disconnected].includes(roomState)) {
103
- return <FullPageProgress text={roomState === HMSRoomState.Connecting ? 'Joining...' : ''} />;
104
- }
105
-
106
- return (
107
- <>
108
- {isHLSStarted ? (
109
- <Box css={{ position: 'fixed', zIndex: 100, w: '100%', h: '100%', left: 0, top: 0 }}>
110
- <FullPageProgress text="Starting live stream..." css={{ opacity: 0.8, bg: '$background_dim' }} />
111
- </Box>
112
- ) : null}
113
- <Flex css={{ size: '100%', overflow: 'hidden' }} direction="column">
114
- {!(screenProps.hideSections.includes('header') || isMwebHLSStream) && (
115
- <Box
116
- ref={headerRef}
117
- css={{
118
- h: '$18',
119
- transition: 'margin 0.3s ease-in-out',
120
- marginTop: isMwebHLSStream ? `-${headerRef.current?.clientHeight}px` : 'none',
121
- '@md': {
122
- h: '$17',
123
- },
124
- }}
125
- data-testid="header"
126
- >
127
- <Header />
128
- </Box>
129
- )}
130
- <Box
131
- css={{
132
- w: '100%',
133
- flex: '1 1 0',
134
- minHeight: 0,
135
- // @ts-ignore
136
- px: (screenProps?.elements as DefaultConferencingScreen_Elements)?.video_tile_layout?.grid?.edge_to_edge
137
- ? 0
138
- : '$10', // TODO: padding to be controlled by section/element
139
- paddingBottom: 'env(safe-area-inset-bottom)',
140
- '@lg': {
141
- px: 0,
142
- },
143
- }}
144
- id="conferencing"
145
- data-testid="conferencing"
146
- >
147
- {screenProps.elements ? (
148
- <VideoStreamingSection
149
- screenType={screenProps.screenType}
150
- elements={screenProps.elements}
151
- hideControls={isMwebHLSStream}
152
- />
153
- ) : null}
154
- </Box>
155
- {!screenProps.hideSections.includes('footer') && screenProps.elements && !isMwebHLSStream && (
156
- <Box
157
- ref={footerRef}
158
- css={{
159
- flexShrink: 0,
160
- maxHeight: '$24',
161
- transition: 'margin 0.3s ease-in-out',
162
- bg: '$background_dim',
163
- marginBottom: isMwebHLSStream ? `-${footerRef.current?.clientHeight}px` : undefined,
164
- '@md': {
165
- maxHeight: 'unset',
166
- bg: screenProps.screenType === 'hls_live_streaming' ? 'transparent' : '$background_dim',
167
- },
168
- }}
169
- data-testid="footer"
170
- >
171
- <Footer elements={screenProps.elements} screenType={screenProps.screenType} />
172
- </Box>
173
- )}
174
- {isMwebHLSStream && !showChat && (
175
- <Flex
176
- css={{
177
- alignItems: 'center',
178
- pr: '$4',
179
- pb: '$4',
180
- position: 'relative',
181
- }}
182
- justify="end"
183
- gap="2"
184
- >
185
- <RaiseHand />
186
- <MoreSettings elements={screenProps.elements} screenType={screenProps.screenType} />
187
- <Box
188
- css={{
189
- position: 'absolute',
190
- bottom: '100%',
191
- mb: '$4',
192
- }}
193
- >
194
- <EmojiReaction />
195
- </Box>
196
- </Flex>
197
- )}
198
- <RoleChangeRequestModal />
199
- <HLSFailureModal />
200
- <ActivatedPIP />
201
- <PreviousRoleInMetadata />
202
- </Flex>
203
- </>
204
- );
205
- };
@@ -1,89 +0,0 @@
1
- import React from 'react';
2
- import { HMSPeerType, selectConnectionQualityByPeerID, selectPeerTypeByID, useHMSStore } from '@100mslive/react-sdk';
3
- import { PoorConnectivityIcon } from '@100mslive/react-icons';
4
- import { styled, Tooltip, useTheme } from '../../..';
5
- // @ts-ignore
6
- import { getColor, getTooltipText } from './connectionQualityUtils';
7
-
8
- const Wrapper = styled('span', {
9
- width: '28px',
10
- height: '28px',
11
- display: 'flex',
12
- alignItems: 'center',
13
- justifyContent: 'center',
14
- borderRadius: '$round',
15
- variants: {
16
- isTile: {
17
- true: {
18
- width: 'unset',
19
- height: 'unset',
20
- },
21
- },
22
- },
23
- });
24
-
25
- export const ConnectionIndicator = ({
26
- peerId,
27
- isTile = false,
28
- hideBg = false,
29
- }: {
30
- peerId: string;
31
- isTile?: boolean;
32
- hideBg?: boolean;
33
- }) => {
34
- const downlinkQuality = useHMSStore(selectConnectionQualityByPeerID(peerId))?.downlinkQuality;
35
- const peerType = useHMSStore(selectPeerTypeByID(peerId));
36
- const { theme } = useTheme();
37
- const defaultColor = theme.colors.on_surface_low;
38
- if (downlinkQuality === -1 || downlinkQuality === undefined || peerType === HMSPeerType.SIP) {
39
- return null;
40
- }
41
- if (downlinkQuality === 0) {
42
- return (
43
- <Tooltip side="left" title={getTooltipText(downlinkQuality)}>
44
- <Wrapper isTile={isTile} css={{ color: '#ED4C5A' }} data-testid="tile_network">
45
- <PoorConnectivityIcon />
46
- </Wrapper>
47
- </Tooltip>
48
- );
49
- }
50
- const size = isTile ? 12 : 16;
51
- return (
52
- <Tooltip side="left" title={getTooltipText(downlinkQuality)}>
53
- <Wrapper isTile={isTile} data-testid="tile_network" css={{ backgroundColor: hideBg ? '' : '$surface_bright' }}>
54
- <svg
55
- width={size}
56
- height={size}
57
- viewBox="0 0 14 12"
58
- xmlns="http://www.w3.org/2000/svg"
59
- xmlSpace="preserve"
60
- style={{
61
- fillRule: 'evenodd',
62
- clipRule: 'evenodd',
63
- strokeLinejoin: 'round',
64
- strokeMiterlimit: 2,
65
- }}
66
- >
67
- <path
68
- d="M6.875 0c2.549.035 4.679.902 6.445 2.648.366.362.45.796.216 1.096-.239.306-.714.34-1.142.072a2.28 2.28 0 0 1-.341-.271C9.24.862 4.924.775 1.992 3.346c-.284.249-.594.419-.983.393-.272-.019-.49-.135-.613-.388-.125-.261-.05-.498.114-.713.073-.092.156-.177.245-.254C2.516.804 4.591.039 6.875 0Z"
69
- fill={getColor(4, downlinkQuality, defaultColor, theme)}
70
- transform="translate(-.333)"
71
- />
72
- <path
73
- d="M7.056 2.964c1.756.035 3.208.7 4.499 1.763.162.134.277.315.354.512.098.251.114.503-.075.72-.193.222-.452.259-.725.198-.293-.066-.518-.247-.738-.443a4.859 4.859 0 0 0-6.198-.26c-.166.127-.318.271-.475.409-.242.211-.513.343-.843.317-.43-.034-.679-.397-.561-.81.062-.211.181-.4.345-.546 1.265-1.162 2.733-1.836 4.417-1.86Z"
74
- fill={getColor(3, downlinkQuality, defaultColor, theme)}
75
- transform="translate(-.333)"
76
- />
77
- <path
78
- d="M7.384,6.052C8.293,6.068 9.157,6.449 9.783,7.108C10.005,7.339 10.157,7.6 10.07,7.942C9.959,8.377 9.435,8.581 9.071,8.243C7.935,7.191 6.356,7.183 5.152,8.183C4.816,8.462 4.6,8.485 4.332,8.27C4.063,8.055 3.998,7.691 4.177,7.358C4.273,7.179 4.414,7.038 4.57,6.911C5.26,6.349 6.149,6.05 7.384,6.052L7.384,6.052Z"
79
- fill={getColor(2, downlinkQuality, defaultColor, theme)}
80
- />
81
- <path
82
- d="M8.214,9.941C8.214,10.234 8.097,10.515 7.888,10.721C7.68,10.928 7.398,11.042 7.104,11.039C6.471,11.036 5.982,10.541 5.993,9.912C6.004,9.259 6.499,8.766 7.133,8.779C7.744,8.791 8.22,9.301 8.214,9.941Z"
83
- fill={getColor(1, downlinkQuality, defaultColor, theme)}
84
- />
85
- </svg>
86
- </Wrapper>
87
- </Tooltip>
88
- );
89
- };
@@ -1,93 +0,0 @@
1
- import React from 'react';
2
- import {
3
- HMSPeerType,
4
- selectPeerTypeByID,
5
- selectScreenShareByPeerID,
6
- selectSessionStore,
7
- useHMSStore,
8
- } from '@100mslive/react-sdk';
9
- import { CallIcon, PinIcon, ShareScreenIcon, SpotlightIcon } from '@100mslive/react-icons';
10
- import { Flex, styled, Text, textEllipsis } from '../../..';
11
- import { ConnectionIndicator } from './ConnectionIndicator';
12
- import { SESSION_STORE_KEY } from '../../common/constants';
13
-
14
- const TileConnection = ({
15
- name,
16
- peerId,
17
- hideLabel,
18
- width,
19
- pinned,
20
- }: {
21
- name: string;
22
- peerId: string;
23
- hideLabel: boolean;
24
- width?: string | number;
25
- pinned?: boolean;
26
- }) => {
27
- const spotlighted = useHMSStore(selectSessionStore(SESSION_STORE_KEY.SPOTLIGHT)) === peerId;
28
- const isPeerScreenSharing = !!useHMSStore(selectScreenShareByPeerID(peerId));
29
- const peerType = useHMSStore(selectPeerTypeByID(peerId));
30
- return (
31
- <Wrapper>
32
- {!hideLabel ? (
33
- <>
34
- {name ? (
35
- <Flex align="center">
36
- {peerType === HMSPeerType.SIP && (
37
- <IconWrapper>
38
- <CallIcon width="15" height="15" />
39
- </IconWrapper>
40
- )}
41
- {isPeerScreenSharing && (
42
- <IconWrapper>
43
- <ShareScreenIcon width="15" height="15" />
44
- </IconWrapper>
45
- )}
46
- {pinned && (
47
- <IconWrapper>
48
- <PinIcon width="15" height="15" />
49
- </IconWrapper>
50
- )}
51
- {spotlighted && (
52
- <IconWrapper>
53
- <SpotlightIcon width="15" height="15" />
54
- </IconWrapper>
55
- )}
56
- <Text
57
- css={{
58
- c: '$on_surface_high',
59
- verticalAlign: 'baseline',
60
- ...(width ? textEllipsis((width as number) - 60) : {}),
61
- }}
62
- variant="xs"
63
- >
64
- {name}
65
- </Text>
66
- </Flex>
67
- ) : null}
68
- <ConnectionIndicator isTile peerId={peerId} hideBg />
69
- </>
70
- ) : null}
71
- </Wrapper>
72
- );
73
- };
74
-
75
- const IconWrapper = styled('div', { c: '$on_surface_high', ml: '$3', mt: '$1', display: 'flex' });
76
-
77
- const Wrapper = styled('div', {
78
- display: 'flex',
79
- alignItems: 'center',
80
- justifyContent: 'space-between',
81
- position: 'absolute',
82
- bottom: '$2',
83
- left: '$2',
84
- backgroundColor: '$background_dim',
85
- borderRadius: '$1',
86
- maxWidth: '85%',
87
- zIndex: 1,
88
- '& p,span': {
89
- p: '$2 $3',
90
- },
91
- });
92
-
93
- export default TileConnection;
@@ -1,37 +0,0 @@
1
- const connectionTooltip = {
2
- 0: 'Reconnecting',
3
- 1: 'Very Bad Connection',
4
- 2: 'Bad Connection',
5
- 3: 'Moderate Connection',
6
- 4: 'Good Connection',
7
- 5: 'Excellent Connection',
8
- };
9
- connectionTooltip[-1] = 'Network Unknown';
10
-
11
- /**
12
- * @param connectionScore -> 1-5 connection score for network quality
13
- */
14
- export const getTooltipText = connectionScore => {
15
- return connectionTooltip[connectionScore];
16
- };
17
-
18
- /**
19
- * position is needed here as we don't want all the dots/arcs to be colored,
20
- * the non colored ones will be passed in the default color. If user is
21
- * disconnected(score=0), no dot/arc will be colored.
22
- * @param position -> 1 to 5
23
- * @param connectionScore -> 0 to 5, 0 means disconnected
24
- * @param defaultColor -> color for components not taking the connection color
25
- */
26
- export const getColor = (position, connectionScore, defaultColor, theme) => {
27
- const shouldBeColored = position <= connectionScore;
28
- if (!shouldBeColored) {
29
- return defaultColor;
30
- }
31
- if (connectionScore >= 4) {
32
- return theme.colors.alert_success;
33
- } else if (connectionScore >= 1) {
34
- return theme.colors.alert_warning;
35
- }
36
- return defaultColor;
37
- };
@@ -1,100 +0,0 @@
1
- import React, { useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import data from '@emoji-mart/data/sets/14/apple.json';
4
- import { init } from 'emoji-mart';
5
- import {
6
- selectAvailableRoleNames,
7
- selectIsConnectedToRoom,
8
- selectLocalPeerID,
9
- useCustomEvent,
10
- useHMSStore,
11
- } from '@100mslive/react-sdk';
12
- import { EmojiIcon } from '@100mslive/react-icons';
13
- import { EmojiCard } from './Footer/EmojiCard';
14
- // import { ToastManager } from './Toast/ToastManager';
15
- import { Dropdown } from '../../Dropdown';
16
- import { Box } from '../../Layout';
17
- import { config as cssConfig } from '../../Theme';
18
- import { Tooltip } from '../../Tooltip';
19
- import IconButton from '../IconButton';
20
- import { useRoomLayoutConferencingScreen } from '../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
21
- import { useDropdownList } from './hooks/useDropdownList';
22
- import { useLandscapeHLSStream, useMobileHLSStream } from '../common/hooks';
23
- import { EMOJI_REACTION_TYPE } from '../common/constants';
24
-
25
- init({ data });
26
-
27
- export const EmojiReaction = ({ showCard = false }) => {
28
- const [open, setOpen] = useState(false);
29
- const isConnected = useHMSStore(selectIsConnectedToRoom);
30
- const { elements } = useRoomLayoutConferencingScreen();
31
- useDropdownList({ open: open, name: 'EmojiReaction' });
32
- // const hmsActions = useHMSActions();
33
- const roles = useHMSStore(selectAvailableRoleNames);
34
- const localPeerId = useHMSStore(selectLocalPeerID);
35
- // const { isStreamingOn } = useRecordingStreaming();
36
- const isMobile = useMedia(cssConfig.media.md);
37
- const isLandscape = useMedia(cssConfig.media.ls);
38
- const isMobileHLSStream = useMobileHLSStream();
39
- const isLandscapeStream = useLandscapeHLSStream();
40
-
41
- const { sendEvent } = useCustomEvent({
42
- type: EMOJI_REACTION_TYPE,
43
- });
44
-
45
- const sendReaction = async emojiId => {
46
- const data = {
47
- type: EMOJI_REACTION_TYPE,
48
- emojiId: emojiId,
49
- senderId: localPeerId,
50
- };
51
- // TODO: RT find a way to figure out hls-viewer roles
52
- sendEvent(data, { roleNames: roles });
53
- window.showFlyingEmoji?.({ emojiId, senderId: localPeerId });
54
- /* if (isStreamingOn) {
55
- try {
56
- await hmsActions.sendHLSTimedMetadata([
57
- {
58
- payload: JSON.stringify(data),
59
- duration: 2,
60
- },
61
- ]);
62
- } catch (error) {
63
- console.log(error);
64
- ToastManager.addToast({ title: error.message });
65
- }
66
- } */
67
- };
68
-
69
- if (!isConnected || !elements.emoji_reactions) {
70
- return null;
71
- }
72
-
73
- if (showCard) {
74
- return <EmojiCard sendReaction={sendReaction} />;
75
- }
76
- return (
77
- <Dropdown.Root open={open} onOpenChange={setOpen}>
78
- <Dropdown.Trigger asChild data-testid="emoji_reaction_btn">
79
- <IconButton
80
- css={
81
- isMobile || isLandscape ? { bg: '$surface_default', r: '$round', border: '1px solid $border_bright' } : {}
82
- }
83
- >
84
- <Tooltip title="Emoji reaction">
85
- <Box>
86
- <EmojiIcon />
87
- </Box>
88
- </Tooltip>
89
- </IconButton>
90
- </Dropdown.Trigger>
91
- <Dropdown.Content
92
- sideOffset={5}
93
- align={isMobileHLSStream || isLandscapeStream ? 'end' : 'center'}
94
- css={{ p: '$8', bg: '$surface_default' }}
95
- >
96
- <EmojiCard sendReaction={sendReaction} />
97
- </Dropdown.Content>
98
- </Dropdown.Root>
99
- );
100
- };
@@ -1,71 +0,0 @@
1
- import React, { useState } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { Flex } from '../../../Layout';
4
- import { config as cssConfig } from '../../../Theme';
5
- import { FEEBACK_INDEX, FeedbackHeader, FeedbackModal } from './FeedbackForm';
6
- import { ThankyouView } from './ThankyouView';
7
- import { useRoomLayoutLeaveScreen } from '../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
8
-
9
- export const Feedback = () => {
10
- const { feedback } = useRoomLayoutLeaveScreen();
11
- const [index, setIndex] = useState(FEEBACK_INDEX.INIT);
12
- const isMobile = useMedia(cssConfig.media.md);
13
-
14
- if (!feedback) {
15
- return null;
16
- }
17
- const { ratings } = feedback;
18
- if (!ratings) {
19
- return null;
20
- }
21
- ratings.sort((a, b) => {
22
- if (!a.value || !b.value) {
23
- return 0;
24
- }
25
- return a.value - b.value;
26
- });
27
- // TO show thank ypu page
28
- if (index === FEEBACK_INDEX.THANK_YOU) {
29
- return (
30
- <Flex
31
- justify="center"
32
- css={{
33
- pt: '$16',
34
- }}
35
- >
36
- <ThankyouView />
37
- </Flex>
38
- );
39
- }
40
- return (
41
- <Flex
42
- justify="center"
43
- css={{
44
- pt: '$16',
45
- w: isMobile ? '100%' : '528px',
46
- }}
47
- >
48
- {index === FEEBACK_INDEX.INIT ? (
49
- <Flex
50
- css={{
51
- p: isMobile ? '$10' : '$12',
52
- border: '1px solid $border_default',
53
- bg: '$surface_dim',
54
- borderRadius: !isMobile ? '$3' : '$3 $3 0 0',
55
- gap: '$10',
56
- '@md': {
57
- position: 'absolute',
58
- bottom: '0',
59
- w: '100%',
60
- },
61
- }}
62
- direction="column"
63
- >
64
- <FeedbackHeader ratings={ratings} onEmojiClicked={setIndex} />
65
- </Flex>
66
- ) : (
67
- <FeedbackModal ratings={ratings} index={index} setIndex={setIndex} />
68
- )}
69
- </Flex>
70
- );
71
- };