@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,138 +0,0 @@
1
- import React, { useCallback, useEffect, useRef } from 'react';
2
- import {
3
- selectIsAllowedToPublish,
4
- selectSessionStore,
5
- useHMSActions,
6
- useHMSStore,
7
- useHMSVanillaStore,
8
- } from '@100mslive/react-sdk';
9
- import { ClosedCaptionIcon } from '@100mslive/react-icons';
10
- import { Box } from '../../../Layout';
11
- import { Text } from '../../../Text';
12
- import { Tooltip } from '../../../Tooltip';
13
- import IconButton from '../../IconButton';
14
- import { Transcriber } from './Transcriber';
15
- import { SESSION_STORE_KEY } from '../../common/constants';
16
-
17
- export function TranscriptionButton() {
18
- const transcriptionState = useHMSStore(selectSessionStore(SESSION_STORE_KEY.TRANSCRIPTION_STATE));
19
- const rawStore = useHMSVanillaStore();
20
- const isTranscriptionEnabled = !!transcriptionState?.enabled;
21
- let transcript = '',
22
- speakingPeer = '';
23
- if (isTranscriptionEnabled) {
24
- transcript = transcriptionState.transcript || '';
25
- speakingPeer = transcriptionState.speakingPeer || '';
26
- }
27
-
28
- const transcriber = useRef(null);
29
- const hmsActions = useHMSActions();
30
- const isAllowedToPublish = useHMSStore(selectIsAllowedToPublish);
31
-
32
- useEffect(() => {
33
- hmsActions.sessionStore.observe(SESSION_STORE_KEY.TRANSCRIPTION_STATE);
34
- }, [hmsActions]);
35
-
36
- useEffect(() => {
37
- if (!transcriber.current) {
38
- // create transcriber with the current room state for transcription
39
- transcriber.current = new Transcriber({
40
- hmsStore: rawStore,
41
- setTranscriptAndSpeakingPeer: async (transcript, peerName) => {
42
- const transcriptionCurrentEnabledState = !!rawStore.getState(
43
- selectSessionStore(SESSION_STORE_KEY.TRANSCRIPTION_STATE),
44
- )?.enabled;
45
- await hmsActions.sessionStore.set(SESSION_STORE_KEY.TRANSCRIPTION_STATE, {
46
- enabled: transcriptionCurrentEnabledState,
47
- transcript,
48
- speakingPeer: peerName,
49
- });
50
- },
51
- setIsTranscriptionEnabled: async newEnabledState => {
52
- await hmsActions.sessionStore.set(SESSION_STORE_KEY.TRANSCRIPTION_STATE, {
53
- enabled: newEnabledState,
54
- });
55
- },
56
- });
57
- }
58
- return () => {
59
- if (transcriber.current) {
60
- transcriber.current.cleanup();
61
- }
62
- };
63
- }, [hmsActions, rawStore]);
64
-
65
- useEffect(() => {
66
- // remote enabled transcript
67
- if (isTranscriptionEnabled) {
68
- transcriber.current.enableTranscription(true);
69
- }
70
- }, [isTranscriptionEnabled]);
71
-
72
- const toggleTranscriptionState = useCallback(() => {
73
- transcriber.current.toggleTranscriptionState();
74
- }, []);
75
-
76
- return (
77
- <>
78
- <Box
79
- css={{
80
- textAlign: 'left',
81
- fontWeight: '$medium',
82
- bottom: '120px',
83
- position: 'fixed',
84
- width: '100%',
85
- fontSize: '$20px',
86
- zIndex: '1000000',
87
- color: 'white',
88
- textShadow: '0px 0px 6px #000',
89
- whiteSpace: 'pre-line',
90
- paddingLeft: '40px',
91
- }}
92
- />
93
- <Box
94
- css={{
95
- textAlign: 'center',
96
- fontWeight: '$medium',
97
- bottom: '90px',
98
- position: 'fixed',
99
- width: '100%',
100
- fontSize: '$20px',
101
- zIndex: '1000000',
102
- color: 'white',
103
- textShadow: '0px 0px 6px #000',
104
- whiteSpace: 'pre-line',
105
- }}
106
- >
107
- <Text
108
- css={{
109
- color: 'white',
110
- textShadow: '0px 0px 6px #000',
111
- }}
112
- >
113
- {transcript}
114
- </Text>
115
- <Text
116
- css={{
117
- color: '#c0bbbb',
118
- textShadow: '0px 0px 6px #000',
119
- textTransform: 'capitalize',
120
- }}
121
- >
122
- {speakingPeer}
123
- </Text>
124
- </Box>
125
- {isAllowedToPublish.audio && (
126
- <Tooltip title={`Turn ${!isTranscriptionEnabled ? 'on' : 'off'} transcription`}>
127
- <IconButton
128
- active={!isTranscriptionEnabled}
129
- onClick={toggleTranscriptionState}
130
- data-testid="transcription_btn"
131
- >
132
- <ClosedCaptionIcon />
133
- </IconButton>
134
- </Tooltip>
135
- )}
136
- </>
137
- );
138
- }
@@ -1 +0,0 @@
1
- export { TranscriptionButton as default } from './TranscriptionButton';
@@ -1,285 +0,0 @@
1
- import React, { useRef } from 'react';
2
- import { CheckIcon, CloudUploadIcon, CrossIcon } from '@100mslive/react-icons';
3
- import { Button } from '../../Button';
4
- import { Checkbox } from '../../Checkbox';
5
- import { HorizontalDivider } from '../../Divider';
6
- import { IconButton } from '../../IconButton';
7
- import { Input } from '../../Input';
8
- import { Label } from '../../Label';
9
- import { Box, Flex } from '../../Layout';
10
- import { Dialog } from '../../Modal';
11
- import { Select } from '../../Select';
12
- import { Switch } from '../../Switch';
13
- import { Text } from '../../Text';
14
- import { flexCenter } from '../../utils';
15
-
16
- export const DialogContent = ({ Icon, title, closeable = true, children, css, iconCSS = {}, ...props }) => {
17
- return (
18
- <Dialog.Portal>
19
- <Dialog.Overlay />
20
- <Dialog.Content css={{ width: 'min(600px, 100%)', ...css }} {...props}>
21
- <Dialog.Title>
22
- <Flex justify="between">
23
- <Flex align="center" css={{ mb: '$1' }}>
24
- {Icon ? (
25
- <Flex css={{ mr: '$2', color: '$on_primary_high', ...flexCenter, ...iconCSS }}>
26
- <Icon />
27
- </Flex>
28
- ) : null}
29
- <Text variant="h6" inline>
30
- {title}
31
- </Text>
32
- </Flex>
33
- {closeable && <Dialog.DefaultClose data-testid="dialoge_cross_icon" />}
34
- </Flex>
35
- </Dialog.Title>
36
- <HorizontalDivider css={{ mt: '0.8rem' }} />
37
- <Box>{children}</Box>
38
- </Dialog.Content>
39
- </Dialog.Portal>
40
- );
41
- };
42
-
43
- export const ErrorDialog = ({ open = true, onOpenChange, title, children, ...props }) => {
44
- return (
45
- <Dialog.Root open={open} onOpenChange={onOpenChange}>
46
- <DialogContent
47
- Icon={CrossIcon}
48
- title={title}
49
- onInteractOutside={e => e.preventDefault()}
50
- onEscapeKeyDown={e => e.preventDefault()}
51
- onPointerDownOutside={e => e.preventDefault()}
52
- closeable={false}
53
- iconCSS={{ color: '$alert_error_default' }}
54
- {...props}
55
- >
56
- <Box css={{ mt: '$lg' }}>{children}</Box>
57
- </DialogContent>
58
- </Dialog.Root>
59
- );
60
- };
61
-
62
- export const RequestDialog = ({ open = true, onOpenChange, title, body, actionText = 'Accept', onAction, Icon }) => (
63
- <Dialog.Root open={open} onOpenChange={onOpenChange}>
64
- <Dialog.Portal>
65
- <Dialog.Overlay />
66
- <Dialog.Content css={{ width: 'min(400px,80%)', p: '$10' }}>
67
- <Dialog.Title css={{ p: 0, display: 'flex', flexDirection: 'row', gap: '$md' }}>
68
- {Icon ? Icon : null}
69
- <Text variant="h6">{title}</Text>
70
- </Dialog.Title>
71
- {typeof body === 'string' ? (
72
- <Text
73
- variant="md"
74
- css={{
75
- fontWeight: 400,
76
- mt: '$4',
77
- mb: '$10',
78
- c: '$on_surface_medium',
79
- }}
80
- >
81
- {body}
82
- </Text>
83
- ) : (
84
- <Box css={{ mt: '$4', mb: '$10' }}>{body}</Box>
85
- )}
86
- <Flex justify="center" align="center" css={{ width: '100%', gap: '$md' }}>
87
- <Box css={{ width: '50%' }}>
88
- <Dialog.Close css={{ width: '100%' }}>
89
- <Button variant="standard" outlined css={{ width: '100%' }}>
90
- Cancel
91
- </Button>
92
- </Dialog.Close>
93
- </Box>
94
- <Box css={{ width: '50%' }}>
95
- <Button variant="primary" css={{ width: '100%' }} onClick={onAction}>
96
- {actionText}
97
- </Button>
98
- </Box>
99
- </Flex>
100
- </Dialog.Content>
101
- </Dialog.Portal>
102
- </Dialog.Root>
103
- );
104
-
105
- /**
106
- * a row of items which breaks into column on small screen. For example title on left and options to select
107
- * from on right for select component.
108
- */
109
- export const DialogRow = ({ children, breakSm = false, css, justify = 'between' }) => {
110
- let finalCSS = {
111
- margin: '$10 0',
112
- w: '100%',
113
- };
114
- if (breakSm) {
115
- finalCSS['@sm'] = {
116
- flexDirection: 'column',
117
- alignItems: 'flex-start',
118
- };
119
- }
120
- if (css) {
121
- finalCSS = Object.assign(finalCSS, css);
122
- }
123
- return (
124
- <Flex align="center" justify={justify} css={finalCSS}>
125
- {children}
126
- </Flex>
127
- );
128
- };
129
-
130
- export const DialogCol = ({ children, breakSm = false, css, align = 'center', justify = 'between', ...props }) => {
131
- let finalCSS = {
132
- margin: '$10 0',
133
- w: '100%',
134
- };
135
- if (breakSm) {
136
- finalCSS['@sm'] = {
137
- alignItems: 'flex-start',
138
- };
139
- }
140
- if (css) {
141
- finalCSS = Object.assign(finalCSS, css);
142
- }
143
- return (
144
- <Flex direction="column" align={align} justify={justify} css={finalCSS} {...props}>
145
- {children}
146
- </Flex>
147
- );
148
- };
149
-
150
- /**
151
- * key field and label field are optional, option is directly used if not passed
152
- */
153
- export const DialogSelect = ({ title, options, keyField, labelField, selected, onChange, ...props }) => {
154
- return (
155
- <DialogRow breakSm>
156
- <Label>{title}</Label>
157
- <Select.Root data-testid={`dialog_select_${title}`} css={{ width: '70%', '@sm': { width: '100%' } }} {...props}>
158
- <Select.DefaultDownIcon />
159
- <Select.Select onChange={e => onChange(e.target.value)} value={selected} css={{ width: '100%' }}>
160
- {options.map(option => {
161
- const id = keyField ? option[keyField] : option;
162
- const label = labelField ? option[labelField] : option;
163
- return (
164
- <option value={id} key={id}>
165
- {label}
166
- </option>
167
- );
168
- })}
169
- </Select.Select>
170
- </Select.Root>
171
- </DialogRow>
172
- );
173
- };
174
-
175
- export const DialogInput = ({ title, value, onChange, placeholder, disabled, type, ...props }) => {
176
- return (
177
- <DialogRow breakSm>
178
- <Label>{title}</Label>
179
- <Input
180
- css={{ width: '70%', '@sm': { width: '100%' }, bg: '$surface_bright' }}
181
- value={value}
182
- onChange={e => onChange(e.target.value)}
183
- placeholder={placeholder}
184
- disabled={disabled}
185
- type={type}
186
- {...props}
187
- />
188
- </DialogRow>
189
- );
190
- };
191
-
192
- export const DialogInputFile = ({ value, onChange, placeholder, disabled, type, ...props }) => {
193
- const inputRef = useRef();
194
- return (
195
- <DialogCol
196
- breakSm
197
- onClick={() => inputRef.current?.click()}
198
- css={{
199
- justifyContent: 'center',
200
- position: 'relative',
201
- cursor: 'pointer',
202
- py: '$12',
203
- border: '1px dashed $border_bright',
204
- r: '$1',
205
- height: 'max(140px, 30%)',
206
- alignItems: 'center',
207
- m: '$6 0',
208
- }}
209
- gap="8"
210
- >
211
- <IconButton
212
- variant="standard"
213
- css={{
214
- border: 'none',
215
- background: 'none',
216
- '&:hover': {
217
- border: 'none',
218
- background: 'none',
219
- bg: 'transparent !important',
220
- },
221
- }}
222
- >
223
- <CloudUploadIcon
224
- style={{
225
- width: '3rem',
226
- height: '3rem',
227
- }}
228
- />
229
- </IconButton>
230
- <Flex direction="row">
231
- <Input
232
- ref={inputRef}
233
- css={{ width: '70%', '@sm': { width: '100%' } }}
234
- value={value}
235
- onChange={e => onChange(e.target)}
236
- placeholder={placeholder}
237
- disabled={disabled}
238
- type={type}
239
- hidden={true}
240
- {...props}
241
- />
242
- <IconButton
243
- variant="standard"
244
- css={{
245
- background: 'none',
246
- border: 'none',
247
- textDecoration: 'underline',
248
- '&:hover': {
249
- background: 'none !important',
250
- border: 'none !important',
251
- },
252
- }}
253
- >
254
- <Text variant="md">{placeholder}</Text>
255
- </IconButton>
256
- </Flex>
257
- </DialogCol>
258
- );
259
- };
260
-
261
- export const DialogSwitch = ({ title, value, onChange, disabled }) => {
262
- return (
263
- <DialogRow>
264
- <Text>{title}</Text>
265
- <Flex justify="end" css={{ width: '70%' }}>
266
- <Switch checked={value} disabled={disabled} onCheckedChange={onChange} />
267
- </Flex>
268
- </DialogRow>
269
- );
270
- };
271
-
272
- export const DialogCheckbox = ({ title, value, onChange, disabled, css, id }) => {
273
- return (
274
- <DialogRow css={css}>
275
- <Label htmlFor={id} css={{ cursor: 'pointer' }}>
276
- {title}
277
- </Label>
278
- <Checkbox.Root checked={value} onCheckedChange={value => onChange(value)} disabled={disabled} id={id}>
279
- <Checkbox.Indicator>
280
- <CheckIcon width={16} height={16} />
281
- </Checkbox.Indicator>
282
- </Checkbox.Root>
283
- </DialogRow>
284
- );
285
- };
@@ -1,46 +0,0 @@
1
- import React from 'react';
2
- import { ChevronDownIcon, ChevronUpIcon } from '@100mslive/react-icons';
3
- import { Dropdown, Flex, Text, textEllipsis } from '../../index';
4
-
5
- const DialogDropdownTrigger = React.forwardRef(({ title, css, open, icon, titleCSS = {} }, ref) => {
6
- return (
7
- <Dropdown.Trigger
8
- asChild
9
- data-testid={`${title}_selector`}
10
- css={{
11
- border: '1px solid $border_bright',
12
- bg: '$surface_bright',
13
- r: '$1',
14
- p: '$6 $9',
15
- zIndex: 10,
16
- ...css,
17
- }}
18
- ref={ref}
19
- >
20
- <Flex
21
- css={{
22
- display: 'flex',
23
- justifyContent: 'space-between',
24
- color: '$on_surface_high',
25
- w: '100%',
26
- }}
27
- >
28
- {icon}
29
- <Text
30
- css={{
31
- color: 'inherit',
32
- ...textEllipsis('90%'),
33
- flex: '1 1 0',
34
- mx: icon ? '$6' : '0',
35
- ...titleCSS,
36
- }}
37
- >
38
- {title}
39
- </Text>
40
- {open ? <ChevronUpIcon /> : <ChevronDownIcon />}
41
- </Flex>
42
- </Dropdown.Trigger>
43
- );
44
- });
45
-
46
- export { DialogDropdownTrigger };
@@ -1,60 +0,0 @@
1
- import type { Layout } from '@100mslive/types-prebuilt';
2
- import { JoinForm_JoinBtnType } from '@100mslive/types-prebuilt/elements/join_form';
3
-
4
- export const defaultLayout: Layout = {
5
- id: '',
6
- role_id: '',
7
- template_id: '',
8
- app_id: '',
9
- typography: {
10
- font_family: 'Inter',
11
- },
12
- themes: [],
13
- options: {},
14
- screens: {
15
- preview: {
16
- default: {
17
- elements: {
18
- preview_header: {
19
- title: 'Get Started',
20
- sub_title: 'Setup your audio and video before joining',
21
- },
22
- join_form: {
23
- join_btn_type: JoinForm_JoinBtnType.JOIN_BTN_TYPE_JOIN_ONLY,
24
- join_btn_label: 'Join Now',
25
- go_live_btn_label: 'Go Live',
26
- },
27
- },
28
- },
29
- },
30
- conferencing: {
31
- default: {
32
- elements: {
33
- chat: {
34
- public_chat_enabled: true,
35
- private_chat_enabled: true,
36
- chat_title: 'Chat',
37
- allow_pinning_messages: true,
38
- message_placeholder: 'Send a message...',
39
- roles_whitelist: [],
40
- real_time_controls: {
41
- can_disable_chat: true,
42
- can_block_user: true,
43
- can_hide_message: true,
44
- },
45
- },
46
- participant_list: {},
47
- video_tile_layout: {
48
- grid: {
49
- enable_local_tile_inset: true,
50
- prominent_roles: [],
51
- enable_spotlighting_peer: true,
52
- },
53
- },
54
- emoji_reactions: {},
55
- },
56
- },
57
- },
58
- leave: {},
59
- },
60
- };
@@ -1,88 +0,0 @@
1
- import { useCallback, useEffect, useRef, useState } from 'react';
2
- import type { GetResponse, Layout } from '@100mslive/types-prebuilt';
3
- import { defaultLayout } from '../constants';
4
-
5
- // TODO: remove this usage
6
- const fetchWithRetry = async (url = '', options = {}) => {
7
- const MAX_RETRIES = 4;
8
- let error = Error('something went wrong');
9
- for (let i = 0; i < MAX_RETRIES; i++) {
10
- try {
11
- return await fetch(url, options);
12
- } catch (err) {
13
- error = err as Error;
14
- }
15
- }
16
- console.error('Fetch failed after max retries', { url, options });
17
- throw error;
18
- };
19
-
20
- // this should take endpoint and return
21
- export type useFetchRoomLayoutProps = {
22
- endpoint?: string;
23
- authToken: string;
24
- };
25
-
26
- export type useFetchRoomLayoutResponse = {
27
- layout: Layout | undefined;
28
- updateRoomLayoutForRole: (role: string) => void;
29
- setOriginalLayout: () => void;
30
- };
31
-
32
- export const useFetchRoomLayout = ({
33
- endpoint = '',
34
- authToken = '',
35
- }: useFetchRoomLayoutProps): useFetchRoomLayoutResponse => {
36
- const [layout, setLayout] = useState<Layout | undefined>(undefined);
37
- const layoutResp = useRef<GetResponse>();
38
- const originalLayout = useRef<Layout>();
39
- const isFetchInProgress = useRef(false);
40
-
41
- const setOriginalLayout = useCallback(() => setLayout(originalLayout.current), []);
42
-
43
- const updateRoomLayoutForRole = useCallback((role: string) => {
44
- if (!layoutResp.current) {
45
- return;
46
- }
47
- const [layout] = (layoutResp.current?.data || []).filter(layout => layout.role === role);
48
- if (layout) {
49
- setLayout(layout);
50
- }
51
- }, []);
52
- useEffect(() => {
53
- (async () => {
54
- if (isFetchInProgress.current || !authToken) {
55
- return;
56
- }
57
- isFetchInProgress.current = true;
58
- try {
59
- const resp = await fetchWithRetry(endpoint || 'https://api.100ms.live/v2/layouts/ui', {
60
- headers: {
61
- Authorization: `Bearer ${authToken}`,
62
- },
63
- });
64
- layoutResp.current = await resp.json();
65
- } catch (e) {
66
- console.error('[Room Layout API]: Failed to fetch / process room layout. Resorting to default layout.', e);
67
- layoutResp.current = {
68
- data: [defaultLayout],
69
- };
70
- }
71
- let layoutForRole = layoutResp.current?.data?.[0];
72
- if (!layoutForRole) {
73
- console.error(
74
- '[Room Layout API]: Unable to figure out room layout from API response. Resorting to default layout.',
75
- );
76
- layoutForRole = defaultLayout;
77
- }
78
- const layout = layoutForRole;
79
- if (!originalLayout.current) {
80
- originalLayout.current = layout;
81
- }
82
- setLayout(layout);
83
- isFetchInProgress.current = false;
84
- })();
85
- }, [authToken, endpoint]);
86
-
87
- return { layout, updateRoomLayoutForRole, setOriginalLayout };
88
- };
@@ -1,10 +0,0 @@
1
- import { useRoomLayout } from '..';
2
-
3
- export const useInsetEnabled = (): boolean => {
4
- const layout = useRoomLayout();
5
- const { enable_local_tile_inset = true } =
6
- //@ts-ignore
7
- layout?.screens?.conferencing?.default?.elements?.video_tile_layout?.grid || {};
8
-
9
- return enable_local_tile_inset;
10
- };