@100mslive/roomkit-react 0.4.3-alpha.0 → 0.4.3-alpha.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (442) hide show
  1. package/dist/index.cjs.css +214 -223
  2. package/dist/index.cjs.css.map +3 -3
  3. package/dist/index.cjs.js +489 -727
  4. package/dist/index.cjs.js.map +4 -4
  5. package/dist/index.css +214 -223
  6. package/dist/index.css.map +3 -3
  7. package/dist/index.js +501 -739
  8. package/dist/index.js.map +4 -4
  9. package/dist/meta.cjs.json +93 -149
  10. package/dist/meta.esbuild.json +92 -148
  11. package/package.json +10 -24
  12. package/src/Accordion/Accordion.stories.tsx +0 -50
  13. package/src/Accordion/Accordion.tsx +0 -88
  14. package/src/Accordion/index.ts +0 -8
  15. package/src/AudioLevel/AudioLevel.tsx +0 -84
  16. package/src/AudioLevel/audio-level.png +0 -0
  17. package/src/AudioLevel/index.ts +0 -2
  18. package/src/AudioLevel/useBorderAudioLevel.tsx +0 -34
  19. package/src/Avatar/Avatar.stories.tsx +0 -33
  20. package/src/Avatar/Avatar.tsx +0 -60
  21. package/src/Avatar/getAvatarBg.ts +0 -50
  22. package/src/Avatar/index.ts +0 -1
  23. package/src/Button/Button.mdx +0 -43
  24. package/src/Button/Button.stories.tsx +0 -52
  25. package/src/Button/Button.tsx +0 -210
  26. package/src/Button/index.tsx +0 -1
  27. package/src/Chat/Chat.mdx +0 -39
  28. package/src/Chat/Chat.stories.tsx +0 -39
  29. package/src/Checkbox/Checkbox.stories.tsx +0 -61
  30. package/src/Checkbox/Checkbox.tsx +0 -35
  31. package/src/Checkbox/index.tsx +0 -1
  32. package/src/Collapsible/Collapsible.tsx +0 -34
  33. package/src/Collapsible/index.tsx +0 -1
  34. package/src/Diagnostics/AudioTest.tsx +0 -188
  35. package/src/Diagnostics/BrowserTest.tsx +0 -141
  36. package/src/Diagnostics/ConnectivityTest.tsx +0 -383
  37. package/src/Diagnostics/DeviceSelector.jsx +0 -71
  38. package/src/Diagnostics/Diagnostics.tsx +0 -190
  39. package/src/Diagnostics/DiagnosticsContext.ts +0 -46
  40. package/src/Diagnostics/VideoTest.tsx +0 -72
  41. package/src/Diagnostics/components.tsx +0 -70
  42. package/src/Diagnostics/index.ts +0 -1
  43. package/src/Divider/Divider.tsx +0 -45
  44. package/src/Divider/HorizontalDivider.stories.tsx +0 -34
  45. package/src/Divider/VerticalDivider.stories.tsx +0 -40
  46. package/src/Divider/index.ts +0 -1
  47. package/src/Dropdown/Dropdown.stories.tsx +0 -94
  48. package/src/Dropdown/Dropdown.tsx +0 -145
  49. package/src/Dropdown/index.tsx +0 -1
  50. package/src/Fieldset/Fieldset.stories.tsx +0 -29
  51. package/src/Fieldset/Fieldset.tsx +0 -11
  52. package/src/Fieldset/index.tsx +0 -1
  53. package/src/Footer/Footer.stories.tsx +0 -61
  54. package/src/Footer/Footer.tsx +0 -47
  55. package/src/Footer/index.tsx +0 -1
  56. package/src/IconButton/IconButton.tsx +0 -43
  57. package/src/IconButton/index.tsx +0 -1
  58. package/src/Icons/Icons.stories.mdx +0 -10
  59. package/src/Icons/IconsList.jsx +0 -17
  60. package/src/Input/Input.stories.tsx +0 -25
  61. package/src/Input/Input.tsx +0 -109
  62. package/src/Input/PasswordInput.stories.tsx +0 -53
  63. package/src/Input/index.tsx +0 -1
  64. package/src/Introduction/Integrating.stories.mdx +0 -100
  65. package/src/Introduction/Introduction.stories.mdx +0 -9
  66. package/src/Label/Label.tsx +0 -8
  67. package/src/Label/index.ts +0 -1
  68. package/src/Layout/Box.tsx +0 -3
  69. package/src/Layout/Flex.tsx +0 -76
  70. package/src/Layout/index.tsx +0 -2
  71. package/src/Link/Link.stories.tsx +0 -18
  72. package/src/Link/Link.tsx +0 -54
  73. package/src/Link/index.tsx +0 -2
  74. package/src/Loading/Loading.mdx +0 -15
  75. package/src/Loading/Loading.stories.tsx +0 -37
  76. package/src/Loading/Loading.tsx +0 -30
  77. package/src/Loading/index.ts +0 -1
  78. package/src/Modal/Dialog.mdx +0 -19
  79. package/src/Modal/Dialog.stories.tsx +0 -68
  80. package/src/Modal/Dialog.tsx +0 -57
  81. package/src/Modal/DialogContent.tsx +0 -65
  82. package/src/Modal/index.ts +0 -1
  83. package/src/Pagination/StyledPagination.stories.tsx +0 -80
  84. package/src/Pagination/StyledPagination.tsx +0 -70
  85. package/src/Pagination/index.tsx +0 -1
  86. package/src/Popover/Popover.mdx +0 -9
  87. package/src/Popover/Popover.stories.tsx +0 -95
  88. package/src/Popover/index.tsx +0 -34
  89. package/src/Prebuilt/App.tsx +0 -318
  90. package/src/Prebuilt/AppContext.tsx +0 -33
  91. package/src/Prebuilt/AppStateContext.tsx +0 -95
  92. package/src/Prebuilt/IconButton.tsx +0 -26
  93. package/src/Prebuilt/Prebuilt.stories.tsx +0 -46
  94. package/src/Prebuilt/common/PeersSorter.ts +0 -111
  95. package/src/Prebuilt/common/constants.ts +0 -151
  96. package/src/Prebuilt/common/hooks.ts +0 -257
  97. package/src/Prebuilt/common/utils.js +0 -185
  98. package/src/Prebuilt/components/AppData/AppData.tsx +0 -208
  99. package/src/Prebuilt/components/AppData/useChatState.js +0 -18
  100. package/src/Prebuilt/components/AppData/useSheet.ts +0 -33
  101. package/src/Prebuilt/components/AppData/useSidepane.js +0 -99
  102. package/src/Prebuilt/components/AppData/useSidepaneResetOnLayoutUpdate.tsx +0 -22
  103. package/src/Prebuilt/components/AppData/useUISettings.js +0 -212
  104. package/src/Prebuilt/components/AudioVideoToggle.tsx +0 -411
  105. package/src/Prebuilt/components/AuthToken.tsx +0 -148
  106. package/src/Prebuilt/components/CaptionIcon.tsx +0 -27
  107. package/src/Prebuilt/components/Chat/ArrowNavigation.tsx +0 -44
  108. package/src/Prebuilt/components/Chat/Chat.tsx +0 -190
  109. package/src/Prebuilt/components/Chat/ChatActions.tsx +0 -314
  110. package/src/Prebuilt/components/Chat/ChatBody.tsx +0 -493
  111. package/src/Prebuilt/components/Chat/ChatFooter.tsx +0 -316
  112. package/src/Prebuilt/components/Chat/ChatSelector.tsx +0 -228
  113. package/src/Prebuilt/components/Chat/ChatSelectorContainer.tsx +0 -158
  114. package/src/Prebuilt/components/Chat/ChatStates.tsx +0 -73
  115. package/src/Prebuilt/components/Chat/EmptyChat.tsx +0 -58
  116. package/src/Prebuilt/components/Chat/MwebChatOption.tsx +0 -24
  117. package/src/Prebuilt/components/Chat/PinnedMessage.tsx +0 -140
  118. package/src/Prebuilt/components/Chat/StickIndicator.tsx +0 -24
  119. package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +0 -32
  120. package/src/Prebuilt/components/Chat/useUnreadCount.ts +0 -19
  121. package/src/Prebuilt/components/Chat/utils.ts +0 -11
  122. package/src/Prebuilt/components/ChatSettings.tsx +0 -68
  123. package/src/Prebuilt/components/Chip.tsx +0 -40
  124. package/src/Prebuilt/components/ConferenceScreen.tsx +0 -205
  125. package/src/Prebuilt/components/Connection/ConnectionIndicator.tsx +0 -89
  126. package/src/Prebuilt/components/Connection/TileConnection.tsx +0 -93
  127. package/src/Prebuilt/components/Connection/connectionQualityUtils.js +0 -37
  128. package/src/Prebuilt/components/EmojiReaction.jsx +0 -100
  129. package/src/Prebuilt/components/EndCallFeedback/Feedback.tsx +0 -71
  130. package/src/Prebuilt/components/EndCallFeedback/FeedbackForm.tsx +0 -381
  131. package/src/Prebuilt/components/EndCallFeedback/ThankyouView.tsx +0 -64
  132. package/src/Prebuilt/components/ErrorBoundary.jsx +0 -102
  133. package/src/Prebuilt/components/Footer/ChatToggle.tsx +0 -53
  134. package/src/Prebuilt/components/Footer/EmojiCard.jsx +0 -34
  135. package/src/Prebuilt/components/Footer/Footer.tsx +0 -115
  136. package/src/Prebuilt/components/Footer/PaginatedParticipants.tsx +0 -124
  137. package/src/Prebuilt/components/Footer/ParticipantList.tsx +0 -478
  138. package/src/Prebuilt/components/Footer/PollsToggle.tsx +0 -37
  139. package/src/Prebuilt/components/Footer/RoleAccordion.tsx +0 -183
  140. package/src/Prebuilt/components/Footer/RoleOptions.tsx +0 -215
  141. package/src/Prebuilt/components/Footer/WhiteboardToggle.tsx +0 -52
  142. package/src/Prebuilt/components/FullPageProgress.tsx +0 -22
  143. package/src/Prebuilt/components/HMSVideo/Controls.jsx +0 -22
  144. package/src/Prebuilt/components/HMSVideo/FullscreenButton.tsx +0 -13
  145. package/src/Prebuilt/components/HMSVideo/HLSAutoplayBlockedPrompt.tsx +0 -72
  146. package/src/Prebuilt/components/HMSVideo/HLSCaptionSelector.tsx +0 -15
  147. package/src/Prebuilt/components/HMSVideo/HLSQualitySelector.tsx +0 -248
  148. package/src/Prebuilt/components/HMSVideo/HMSVideo.jsx +0 -75
  149. package/src/Prebuilt/components/HMSVideo/MwebHLSViewTitle.tsx +0 -86
  150. package/src/Prebuilt/components/HMSVideo/PlayPauseButton.tsx +0 -27
  151. package/src/Prebuilt/components/HMSVideo/PlayPauseSeekControls.tsx +0 -158
  152. package/src/Prebuilt/components/HMSVideo/PlayerContext.tsx +0 -15
  153. package/src/Prebuilt/components/HMSVideo/SeekControl.tsx +0 -22
  154. package/src/Prebuilt/components/HMSVideo/VideoProgress.tsx +0 -100
  155. package/src/Prebuilt/components/HMSVideo/VideoTime.tsx +0 -52
  156. package/src/Prebuilt/components/HMSVideo/VolumeControl.tsx +0 -70
  157. package/src/Prebuilt/components/HMSVideo/index.ts +0 -24
  158. package/src/Prebuilt/components/HMSVideo/utils.ts +0 -37
  159. package/src/Prebuilt/components/Header/Header.tsx +0 -52
  160. package/src/Prebuilt/components/Header/HeaderComponents.jsx +0 -57
  161. package/src/Prebuilt/components/Header/ParticipantFilter.jsx +0 -89
  162. package/src/Prebuilt/components/Header/RoomDetailsHeader.tsx +0 -51
  163. package/src/Prebuilt/components/Header/StreamActions.tsx +0 -297
  164. package/src/Prebuilt/components/Header/common.jsx +0 -196
  165. package/src/Prebuilt/components/Header/index.tsx +0 -1
  166. package/src/Prebuilt/components/HlsStatsOverlay.jsx +0 -89
  167. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.stories.tsx +0 -40
  168. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.tsx +0 -167
  169. package/src/Prebuilt/components/Input/KeyboardInputManager.js +0 -107
  170. package/src/Prebuilt/components/InsetTile.tsx +0 -136
  171. package/src/Prebuilt/components/LayoutModeSelector.tsx +0 -112
  172. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +0 -166
  173. package/src/Prebuilt/components/Leave/EndSessionContent.tsx +0 -64
  174. package/src/Prebuilt/components/Leave/LeaveAtoms.tsx +0 -26
  175. package/src/Prebuilt/components/Leave/LeaveCard.tsx +0 -36
  176. package/src/Prebuilt/components/Leave/LeaveRoom.tsx +0 -82
  177. package/src/Prebuilt/components/Leave/LeaveSessionContent.tsx +0 -61
  178. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +0 -135
  179. package/src/Prebuilt/components/LeaveScreen.tsx +0 -71
  180. package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +0 -60
  181. package/src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx +0 -139
  182. package/src/Prebuilt/components/MoreSettings/CaptionContent.tsx +0 -143
  183. package/src/Prebuilt/components/MoreSettings/CaptionModal.tsx +0 -37
  184. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.tsx +0 -123
  185. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.tsx +0 -78
  186. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +0 -81
  187. package/src/Prebuilt/components/MoreSettings/FullScreenItem.tsx +0 -26
  188. package/src/Prebuilt/components/MoreSettings/MoreSettings.tsx +0 -29
  189. package/src/Prebuilt/components/MoreSettings/MuteAllContent.tsx +0 -81
  190. package/src/Prebuilt/components/MoreSettings/MuteAllModal.tsx +0 -72
  191. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx +0 -282
  192. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx +0 -387
  193. package/src/Prebuilt/components/MoreSettings/constants.ts +0 -14
  194. package/src/Prebuilt/components/MwebLandscapePrompt.tsx +0 -81
  195. package/src/Prebuilt/components/Notifications/AutoplayBlockedModal.tsx +0 -39
  196. package/src/Prebuilt/components/Notifications/ChatNotifications.tsx +0 -34
  197. package/src/Prebuilt/components/Notifications/DeviceChangeNotifications.tsx +0 -18
  198. package/src/Prebuilt/components/Notifications/DeviceInUseError.tsx +0 -86
  199. package/src/Prebuilt/components/Notifications/ErrorNotifications.tsx +0 -56
  200. package/src/Prebuilt/components/Notifications/HLSFailureModal.tsx +0 -71
  201. package/src/Prebuilt/components/Notifications/HandRaisedNotifications.tsx +0 -78
  202. package/src/Prebuilt/components/Notifications/InitErrorModal.tsx +0 -42
  203. package/src/Prebuilt/components/Notifications/MessageNotifications.tsx +0 -24
  204. package/src/Prebuilt/components/Notifications/Notifications.tsx +0 -65
  205. package/src/Prebuilt/components/Notifications/PeerNotifications.tsx +0 -52
  206. package/src/Prebuilt/components/Notifications/PermissionErrorModal.tsx +0 -144
  207. package/src/Prebuilt/components/Notifications/PollNotificationModal.tsx +0 -71
  208. package/src/Prebuilt/components/Notifications/ReconnectNotifications.tsx +0 -33
  209. package/src/Prebuilt/components/Notifications/RoleChangeNotification.tsx +0 -24
  210. package/src/Prebuilt/components/Notifications/TrackBulkUnmuteModal.tsx +0 -61
  211. package/src/Prebuilt/components/Notifications/TrackNotifications.tsx +0 -41
  212. package/src/Prebuilt/components/Notifications/TrackUnmuteModal.tsx +0 -63
  213. package/src/Prebuilt/components/Notifications/TranscriptionNotifications.tsx +0 -58
  214. package/src/Prebuilt/components/Notifications/index.tsx +0 -1
  215. package/src/Prebuilt/components/PIP/PIPChat.tsx +0 -292
  216. package/src/Prebuilt/components/PIP/PIPChatOption.tsx +0 -18
  217. package/src/Prebuilt/components/PIP/PIPComponent.tsx +0 -90
  218. package/src/Prebuilt/components/PIP/PIPManager.ts +0 -335
  219. package/src/Prebuilt/components/PIP/PIPProvider.tsx +0 -56
  220. package/src/Prebuilt/components/PIP/PIPWindow.tsx +0 -13
  221. package/src/Prebuilt/components/PIP/SetupMediaSession.js +0 -60
  222. package/src/Prebuilt/components/PIP/context.ts +0 -10
  223. package/src/Prebuilt/components/PIP/index.jsx +0 -6
  224. package/src/Prebuilt/components/PIP/pip.test.js +0 -72
  225. package/src/Prebuilt/components/PIP/pipUtils.js +0 -183
  226. package/src/Prebuilt/components/PIP/usePIPChat.tsx +0 -105
  227. package/src/Prebuilt/components/PIP/usePIPWindow.tsx +0 -12
  228. package/src/Prebuilt/components/Pagination.tsx +0 -60
  229. package/src/Prebuilt/components/Polls/CreatePollQuiz/PollsQuizMenu.tsx +0 -248
  230. package/src/Prebuilt/components/Polls/CreateQuestions/CreateQuestions.jsx +0 -142
  231. package/src/Prebuilt/components/Polls/CreateQuestions/DeleteQuestionModal.tsx +0 -74
  232. package/src/Prebuilt/components/Polls/CreateQuestions/QuestionForm.tsx +0 -324
  233. package/src/Prebuilt/components/Polls/CreateQuestions/SavedQuestion.tsx +0 -64
  234. package/src/Prebuilt/components/Polls/Polls.tsx +0 -31
  235. package/src/Prebuilt/components/Polls/Voting/LeaderboardEntry.tsx +0 -76
  236. package/src/Prebuilt/components/Polls/Voting/LeaderboardSummary.tsx +0 -116
  237. package/src/Prebuilt/components/Polls/Voting/PeerParticipationSummary.tsx +0 -60
  238. package/src/Prebuilt/components/Polls/Voting/QuestionCard.jsx +0 -221
  239. package/src/Prebuilt/components/Polls/Voting/StandardVoting.tsx +0 -47
  240. package/src/Prebuilt/components/Polls/Voting/StatisticBox.tsx +0 -20
  241. package/src/Prebuilt/components/Polls/Voting/TimedVoting.tsx +0 -55
  242. package/src/Prebuilt/components/Polls/Voting/Voting.tsx +0 -143
  243. package/src/Prebuilt/components/Polls/Voting/useQuizSummary.tsx +0 -50
  244. package/src/Prebuilt/components/Polls/common/Line.tsx +0 -4
  245. package/src/Prebuilt/components/Polls/common/MultipleChoiceOptions.jsx +0 -115
  246. package/src/Prebuilt/components/Polls/common/OptionInputWithDelete.tsx +0 -38
  247. package/src/Prebuilt/components/Polls/common/SingleChoiceOptions.jsx +0 -140
  248. package/src/Prebuilt/components/Polls/common/StatusIndicator.tsx +0 -35
  249. package/src/Prebuilt/components/Polls/common/VoteCount.tsx +0 -15
  250. package/src/Prebuilt/components/Polls/common/VoteProgress.tsx +0 -18
  251. package/src/Prebuilt/components/Polls/common/constants.ts +0 -5
  252. package/src/Prebuilt/components/Polls/common/utils.ts +0 -22
  253. package/src/Prebuilt/components/Preview/PreviewForm.tsx +0 -94
  254. package/src/Prebuilt/components/Preview/PreviewJoin.tsx +0 -292
  255. package/src/Prebuilt/components/Preview/PreviewScreen.tsx +0 -38
  256. package/src/Prebuilt/components/PreviousRoleInMetadata.tsx +0 -20
  257. package/src/Prebuilt/components/RaiseHand.tsx +0 -30
  258. package/src/Prebuilt/components/RemoveParticipant.tsx +0 -35
  259. package/src/Prebuilt/components/RoleChangeModal.tsx +0 -188
  260. package/src/Prebuilt/components/RoleChangeRequest/RequestPrompt.tsx +0 -75
  261. package/src/Prebuilt/components/RoleChangeRequest/RoleChangeRequestModal.tsx +0 -94
  262. package/src/Prebuilt/components/RoomDetails/Duration.tsx +0 -26
  263. package/src/Prebuilt/components/RoomDetails/RoomDetailsPane.tsx +0 -63
  264. package/src/Prebuilt/components/RoomDetails/RoomDetailsRow.tsx +0 -23
  265. package/src/Prebuilt/components/RoomDetails/RoomDetailsSheet.tsx +0 -45
  266. package/src/Prebuilt/components/ScreenShareToggle.jsx +0 -58
  267. package/src/Prebuilt/components/ScreenshareDisplay.tsx +0 -39
  268. package/src/Prebuilt/components/ScreenshareTile.tsx +0 -134
  269. package/src/Prebuilt/components/SecondaryTiles.tsx +0 -81
  270. package/src/Prebuilt/components/Settings/DeviceSettings.jsx +0 -208
  271. package/src/Prebuilt/components/Settings/LayoutSettings.tsx +0 -74
  272. package/src/Prebuilt/components/Settings/NotificationSettings.tsx +0 -66
  273. package/src/Prebuilt/components/Settings/SettingsModal.jsx +0 -301
  274. package/src/Prebuilt/components/Settings/StartRecording.jsx +0 -101
  275. package/src/Prebuilt/components/Settings/SwitchWithLabel.tsx +0 -53
  276. package/src/Prebuilt/components/Settings/common.ts +0 -16
  277. package/src/Prebuilt/components/ShareMenuIcon.jsx +0 -27
  278. package/src/Prebuilt/components/SidePaneTabs.tsx +0 -214
  279. package/src/Prebuilt/components/StatsForNerds.jsx +0 -373
  280. package/src/Prebuilt/components/Streaming/Common.jsx +0 -143
  281. package/src/Prebuilt/components/Streaming/ResolutionInput.jsx +0 -88
  282. package/src/Prebuilt/components/TileMenu/TileMenu.tsx +0 -148
  283. package/src/Prebuilt/components/TileMenu/TileMenuContent.tsx +0 -393
  284. package/src/Prebuilt/components/TileMenu/utils.ts +0 -7
  285. package/src/Prebuilt/components/Toast/Toast.jsx +0 -17
  286. package/src/Prebuilt/components/Toast/ToastBatcher.js +0 -64
  287. package/src/Prebuilt/components/Toast/ToastConfig.jsx +0 -177
  288. package/src/Prebuilt/components/Toast/ToastContainer.jsx +0 -30
  289. package/src/Prebuilt/components/Toast/ToastManager.js +0 -44
  290. package/src/Prebuilt/components/VideoLayouts/EqualProminence.tsx +0 -62
  291. package/src/Prebuilt/components/VideoLayouts/Grid.tsx +0 -43
  292. package/src/Prebuilt/components/VideoLayouts/GridLayout.tsx +0 -155
  293. package/src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx +0 -91
  294. package/src/Prebuilt/components/VideoLayouts/RoleProminence.tsx +0 -66
  295. package/src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx +0 -74
  296. package/src/Prebuilt/components/VideoLayouts/WhiteboardLayout.tsx +0 -93
  297. package/src/Prebuilt/components/VideoLayouts/interface.ts +0 -11
  298. package/src/Prebuilt/components/VideoTile.tsx +0 -203
  299. package/src/Prebuilt/components/VirtualBackground/VBCollection.tsx +0 -52
  300. package/src/Prebuilt/components/VirtualBackground/VBHandler.tsx +0 -130
  301. package/src/Prebuilt/components/VirtualBackground/VBOption.tsx +0 -57
  302. package/src/Prebuilt/components/VirtualBackground/VBPicker.tsx +0 -252
  303. package/src/Prebuilt/components/VirtualBackground/VBToggle.tsx +0 -50
  304. package/src/Prebuilt/components/hooks/useAudioOutputTest.tsx +0 -20
  305. package/src/Prebuilt/components/hooks/useAutoStartStreaming.tsx +0 -70
  306. package/src/Prebuilt/components/hooks/useChatBlacklist.ts +0 -29
  307. package/src/Prebuilt/components/hooks/useCloseScreenshareWhiteboard.tsx +0 -17
  308. package/src/Prebuilt/components/hooks/useDropdownList.ts +0 -24
  309. package/src/Prebuilt/components/hooks/useDropdownSelection.jsx +0 -3
  310. package/src/Prebuilt/components/hooks/useFullscreen.ts +0 -46
  311. package/src/Prebuilt/components/hooks/useGroupOnStageActions.tsx +0 -54
  312. package/src/Prebuilt/components/hooks/useMetadata.tsx +0 -56
  313. package/src/Prebuilt/components/hooks/usePeerOnStageActions.tsx +0 -49
  314. package/src/Prebuilt/components/hooks/usePinnedBy.tsx +0 -22
  315. package/src/Prebuilt/components/hooks/usePinnedMessages.ts +0 -78
  316. package/src/Prebuilt/components/hooks/usePlaylist.js +0 -25
  317. package/src/Prebuilt/components/hooks/usePlaylistMusic.js +0 -35
  318. package/src/Prebuilt/components/hooks/useRedirectToLeave.tsx +0 -23
  319. package/src/Prebuilt/components/hooks/useRoleProminencePeers.tsx +0 -39
  320. package/src/Prebuilt/components/hooks/useScreenshareAudio.js +0 -28
  321. package/src/Prebuilt/components/hooks/useTileLayout.tsx +0 -128
  322. package/src/Prebuilt/components/hooks/useUnreadPollQuizPresent.tsx +0 -17
  323. package/src/Prebuilt/components/hooks/useUserPreferences.jsx +0 -26
  324. package/src/Prebuilt/components/hooks/useVideoTileLayout.ts +0 -26
  325. package/src/Prebuilt/components/init/Init.jsx +0 -31
  326. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +0 -42
  327. package/src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx +0 -31
  328. package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +0 -32
  329. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +0 -211
  330. package/src/Prebuilt/components/pdfAnnotator/submitPdf.jsx +0 -48
  331. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +0 -71
  332. package/src/Prebuilt/components/peerTileUtils.tsx +0 -42
  333. package/src/Prebuilt/images/android-perm-1.png +0 -0
  334. package/src/Prebuilt/images/empty-chat.svg +0 -12
  335. package/src/Prebuilt/images/ios-perm-0.png +0 -0
  336. package/src/Prebuilt/images/pdf-share.png +0 -0
  337. package/src/Prebuilt/images/rtmp.png +0 -0
  338. package/src/Prebuilt/images/screen-share.png +0 -0
  339. package/src/Prebuilt/images/transaction_error.svg +0 -12
  340. package/src/Prebuilt/index.ts +0 -1
  341. package/src/Prebuilt/layouts/EmbedView.jsx +0 -94
  342. package/src/Prebuilt/layouts/HLSView.jsx +0 -747
  343. package/src/Prebuilt/layouts/PDFView.jsx +0 -67
  344. package/src/Prebuilt/layouts/Sheet.tsx +0 -14
  345. package/src/Prebuilt/layouts/SidePane.tsx +0 -241
  346. package/src/Prebuilt/layouts/VideoStreamingSection.tsx +0 -164
  347. package/src/Prebuilt/layouts/WaitingView.tsx +0 -52
  348. package/src/Prebuilt/plugins/CaptionsViewer.tsx +0 -261
  349. package/src/Prebuilt/plugins/FlyingEmoji.jsx +0 -154
  350. package/src/Prebuilt/plugins/RemoteStopScreenshare.jsx +0 -18
  351. package/src/Prebuilt/plugins/transcription/Transcriber.js +0 -216
  352. package/src/Prebuilt/plugins/transcription/TranscriptionButton.jsx +0 -138
  353. package/src/Prebuilt/plugins/transcription/index.jsx +0 -1
  354. package/src/Prebuilt/primitives/DialogContent.jsx +0 -285
  355. package/src/Prebuilt/primitives/DropdownTrigger.jsx +0 -46
  356. package/src/Prebuilt/provider/roomLayoutProvider/constants/index.ts +0 -60
  357. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +0 -88
  358. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useInsetEnabled.ts +0 -10
  359. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useRoomLayoutScreen.ts +0 -112
  360. package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +0 -53
  361. package/src/Prebuilt/services/FeatureFlags.jsx +0 -46
  362. package/src/Progress/index.tsx +0 -17
  363. package/src/QRCode/QRCode.mdx +0 -9
  364. package/src/QRCode/QRCode.stories.tsx +0 -29
  365. package/src/QRCode/QRCode.tsx +0 -6
  366. package/src/QRCode/index.tsx +0 -1
  367. package/src/RadioGroup/RadioGroup.stories.tsx +0 -32
  368. package/src/RadioGroup/RadioGroup.tsx +0 -33
  369. package/src/RadioGroup/index.tsx +0 -1
  370. package/src/ReactSelect/ReactSelect.stories.tsx +0 -83
  371. package/src/ReactSelect/ReactSelect.tsx +0 -97
  372. package/src/ReactSelect/index.ts +0 -1
  373. package/src/Select/Select.stories.tsx +0 -33
  374. package/src/Select/Select.tsx +0 -63
  375. package/src/Select/index.ts +0 -1
  376. package/src/Sheet/Sheet.mdx +0 -19
  377. package/src/Sheet/Sheet.stories.tsx +0 -103
  378. package/src/Sheet/Sheet.tsx +0 -122
  379. package/src/Sheet/index.ts +0 -1
  380. package/src/Slider/Slider.stories.tsx +0 -21
  381. package/src/Slider/Slider.tsx +0 -70
  382. package/src/Slider/index.ts +0 -1
  383. package/src/Stats/Stats.tsx +0 -243
  384. package/src/Stats/StyledStats.tsx +0 -57
  385. package/src/Stats/formatBytes.ts +0 -19
  386. package/src/Stats/index.tsx +0 -2
  387. package/src/Stats/useQoE.ts +0 -79
  388. package/src/Switch/Switch.mdx +0 -11
  389. package/src/Switch/Switch.stories.tsx +0 -46
  390. package/src/Switch/Switch.tsx +0 -52
  391. package/src/Switch/index.ts +0 -1
  392. package/src/Tabs/Tabs.stories.tsx +0 -77
  393. package/src/Tabs/Tabs.tsx +0 -41
  394. package/src/Tabs/index.tsx +0 -1
  395. package/src/Text/Text.stories.tsx +0 -21
  396. package/src/Text/Text.tsx +0 -149
  397. package/src/Text/index.tsx +0 -1
  398. package/src/TextArea/TextArea.tsx +0 -30
  399. package/src/TextArea/index.tsx +0 -1
  400. package/src/Theme/Theme.stories.mdx +0 -8
  401. package/src/Theme/ThemeProvider.tsx +0 -98
  402. package/src/Theme/ThemeStory.jsx +0 -56
  403. package/src/Theme/base.config.ts +0 -236
  404. package/src/Theme/index.tsx +0 -2
  405. package/src/Theme/stitches.config.ts +0 -88
  406. package/src/Theme/useSSR.tsx +0 -24
  407. package/src/TileMenu/StyledMenuTile.tsx +0 -105
  408. package/src/TileMenu/TileMenu.tsx +0 -98
  409. package/src/TileMenu/index.tsx +0 -1
  410. package/src/Toast/AppToast.stories.tsx +0 -56
  411. package/src/Toast/Toast.mdx +0 -19
  412. package/src/Toast/Toast.stories.tsx +0 -57
  413. package/src/Toast/Toast.tsx +0 -170
  414. package/src/Toast/index.tsx +0 -1
  415. package/src/Tooltip/Tooltip.stories.tsx +0 -62
  416. package/src/Tooltip/Tooltip.tsx +0 -79
  417. package/src/Tooltip/index.ts +0 -1
  418. package/src/Video/UseVideo.mdx +0 -22
  419. package/src/Video/UseVideo.stories.tsx +0 -26
  420. package/src/Video/Video.mdx +0 -24
  421. package/src/Video/Video.stories.tsx +0 -27
  422. package/src/Video/Video.tsx +0 -61
  423. package/src/Video/index.tsx +0 -1
  424. package/src/VideoList/StyledVideoList.tsx +0 -39
  425. package/src/VideoList/VideoList.stories.tsx +0 -92
  426. package/src/VideoList/index.tsx +0 -2
  427. package/src/VideoList/videoListUtils.tsx +0 -20
  428. package/src/VideoTile/StyledVideoTile.tsx +0 -146
  429. package/src/VideoTile/VideoTile.mdx +0 -28
  430. package/src/VideoTile/VideoTile.stories.tsx +0 -32
  431. package/src/VideoTile/index.tsx +0 -1
  432. package/src/context/DialogContext.tsx +0 -13
  433. package/src/fixtures/chats.ts +0 -25
  434. package/src/fixtures/peers.ts +0 -27
  435. package/src/fixtures/tracks.ts +0 -11
  436. package/src/hooks/useDialogContainerSelector.tsx +0 -7
  437. package/src/index.ts +0 -41
  438. package/src/store/SetupFakeStore.ts +0 -33
  439. package/src/store/StorybookSDK.ts +0 -231
  440. package/src/utils/animations.ts +0 -114
  441. package/src/utils/index.ts +0 -2
  442. package/src/utils/styles.ts +0 -22
@@ -1,190 +0,0 @@
1
- import React, { MutableRefObject, useCallback, useRef } from 'react';
2
- import { useMedia } from 'react-use';
3
- import { VariableSizeList } from 'react-window';
4
- import { selectSessionStore, selectUnreadHMSMessagesCount } from '@100mslive/hms-video-store';
5
- import { match } from 'ts-pattern';
6
- import { selectHMSMessagesCount, useHMSActions, useHMSStore, useHMSVanillaStore } from '@100mslive/react-sdk';
7
- import { ChevronDownIcon } from '@100mslive/react-icons';
8
- import { Button } from '../../../Button';
9
- import { Box, Flex } from '../../../Layout';
10
- import { config as cssConfig } from '../../../Theme';
11
- // @ts-ignore: No implicit Any
12
- import { EmojiReaction } from '../EmojiReaction';
13
- import { MoreSettings } from '../MoreSettings/MoreSettings';
14
- import { RaiseHand } from '../RaiseHand';
15
- import { ChatBody } from './ChatBody';
16
- import { ChatFooter } from './ChatFooter';
17
- import { ChatBlocked, ChatPaused } from './ChatStates';
18
- import { PinnedMessage } from './PinnedMessage';
19
- import { useRoomLayoutConferencingScreen } from '../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
20
- import { useSidepaneResetOnLayoutUpdate } from '../AppData/useSidepaneResetOnLayoutUpdate';
21
- import { useIsPeerBlacklisted } from '../hooks/useChatBlacklist';
22
- import { useLandscapeHLSStream, useMobileHLSStream } from '../../common/hooks';
23
- import { SESSION_STORE_KEY, SIDE_PANE_OPTIONS } from '../../common/constants';
24
-
25
- export const Chat = () => {
26
- const { elements, screenType } = useRoomLayoutConferencingScreen();
27
- const listRef = useRef<VariableSizeList | null>(null);
28
- const hmsActions = useHMSActions();
29
- const vanillaStore = useHMSVanillaStore();
30
- const { enabled: isChatEnabled = true } = useHMSStore(selectSessionStore(SESSION_STORE_KEY.CHAT_STATE)) || {};
31
- const isMobile = useMedia(cssConfig.media.md);
32
- const isMobileHLSStream = useMobileHLSStream();
33
- const isLandscapeStream = useLandscapeHLSStream();
34
- useSidepaneResetOnLayoutUpdate('chat', SIDE_PANE_OPTIONS.CHAT);
35
- const isLocalPeerBlacklisted = useIsPeerBlacklisted({ local: true });
36
-
37
- const scrollToBottom = useCallback(
38
- (unreadCount = 0) => {
39
- if (listRef.current && listRef.current.scrollToItem && unreadCount > 0) {
40
- const messagesCount = vanillaStore.getState(selectHMSMessagesCount);
41
- listRef.current?.scrollToItem(messagesCount, 'end');
42
- requestAnimationFrame(() => {
43
- listRef.current?.scrollToItem(messagesCount, 'end');
44
- });
45
- hmsActions.setMessageRead(true);
46
- }
47
- },
48
- [hmsActions, vanillaStore],
49
- );
50
-
51
- const streaming = isMobileHLSStream || isLandscapeStream;
52
-
53
- return (
54
- <Flex
55
- direction="column"
56
- justify="end"
57
- css={{
58
- size: '100%',
59
- gap: '$4',
60
- }}
61
- >
62
- {isMobile && elements?.chat?.is_overlay && !streaming ? null : <PinnedMessage />}
63
- <ChatBody ref={listRef} scrollToBottom={scrollToBottom} />
64
- <Flex align="center" css={{ w: '100%', gap: '$2' }}>
65
- <ChatPaused />
66
- <ChatBlocked />
67
- {streaming && (!isChatEnabled || isLocalPeerBlacklisted) && (
68
- <>
69
- <RaiseHand css={{ bg: '$surface_default' }} />
70
- <MoreSettings elements={elements} screenType={screenType} />
71
- </>
72
- )}
73
- </Flex>
74
- {isMobile && elements?.chat?.is_overlay && !streaming ? <PinnedMessage /> : null}
75
- {isChatEnabled ? (
76
- <ChatFooter onSend={scrollToBottom}>
77
- <NewMessageIndicator scrollToBottom={scrollToBottom} listRef={listRef} />
78
- </ChatFooter>
79
- ) : null}
80
- {streaming && (
81
- <Box
82
- css={{
83
- position: 'absolute',
84
- ...match({ isLandscapeStream, isMobileHLSStream, isChatEnabled, isLocalPeerBlacklisted })
85
- .with(
86
- {
87
- isLandscapeStream: true,
88
- isChatEnabled: true,
89
- },
90
- () => ({ bottom: '$19', right: '$10' }),
91
- )
92
- .with(
93
- {
94
- isLandscapeStream: true,
95
- isChatEnabled: false,
96
- },
97
- () => ({ bottom: '$20', right: '$10' }),
98
- )
99
- .with(
100
- {
101
- isMobileHLSStream: true,
102
- isChatEnabled: false,
103
- },
104
- () => ({ bottom: '$19', right: '$8' }),
105
- )
106
- .with(
107
- {
108
- isMobileHLSStream: true,
109
- isChatEnabled: true,
110
- isLocalPeerBlacklisted: false,
111
- },
112
- () => ({ bottom: '$17', right: '$8' }),
113
- )
114
- .with(
115
- {
116
- isLandscapeStream: false,
117
- isChatEnabled: true,
118
- isLocalPeerBlacklisted: true,
119
- },
120
- () => ({ bottom: '$18', right: '$8' }),
121
- )
122
- .with(
123
- {
124
- isMobileHLSStream: true,
125
- isLocalPeerBlacklisted: true,
126
- },
127
- () => ({ bottom: '$20', right: '$8' }),
128
- )
129
- .otherwise(() => ({})),
130
- }}
131
- >
132
- <EmojiReaction />
133
- </Box>
134
- )}
135
- </Flex>
136
- );
137
- };
138
-
139
- const NewMessageIndicator = ({
140
- scrollToBottom,
141
- listRef,
142
- }: {
143
- scrollToBottom: (count: number) => void;
144
- listRef: MutableRefObject<VariableSizeList | null>;
145
- }) => {
146
- const unreadCount = useHMSStore(selectUnreadHMSMessagesCount);
147
- if (!unreadCount || !listRef.current) {
148
- return null;
149
- }
150
- // @ts-ignore
151
- const outerElement = listRef.current._outerRef;
152
- if (
153
- outerElement &&
154
- outerElement.clientHeight + outerElement.scrollTop + outerElement.offsetTop >= outerElement.scrollHeight
155
- ) {
156
- return null;
157
- }
158
-
159
- return (
160
- <Flex
161
- justify="center"
162
- css={{
163
- width: '100%',
164
- left: 0,
165
- bottom: '$28',
166
- position: 'absolute',
167
- }}
168
- >
169
- <Button
170
- variant="standard"
171
- onClick={() => {
172
- scrollToBottom(unreadCount);
173
- }}
174
- icon
175
- css={{
176
- p: '$3 $4',
177
- pl: '$6',
178
- '& > svg': { ml: '$4' },
179
- borderRadius: '$round',
180
- fontSize: '$xs',
181
- fontWeight: '$semiBold',
182
- c: '$on_secondary_high',
183
- }}
184
- >
185
- New {unreadCount === 1 ? 'message' : 'messages'}
186
- <ChevronDownIcon height={16} width={16} />
187
- </Button>
188
- </Flex>
189
- );
190
- };
@@ -1,314 +0,0 @@
1
- import React, { useCallback, useState } from 'react';
2
- import { HMSMessage, selectLocalPeerName, selectPermissions, useHMSActions, useHMSStore } from '@100mslive/react-sdk';
3
- import {
4
- CopyIcon,
5
- CrossCircleIcon,
6
- CrossIcon,
7
- EyeCloseIcon,
8
- PeopleRemoveIcon,
9
- PinIcon,
10
- ReplyGroupIcon,
11
- ReplyIcon,
12
- VerticalMenuIcon,
13
- } from '@100mslive/react-icons';
14
- import { Dropdown } from '../../../Dropdown';
15
- import { IconButton } from '../../../IconButton';
16
- import { Flex } from '../../../Layout';
17
- import { Sheet } from '../../../Sheet';
18
- import { Text } from '../../../Text';
19
- import { Tooltip } from '../../../Tooltip';
20
- // @ts-ignore
21
- import { ToastManager } from '../Toast/ToastManager';
22
- import { MwebChatOption } from './MwebChatOption';
23
- import { useRoomLayoutConferencingScreen } from '../../provider/roomLayoutProvider/hooks/useRoomLayoutScreen';
24
- import { useChatBlacklist, useIsPeerBlacklisted } from '../hooks/useChatBlacklist';
25
- import { usePinnedMessages } from '../hooks/usePinnedMessages';
26
- import { SESSION_STORE_KEY } from '../../common/constants';
27
-
28
- const iconStyle = { height: '1.125rem', width: '1.125rem' };
29
- const tooltipBoxCSS = {
30
- fontSize: '$xs',
31
- backgroundColor: '$surface_default',
32
- p: '$1 $5',
33
- fontWeight: '$regular',
34
- borderRadius: '$3',
35
- };
36
-
37
- export const ChatActions = ({
38
- showPinAction,
39
- onReply,
40
- onReplyGroup,
41
- showReply,
42
- message,
43
- sentByLocalPeer,
44
- isMobile,
45
- openSheet,
46
- setOpenSheet,
47
- }: {
48
- showPinAction: boolean;
49
- onReply: () => void;
50
- onReplyGroup: () => void;
51
- showReply: boolean;
52
- message: HMSMessage;
53
- sentByLocalPeer: boolean;
54
- isMobile: boolean;
55
- openSheet: boolean;
56
- setOpenSheet: (value: boolean, e?: React.MouseEvent<HTMLElement, MouseEvent>) => void;
57
- }) => {
58
- const { elements } = useRoomLayoutConferencingScreen();
59
- const { can_hide_message = false, can_block_user = false } = elements?.chat?.real_time_controls || {};
60
- const { roles_whitelist = [] } = elements?.chat || {};
61
-
62
- const [open, setOpen] = useState(false);
63
- const actions = useHMSActions();
64
- const canRemoveOthers = useHMSStore(selectPermissions)?.removeOthers;
65
- const { blacklistItem: blacklistPeer } = useChatBlacklist(SESSION_STORE_KEY.CHAT_PEER_BLACKLIST);
66
- const localPeerName = useHMSStore(selectLocalPeerName);
67
- const { setPinnedMessages, unpinBlacklistedMessages } = usePinnedMessages();
68
-
69
- const { blacklistItem: blacklistMessage, blacklistedIDs: blacklistedMessageIDs } = useChatBlacklist(
70
- SESSION_STORE_KEY.CHAT_MESSAGE_BLACKLIST,
71
- );
72
-
73
- const isSenderBlocked = useIsPeerBlacklisted({ peerCustomerUserId: message.senderUserId });
74
-
75
- const updatePinnedMessages = useCallback(
76
- (messageID = '') => {
77
- const blacklistedMessageIDSet = new Set([...(blacklistedMessageIDs || []), messageID]);
78
- unpinBlacklistedMessages(blacklistedMessageIDSet);
79
- },
80
- [blacklistedMessageIDs, unpinBlacklistedMessages],
81
- );
82
-
83
- const copyMessageContent = useCallback(() => {
84
- try {
85
- navigator?.clipboard.writeText(message.message);
86
- ToastManager.addToast({
87
- title: 'Message copied successfully',
88
- });
89
- } catch (e) {
90
- console.log(e);
91
- ToastManager.addToast({
92
- title: 'Could not copy message',
93
- });
94
- }
95
- }, [message]);
96
-
97
- const options: Record<
98
- string,
99
- {
100
- text: string;
101
- tooltipText?: string;
102
- icon: React.ReactNode;
103
- onClick: () => void | Promise<void>;
104
- show: boolean;
105
- color?: string;
106
- }
107
- > = {
108
- reply: {
109
- text: 'Reply privately',
110
- tooltipText: 'Reply privately',
111
- icon: <ReplyIcon style={iconStyle} />,
112
- onClick: onReply,
113
- show: showReply,
114
- },
115
- replyGroup: {
116
- text: 'Reply to group',
117
- tooltipText: 'Reply to group',
118
- icon: <ReplyGroupIcon style={iconStyle} />,
119
- onClick: onReplyGroup,
120
- show: !!message.senderRole && roles_whitelist.includes(message.senderRole),
121
- },
122
- pin: {
123
- text: 'Pin message',
124
- tooltipText: 'Pin',
125
- icon: <PinIcon style={iconStyle} />,
126
- onClick: () => setPinnedMessages(message, localPeerName || ''),
127
- show: showPinAction,
128
- },
129
- copy: {
130
- text: 'Copy text',
131
- tooltipText: 'Copy',
132
- icon: <CopyIcon style={iconStyle} />,
133
- onClick: copyMessageContent,
134
- show: true,
135
- },
136
- hide: {
137
- text: message.recipientPeer ? 'Hide for both' : 'Hide for everyone',
138
- icon: <EyeCloseIcon style={iconStyle} />,
139
- onClick: async () => {
140
- blacklistMessage(message.id);
141
- updatePinnedMessages(message.id);
142
- },
143
- show: !!can_hide_message,
144
- },
145
- block: {
146
- text: 'Block from chat',
147
- icon: <CrossCircleIcon style={iconStyle} />,
148
- onClick: async () => {
149
- if (message.senderUserId) {
150
- blacklistPeer(message.senderUserId);
151
- }
152
- },
153
- color: '$alert_error_default',
154
- show: !!can_block_user && !sentByLocalPeer && !isSenderBlocked,
155
- },
156
- remove: {
157
- text: 'Remove participant',
158
- icon: <PeopleRemoveIcon style={iconStyle} />,
159
- color: '$alert_error_default',
160
- show: !!canRemoveOthers && !sentByLocalPeer,
161
- onClick: async () => {
162
- if (!message.sender) {
163
- return;
164
- }
165
- try {
166
- await actions.removePeer(message.sender, '');
167
- } catch (error) {
168
- ToastManager.addToast({ title: (error as Error).message, variant: 'error' });
169
- }
170
- },
171
- },
172
- };
173
-
174
- if (isMobile) {
175
- return (
176
- <Sheet.Root open={openSheet} onOpenChange={setOpenSheet}>
177
- <Sheet.Content css={{ bg: '$surface_default', pb: '$14' }} onClick={e => setOpenSheet(false, e)}>
178
- <Sheet.Title
179
- css={{
180
- display: 'flex',
181
- color: '$on_surface_high',
182
- w: '100%',
183
- justifyContent: 'space-between',
184
- mt: '$8',
185
- fontSize: '$md',
186
- px: '$10',
187
- pb: '$8',
188
- borderBottom: '1px solid $border_bright',
189
- alignItems: 'center',
190
- }}
191
- >
192
- Message options
193
- <Sheet.Close css={{ color: '$on_surface_high' }} onClick={e => setOpenSheet(false, e)}>
194
- <CrossIcon />
195
- </Sheet.Close>
196
- </Sheet.Title>
197
-
198
- {Object.keys(options).map(optionKey => {
199
- const option = options[optionKey];
200
- return option.show ? (
201
- <MwebChatOption
202
- key={optionKey}
203
- text={option.text}
204
- icon={option.icon}
205
- onClick={option.onClick}
206
- color={option?.color}
207
- />
208
- ) : null;
209
- })}
210
- </Sheet.Content>
211
- </Sheet.Root>
212
- );
213
- }
214
-
215
- return (
216
- <Dropdown.Root open={open} onOpenChange={setOpen} css={{ '@md': { display: 'none' } }}>
217
- <Flex
218
- className="chat_actions"
219
- css={{
220
- background: '$surface_bright',
221
- borderRadius: '$1',
222
- p: '$2',
223
- opacity: open ? 1 : 0,
224
- position: 'absolute',
225
- top: 0,
226
- right: 0,
227
- zIndex: 1,
228
- '@md': { opacity: 1 },
229
- }}
230
- >
231
- {options.reply.show ? (
232
- <Tooltip boxCss={tooltipBoxCSS} title={options.reply.tooltipText}>
233
- <IconButton data-testid="reply_message_btn" onClick={options.reply.onClick}>
234
- {options.reply.icon}
235
- </IconButton>
236
- </Tooltip>
237
- ) : null}
238
- {options.replyGroup.show ? (
239
- <Tooltip boxCss={tooltipBoxCSS} title={options.replyGroup.tooltipText}>
240
- <IconButton data-testid="reply_group_message_btn" onClick={options.replyGroup.onClick}>
241
- {options.replyGroup.icon}
242
- </IconButton>
243
- </Tooltip>
244
- ) : null}
245
- {options.pin.show ? (
246
- <Tooltip boxCss={tooltipBoxCSS} title={options.pin.tooltipText}>
247
- <IconButton data-testid="pin_message_btn" onClick={options.pin.onClick}>
248
- {options.pin.icon}
249
- </IconButton>
250
- </Tooltip>
251
- ) : null}
252
-
253
- {options.copy.show ? (
254
- <Tooltip boxCss={tooltipBoxCSS} title={options.copy.tooltipText}>
255
- <IconButton onClick={options.copy.onClick} data-testid="copy_message_btn">
256
- <CopyIcon style={iconStyle} />
257
- </IconButton>
258
- </Tooltip>
259
- ) : null}
260
-
261
- {options.block.show || options.hide.show || options.remove.show ? (
262
- <Tooltip boxCss={tooltipBoxCSS} title="More actions">
263
- <Dropdown.Trigger asChild>
264
- <IconButton>
265
- <VerticalMenuIcon style={iconStyle} />
266
- </IconButton>
267
- </Dropdown.Trigger>
268
- </Tooltip>
269
- ) : null}
270
- </Flex>
271
- <Dropdown.Portal>
272
- <Dropdown.Content
273
- sideOffset={5}
274
- align="end"
275
- css={{ width: '$48', backgroundColor: '$surface_bright', py: '$0', border: '1px solid $border_bright' }}
276
- >
277
- {options.hide.show ? (
278
- <Dropdown.Item data-testid="hide_message_btn" onClick={options.hide.onClick}>
279
- {options.hide.icon}
280
- <Text variant="sm" css={{ ml: '$4', fontWeight: '$semiBold' }}>
281
- {options.hide.text}
282
- </Text>
283
- </Dropdown.Item>
284
- ) : null}
285
-
286
- {options.block.show ? (
287
- <Dropdown.Item
288
- data-testid="block_peer_btn"
289
- onClick={options.block.onClick}
290
- css={{ color: options.block.color }}
291
- >
292
- {options.block.icon}
293
- <Text variant="sm" css={{ ml: '$4', color: 'inherit', fontWeight: '$semiBold' }}>
294
- {options.block.text}
295
- </Text>
296
- </Dropdown.Item>
297
- ) : null}
298
- {options.remove.show ? (
299
- <Dropdown.Item
300
- data-testid="remove_peer_btn"
301
- onClick={options.remove.onClick}
302
- css={{ color: options.remove.color }}
303
- >
304
- {options.remove.icon}
305
- <Text variant="sm" css={{ ml: '$4', color: 'inherit', fontWeight: '$semiBold' }}>
306
- {options.remove.text}
307
- </Text>
308
- </Dropdown.Item>
309
- ) : null}
310
- </Dropdown.Content>
311
- </Dropdown.Portal>
312
- </Dropdown.Root>
313
- );
314
- };