@100mslive/react-native-room-kit 1.0.0 → 1.0.1

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 (512) hide show
  1. package/README.md +1 -1
  2. package/lib/commonjs/HMSInstanceSetup.js +2 -2
  3. package/lib/commonjs/HMSInstanceSetup.js.map +1 -1
  4. package/lib/commonjs/HMSPrebuilt.js +5 -7
  5. package/lib/commonjs/HMSPrebuilt.js.map +1 -1
  6. package/lib/commonjs/HMSRoomSetup.js +3 -3
  7. package/lib/commonjs/HMSRoomSetup.js.map +1 -1
  8. package/lib/commonjs/Icons/Chevron/index.js +5 -1
  9. package/lib/commonjs/Icons/Chevron/index.js.map +1 -1
  10. package/lib/commonjs/Icons/Leave/index.js +5 -1
  11. package/lib/commonjs/Icons/Leave/index.js.map +1 -1
  12. package/lib/commonjs/Icons/WelcomeHand/assets/welcome-hand.png +0 -0
  13. package/lib/commonjs/Icons/WelcomeHand/assets/welcome-hand@2x.png +0 -0
  14. package/lib/commonjs/Icons/WelcomeHand/assets/welcome-hand@3x.png +0 -0
  15. package/lib/commonjs/Icons/WelcomeHand/index.js +30 -0
  16. package/lib/commonjs/Icons/WelcomeHand/index.js.map +1 -0
  17. package/lib/commonjs/Icons/index.js +11 -0
  18. package/lib/commonjs/Icons/index.js.map +1 -1
  19. package/lib/commonjs/components/AnimatedFooter.js +2 -2
  20. package/lib/commonjs/components/AnimatedFooter.js.map +1 -1
  21. package/lib/commonjs/components/AnimatedHLSFooter.js +2 -2
  22. package/lib/commonjs/components/AnimatedHLSFooter.js.map +1 -1
  23. package/lib/commonjs/components/AnimatedHeader.js +2 -2
  24. package/lib/commonjs/components/AnimatedHeader.js.map +1 -1
  25. package/lib/commonjs/components/AvatarView.js +2 -2
  26. package/lib/commonjs/components/AvatarView.js.map +1 -1
  27. package/lib/commonjs/components/BackButton.js +2 -2
  28. package/lib/commonjs/components/BackButton.js.map +1 -1
  29. package/lib/commonjs/components/BottomSheet.js +2 -2
  30. package/lib/commonjs/components/BottomSheet.js.map +1 -1
  31. package/lib/commonjs/components/ChangeNameModalContent.js +25 -6
  32. package/lib/commonjs/components/ChangeNameModalContent.js.map +1 -1
  33. package/lib/commonjs/components/Chat/ChatBanner.js +2 -2
  34. package/lib/commonjs/components/Chat/ChatBanner.js.map +1 -1
  35. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js +3 -4
  36. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  37. package/lib/commonjs/components/Chat/ChatFilterBottomSheetView.js +3 -4
  38. package/lib/commonjs/components/Chat/ChatFilterBottomSheetView.js.map +1 -1
  39. package/lib/commonjs/components/Chat/ChatFilterItem.js +3 -4
  40. package/lib/commonjs/components/Chat/ChatFilterItem.js.map +1 -1
  41. package/lib/commonjs/components/Chat/ChatFilterView.js +3 -4
  42. package/lib/commonjs/components/Chat/ChatFilterView.js.map +1 -1
  43. package/lib/commonjs/components/Chat/ChatList.js +3 -4
  44. package/lib/commonjs/components/Chat/ChatList.js.map +1 -1
  45. package/lib/commonjs/components/Chat/ChatMessage.js +3 -4
  46. package/lib/commonjs/components/Chat/ChatMessage.js.map +1 -1
  47. package/lib/commonjs/components/Chat/PinnedMessage.js +2 -2
  48. package/lib/commonjs/components/Chat/PinnedMessage.js.map +1 -1
  49. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js +2 -2
  50. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  51. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js +7 -7
  52. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  53. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -4
  54. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  55. package/lib/commonjs/components/ChatAndParticipants/ChatView.js +3 -4
  56. package/lib/commonjs/components/ChatAndParticipants/ChatView.js.map +1 -1
  57. package/lib/commonjs/components/ChatAndParticipants/ParticipantsView.js +15 -14
  58. package/lib/commonjs/components/ChatAndParticipants/ParticipantsView.js.map +1 -1
  59. package/lib/commonjs/components/DisplayView.js +2 -2
  60. package/lib/commonjs/components/DisplayView.js.map +1 -1
  61. package/lib/commonjs/components/EndRoomModalContent.js +2 -2
  62. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -1
  63. package/lib/commonjs/components/Footer.js +4 -5
  64. package/lib/commonjs/components/Footer.js.map +1 -1
  65. package/lib/commonjs/components/FullScreenVideoView.js +2 -2
  66. package/lib/commonjs/components/FullScreenVideoView.js.map +1 -1
  67. package/lib/commonjs/components/GridView.js +3 -4
  68. package/lib/commonjs/components/GridView.js.map +1 -1
  69. package/lib/commonjs/components/HLSFooter.js +2 -2
  70. package/lib/commonjs/components/HLSFooter.js.map +1 -1
  71. package/lib/commonjs/components/HLSView.js +2 -2
  72. package/lib/commonjs/components/HLSView.js.map +1 -1
  73. package/lib/commonjs/components/HMSBaseButton.js +2 -2
  74. package/lib/commonjs/components/HMSBaseButton.js.map +1 -1
  75. package/lib/commonjs/components/HMSChat.js +2 -2
  76. package/lib/commonjs/components/HMSChat.js.map +1 -1
  77. package/lib/commonjs/components/HMSDangerButton.js +4 -3
  78. package/lib/commonjs/components/HMSDangerButton.js.map +1 -1
  79. package/lib/commonjs/components/HMSHLSMessage.js +3 -4
  80. package/lib/commonjs/components/HMSHLSMessage.js.map +1 -1
  81. package/lib/commonjs/components/HMSHLSMessageList.js +2 -2
  82. package/lib/commonjs/components/HMSHLSMessageList.js.map +1 -1
  83. package/lib/commonjs/components/HMSHLSNotStarted.js +2 -2
  84. package/lib/commonjs/components/HMSHLSNotStarted.js.map +1 -1
  85. package/lib/commonjs/components/HMSHLSStreamLoading.js +6 -4
  86. package/lib/commonjs/components/HMSHLSStreamLoading.js.map +1 -1
  87. package/lib/commonjs/components/HMSHandRaiseNotification.js +2 -2
  88. package/lib/commonjs/components/HMSHandRaiseNotification.js.map +1 -1
  89. package/lib/commonjs/components/HMSKeyboardAvoidingView.js +4 -5
  90. package/lib/commonjs/components/HMSKeyboardAvoidingView.js.map +1 -1
  91. package/lib/commonjs/components/HMSLiveIndicator.js +5 -6
  92. package/lib/commonjs/components/HMSLiveIndicator.js.map +1 -1
  93. package/lib/commonjs/components/HMSLocalScreenshareNotification.js +2 -2
  94. package/lib/commonjs/components/HMSLocalScreenshareNotification.js.map +1 -1
  95. package/lib/commonjs/components/HMSLocalVideoView.js +2 -2
  96. package/lib/commonjs/components/HMSLocalVideoView.js.map +1 -1
  97. package/lib/commonjs/components/HMSManageAudioOutput.js +2 -2
  98. package/lib/commonjs/components/HMSManageAudioOutput.js.map +1 -1
  99. package/lib/commonjs/components/HMSManageCameraRotation.js +2 -2
  100. package/lib/commonjs/components/HMSManageCameraRotation.js.map +1 -1
  101. package/lib/commonjs/components/HMSManageLeave.js +4 -3
  102. package/lib/commonjs/components/HMSManageLeave.js.map +1 -1
  103. package/lib/commonjs/components/HMSManageLocalAudio.js +2 -2
  104. package/lib/commonjs/components/HMSManageLocalAudio.js.map +1 -1
  105. package/lib/commonjs/components/HMSManageLocalVideo.js +2 -2
  106. package/lib/commonjs/components/HMSManageLocalVideo.js.map +1 -1
  107. package/lib/commonjs/components/HMSManageRaiseHand.js +23 -11
  108. package/lib/commonjs/components/HMSManageRaiseHand.js.map +1 -1
  109. package/lib/commonjs/components/HMSMeetingEnded.js +2 -2
  110. package/lib/commonjs/components/HMSMeetingEnded.js.map +1 -1
  111. package/lib/commonjs/components/HMSNotification.js +2 -2
  112. package/lib/commonjs/components/HMSNotification.js.map +1 -1
  113. package/lib/commonjs/components/HMSNotifications.js +2 -2
  114. package/lib/commonjs/components/HMSNotifications.js.map +1 -1
  115. package/lib/commonjs/components/HMSOverlayChatView.js +2 -2
  116. package/lib/commonjs/components/HMSOverlayChatView.js.map +1 -1
  117. package/lib/commonjs/components/HMSPreviewEditName.js +2 -2
  118. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  119. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +5 -4
  120. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  121. package/lib/commonjs/components/HMSPreviewJoinButton.js +10 -5
  122. package/lib/commonjs/components/HMSPreviewJoinButton.js.map +1 -1
  123. package/lib/commonjs/components/HMSPreviewNetworkQuality.js +2 -2
  124. package/lib/commonjs/components/HMSPreviewNetworkQuality.js.map +1 -1
  125. package/lib/commonjs/components/HMSPreviewPeersList.js +2 -2
  126. package/lib/commonjs/components/HMSPreviewPeersList.js.map +1 -1
  127. package/lib/commonjs/components/HMSPreviewSubtitle.js +2 -2
  128. package/lib/commonjs/components/HMSPreviewSubtitle.js.map +1 -1
  129. package/lib/commonjs/components/HMSPreviewTile.js +3 -3
  130. package/lib/commonjs/components/HMSPreviewTile.js.map +1 -1
  131. package/lib/commonjs/components/HMSPreviewTitle.js +2 -2
  132. package/lib/commonjs/components/HMSPreviewTitle.js.map +1 -1
  133. package/lib/commonjs/components/HMSPrimaryButton.js +2 -2
  134. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -1
  135. package/lib/commonjs/components/HMSRecordingIndicator.js +6 -3
  136. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -1
  137. package/lib/commonjs/components/HMSRoleChangeDeclinedNotification.js +2 -2
  138. package/lib/commonjs/components/HMSRoleChangeDeclinedNotification.js.map +1 -1
  139. package/lib/commonjs/components/HMSRoomOptions.js +2 -2
  140. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  141. package/lib/commonjs/components/HMSSendMessageInput.js +2 -2
  142. package/lib/commonjs/components/HMSSendMessageInput.js.map +1 -1
  143. package/lib/commonjs/components/HMSTextInput.js +5 -5
  144. package/lib/commonjs/components/HMSTextInput.js.map +1 -1
  145. package/lib/commonjs/components/HMSVideoView.js +2 -2
  146. package/lib/commonjs/components/HMSVideoView.js.map +1 -1
  147. package/lib/commonjs/components/Header.js +4 -6
  148. package/lib/commonjs/components/Header.js.map +1 -1
  149. package/lib/commonjs/components/LocalPeerRegularVideoView.js +2 -2
  150. package/lib/commonjs/components/LocalPeerRegularVideoView.js.map +1 -1
  151. package/lib/commonjs/components/LocalPeerScreenshareView.js +2 -2
  152. package/lib/commonjs/components/LocalPeerScreenshareView.js.map +1 -1
  153. package/lib/commonjs/components/Meeting.js +2 -2
  154. package/lib/commonjs/components/Meeting.js.map +1 -1
  155. package/lib/commonjs/components/MeetingScreenContent.js +2 -2
  156. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  157. package/lib/commonjs/components/MiniView.js +2 -2
  158. package/lib/commonjs/components/MiniView.js.map +1 -1
  159. package/lib/commonjs/components/Modals.js +2 -2
  160. package/lib/commonjs/components/Modals.js.map +1 -1
  161. package/lib/commonjs/components/OverlayContainer.js +2 -2
  162. package/lib/commonjs/components/OverlayContainer.js.map +1 -1
  163. package/lib/commonjs/components/OverlayedViews.js +3 -4
  164. package/lib/commonjs/components/OverlayedViews.js.map +1 -1
  165. package/lib/commonjs/components/PIPView.js +24 -18
  166. package/lib/commonjs/components/PIPView.js.map +1 -1
  167. package/lib/commonjs/components/PaginationDots.js +3 -4
  168. package/lib/commonjs/components/PaginationDots.js.map +1 -1
  169. package/lib/commonjs/components/Participants/MultiRoleParticipantsList.js +65 -0
  170. package/lib/commonjs/components/Participants/MultiRoleParticipantsList.js.map +1 -0
  171. package/lib/commonjs/components/Participants/ParticipantsAccordian.js +60 -0
  172. package/lib/commonjs/components/Participants/ParticipantsAccordian.js.map +1 -0
  173. package/lib/commonjs/components/Participants/ParticipantsAccordianExpanded.js +25 -0
  174. package/lib/commonjs/components/Participants/ParticipantsAccordianExpanded.js.map +1 -0
  175. package/lib/commonjs/components/Participants/ParticipantsGroupFooter.js +61 -0
  176. package/lib/commonjs/components/Participants/ParticipantsGroupFooter.js.map +1 -0
  177. package/lib/commonjs/components/Participants/ParticipantsGroupHeader.js +31 -31
  178. package/lib/commonjs/components/Participants/ParticipantsGroupHeader.js.map +1 -1
  179. package/lib/commonjs/components/Participants/ParticipantsGroupOptions.js +3 -4
  180. package/lib/commonjs/components/Participants/ParticipantsGroupOptions.js.map +1 -1
  181. package/lib/commonjs/components/Participants/ParticipantsItem.js +12 -21
  182. package/lib/commonjs/components/Participants/ParticipantsItem.js.map +1 -1
  183. package/lib/commonjs/components/Participants/ParticipantsItemOption.js +3 -4
  184. package/lib/commonjs/components/Participants/ParticipantsItemOption.js.map +1 -1
  185. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js +4 -5
  186. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js.map +1 -1
  187. package/lib/commonjs/components/Participants/ParticipantsList.js +157 -22
  188. package/lib/commonjs/components/Participants/ParticipantsList.js.map +1 -1
  189. package/lib/commonjs/components/Participants/ParticipantsListFooter.js +43 -0
  190. package/lib/commonjs/components/Participants/ParticipantsListFooter.js.map +1 -0
  191. package/lib/commonjs/components/Participants/ParticipantsSeachInput.js +4 -4
  192. package/lib/commonjs/components/Participants/ParticipantsSeachInput.js.map +1 -1
  193. package/lib/commonjs/components/Participants/index.js +11 -0
  194. package/lib/commonjs/components/Participants/index.js.map +1 -1
  195. package/lib/commonjs/components/ParticipantsCount.js +3 -4
  196. package/lib/commonjs/components/ParticipantsCount.js.map +1 -1
  197. package/lib/commonjs/components/PeerDisplayView.js +1 -2
  198. package/lib/commonjs/components/PeerDisplayView.js.map +1 -1
  199. package/lib/commonjs/components/PeerMinimizedView.js +3 -4
  200. package/lib/commonjs/components/PeerMinimizedView.js.map +1 -1
  201. package/lib/commonjs/components/PeerRTCStatsContainer.js +3 -4
  202. package/lib/commonjs/components/PeerRTCStatsContainer.js.map +1 -1
  203. package/lib/commonjs/components/PeerRTCStatsView.js +1 -2
  204. package/lib/commonjs/components/PeerRTCStatsView.js.map +1 -1
  205. package/lib/commonjs/components/PeerVideoTile/AvatarView.js +4 -5
  206. package/lib/commonjs/components/PeerVideoTile/AvatarView.js.map +1 -1
  207. package/lib/commonjs/components/PeerVideoTile/HMSFullScreenButton.js +2 -2
  208. package/lib/commonjs/components/PeerVideoTile/HMSFullScreenButton.js.map +1 -1
  209. package/lib/commonjs/components/PeerVideoTile/HMSPinchGesture.js +2 -2
  210. package/lib/commonjs/components/PeerVideoTile/HMSPinchGesture.js.map +1 -1
  211. package/lib/commonjs/components/PeerVideoTile/PeerAudioIndicator.js +12 -7
  212. package/lib/commonjs/components/PeerVideoTile/PeerAudioIndicator.js.map +1 -1
  213. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js +22 -12
  214. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js.map +1 -1
  215. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js +2 -2
  216. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -1
  217. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js +26 -12
  218. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  219. package/lib/commonjs/components/PeerVideoTile/VideoView.js +3 -4
  220. package/lib/commonjs/components/PeerVideoTile/VideoView.js.map +1 -1
  221. package/lib/commonjs/components/PressableIcon.js +2 -2
  222. package/lib/commonjs/components/PressableIcon.js.map +1 -1
  223. package/lib/commonjs/components/Preview.js +5 -1
  224. package/lib/commonjs/components/Preview.js.map +1 -1
  225. package/lib/commonjs/components/PreviewForRoleChangeModal.js +4 -10
  226. package/lib/commonjs/components/PreviewForRoleChangeModal.js.map +1 -1
  227. package/lib/commonjs/components/ReconnectionView.js +3 -4
  228. package/lib/commonjs/components/ReconnectionView.js.map +1 -1
  229. package/lib/commonjs/components/RoomSettingsModalContent.js +49 -13
  230. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  231. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +1 -1
  232. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  233. package/lib/commonjs/components/StatusBar.js +2 -2
  234. package/lib/commonjs/components/StatusBar.js.map +1 -1
  235. package/lib/commonjs/components/StopRecordingModalContent.js +2 -2
  236. package/lib/commonjs/components/StopRecordingModalContent.js.map +1 -1
  237. package/lib/commonjs/components/StreamingQualityModalContent.js +2 -2
  238. package/lib/commonjs/components/StreamingQualityModalContent.js.map +1 -1
  239. package/lib/commonjs/components/Tile.js +1 -2
  240. package/lib/commonjs/components/Tile.js.map +1 -1
  241. package/lib/commonjs/components/TilesContainer.js +1 -2
  242. package/lib/commonjs/components/TilesContainer.js.map +1 -1
  243. package/lib/commonjs/components/UnmountAfterDelay.js +3 -4
  244. package/lib/commonjs/components/UnmountAfterDelay.js.map +1 -1
  245. package/lib/commonjs/components/WebrtcView.js +5 -5
  246. package/lib/commonjs/components/WebrtcView.js.map +1 -1
  247. package/lib/commonjs/components/WelcomeInMeeting.js +30 -9
  248. package/lib/commonjs/components/WelcomeInMeeting.js.map +1 -1
  249. package/lib/commonjs/components/styles.js +1 -2
  250. package/lib/commonjs/components/styles.js.map +1 -1
  251. package/lib/commonjs/hooks-sdk.js +46 -1
  252. package/lib/commonjs/hooks-sdk.js.map +1 -1
  253. package/lib/commonjs/hooks-util.js +133 -119
  254. package/lib/commonjs/hooks-util.js.map +1 -1
  255. package/lib/commonjs/redux/actionTypes.js +6 -5
  256. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  257. package/lib/commonjs/redux/actions/index.js +20 -4
  258. package/lib/commonjs/redux/actions/index.js.map +1 -1
  259. package/lib/commonjs/redux/index.js +1 -2
  260. package/lib/commonjs/redux/index.js.map +1 -1
  261. package/lib/commonjs/redux/reducers/appState.js +3 -4
  262. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  263. package/lib/commonjs/redux/reducers/chatWindow.js +1 -2
  264. package/lib/commonjs/redux/reducers/chatWindow.js.map +1 -1
  265. package/lib/commonjs/redux/reducers/hmsStates.js +192 -22
  266. package/lib/commonjs/redux/reducers/hmsStates.js.map +1 -1
  267. package/lib/commonjs/redux/reducers/index.js +1 -2
  268. package/lib/commonjs/redux/reducers/index.js.map +1 -1
  269. package/lib/commonjs/redux/reducers/message.js +3 -4
  270. package/lib/commonjs/redux/reducers/message.js.map +1 -1
  271. package/lib/commonjs/redux/reducers/userState.js +3 -4
  272. package/lib/commonjs/redux/reducers/userState.js.map +1 -1
  273. package/lib/commonjs/types.js +1 -2
  274. package/lib/commonjs/types.js.map +1 -1
  275. package/lib/commonjs/utils/dimension.js +2 -4
  276. package/lib/commonjs/utils/dimension.js.map +1 -1
  277. package/lib/commonjs/utils/functions.js.map +1 -1
  278. package/lib/commonjs/utils/theme.js +5 -10
  279. package/lib/commonjs/utils/theme.js.map +1 -1
  280. package/lib/commonjs/utils/types.js +13 -23
  281. package/lib/commonjs/utils/types.js.map +1 -1
  282. package/lib/commonjs/utils.js +1 -2
  283. package/lib/commonjs/utils.js.map +1 -1
  284. package/lib/module/HMSPrebuilt.js +2 -3
  285. package/lib/module/HMSPrebuilt.js.map +1 -1
  286. package/lib/module/HMSRoomSetup.js +1 -1
  287. package/lib/module/HMSRoomSetup.js.map +1 -1
  288. package/lib/module/Icons/Chevron/index.js +5 -1
  289. package/lib/module/Icons/Chevron/index.js.map +1 -1
  290. package/lib/module/Icons/Leave/index.js +5 -1
  291. package/lib/module/Icons/Leave/index.js.map +1 -1
  292. package/lib/module/Icons/WelcomeHand/assets/welcome-hand.png +0 -0
  293. package/lib/module/Icons/WelcomeHand/assets/welcome-hand@2x.png +0 -0
  294. package/lib/module/Icons/WelcomeHand/assets/welcome-hand@3x.png +0 -0
  295. package/lib/module/Icons/WelcomeHand/index.js +22 -0
  296. package/lib/module/Icons/WelcomeHand/index.js.map +1 -0
  297. package/lib/module/Icons/index.js +1 -0
  298. package/lib/module/Icons/index.js.map +1 -1
  299. package/lib/module/components/ChangeNameModalContent.js +25 -6
  300. package/lib/module/components/ChangeNameModalContent.js.map +1 -1
  301. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js +4 -3
  302. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  303. package/lib/module/components/ChatAndParticipants/ParticipantsView.js +13 -12
  304. package/lib/module/components/ChatAndParticipants/ParticipantsView.js.map +1 -1
  305. package/lib/module/components/Footer.js +1 -1
  306. package/lib/module/components/Footer.js.map +1 -1
  307. package/lib/module/components/HMSDangerButton.js +2 -1
  308. package/lib/module/components/HMSDangerButton.js.map +1 -1
  309. package/lib/module/components/HMSHLSStreamLoading.js +5 -3
  310. package/lib/module/components/HMSHLSStreamLoading.js.map +1 -1
  311. package/lib/module/components/HMSKeyboardAvoidingView.js +3 -4
  312. package/lib/module/components/HMSKeyboardAvoidingView.js.map +1 -1
  313. package/lib/module/components/HMSLiveIndicator.js +3 -3
  314. package/lib/module/components/HMSLiveIndicator.js.map +1 -1
  315. package/lib/module/components/HMSManageLeave.js +2 -1
  316. package/lib/module/components/HMSManageLeave.js.map +1 -1
  317. package/lib/module/components/HMSManageRaiseHand.js +22 -10
  318. package/lib/module/components/HMSManageRaiseHand.js.map +1 -1
  319. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +3 -2
  320. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  321. package/lib/module/components/HMSPreviewJoinButton.js +9 -4
  322. package/lib/module/components/HMSPreviewJoinButton.js.map +1 -1
  323. package/lib/module/components/HMSPreviewTile.js +1 -1
  324. package/lib/module/components/HMSPreviewTile.js.map +1 -1
  325. package/lib/module/components/HMSRecordingIndicator.js +4 -1
  326. package/lib/module/components/HMSRecordingIndicator.js.map +1 -1
  327. package/lib/module/components/HMSTextInput.js +3 -3
  328. package/lib/module/components/HMSTextInput.js.map +1 -1
  329. package/lib/module/components/PIPView.js +21 -13
  330. package/lib/module/components/PIPView.js.map +1 -1
  331. package/lib/module/components/Participants/MultiRoleParticipantsList.js +56 -0
  332. package/lib/module/components/Participants/MultiRoleParticipantsList.js.map +1 -0
  333. package/lib/module/components/Participants/ParticipantsAccordian.js +51 -0
  334. package/lib/module/components/Participants/ParticipantsAccordian.js.map +1 -0
  335. package/lib/module/components/Participants/ParticipantsAccordianExpanded.js +16 -0
  336. package/lib/module/components/Participants/ParticipantsAccordianExpanded.js.map +1 -0
  337. package/lib/module/components/Participants/ParticipantsGroupFooter.js +53 -0
  338. package/lib/module/components/Participants/ParticipantsGroupFooter.js.map +1 -0
  339. package/lib/module/components/Participants/ParticipantsGroupHeader.js +28 -27
  340. package/lib/module/components/Participants/ParticipantsGroupHeader.js.map +1 -1
  341. package/lib/module/components/Participants/ParticipantsGroupOptions.js.map +1 -1
  342. package/lib/module/components/Participants/ParticipantsItem.js +10 -18
  343. package/lib/module/components/Participants/ParticipantsItem.js.map +1 -1
  344. package/lib/module/components/Participants/ParticipantsItemOptions.js +1 -1
  345. package/lib/module/components/Participants/ParticipantsItemOptions.js.map +1 -1
  346. package/lib/module/components/Participants/ParticipantsList.js +156 -21
  347. package/lib/module/components/Participants/ParticipantsList.js.map +1 -1
  348. package/lib/module/components/Participants/ParticipantsListFooter.js +35 -0
  349. package/lib/module/components/Participants/ParticipantsListFooter.js.map +1 -0
  350. package/lib/module/components/Participants/ParticipantsSeachInput.js +2 -2
  351. package/lib/module/components/Participants/ParticipantsSeachInput.js.map +1 -1
  352. package/lib/module/components/Participants/index.js +1 -0
  353. package/lib/module/components/Participants/index.js.map +1 -1
  354. package/lib/module/components/PeerVideoTile/AvatarView.js +1 -1
  355. package/lib/module/components/PeerVideoTile/AvatarView.js.map +1 -1
  356. package/lib/module/components/PeerVideoTile/PeerAudioIndicator.js +11 -6
  357. package/lib/module/components/PeerVideoTile/PeerAudioIndicator.js.map +1 -1
  358. package/lib/module/components/PeerVideoTile/PeerMetadata.js +21 -11
  359. package/lib/module/components/PeerVideoTile/PeerMetadata.js.map +1 -1
  360. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js +22 -6
  361. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  362. package/lib/module/components/Preview.js +6 -2
  363. package/lib/module/components/Preview.js.map +1 -1
  364. package/lib/module/components/PreviewForRoleChangeModal.js +1 -6
  365. package/lib/module/components/PreviewForRoleChangeModal.js.map +1 -1
  366. package/lib/module/components/RoomSettingsModalContent.js +49 -13
  367. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  368. package/lib/module/components/RoomSettingsModalDebugModeContent.js +1 -1
  369. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  370. package/lib/module/components/WebrtcView.js +2 -1
  371. package/lib/module/components/WebrtcView.js.map +1 -1
  372. package/lib/module/components/WelcomeInMeeting.js +29 -8
  373. package/lib/module/components/WelcomeInMeeting.js.map +1 -1
  374. package/lib/module/hooks-sdk.js +46 -1
  375. package/lib/module/hooks-sdk.js.map +1 -1
  376. package/lib/module/hooks-util.js +135 -122
  377. package/lib/module/hooks-util.js.map +1 -1
  378. package/lib/module/redux/actionTypes.js +4 -1
  379. package/lib/module/redux/actionTypes.js.map +1 -1
  380. package/lib/module/redux/actions/index.js +14 -1
  381. package/lib/module/redux/actions/index.js.map +1 -1
  382. package/lib/module/redux/reducers/hmsStates.js +191 -20
  383. package/lib/module/redux/reducers/hmsStates.js.map +1 -1
  384. package/lib/module/utils/functions.js.map +1 -1
  385. package/lib/module/utils/types.js +1 -0
  386. package/lib/module/utils/types.js.map +1 -1
  387. package/lib/typescript/HMSPrebuilt.d.ts.map +1 -1
  388. package/lib/typescript/Icons/Chevron/index.d.ts +1 -1
  389. package/lib/typescript/Icons/Chevron/index.d.ts.map +1 -1
  390. package/lib/typescript/Icons/Leave/index.d.ts.map +1 -1
  391. package/lib/typescript/Icons/WelcomeHand/index.d.ts +7 -0
  392. package/lib/typescript/Icons/WelcomeHand/index.d.ts.map +1 -0
  393. package/lib/typescript/Icons/index.d.ts +1 -0
  394. package/lib/typescript/Icons/index.d.ts.map +1 -1
  395. package/lib/typescript/components/ChangeNameModalContent.d.ts.map +1 -1
  396. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsHeader.d.ts.map +1 -1
  397. package/lib/typescript/components/ChatAndParticipants/ParticipantsView.d.ts.map +1 -1
  398. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -1
  399. package/lib/typescript/components/HMSHLSStreamLoading.d.ts.map +1 -1
  400. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts.map +1 -1
  401. package/lib/typescript/components/HMSManageLeave.d.ts.map +1 -1
  402. package/lib/typescript/components/HMSManageRaiseHand.d.ts.map +1 -1
  403. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  404. package/lib/typescript/components/HMSPreviewJoinButton.d.ts.map +1 -1
  405. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -1
  406. package/lib/typescript/components/PIPView.d.ts +2 -1
  407. package/lib/typescript/components/PIPView.d.ts.map +1 -1
  408. package/lib/typescript/components/Participants/MultiRoleParticipantsList.d.ts +7 -0
  409. package/lib/typescript/components/Participants/MultiRoleParticipantsList.d.ts.map +1 -0
  410. package/lib/typescript/components/Participants/ParticipantsAccordian.d.ts +11 -0
  411. package/lib/typescript/components/Participants/ParticipantsAccordian.d.ts.map +1 -0
  412. package/lib/typescript/components/Participants/ParticipantsAccordianExpanded.d.ts +9 -0
  413. package/lib/typescript/components/Participants/ParticipantsAccordianExpanded.d.ts.map +1 -0
  414. package/lib/typescript/components/Participants/ParticipantsGroupFooter.d.ts +9 -0
  415. package/lib/typescript/components/Participants/ParticipantsGroupFooter.d.ts.map +1 -0
  416. package/lib/typescript/components/Participants/ParticipantsGroupHeader.d.ts +6 -3
  417. package/lib/typescript/components/Participants/ParticipantsGroupHeader.d.ts.map +1 -1
  418. package/lib/typescript/components/Participants/ParticipantsGroupOptions.d.ts +0 -2
  419. package/lib/typescript/components/Participants/ParticipantsGroupOptions.d.ts.map +1 -1
  420. package/lib/typescript/components/Participants/ParticipantsItem.d.ts +3 -3
  421. package/lib/typescript/components/Participants/ParticipantsItem.d.ts.map +1 -1
  422. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts +2 -2
  423. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts.map +1 -1
  424. package/lib/typescript/components/Participants/ParticipantsList.d.ts +3 -4
  425. package/lib/typescript/components/Participants/ParticipantsList.d.ts.map +1 -1
  426. package/lib/typescript/components/Participants/ParticipantsListFooter.d.ts +6 -0
  427. package/lib/typescript/components/Participants/ParticipantsListFooter.d.ts.map +1 -0
  428. package/lib/typescript/components/Participants/index.d.ts +1 -0
  429. package/lib/typescript/components/Participants/index.d.ts.map +1 -1
  430. package/lib/typescript/components/PeerVideoTile/PeerAudioIndicator.d.ts.map +1 -1
  431. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts +1 -0
  432. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts.map +1 -1
  433. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -1
  434. package/lib/typescript/components/Preview.d.ts.map +1 -1
  435. package/lib/typescript/components/PreviewForRoleChangeModal.d.ts.map +1 -1
  436. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  437. package/lib/typescript/components/WebrtcView.d.ts.map +1 -1
  438. package/lib/typescript/components/WelcomeInMeeting.d.ts.map +1 -1
  439. package/lib/typescript/hooks-sdk.d.ts +4 -0
  440. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  441. package/lib/typescript/hooks-util.d.ts +9 -19
  442. package/lib/typescript/hooks-util.d.ts.map +1 -1
  443. package/lib/typescript/redux/actionTypes.d.ts +4 -1
  444. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  445. package/lib/typescript/redux/actions/index.d.ts +13 -0
  446. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  447. package/lib/typescript/redux/index.d.ts +1 -1
  448. package/lib/typescript/redux/reducers/hmsStates.d.ts +16 -3
  449. package/lib/typescript/redux/reducers/hmsStates.d.ts.map +1 -1
  450. package/lib/typescript/redux/reducers/index.d.ts +1 -1
  451. package/lib/typescript/utils/functions.d.ts +0 -1
  452. package/lib/typescript/utils/functions.d.ts.map +1 -1
  453. package/lib/typescript/utils/types.d.ts +1 -0
  454. package/lib/typescript/utils/types.d.ts.map +1 -1
  455. package/package.json +3 -4
  456. package/src/HMSPrebuilt.tsx +3 -6
  457. package/src/HMSRoomSetup.tsx +1 -1
  458. package/src/Icons/Chevron/index.tsx +9 -2
  459. package/src/Icons/Leave/index.tsx +7 -1
  460. package/src/Icons/WelcomeHand/assets/welcome-hand.png +0 -0
  461. package/src/Icons/WelcomeHand/assets/welcome-hand@2x.png +0 -0
  462. package/src/Icons/WelcomeHand/assets/welcome-hand@3x.png +0 -0
  463. package/src/Icons/WelcomeHand/index.tsx +27 -0
  464. package/src/Icons/index.ts +1 -0
  465. package/src/components/ChangeNameModalContent.tsx +28 -9
  466. package/src/components/ChatAndParticipants/ChatAndParticipantsHeader.tsx +6 -3
  467. package/src/components/ChatAndParticipants/ParticipantsView.tsx +21 -13
  468. package/src/components/Footer.tsx +1 -1
  469. package/src/components/HMSDangerButton.tsx +2 -1
  470. package/src/components/HMSHLSStreamLoading.tsx +9 -3
  471. package/src/components/HMSKeyboardAvoidingView.tsx +3 -3
  472. package/src/components/HMSLiveIndicator.tsx +3 -3
  473. package/src/components/HMSManageLeave.tsx +2 -1
  474. package/src/components/HMSManageRaiseHand.tsx +20 -13
  475. package/src/components/HMSPreviewHLSLiveIndicator.tsx +3 -2
  476. package/src/components/HMSPreviewJoinButton.tsx +15 -4
  477. package/src/components/HMSPreviewTile.tsx +1 -1
  478. package/src/components/HMSRecordingIndicator.tsx +3 -1
  479. package/src/components/HMSTextInput.tsx +3 -3
  480. package/src/components/PIPView.tsx +34 -13
  481. package/src/components/Participants/MultiRoleParticipantsList.tsx +70 -0
  482. package/src/components/Participants/ParticipantsAccordian.tsx +70 -0
  483. package/src/components/Participants/ParticipantsAccordianExpanded.tsx +27 -0
  484. package/src/components/Participants/ParticipantsGroupFooter.tsx +65 -0
  485. package/src/components/Participants/ParticipantsGroupHeader.tsx +37 -37
  486. package/src/components/Participants/ParticipantsGroupOptions.tsx +1 -6
  487. package/src/components/Participants/ParticipantsItem.tsx +16 -33
  488. package/src/components/Participants/ParticipantsItemOptions.tsx +3 -3
  489. package/src/components/Participants/ParticipantsList.tsx +197 -34
  490. package/src/components/Participants/ParticipantsListFooter.tsx +45 -0
  491. package/src/components/Participants/ParticipantsSeachInput.tsx +2 -2
  492. package/src/components/Participants/index.ts +1 -0
  493. package/src/components/PeerVideoTile/AvatarView.tsx +1 -1
  494. package/src/components/PeerVideoTile/PeerAudioIndicator.tsx +11 -6
  495. package/src/components/PeerVideoTile/PeerMetadata.tsx +21 -12
  496. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +25 -8
  497. package/src/components/Preview.tsx +23 -9
  498. package/src/components/PreviewForRoleChangeModal.tsx +1 -6
  499. package/src/components/RoomSettingsModalContent.tsx +44 -9
  500. package/src/components/RoomSettingsModalDebugModeContent.tsx +1 -1
  501. package/src/components/WebrtcView.tsx +10 -1
  502. package/src/components/WelcomeInMeeting.tsx +33 -5
  503. package/src/hooks-sdk.ts +58 -0
  504. package/src/hooks-util.ts +229 -193
  505. package/src/redux/actionTypes.ts +4 -1
  506. package/src/redux/actions/index.ts +17 -1
  507. package/src/redux/reducers/hmsStates.ts +269 -36
  508. package/src/utils/functions.ts +0 -1
  509. package/src/utils/types.ts +2 -0
  510. package/lib/commonjs/assets/welcome.png +0 -0
  511. package/lib/module/assets/welcome.png +0 -0
  512. package/src/assets/welcome.png +0 -0
@@ -1,65 +1,213 @@
1
1
  import * as React from 'react';
2
2
  import { StyleSheet, Text, View } from 'react-native';
3
3
  import { FlashList } from '@shopify/flash-list';
4
- import type { HMSLocalPeer, HMSRemotePeer } from '@100mslive/react-native-hms';
4
+ import type { HMSPeer } from '@100mslive/react-native-hms';
5
5
 
6
- import { useHMSRoomStyle } from '../../hooks-util';
7
- import type {
8
- ListItemUI,
9
- ParticipantHandRaisedHeaderData,
10
- ParticipantHeaderData,
6
+ import {
7
+ useHMSInstance,
8
+ useHMSLayoutConfig,
9
+ useHMSRoomStyleSheet,
11
10
  } from '../../hooks-util';
12
11
  import { ParticipantsItem } from './ParticipantsItem';
13
12
  import { ParticipantsGroupHeader } from './ParticipantsGroupHeader';
13
+ import { useSelector } from 'react-redux';
14
+ import type { RootState } from '../../redux';
15
+ import { ParticipantsListFooter } from './ParticipantsListFooter';
14
16
 
15
17
  export type ParticipantsListProps = {
16
- data: ListItemUI[];
17
- searchTextExists: boolean;
18
- setExpandedGroups: React.Dispatch<React.SetStateAction<string[]>>;
18
+ searchText: string;
19
+ selectedGroupId: string;
20
+ onBackPress(): void;
19
21
  };
20
22
 
23
+ const stickyIndices = [0];
24
+
21
25
  export const ParticipantsList: React.FC<ParticipantsListProps> = ({
22
- data,
23
- searchTextExists,
24
- setExpandedGroups,
26
+ searchText,
27
+ selectedGroupId,
28
+ onBackPress,
25
29
  }) => {
26
- const emptyTextStyles = useHMSRoomStyle((theme, typography) => ({
27
- color: theme.palette.on_surface_medium,
28
- fontFamily: `${typography.font_family}-SemiBold`,
29
- }));
30
+ const mountedRef = React.useRef(true);
31
+ const fetchedInitialDataRef = React.useRef(false);
32
+ const hmsInstance = useHMSInstance();
33
+
34
+ // Currect is current selected group and off-stage gorup
35
+ const isOffStageGroup = useHMSLayoutConfig((layoutConfig) => {
36
+ const offStageRoles =
37
+ layoutConfig?.screens?.conferencing?.default?.elements?.on_stage_exp
38
+ ?.off_stage_roles || null;
39
+ return offStageRoles ? offStageRoles.includes(selectedGroupId) : false;
40
+ });
41
+
42
+ // Getting initial data for the selected group Id
43
+ const dataForGroupId = useSelector(
44
+ (state: RootState) => {
45
+ return selectedGroupId === 'hand-raised' ? state.hmsStates.groupedParticipants : state.hmsStates.groupedParticipants[selectedGroupId]
46
+ }
47
+ );
48
+
49
+ const finalDataForGroupId = React.useMemo(() => {
50
+ if (Array.isArray(dataForGroupId)) {
51
+ return dataForGroupId;
52
+ }
53
+
54
+ if (dataForGroupId && selectedGroupId === 'hand-raised') {
55
+ return Object.values(dataForGroupId).flat().filter(peer => peer.isHandRaised);
56
+ }
57
+
58
+ return null;
59
+ }, [dataForGroupId, selectedGroupId]);
60
+
61
+ // Creating Header Data
62
+ const headerData = React.useMemo(() => {
63
+ return {
64
+ id: selectedGroupId,
65
+ label:
66
+ selectedGroupId === 'hand-raised' ? 'Hand Raised' : selectedGroupId,
67
+ };
68
+ }, [selectedGroupId]);
69
+
70
+ // Created List with Header Data as first item in list
71
+ const dataWithHeader = React.useMemo(
72
+ () => [headerData, ...(finalDataForGroupId ?? [])],
73
+ [finalDataForGroupId, headerData]
74
+ );
75
+
76
+ const [offStageData, setOffStageData] = React.useState(dataWithHeader);
77
+ const [loading, setLoading] = React.useState(false);
78
+
79
+ // Created Peer List Iterator for current selected group if it is an 'off-stage' group
80
+ const peerListIterator = React.useMemo(() => {
81
+ if (!isOffStageGroup) {
82
+ return null;
83
+ }
84
+ return hmsInstance.getPeerListIterator({
85
+ limit: 20,
86
+ byRoleName: selectedGroupId,
87
+ });
88
+ }, [selectedGroupId, isOffStageGroup, hmsInstance]);
89
+
90
+ // #Effect: Fetching first page from Peer List Iterator
91
+ React.useEffect(() => {
92
+ let mounted = true;
93
+ mountedRef.current = true;
94
+
95
+ if (peerListIterator) {
96
+ setLoading(true);
97
+
98
+ peerListIterator
99
+ .next()
100
+ .then((peers: HMSPeer[]) => {
101
+ if (mounted) {
102
+ setLoading(false);
103
+ setOffStageData([headerData, ...peers]);
104
+ fetchedInitialDataRef.current = true;
105
+ }
106
+ })
107
+ .catch(() => {
108
+ if (mounted) {
109
+ setLoading(false);
110
+ }
111
+ });
112
+ }
113
+
114
+ return () => {
115
+ mounted = false;
116
+ mountedRef.current = false;
117
+ };
118
+ }, [headerData, peerListIterator]);
30
119
 
31
- const _keyExtractor = React.useCallback((item: ListItemUI) => item.key, []);
120
+ const filteredSearchText = searchText.trim().toLowerCase();
121
+
122
+ //#region Flaslist props
123
+ const data = React.useMemo(() => {
124
+ return (isOffStageGroup ? offStageData : dataWithHeader).filter((item) =>
125
+ 'id' in item ? true : item.name.toLowerCase().includes(filteredSearchText)
126
+ );
127
+ }, [filteredSearchText, offStageData, dataWithHeader, isOffStageGroup]);
128
+
129
+ const _keyExtractor = React.useCallback(
130
+ (item: HMSPeer | { id: string; label: string }) =>
131
+ 'id' in item ? item.id : item.peerID,
132
+ []
133
+ );
32
134
 
33
135
  const _renderItem = React.useCallback(
34
- (data: { item: ListItemUI }) => {
35
- if ('label' in data.item.data) {
136
+ (data: { item: HMSPeer | { id: string; label: string } }) => {
137
+ if ('id' in data.item) {
36
138
  return (
37
- <ParticipantsGroupHeader
38
- data={
39
- data.item as ListItemUI<
40
- ParticipantHeaderData | ParticipantHandRaisedHeaderData
41
- >
42
- }
43
- setExpandedGroups={setExpandedGroups}
44
- />
139
+ <View style={hmsRoomStyles.stickyHeader}>
140
+ <View style={[styles.headerWrapper, hmsRoomStyles.stickyHeader]}>
141
+ <ParticipantsGroupHeader
142
+ id={data.item.id}
143
+ label={data.item.label}
144
+ expanded={true}
145
+ onBackPress={onBackPress}
146
+ />
147
+ </View>
148
+ </View>
45
149
  );
46
150
  }
47
151
 
48
152
  return (
49
- <ParticipantsItem
50
- data={data.item as ListItemUI<HMSLocalPeer | HMSRemotePeer>}
51
- />
153
+ <View style={[styles.itemWrapper, hmsRoomStyles.item]}>
154
+ <ParticipantsItem groupId={selectedGroupId} data={data.item} />
155
+ </View>
52
156
  );
53
157
  },
54
- [setExpandedGroups]
158
+ [selectedGroupId]
55
159
  );
56
160
 
57
- const _getItemType = React.useCallback((item: ListItemUI) => item.type, []);
161
+ const _getItemType = React.useCallback(
162
+ (item: HMSPeer | { id: string; label: string }) =>
163
+ 'id' in item ? 'header' : 'item',
164
+ []
165
+ );
166
+
167
+ const _onEndReached = React.useCallback(() => {
168
+ if (loading || !fetchedInitialDataRef.current || !mountedRef.current) {
169
+ return;
170
+ }
171
+
172
+ if (peerListIterator) {
173
+ setLoading(true);
174
+ peerListIterator
175
+ .next()
176
+ .then((peers: HMSPeer[]) => {
177
+ if (mountedRef.current) {
178
+ setLoading(false);
179
+ setOffStageData((prev) => [...prev, ...peers]);
180
+ }
181
+ })
182
+ .catch(() => {
183
+ if (mountedRef.current) {
184
+ setLoading(false);
185
+ }
186
+ });
187
+ }
188
+ }, [loading, peerListIterator]);
189
+ //#endregion Flaslist props
190
+
191
+ const searchTextExists = searchText.length > 0;
58
192
 
59
- if (searchTextExists && data.length <= 0) {
193
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
194
+ emptyText: {
195
+ color: theme.palette.on_surface_medium,
196
+ fontFamily: `${typography.font_family}-SemiBold`,
197
+ },
198
+ stickyHeader: {
199
+ backgroundColor: theme.palette.surface_dim,
200
+ borderColor: theme.palette.border_bright,
201
+ },
202
+ item: {
203
+ borderColor: theme.palette.border_bright,
204
+ },
205
+ }));
206
+
207
+ if (!data || (searchTextExists && data.length <= 1)) {
60
208
  return (
61
209
  <View style={styles.emptyContainer}>
62
- <Text style={[styles.emptyText, emptyTextStyles]}>
210
+ <Text style={[styles.emptyText, hmsRoomStyles.emptyText]}>
63
211
  No results found...
64
212
  </Text>
65
213
  </View>
@@ -72,9 +220,15 @@ export const ParticipantsList: React.FC<ParticipantsListProps> = ({
72
220
  estimatedItemSize={56}
73
221
  contentContainerStyle={styles.list}
74
222
  keyboardShouldPersistTaps="always"
223
+ ListFooterComponent={<ParticipantsListFooter loading={loading} />}
224
+ stickyHeaderIndices={stickyIndices}
75
225
  keyExtractor={_keyExtractor}
76
226
  renderItem={_renderItem}
77
227
  getItemType={_getItemType}
228
+ onEndReached={
229
+ searchTextExists || !peerListIterator ? null : _onEndReached
230
+ }
231
+ onEndReachedThreshold={0.8}
78
232
  />
79
233
  );
80
234
  };
@@ -93,4 +247,13 @@ const styles = StyleSheet.create({
93
247
  lineHeight: 20,
94
248
  letterSpacing: 0.25,
95
249
  },
250
+ headerWrapper: {
251
+ borderWidth: 1,
252
+ borderTopLeftRadius: 8,
253
+ borderTopRightRadius: 8,
254
+ },
255
+ itemWrapper: {
256
+ borderRightWidth: 1,
257
+ borderLeftWidth: 1,
258
+ },
96
259
  });
@@ -0,0 +1,45 @@
1
+ import * as React from 'react';
2
+ import { ActivityIndicator, StyleSheet, View } from 'react-native';
3
+
4
+ import {
5
+ useHMSRoomColorPalette,
6
+ useHMSRoomStyleSheet,
7
+ } from '../../hooks-util';
8
+
9
+ export type ParticipantsListFooterProps = {
10
+ loading: boolean;
11
+ };
12
+
13
+ const _ParticipantsListFooter: React.FC<ParticipantsListFooterProps> = ({
14
+ loading
15
+ }) => {
16
+ const { on_surface_high: onSurfaceHigh } = useHMSRoomColorPalette();
17
+
18
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
19
+ footer: {
20
+ borderColor: theme.palette.border_bright,
21
+ },
22
+ }));
23
+
24
+ return (
25
+ <View style={[styles.footer, hmsRoomStyles.footer]}>
26
+ {loading ? (
27
+ <ActivityIndicator size={'small'} color={onSurfaceHigh} />
28
+ ) : null}
29
+ </View>
30
+ );
31
+ };
32
+
33
+ export const ParticipantsListFooter = React.memo(_ParticipantsListFooter);
34
+
35
+ const styles = StyleSheet.create({
36
+ footer: {
37
+ width: '100%',
38
+ paddingBottom: 16,
39
+ borderBottomWidth: 1,
40
+ borderRightWidth: 1,
41
+ borderLeftWidth: 1,
42
+ borderBottomRightRadius: 8,
43
+ borderBottomLeftRadius: 8,
44
+ },
45
+ });
@@ -13,7 +13,7 @@ type ParticipantsSearchInputProps = {
13
13
  export const ParticipantsSearchInput: React.FC<
14
14
  ParticipantsSearchInputProps
15
15
  > = ({ searchText, setSearchText }) => {
16
- const { on_surface_low: onSurfaceLowColor } = useHMSRoomColorPalette();
16
+ const { on_surface_medium: onSurfaceMediumColor } = useHMSRoomColorPalette();
17
17
 
18
18
  const textInputStyle = useHMSRoomStyle((theme) => ({
19
19
  backgroundColor: theme.palette.surface_default,
@@ -28,7 +28,7 @@ export const ParticipantsSearchInput: React.FC<
28
28
  style={styles.input}
29
29
  containerStyle={[styles.textInputContainer, textInputStyle]}
30
30
  focusedContainerStyle={[styles.focusedTextInputContainer, textInputStyle]}
31
- placeholderTextColor={onSurfaceLowColor}
31
+ placeholderTextColor={onSurfaceMediumColor}
32
32
  leftIcon={<SearchIcon style={styles.searchIcon} />}
33
33
  />
34
34
  );
@@ -1,2 +1,3 @@
1
1
  export * from './ParticipantsList';
2
2
  export * from './ParticipantsSeachInput';
3
+ export * from './MultiRoleParticipantsList';
@@ -33,7 +33,7 @@ export const _AvatarView: React.FC<AvatarViewProps> = ({
33
33
  backgroundColor: COLORS.EXTENDED.PURPLE,
34
34
  },
35
35
  avatarText: {
36
- color: theme.palette.on_surface_high,
36
+ color: COLORS.WHITE,
37
37
  fontFamily: `${typography.font_family}-SemiBold`,
38
38
  },
39
39
  }));
@@ -5,7 +5,7 @@ import { useSelector } from 'react-redux';
5
5
  import LottieView from 'lottie-react-native';
6
6
 
7
7
  import { MicIcon } from '../../Icons';
8
- import { useHMSRoomStyle } from '../../hooks-util';
8
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
9
9
  import type { RootState } from '../../redux';
10
10
 
11
11
  export interface PeerAudioIndicatorProps {
@@ -24,21 +24,26 @@ export const PeerAudioIndicator: React.FC<PeerAudioIndicatorProps> = ({
24
24
  ) >= 0
25
25
  );
26
26
 
27
- const iconWrapperStyles = useHMSRoomStyle((theme) => ({
28
- backgroundColor: theme.palette.secondary_dim,
27
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
28
+ iconWrapper: {
29
+ backgroundColor: theme.palette.secondary_dim,
30
+ },
31
+ icon: {
32
+ tintColor: theme.palette.on_secondary_high,
33
+ },
29
34
  }));
30
35
 
31
36
  if (isMuted) {
32
37
  return (
33
- <View style={[styles.iconWrapper, iconWrapperStyles]}>
34
- <MicIcon muted={true} style={styles.icon} />
38
+ <View style={[styles.iconWrapper, hmsRoomStyles.iconWrapper]}>
39
+ <MicIcon muted={true} style={[styles.icon, hmsRoomStyles.icon]} />
35
40
  </View>
36
41
  );
37
42
  }
38
43
 
39
44
  if (activeSpeaker) {
40
45
  return (
41
- <View style={[styles.speakerIconWrapper, iconWrapperStyles]}>
46
+ <View style={[styles.speakerIconWrapper, hmsRoomStyles.iconWrapper]}>
42
47
  <LottieView
43
48
  style={styles.speakerIcon}
44
49
  source={require('../../assets/audio-level-white.json')}
@@ -3,31 +3,40 @@ import { StyleSheet, View } from 'react-native';
3
3
 
4
4
  import { parseMetadata } from '../../utils/functions';
5
5
  import { BRBIcon, HandIcon } from '../../Icons';
6
- import { useHMSRoomStyle } from '../../hooks-util';
6
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
7
7
 
8
8
  export interface PeerMetadataProps {
9
9
  metadata: string | undefined;
10
+ isHandRaised: boolean;
10
11
  }
11
12
 
12
- export const PeerMetadata: React.FC<PeerMetadataProps> = ({ metadata }) => {
13
- const parsedMetadata = parseMetadata(metadata);
14
-
15
- const iconWrapperStyles = useHMSRoomStyle((theme) => ({
16
- backgroundColor: theme.palette.secondary_dim,
13
+ export const PeerMetadata: React.FC<PeerMetadataProps> = ({
14
+ metadata,
15
+ isHandRaised,
16
+ }) => {
17
+ const isBRBOn = !!parseMetadata(metadata).isBRBOn;
18
+
19
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
20
+ iconWrapper: {
21
+ backgroundColor: theme.palette.secondary_dim,
22
+ },
23
+ icon: {
24
+ tintColor: theme.palette.on_secondary_high,
25
+ },
17
26
  }));
18
27
 
19
- if (parsedMetadata.isBRBOn) {
28
+ if (isBRBOn) {
20
29
  return (
21
- <View style={[styles.iconWrapper, iconWrapperStyles]}>
22
- <BRBIcon />
30
+ <View style={[styles.iconWrapper, hmsRoomStyles.iconWrapper]}>
31
+ <BRBIcon style={hmsRoomStyles.icon} />
23
32
  </View>
24
33
  );
25
34
  }
26
35
 
27
- if (parsedMetadata.isHandRaised) {
36
+ if (isHandRaised) {
28
37
  return (
29
- <View style={[styles.iconWrapper, iconWrapperStyles]}>
30
- <HandIcon />
38
+ <View style={[styles.iconWrapper, hmsRoomStyles.iconWrapper]}>
39
+ <HandIcon style={hmsRoomStyles.icon} />
31
40
  </View>
32
41
  );
33
42
  }
@@ -18,6 +18,7 @@ import { ThreeDotsIcon } from '../../Icons';
18
18
  import { hexToRgbA } from '../../utils/theme';
19
19
  import { PeerNameAndNetwork } from './PeerNameAndNetwork';
20
20
  import { UnmountAfterDelay } from '../UnmountAfterDelay';
21
+ import { PipModes } from '../../utils/types';
21
22
  import type { PeerTrackNode } from '../../utils/types';
22
23
  import { isTileOnSpotlight } from '../../utils/functions';
23
24
  import {
@@ -47,6 +48,10 @@ export const _PeerVideoTileView = React.forwardRef<
47
48
  > | null>(null);
48
49
  const [mounted, setMounted] = React.useState(true);
49
50
 
51
+ const isPipModeActive = useSelector(
52
+ (state: RootState) => state.app.pipModeStatus === PipModes.ACTIVE
53
+ );
54
+
50
55
  const onSpotlight = useSelector((state: RootState) => {
51
56
  const { onSpotlight } = isTileOnSpotlight(state.user.spotlightTrackId, {
52
57
  tileVideoTrack: peerTrackNode.track,
@@ -93,7 +98,11 @@ export const _PeerVideoTileView = React.forwardRef<
93
98
  return (allowed && allowed.length > 0) ?? false;
94
99
  });
95
100
 
96
- const localPeerPermissions = useSelector((state: RootState) => {
101
+ const canTakeActionOnPeer = useSelector((state: RootState) => {
102
+ if (peer.isLocal) {
103
+ return true;
104
+ }
105
+
97
106
  const permissions = state.hmsStates.localPeer?.role?.permissions;
98
107
  return (
99
108
  permissions &&
@@ -126,6 +135,13 @@ export const _PeerVideoTileView = React.forwardRef<
126
135
  track.type === HMSTrackType.VIDEO &&
127
136
  track.isMute() === false;
128
137
 
138
+ const hide3DotsButton =
139
+ !onMoreOptionsPress || // If button press handler is not available, Or
140
+ isPipModeActive || // If Pip Window is active, Or
141
+ (track && track?.source !== HMSTrackSource.REGULAR) || // If track is non-regular, like screen share, Or
142
+ !canTakeActionOnPeer || // If local peer can't take action on peer, Or
143
+ !allowedToPublish; // If local peer can't publish tracks
144
+
129
145
  return (
130
146
  <View style={styles.container}>
131
147
  <AvatarView
@@ -133,7 +149,7 @@ export const _PeerVideoTileView = React.forwardRef<
133
149
  avatarContainerStyles={
134
150
  insetMode ? hmsRoomStyles.avatarContainer : null
135
151
  }
136
- isInset={insetMode}
152
+ isInset={insetMode || isPipModeActive}
137
153
  videoView={
138
154
  showingVideoTrack ? (
139
155
  <VideoView
@@ -154,7 +170,10 @@ export const _PeerVideoTileView = React.forwardRef<
154
170
  />
155
171
 
156
172
  {/* Handling Peer Metadata */}
157
- <PeerMetadata metadata={peer.metadata} />
173
+ <PeerMetadata
174
+ metadata={peer.metadata}
175
+ isHandRaised={peer.isHandRaised}
176
+ />
158
177
 
159
178
  {/* Handling Peer Audio Mute indicator */}
160
179
  {screenShareTile && showingVideoTrack ? (
@@ -164,7 +183,7 @@ export const _PeerVideoTileView = React.forwardRef<
164
183
  ) : null}
165
184
 
166
185
  {/* Handling showing Peer name */}
167
- {insetMode ? null : (
186
+ {(insetMode || isPipModeActive) ? null : (
168
187
  <PeerNameAndNetwork
169
188
  name={peer.name}
170
189
  isLocal={peer.isLocal}
@@ -179,9 +198,7 @@ export const _PeerVideoTileView = React.forwardRef<
179
198
  ) : null}
180
199
 
181
200
  {/* 3 dots option menu */}
182
- {!onMoreOptionsPress ||
183
- (track &&
184
- track?.source !== HMSTrackSource.REGULAR) ? null : insetMode ? (
201
+ {hide3DotsButton ? null : insetMode ? (
185
202
  <UnmountAfterDelay
186
203
  ref={unmountAfterDelayRef}
187
204
  visible={mounted}
@@ -196,7 +213,7 @@ export const _PeerVideoTileView = React.forwardRef<
196
213
  <ThreeDotsIcon stack="vertical" style={styles.icon} />
197
214
  </PressableIcon>
198
215
  </UnmountAfterDelay>
199
- ) : !allowedToPublish || !localPeerPermissions ? null : (
216
+ ) : (
200
217
  <PressableIcon
201
218
  activeOpacity={0.7}
202
219
  style={[styles.iconWrapper, hmsRoomStyles.iconWrapperStyles]}
@@ -23,20 +23,17 @@ import { HMSPreviewNetworkQuality } from './HMSPreviewNetworkQuality';
23
23
  import { useCanPublishVideo } from '../hooks-sdk';
24
24
  import { HMSPreviewHLSLiveIndicator } from './HMSPreviewHLSLiveIndicator';
25
25
  import { CompanyLogo } from './CompanyLogo';
26
- import { useHMSRoomStyleSheet, useIsHLSViewer } from '../hooks-util';
26
+ import {
27
+ useHMSRoomColorPalette,
28
+ useHMSRoomStyleSheet,
29
+ useIsHLSViewer,
30
+ } from '../hooks-util';
27
31
  import { HMSKeyboardAvoidingView } from './HMSKeyboardAvoidingView';
32
+ import { hexToRgbA } from '../utils/theme';
28
33
 
29
34
  const backButtonEdges = ['top'] as const;
30
35
  const headerEdges = ['top', 'left', 'right'] as const;
31
36
 
32
- const gradientColorShades = [
33
- '#000000',
34
- 'rgba(0, 0, 0, 0.9)',
35
- 'rgba(0, 0, 0, 0.7)',
36
- 'rgba(0, 0, 0, 0.1)',
37
- 'rgba(0, 0, 0, 0.05)',
38
- 'rgba(0, 0, 0, 0)',
39
- ];
40
37
  const gradientColorShadeLocations = [0.45, 0.55, 0.7, 0.9, 0.95, 1];
41
38
 
42
39
  export const Preview = ({
@@ -49,6 +46,23 @@ export const Preview = ({
49
46
  const canPublishVideo = useCanPublishVideo();
50
47
  const isHLSViewer = useIsHLSViewer();
51
48
 
49
+ const { background_dim } = useHMSRoomColorPalette();
50
+
51
+ const gradientColorShades = React.useMemo(
52
+ () =>
53
+ background_dim
54
+ ? [
55
+ hexToRgbA(background_dim, 1),
56
+ hexToRgbA(background_dim, 0.9),
57
+ hexToRgbA(background_dim, 0.7),
58
+ hexToRgbA(background_dim, 0.1),
59
+ hexToRgbA(background_dim, 0.05),
60
+ hexToRgbA(background_dim, 0),
61
+ ]
62
+ : [],
63
+ [background_dim]
64
+ );
65
+
52
66
  const hmsRoomStyles = useHMSRoomStyleSheet(
53
67
  (theme) => ({
54
68
  container: {
@@ -138,12 +138,7 @@ const _PreviewForRoleChangeModal = () => {
138
138
  }
139
139
 
140
140
  // lower hand
141
- const newMetadata = {
142
- ...localPeerMetadata,
143
- isHandRaised: false,
144
- isBRBOn: localPeerMetadata.isBRBOn,
145
- };
146
- await hmsActions.changeMetadata(newMetadata);
141
+ await hmsActions.lowerLocalPeerHand();
147
142
  }
148
143
  };
149
144