@100mslive/react-native-room-kit 0.0.3 → 0.1.0

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 (857) hide show
  1. package/README.md +413 -11
  2. package/lib/commonjs/HMSInstanceSetup.js +3 -15
  3. package/lib/commonjs/HMSInstanceSetup.js.map +1 -1
  4. package/lib/commonjs/HMSPrebuilt.js +17 -6
  5. package/lib/commonjs/HMSPrebuilt.js.map +1 -1
  6. package/lib/commonjs/HMSRoomSetup.js +76 -21
  7. package/lib/commonjs/HMSRoomSetup.js.map +1 -1
  8. package/lib/commonjs/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  9. package/lib/commonjs/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  10. package/lib/commonjs/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  11. package/lib/commonjs/Icons/AlertTriangle/index.js +34 -0
  12. package/lib/commonjs/Icons/AlertTriangle/index.js.map +1 -0
  13. package/lib/commonjs/Icons/AnswerPhone/index.js +5 -1
  14. package/lib/commonjs/Icons/AnswerPhone/index.js.map +1 -1
  15. package/lib/commonjs/Icons/BRB/assets/BRB.png +0 -0
  16. package/lib/commonjs/Icons/BRB/assets/BRB@2x.png +0 -0
  17. package/lib/commonjs/Icons/BRB/assets/BRB@3x.png +0 -0
  18. package/lib/commonjs/Icons/BRB/index.js +35 -0
  19. package/lib/commonjs/Icons/BRB/index.js.map +1 -0
  20. package/lib/commonjs/Icons/Bluetooth/index.js +5 -1
  21. package/lib/commonjs/Icons/Bluetooth/index.js.map +1 -1
  22. package/lib/commonjs/Icons/Camera/index.js +5 -1
  23. package/lib/commonjs/Icons/Camera/index.js.map +1 -1
  24. package/lib/commonjs/Icons/Chat/index.js +5 -1
  25. package/lib/commonjs/Icons/Chat/index.js.map +1 -1
  26. package/lib/commonjs/Icons/Check/assets/check.png +0 -0
  27. package/lib/commonjs/Icons/Check/assets/check@2x.png +0 -0
  28. package/lib/commonjs/Icons/Check/assets/check@3x.png +0 -0
  29. package/lib/commonjs/Icons/Check/index.js +34 -0
  30. package/lib/commonjs/Icons/Check/index.js.map +1 -0
  31. package/lib/commonjs/Icons/Chevron/index.js +5 -1
  32. package/lib/commonjs/Icons/Chevron/index.js.map +1 -1
  33. package/lib/commonjs/Icons/Close/index.js +5 -1
  34. package/lib/commonjs/Icons/Close/index.js.map +1 -1
  35. package/lib/commonjs/Icons/Hamburger/assets/hamburger.png +0 -0
  36. package/lib/commonjs/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  37. package/lib/commonjs/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  38. package/lib/commonjs/Icons/Hamburger/index.js +34 -0
  39. package/lib/commonjs/Icons/Hamburger/index.js.map +1 -0
  40. package/lib/commonjs/Icons/Hand/index.js +6 -4
  41. package/lib/commonjs/Icons/Hand/index.js.map +1 -1
  42. package/lib/commonjs/Icons/Headphones/index.js +5 -1
  43. package/lib/commonjs/Icons/Headphones/index.js.map +1 -1
  44. package/lib/commonjs/Icons/Maximize/assets/maximize.png +0 -0
  45. package/lib/commonjs/Icons/Maximize/assets/maximize@2x.png +0 -0
  46. package/lib/commonjs/Icons/Maximize/assets/maximize@3x.png +0 -0
  47. package/lib/commonjs/Icons/Maximize/index.js +34 -0
  48. package/lib/commonjs/Icons/Maximize/index.js.map +1 -0
  49. package/lib/commonjs/Icons/Mic/index.js +5 -1
  50. package/lib/commonjs/Icons/Mic/index.js.map +1 -1
  51. package/lib/commonjs/Icons/Minimize/assets/minimize.png +0 -0
  52. package/lib/commonjs/Icons/Minimize/assets/minimize@2x.png +0 -0
  53. package/lib/commonjs/Icons/Minimize/assets/minimize@3x.png +0 -0
  54. package/lib/commonjs/Icons/Minimize/index.js +34 -0
  55. package/lib/commonjs/Icons/Minimize/index.js.map +1 -0
  56. package/lib/commonjs/Icons/Participants/index.js +5 -1
  57. package/lib/commonjs/Icons/Participants/index.js.map +1 -1
  58. package/lib/commonjs/Icons/Pencil/assets/pencil.png +0 -0
  59. package/lib/commonjs/Icons/Pencil/assets/pencil@2x.png +0 -0
  60. package/lib/commonjs/Icons/Pencil/assets/pencil@3x.png +0 -0
  61. package/lib/commonjs/Icons/Pencil/index.js +34 -0
  62. package/lib/commonjs/Icons/Pencil/index.js.map +1 -0
  63. package/lib/commonjs/Icons/Pin/assets/pin.png +0 -0
  64. package/lib/commonjs/Icons/Pin/assets/pin@2x.png +0 -0
  65. package/lib/commonjs/Icons/Pin/assets/pin@3x.png +0 -0
  66. package/lib/commonjs/Icons/Pin/index.js +34 -0
  67. package/lib/commonjs/Icons/Pin/index.js.map +1 -0
  68. package/lib/commonjs/Icons/Radio/assets/radio.png +0 -0
  69. package/lib/commonjs/Icons/Radio/assets/radio@2x.png +0 -0
  70. package/lib/commonjs/Icons/Radio/assets/radio@3x.png +0 -0
  71. package/lib/commonjs/Icons/Radio/index.js +30 -0
  72. package/lib/commonjs/Icons/Radio/index.js.map +1 -0
  73. package/lib/commonjs/Icons/Recording/assets/recording.png +0 -0
  74. package/lib/commonjs/Icons/Recording/assets/recording@2x.png +0 -0
  75. package/lib/commonjs/Icons/Recording/assets/recording@3x.png +0 -0
  76. package/lib/commonjs/Icons/Recording/index.js +34 -0
  77. package/lib/commonjs/Icons/Recording/index.js.map +1 -0
  78. package/lib/commonjs/Icons/RotateCamera/index.js +5 -1
  79. package/lib/commonjs/Icons/RotateCamera/index.js.map +1 -1
  80. package/lib/commonjs/Icons/ScreenShare/index.js +5 -1
  81. package/lib/commonjs/Icons/ScreenShare/index.js.map +1 -1
  82. package/lib/commonjs/Icons/Speaker/index.js +5 -1
  83. package/lib/commonjs/Icons/Speaker/index.js.map +1 -1
  84. package/lib/commonjs/Icons/Star/assets/star.png +0 -0
  85. package/lib/commonjs/Icons/Star/assets/star@2x.png +0 -0
  86. package/lib/commonjs/Icons/Star/assets/star@3x.png +0 -0
  87. package/lib/commonjs/Icons/Star/index.js +34 -0
  88. package/lib/commonjs/Icons/Star/index.js.map +1 -0
  89. package/lib/commonjs/Icons/Stop/assets/stop.png +0 -0
  90. package/lib/commonjs/Icons/Stop/assets/stop@2x.png +0 -0
  91. package/lib/commonjs/Icons/Stop/assets/stop@3x.png +0 -0
  92. package/lib/commonjs/Icons/Stop/index.js +34 -0
  93. package/lib/commonjs/Icons/Stop/index.js.map +1 -0
  94. package/lib/commonjs/Icons/ThreeDots/index.js +5 -1
  95. package/lib/commonjs/Icons/ThreeDots/index.js.map +1 -1
  96. package/lib/commonjs/Icons/Wave/index.js +5 -1
  97. package/lib/commonjs/Icons/Wave/index.js.map +1 -1
  98. package/lib/commonjs/Icons/index.js +132 -0
  99. package/lib/commonjs/Icons/index.js.map +1 -1
  100. package/lib/commonjs/components/AvatarView.js +1 -2
  101. package/lib/commonjs/components/AvatarView.js.map +1 -1
  102. package/lib/commonjs/components/BackButton.js +8 -6
  103. package/lib/commonjs/components/BackButton.js.map +1 -1
  104. package/lib/commonjs/components/BottomSheet.js +157 -0
  105. package/lib/commonjs/components/BottomSheet.js.map +1 -0
  106. package/lib/commonjs/components/ChangeNameModalContent.js +131 -0
  107. package/lib/commonjs/components/ChangeNameModalContent.js.map +1 -0
  108. package/lib/commonjs/components/CompanyLogo.js +38 -0
  109. package/lib/commonjs/components/CompanyLogo.js.map +1 -0
  110. package/lib/commonjs/components/CustomInput.js +2 -3
  111. package/lib/commonjs/components/CustomInput.js.map +1 -1
  112. package/lib/commonjs/components/DisplayView.js +12 -58
  113. package/lib/commonjs/components/DisplayView.js.map +1 -1
  114. package/lib/commonjs/components/EndRoomModalContent.js +85 -0
  115. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -0
  116. package/lib/commonjs/components/Footer.js +8 -9
  117. package/lib/commonjs/components/Footer.js.map +1 -1
  118. package/lib/commonjs/components/GridView.js +53 -7
  119. package/lib/commonjs/components/GridView.js.map +1 -1
  120. package/lib/commonjs/components/HMSBaseButton.js +66 -0
  121. package/lib/commonjs/components/HMSBaseButton.js.map +1 -0
  122. package/lib/commonjs/components/HMSDangerButton.js +53 -0
  123. package/lib/commonjs/components/HMSDangerButton.js.map +1 -0
  124. package/lib/commonjs/components/HMSHLSStreamLoading.js +65 -0
  125. package/lib/commonjs/components/HMSHLSStreamLoading.js.map +1 -0
  126. package/lib/commonjs/components/HMSLocalVideoView.js +41 -0
  127. package/lib/commonjs/components/HMSLocalVideoView.js.map +1 -0
  128. package/lib/commonjs/components/{HMSSpeakerSettings.js → HMSManageAudioOutput.js} +70 -76
  129. package/lib/commonjs/components/HMSManageAudioOutput.js.map +1 -0
  130. package/lib/commonjs/components/HMSManageCameraRotation.js +5 -4
  131. package/lib/commonjs/components/HMSManageCameraRotation.js.map +1 -1
  132. package/lib/commonjs/components/HMSManageLeave.js +91 -159
  133. package/lib/commonjs/components/HMSManageLeave.js.map +1 -1
  134. package/lib/commonjs/components/HMSManageLocalAudio.js +1 -9
  135. package/lib/commonjs/components/HMSManageLocalAudio.js.map +1 -1
  136. package/lib/commonjs/components/HMSManageLocalVideo.js +1 -9
  137. package/lib/commonjs/components/HMSManageLocalVideo.js.map +1 -1
  138. package/lib/commonjs/components/HMSMeetingEnded.js +35 -0
  139. package/lib/commonjs/components/HMSMeetingEnded.js.map +1 -0
  140. package/lib/commonjs/components/HMSPreviewEditName.js +7 -38
  141. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  142. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +71 -0
  143. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -0
  144. package/lib/commonjs/components/HMSPreviewJoinButton.js +26 -37
  145. package/lib/commonjs/components/HMSPreviewJoinButton.js.map +1 -1
  146. package/lib/commonjs/components/HMSPreviewNetworkQuality.js +45 -0
  147. package/lib/commonjs/components/HMSPreviewNetworkQuality.js.map +1 -0
  148. package/lib/commonjs/components/HMSPreviewPeersList.js +21 -33
  149. package/lib/commonjs/components/HMSPreviewPeersList.js.map +1 -1
  150. package/lib/commonjs/components/HMSPreviewSubtitle.js +43 -7
  151. package/lib/commonjs/components/HMSPreviewSubtitle.js.map +1 -1
  152. package/lib/commonjs/components/HMSPreviewTile.js +18 -26
  153. package/lib/commonjs/components/HMSPreviewTile.js.map +1 -1
  154. package/lib/commonjs/components/HMSPreviewTitle.js +14 -6
  155. package/lib/commonjs/components/HMSPreviewTitle.js.map +1 -1
  156. package/lib/commonjs/components/HMSPrimaryButton.js +53 -0
  157. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -0
  158. package/lib/commonjs/components/HMSRecordingIndicator.js +46 -0
  159. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -0
  160. package/lib/commonjs/components/HMSRoomOptions.js +22 -10
  161. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  162. package/lib/commonjs/components/HMSShowNetworkQuality.js +5 -6
  163. package/lib/commonjs/components/HMSShowNetworkQuality.js.map +1 -1
  164. package/lib/commonjs/components/HMSTextInput.js +66 -0
  165. package/lib/commonjs/components/HMSTextInput.js.map +1 -0
  166. package/lib/commonjs/components/Header.js +30 -30
  167. package/lib/commonjs/components/Header.js.map +1 -1
  168. package/lib/commonjs/components/LocalPeerRegularVideoView.js +26 -0
  169. package/lib/commonjs/components/LocalPeerRegularVideoView.js.map +1 -0
  170. package/lib/commonjs/components/LocalPeerScreenshareView.js +76 -0
  171. package/lib/commonjs/components/LocalPeerScreenshareView.js.map +1 -0
  172. package/lib/commonjs/components/Meeting.js +14 -3
  173. package/lib/commonjs/components/Meeting.js.map +1 -1
  174. package/lib/commonjs/components/MenuModal/Menu.js +1 -2
  175. package/lib/commonjs/components/MenuModal/Menu.js.map +1 -1
  176. package/lib/commonjs/components/MiniView.js +163 -0
  177. package/lib/commonjs/components/MiniView.js.map +1 -0
  178. package/lib/commonjs/components/Modals.js +35 -380
  179. package/lib/commonjs/components/Modals.js.map +1 -1
  180. package/lib/commonjs/components/PaginationDots.js +56 -0
  181. package/lib/commonjs/components/PaginationDots.js.map +1 -0
  182. package/lib/commonjs/components/Participants/ParticipantsList.js +1 -20
  183. package/lib/commonjs/components/Participants/ParticipantsList.js.map +1 -1
  184. package/lib/commonjs/components/ParticipantsCount.js +55 -0
  185. package/lib/commonjs/components/ParticipantsCount.js.map +1 -0
  186. package/lib/commonjs/components/PeerMinimizedView.js +114 -0
  187. package/lib/commonjs/components/PeerMinimizedView.js.map +1 -0
  188. package/lib/commonjs/components/PeerSettingsModalContent.js +69 -63
  189. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  190. package/lib/commonjs/components/PeerVideoTile/AvatarView.js +76 -0
  191. package/lib/commonjs/components/PeerVideoTile/AvatarView.js.map +1 -0
  192. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js +44 -0
  193. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  194. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js +44 -0
  195. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  196. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js +74 -0
  197. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  198. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js +146 -0
  199. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  200. package/lib/commonjs/components/PeerVideoTile/VideoView.js +84 -0
  201. package/lib/commonjs/components/PeerVideoTile/VideoView.js.map +1 -0
  202. package/lib/commonjs/components/PeerVideoTile/index.js +2 -0
  203. package/lib/commonjs/components/PeerVideoTile/index.js.map +1 -0
  204. package/lib/commonjs/components/PressableIcon.js +15 -8
  205. package/lib/commonjs/components/PressableIcon.js.map +1 -1
  206. package/lib/commonjs/components/Preview.js +93 -72
  207. package/lib/commonjs/components/Preview.js.map +1 -1
  208. package/lib/commonjs/components/RoomSettingsModalContent.js +228 -457
  209. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  210. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +295 -0
  211. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  212. package/lib/commonjs/components/StopRecordingModalContent.js +97 -0
  213. package/lib/commonjs/components/StopRecordingModalContent.js.map +1 -0
  214. package/lib/commonjs/components/Tile.js +29 -90
  215. package/lib/commonjs/components/Tile.js.map +1 -1
  216. package/lib/commonjs/components/TilesContainer.js +99 -10
  217. package/lib/commonjs/components/TilesContainer.js.map +1 -1
  218. package/lib/commonjs/components/UnmountAfterDelay.js +48 -0
  219. package/lib/commonjs/components/UnmountAfterDelay.js.map +1 -0
  220. package/lib/commonjs/components/WebrtcView.js +51 -0
  221. package/lib/commonjs/components/WebrtcView.js.map +1 -0
  222. package/lib/commonjs/components/WelcomeInMeeting.js +54 -0
  223. package/lib/commonjs/components/WelcomeInMeeting.js.map +1 -0
  224. package/lib/commonjs/components/index.js +0 -11
  225. package/lib/commonjs/components/index.js.map +1 -1
  226. package/lib/commonjs/hooks/useHmsInstance.js +0 -1
  227. package/lib/commonjs/hooks/useHmsInstance.js.map +1 -1
  228. package/lib/commonjs/hooks-sdk-selectors.js +6 -1
  229. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  230. package/lib/commonjs/hooks-sdk.js +16 -1
  231. package/lib/commonjs/hooks-sdk.js.map +1 -1
  232. package/lib/commonjs/hooks-util-selectors.js +14 -1
  233. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  234. package/lib/commonjs/hooks-util.js +421 -98
  235. package/lib/commonjs/hooks-util.js.map +1 -1
  236. package/lib/commonjs/modules/HMSManager.js +23 -0
  237. package/lib/commonjs/modules/HMSManager.js.map +1 -0
  238. package/lib/commonjs/modules/parser.js +22 -0
  239. package/lib/commonjs/modules/parser.js.map +1 -0
  240. package/lib/commonjs/peerTrackNodeUtils.js +8 -3
  241. package/lib/commonjs/peerTrackNodeUtils.js.map +1 -1
  242. package/lib/commonjs/redux/actionTypes.js +20 -1
  243. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  244. package/lib/commonjs/redux/actions/index.js +65 -1
  245. package/lib/commonjs/redux/actions/index.js.map +1 -1
  246. package/lib/commonjs/redux/reducers/appState.js +70 -1
  247. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  248. package/lib/commonjs/redux/reducers/hmsStates.js +7 -1
  249. package/lib/commonjs/redux/reducers/hmsStates.js.map +1 -1
  250. package/lib/commonjs/redux/reducers/userState.js +3 -1
  251. package/lib/commonjs/redux/reducers/userState.js.map +1 -1
  252. package/lib/commonjs/utils/functions.js +51 -1
  253. package/lib/commonjs/utils/functions.js.map +1 -1
  254. package/lib/commonjs/utils/theme.js +63 -8
  255. package/lib/commonjs/utils/theme.js.map +1 -1
  256. package/lib/commonjs/utils/types.js +8 -2
  257. package/lib/commonjs/utils/types.js.map +1 -1
  258. package/lib/commonjs/utils.js +2 -2
  259. package/lib/commonjs/utils.js.map +1 -1
  260. package/lib/module/HMSInstanceSetup.js +3 -15
  261. package/lib/module/HMSInstanceSetup.js.map +1 -1
  262. package/lib/module/HMSPrebuilt.js +17 -5
  263. package/lib/module/HMSPrebuilt.js.map +1 -1
  264. package/lib/module/HMSRoomSetup.js +81 -26
  265. package/lib/module/HMSRoomSetup.js.map +1 -1
  266. package/lib/module/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  267. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  268. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  269. package/lib/module/Icons/AlertTriangle/index.js +26 -0
  270. package/lib/module/Icons/AlertTriangle/index.js.map +1 -0
  271. package/lib/module/Icons/AnswerPhone/index.js +5 -1
  272. package/lib/module/Icons/AnswerPhone/index.js.map +1 -1
  273. package/lib/module/Icons/BRB/assets/BRB.png +0 -0
  274. package/lib/module/Icons/BRB/assets/BRB@2x.png +0 -0
  275. package/lib/module/Icons/BRB/assets/BRB@3x.png +0 -0
  276. package/lib/module/Icons/BRB/index.js +27 -0
  277. package/lib/module/Icons/BRB/index.js.map +1 -0
  278. package/lib/module/Icons/Bluetooth/index.js +5 -1
  279. package/lib/module/Icons/Bluetooth/index.js.map +1 -1
  280. package/lib/module/Icons/Camera/index.js +5 -1
  281. package/lib/module/Icons/Camera/index.js.map +1 -1
  282. package/lib/module/Icons/Chat/index.js +5 -1
  283. package/lib/module/Icons/Chat/index.js.map +1 -1
  284. package/lib/module/Icons/Check/assets/check.png +0 -0
  285. package/lib/module/Icons/Check/assets/check@2x.png +0 -0
  286. package/lib/module/Icons/Check/assets/check@3x.png +0 -0
  287. package/lib/module/Icons/Check/index.js +26 -0
  288. package/lib/module/Icons/Check/index.js.map +1 -0
  289. package/lib/module/Icons/Chevron/index.js +5 -1
  290. package/lib/module/Icons/Chevron/index.js.map +1 -1
  291. package/lib/module/Icons/Close/index.js +5 -1
  292. package/lib/module/Icons/Close/index.js.map +1 -1
  293. package/lib/module/Icons/Hamburger/assets/hamburger.png +0 -0
  294. package/lib/module/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  295. package/lib/module/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  296. package/lib/module/Icons/Hamburger/index.js +26 -0
  297. package/lib/module/Icons/Hamburger/index.js.map +1 -0
  298. package/lib/module/Icons/Hand/index.js +6 -4
  299. package/lib/module/Icons/Hand/index.js.map +1 -1
  300. package/lib/module/Icons/Headphones/index.js +5 -1
  301. package/lib/module/Icons/Headphones/index.js.map +1 -1
  302. package/lib/module/Icons/Maximize/assets/maximize.png +0 -0
  303. package/lib/module/Icons/Maximize/assets/maximize@2x.png +0 -0
  304. package/lib/module/Icons/Maximize/assets/maximize@3x.png +0 -0
  305. package/lib/module/Icons/Maximize/index.js +26 -0
  306. package/lib/module/Icons/Maximize/index.js.map +1 -0
  307. package/lib/module/Icons/Mic/index.js +5 -1
  308. package/lib/module/Icons/Mic/index.js.map +1 -1
  309. package/lib/module/Icons/Minimize/assets/minimize.png +0 -0
  310. package/lib/module/Icons/Minimize/assets/minimize@2x.png +0 -0
  311. package/lib/module/Icons/Minimize/assets/minimize@3x.png +0 -0
  312. package/lib/module/Icons/Minimize/index.js +26 -0
  313. package/lib/module/Icons/Minimize/index.js.map +1 -0
  314. package/lib/module/Icons/Participants/index.js +5 -1
  315. package/lib/module/Icons/Participants/index.js.map +1 -1
  316. package/lib/module/Icons/Pencil/assets/pencil.png +0 -0
  317. package/lib/module/Icons/Pencil/assets/pencil@2x.png +0 -0
  318. package/lib/module/Icons/Pencil/assets/pencil@3x.png +0 -0
  319. package/lib/module/Icons/Pencil/index.js +26 -0
  320. package/lib/module/Icons/Pencil/index.js.map +1 -0
  321. package/lib/module/Icons/Pin/assets/pin.png +0 -0
  322. package/lib/module/Icons/Pin/assets/pin@2x.png +0 -0
  323. package/lib/module/Icons/Pin/assets/pin@3x.png +0 -0
  324. package/lib/module/Icons/Pin/index.js +26 -0
  325. package/lib/module/Icons/Pin/index.js.map +1 -0
  326. package/lib/module/Icons/Radio/assets/radio.png +0 -0
  327. package/lib/module/Icons/Radio/assets/radio@2x.png +0 -0
  328. package/lib/module/Icons/Radio/assets/radio@3x.png +0 -0
  329. package/lib/module/Icons/Radio/index.js +22 -0
  330. package/lib/module/Icons/Radio/index.js.map +1 -0
  331. package/lib/module/Icons/Recording/assets/recording.png +0 -0
  332. package/lib/module/Icons/Recording/assets/recording@2x.png +0 -0
  333. package/lib/module/Icons/Recording/assets/recording@3x.png +0 -0
  334. package/lib/module/Icons/Recording/index.js +26 -0
  335. package/lib/module/Icons/Recording/index.js.map +1 -0
  336. package/lib/module/Icons/RotateCamera/index.js +5 -1
  337. package/lib/module/Icons/RotateCamera/index.js.map +1 -1
  338. package/lib/module/Icons/ScreenShare/index.js +5 -1
  339. package/lib/module/Icons/ScreenShare/index.js.map +1 -1
  340. package/lib/module/Icons/Speaker/index.js +5 -1
  341. package/lib/module/Icons/Speaker/index.js.map +1 -1
  342. package/lib/module/Icons/Star/assets/star.png +0 -0
  343. package/lib/module/Icons/Star/assets/star@2x.png +0 -0
  344. package/lib/module/Icons/Star/assets/star@3x.png +0 -0
  345. package/lib/module/Icons/Star/index.js +26 -0
  346. package/lib/module/Icons/Star/index.js.map +1 -0
  347. package/lib/module/Icons/Stop/assets/stop.png +0 -0
  348. package/lib/module/Icons/Stop/assets/stop@2x.png +0 -0
  349. package/lib/module/Icons/Stop/assets/stop@3x.png +0 -0
  350. package/lib/module/Icons/Stop/index.js +26 -0
  351. package/lib/module/Icons/Stop/index.js.map +1 -0
  352. package/lib/module/Icons/ThreeDots/index.js +5 -1
  353. package/lib/module/Icons/ThreeDots/index.js.map +1 -1
  354. package/lib/module/Icons/Wave/index.js +5 -1
  355. package/lib/module/Icons/Wave/index.js.map +1 -1
  356. package/lib/module/Icons/index.js +12 -0
  357. package/lib/module/Icons/index.js.map +1 -1
  358. package/lib/module/components/AvatarView.js +1 -2
  359. package/lib/module/components/AvatarView.js.map +1 -1
  360. package/lib/module/components/BackButton.js +9 -7
  361. package/lib/module/components/BackButton.js.map +1 -1
  362. package/lib/module/components/BottomSheet.js +146 -0
  363. package/lib/module/components/BottomSheet.js.map +1 -0
  364. package/lib/module/components/ChangeNameModalContent.js +122 -0
  365. package/lib/module/components/ChangeNameModalContent.js.map +1 -0
  366. package/lib/module/components/CompanyLogo.js +30 -0
  367. package/lib/module/components/CompanyLogo.js.map +1 -0
  368. package/lib/module/components/CustomInput.js +2 -3
  369. package/lib/module/components/CustomInput.js.map +1 -1
  370. package/lib/module/components/DisplayView.js +16 -61
  371. package/lib/module/components/DisplayView.js.map +1 -1
  372. package/lib/module/components/EndRoomModalContent.js +76 -0
  373. package/lib/module/components/EndRoomModalContent.js.map +1 -0
  374. package/lib/module/components/Footer.js +9 -10
  375. package/lib/module/components/Footer.js.map +1 -1
  376. package/lib/module/components/GridView.js +55 -10
  377. package/lib/module/components/GridView.js.map +1 -1
  378. package/lib/module/components/HMSBaseButton.js +57 -0
  379. package/lib/module/components/HMSBaseButton.js.map +1 -0
  380. package/lib/module/components/HMSDangerButton.js +44 -0
  381. package/lib/module/components/HMSDangerButton.js.map +1 -0
  382. package/lib/module/components/HMSHLSStreamLoading.js +56 -0
  383. package/lib/module/components/HMSHLSStreamLoading.js.map +1 -0
  384. package/lib/module/components/HMSLocalVideoView.js +32 -0
  385. package/lib/module/components/HMSLocalVideoView.js.map +1 -0
  386. package/lib/module/components/{HMSSpeakerSettings.js → HMSManageAudioOutput.js} +70 -77
  387. package/lib/module/components/HMSManageAudioOutput.js.map +1 -0
  388. package/lib/module/components/HMSManageCameraRotation.js +5 -4
  389. package/lib/module/components/HMSManageCameraRotation.js.map +1 -1
  390. package/lib/module/components/HMSManageLeave.js +95 -161
  391. package/lib/module/components/HMSManageLeave.js.map +1 -1
  392. package/lib/module/components/HMSManageLocalAudio.js +1 -9
  393. package/lib/module/components/HMSManageLocalAudio.js.map +1 -1
  394. package/lib/module/components/HMSManageLocalVideo.js +1 -9
  395. package/lib/module/components/HMSManageLocalVideo.js.map +1 -1
  396. package/lib/module/components/HMSMeetingEnded.js +26 -0
  397. package/lib/module/components/HMSMeetingEnded.js.map +1 -0
  398. package/lib/module/components/HMSPreviewEditName.js +7 -38
  399. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  400. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +62 -0
  401. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -0
  402. package/lib/module/components/HMSPreviewJoinButton.js +28 -39
  403. package/lib/module/components/HMSPreviewJoinButton.js.map +1 -1
  404. package/lib/module/components/HMSPreviewNetworkQuality.js +36 -0
  405. package/lib/module/components/HMSPreviewNetworkQuality.js.map +1 -0
  406. package/lib/module/components/HMSPreviewPeersList.js +21 -33
  407. package/lib/module/components/HMSPreviewPeersList.js.map +1 -1
  408. package/lib/module/components/HMSPreviewSubtitle.js +43 -7
  409. package/lib/module/components/HMSPreviewSubtitle.js.map +1 -1
  410. package/lib/module/components/HMSPreviewTile.js +18 -26
  411. package/lib/module/components/HMSPreviewTile.js.map +1 -1
  412. package/lib/module/components/HMSPreviewTitle.js +14 -6
  413. package/lib/module/components/HMSPreviewTitle.js.map +1 -1
  414. package/lib/module/components/HMSPrimaryButton.js +44 -0
  415. package/lib/module/components/HMSPrimaryButton.js.map +1 -0
  416. package/lib/module/components/HMSRecordingIndicator.js +37 -0
  417. package/lib/module/components/HMSRecordingIndicator.js.map +1 -0
  418. package/lib/module/components/HMSRoomOptions.js +23 -11
  419. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  420. package/lib/module/components/HMSShowNetworkQuality.js +6 -7
  421. package/lib/module/components/HMSShowNetworkQuality.js.map +1 -1
  422. package/lib/module/components/HMSTextInput.js +57 -0
  423. package/lib/module/components/HMSTextInput.js.map +1 -0
  424. package/lib/module/components/Header.js +32 -32
  425. package/lib/module/components/Header.js.map +1 -1
  426. package/lib/module/components/LocalPeerRegularVideoView.js +17 -0
  427. package/lib/module/components/LocalPeerRegularVideoView.js.map +1 -0
  428. package/lib/module/components/LocalPeerScreenshareView.js +66 -0
  429. package/lib/module/components/LocalPeerScreenshareView.js.map +1 -0
  430. package/lib/module/components/Meeting.js +15 -4
  431. package/lib/module/components/Meeting.js.map +1 -1
  432. package/lib/module/components/MenuModal/Menu.js +1 -2
  433. package/lib/module/components/MenuModal/Menu.js.map +1 -1
  434. package/lib/module/components/MiniView.js +154 -0
  435. package/lib/module/components/MiniView.js.map +1 -0
  436. package/lib/module/components/Modals.js +37 -378
  437. package/lib/module/components/Modals.js.map +1 -1
  438. package/lib/module/components/PaginationDots.js +47 -0
  439. package/lib/module/components/PaginationDots.js.map +1 -0
  440. package/lib/module/components/Participants/ParticipantsList.js +1 -20
  441. package/lib/module/components/Participants/ParticipantsList.js.map +1 -1
  442. package/lib/module/components/ParticipantsCount.js +46 -0
  443. package/lib/module/components/ParticipantsCount.js.map +1 -0
  444. package/lib/module/components/PeerMinimizedView.js +104 -0
  445. package/lib/module/components/PeerMinimizedView.js.map +1 -0
  446. package/lib/module/components/PeerSettingsModalContent.js +72 -66
  447. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  448. package/lib/module/components/PeerVideoTile/AvatarView.js +66 -0
  449. package/lib/module/components/PeerVideoTile/AvatarView.js.map +1 -0
  450. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js +35 -0
  451. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  452. package/lib/module/components/PeerVideoTile/PeerMetadata.js +35 -0
  453. package/lib/module/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  454. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js +65 -0
  455. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  456. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js +136 -0
  457. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  458. package/lib/module/components/PeerVideoTile/VideoView.js +75 -0
  459. package/lib/module/components/PeerVideoTile/VideoView.js.map +1 -0
  460. package/lib/module/components/PeerVideoTile/index.js +2 -0
  461. package/lib/module/components/PeerVideoTile/index.js.map +1 -0
  462. package/lib/module/components/PressableIcon.js +15 -8
  463. package/lib/module/components/PressableIcon.js.map +1 -1
  464. package/lib/module/components/Preview.js +93 -72
  465. package/lib/module/components/Preview.js.map +1 -1
  466. package/lib/module/components/RoomSettingsModalContent.js +231 -459
  467. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  468. package/lib/module/components/RoomSettingsModalDebugModeContent.js +287 -0
  469. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  470. package/lib/module/components/StopRecordingModalContent.js +88 -0
  471. package/lib/module/components/StopRecordingModalContent.js.map +1 -0
  472. package/lib/module/components/Tile.js +30 -91
  473. package/lib/module/components/Tile.js.map +1 -1
  474. package/lib/module/components/TilesContainer.js +100 -10
  475. package/lib/module/components/TilesContainer.js.map +1 -1
  476. package/lib/module/components/UnmountAfterDelay.js +39 -0
  477. package/lib/module/components/UnmountAfterDelay.js.map +1 -0
  478. package/lib/module/components/WebrtcView.js +41 -0
  479. package/lib/module/components/WebrtcView.js.map +1 -0
  480. package/lib/module/components/WelcomeInMeeting.js +45 -0
  481. package/lib/module/components/WelcomeInMeeting.js.map +1 -0
  482. package/lib/module/components/index.js +0 -1
  483. package/lib/module/components/index.js.map +1 -1
  484. package/lib/module/hooks/useHmsInstance.js +0 -1
  485. package/lib/module/hooks/useHmsInstance.js.map +1 -1
  486. package/lib/module/hooks-sdk-selectors.js +4 -0
  487. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  488. package/lib/module/hooks-sdk.js +16 -1
  489. package/lib/module/hooks-sdk.js.map +1 -1
  490. package/lib/module/hooks-util-selectors.js +12 -0
  491. package/lib/module/hooks-util-selectors.js.map +1 -1
  492. package/lib/module/hooks-util.js +417 -104
  493. package/lib/module/hooks-util.js.map +1 -1
  494. package/lib/module/modules/HMSManager.js +17 -0
  495. package/lib/module/modules/HMSManager.js.map +1 -0
  496. package/lib/module/modules/parser.js +16 -0
  497. package/lib/module/modules/parser.js.map +1 -0
  498. package/lib/module/peerTrackNodeUtils.js +6 -2
  499. package/lib/module/peerTrackNodeUtils.js.map +1 -1
  500. package/lib/module/redux/actionTypes.js +20 -1
  501. package/lib/module/redux/actionTypes.js.map +1 -1
  502. package/lib/module/redux/actions/index.js +54 -0
  503. package/lib/module/redux/actions/index.js.map +1 -1
  504. package/lib/module/redux/reducers/appState.js +70 -1
  505. package/lib/module/redux/reducers/appState.js.map +1 -1
  506. package/lib/module/redux/reducers/hmsStates.js +7 -1
  507. package/lib/module/redux/reducers/hmsStates.js.map +1 -1
  508. package/lib/module/redux/reducers/userState.js +3 -1
  509. package/lib/module/redux/reducers/userState.js.map +1 -1
  510. package/lib/module/utils/functions.js +47 -0
  511. package/lib/module/utils/functions.js.map +1 -1
  512. package/lib/module/utils/theme.js +58 -5
  513. package/lib/module/utils/theme.js.map +1 -1
  514. package/lib/module/utils/types.js +6 -1
  515. package/lib/module/utils/types.js.map +1 -1
  516. package/lib/module/utils.js +2 -2
  517. package/lib/module/utils.js.map +1 -1
  518. package/lib/typescript/HMSInstanceSetup.d.ts.map +1 -1
  519. package/lib/typescript/HMSPrebuilt.d.ts +3 -3
  520. package/lib/typescript/HMSPrebuilt.d.ts.map +1 -1
  521. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  522. package/lib/typescript/Icons/AlertTriangle/index.d.ts +7 -0
  523. package/lib/typescript/Icons/AlertTriangle/index.d.ts.map +1 -0
  524. package/lib/typescript/Icons/AnswerPhone/index.d.ts.map +1 -1
  525. package/lib/typescript/Icons/BRB/index.d.ts +7 -0
  526. package/lib/typescript/Icons/BRB/index.d.ts.map +1 -0
  527. package/lib/typescript/Icons/Bluetooth/index.d.ts.map +1 -1
  528. package/lib/typescript/Icons/Camera/index.d.ts.map +1 -1
  529. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  530. package/lib/typescript/Icons/Check/index.d.ts +7 -0
  531. package/lib/typescript/Icons/Check/index.d.ts.map +1 -0
  532. package/lib/typescript/Icons/Chevron/index.d.ts.map +1 -1
  533. package/lib/typescript/Icons/Close/index.d.ts.map +1 -1
  534. package/lib/typescript/Icons/Hamburger/index.d.ts +7 -0
  535. package/lib/typescript/Icons/Hamburger/index.d.ts.map +1 -0
  536. package/lib/typescript/Icons/Hand/index.d.ts.map +1 -1
  537. package/lib/typescript/Icons/Headphones/index.d.ts.map +1 -1
  538. package/lib/typescript/Icons/Maximize/index.d.ts +7 -0
  539. package/lib/typescript/Icons/Maximize/index.d.ts.map +1 -0
  540. package/lib/typescript/Icons/Mic/index.d.ts.map +1 -1
  541. package/lib/typescript/Icons/Minimize/index.d.ts +7 -0
  542. package/lib/typescript/Icons/Minimize/index.d.ts.map +1 -0
  543. package/lib/typescript/Icons/Participants/index.d.ts.map +1 -1
  544. package/lib/typescript/Icons/Pencil/index.d.ts +7 -0
  545. package/lib/typescript/Icons/Pencil/index.d.ts.map +1 -0
  546. package/lib/typescript/Icons/Pin/index.d.ts +7 -0
  547. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -0
  548. package/lib/typescript/Icons/Radio/index.d.ts +7 -0
  549. package/lib/typescript/Icons/Radio/index.d.ts.map +1 -0
  550. package/lib/typescript/Icons/Recording/index.d.ts +7 -0
  551. package/lib/typescript/Icons/Recording/index.d.ts.map +1 -0
  552. package/lib/typescript/Icons/RotateCamera/index.d.ts.map +1 -1
  553. package/lib/typescript/Icons/ScreenShare/index.d.ts.map +1 -1
  554. package/lib/typescript/Icons/Speaker/index.d.ts.map +1 -1
  555. package/lib/typescript/Icons/Star/index.d.ts +7 -0
  556. package/lib/typescript/Icons/Star/index.d.ts.map +1 -0
  557. package/lib/typescript/Icons/Stop/index.d.ts +7 -0
  558. package/lib/typescript/Icons/Stop/index.d.ts.map +1 -0
  559. package/lib/typescript/Icons/ThreeDots/index.d.ts.map +1 -1
  560. package/lib/typescript/Icons/Wave/index.d.ts.map +1 -1
  561. package/lib/typescript/Icons/index.d.ts +12 -0
  562. package/lib/typescript/Icons/index.d.ts.map +1 -1
  563. package/lib/typescript/components/BackButton.d.ts.map +1 -1
  564. package/lib/typescript/components/BottomSheet.d.ts +25 -0
  565. package/lib/typescript/components/BottomSheet.d.ts.map +1 -0
  566. package/lib/typescript/components/ChangeNameModalContent.d.ts +6 -0
  567. package/lib/typescript/components/ChangeNameModalContent.d.ts.map +1 -0
  568. package/lib/typescript/components/CompanyLogo.d.ts +7 -0
  569. package/lib/typescript/components/CompanyLogo.d.ts.map +1 -0
  570. package/lib/typescript/components/CustomInput.d.ts +1 -1
  571. package/lib/typescript/components/CustomInput.d.ts.map +1 -1
  572. package/lib/typescript/components/DisplayView.d.ts.map +1 -1
  573. package/lib/typescript/components/EndRoomModalContent.d.ts +6 -0
  574. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -0
  575. package/lib/typescript/components/Footer.d.ts.map +1 -1
  576. package/lib/typescript/components/GridView.d.ts +3 -4
  577. package/lib/typescript/components/GridView.d.ts.map +1 -1
  578. package/lib/typescript/components/HMSBaseButton.d.ts +15 -0
  579. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -0
  580. package/lib/typescript/components/HMSDangerButton.d.ts +12 -0
  581. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -0
  582. package/lib/typescript/components/HMSHLSStreamLoading.d.ts +3 -0
  583. package/lib/typescript/components/HMSHLSStreamLoading.d.ts.map +1 -0
  584. package/lib/typescript/components/HMSLocalVideoView.d.ts +3 -0
  585. package/lib/typescript/components/HMSLocalVideoView.d.ts.map +1 -0
  586. package/lib/typescript/components/HMSManageAudioOutput.d.ts +3 -0
  587. package/lib/typescript/components/HMSManageAudioOutput.d.ts.map +1 -0
  588. package/lib/typescript/components/HMSManageLeave.d.ts.map +1 -1
  589. package/lib/typescript/components/HMSManageLocalAudio.d.ts.map +1 -1
  590. package/lib/typescript/components/HMSManageLocalVideo.d.ts.map +1 -1
  591. package/lib/typescript/components/HMSMeetingEnded.d.ts +3 -0
  592. package/lib/typescript/components/HMSMeetingEnded.d.ts.map +1 -0
  593. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  594. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts +3 -0
  595. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -0
  596. package/lib/typescript/components/HMSPreviewJoinButton.d.ts.map +1 -1
  597. package/lib/typescript/components/HMSPreviewNetworkQuality.d.ts +3 -0
  598. package/lib/typescript/components/HMSPreviewNetworkQuality.d.ts.map +1 -0
  599. package/lib/typescript/components/HMSPreviewPeersList.d.ts.map +1 -1
  600. package/lib/typescript/components/HMSPreviewSubtitle.d.ts.map +1 -1
  601. package/lib/typescript/components/HMSPreviewTile.d.ts.map +1 -1
  602. package/lib/typescript/components/HMSPreviewTitle.d.ts.map +1 -1
  603. package/lib/typescript/components/HMSPrimaryButton.d.ts +12 -0
  604. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -0
  605. package/lib/typescript/components/HMSRecordingIndicator.d.ts +3 -0
  606. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -0
  607. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  608. package/lib/typescript/components/HMSShowNetworkQuality.d.ts.map +1 -1
  609. package/lib/typescript/components/HMSTextInput.d.ts +10 -0
  610. package/lib/typescript/components/HMSTextInput.d.ts.map +1 -0
  611. package/lib/typescript/components/Header.d.ts.map +1 -1
  612. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts +6 -0
  613. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts.map +1 -0
  614. package/lib/typescript/components/LocalPeerScreenshareView.d.ts +3 -0
  615. package/lib/typescript/components/LocalPeerScreenshareView.d.ts.map +1 -0
  616. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  617. package/lib/typescript/components/MenuModal/Menu.d.ts.map +1 -1
  618. package/lib/typescript/components/MiniView.d.ts +9 -0
  619. package/lib/typescript/components/MiniView.d.ts.map +1 -0
  620. package/lib/typescript/components/Modals.d.ts +1 -16
  621. package/lib/typescript/components/Modals.d.ts.map +1 -1
  622. package/lib/typescript/components/PaginationDots.d.ts +6 -0
  623. package/lib/typescript/components/PaginationDots.d.ts.map +1 -0
  624. package/lib/typescript/components/Participants/ParticipantsList.d.ts.map +1 -1
  625. package/lib/typescript/components/ParticipantsCount.d.ts +3 -0
  626. package/lib/typescript/components/ParticipantsCount.d.ts.map +1 -0
  627. package/lib/typescript/components/PeerMinimizedView.d.ts +12 -0
  628. package/lib/typescript/components/PeerMinimizedView.d.ts.map +1 -0
  629. package/lib/typescript/components/PeerSettingsModalContent.d.ts +1 -0
  630. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  631. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts +9 -0
  632. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts.map +1 -0
  633. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts +6 -0
  634. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts.map +1 -0
  635. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts +6 -0
  636. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts.map +1 -0
  637. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts +10 -0
  638. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts.map +1 -0
  639. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts +10 -0
  640. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -0
  641. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts +13 -0
  642. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts.map +1 -0
  643. package/lib/typescript/components/PeerVideoTile/index.d.ts +1 -0
  644. package/lib/typescript/components/PeerVideoTile/index.d.ts.map +1 -0
  645. package/lib/typescript/components/PressableIcon.d.ts.map +1 -1
  646. package/lib/typescript/components/Preview.d.ts.map +1 -1
  647. package/lib/typescript/components/RoomSettingsModalContent.d.ts +2 -2
  648. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  649. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts +17 -0
  650. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -0
  651. package/lib/typescript/components/StopRecordingModalContent.d.ts +6 -0
  652. package/lib/typescript/components/StopRecordingModalContent.d.ts.map +1 -0
  653. package/lib/typescript/components/Tile.d.ts +12 -3
  654. package/lib/typescript/components/Tile.d.ts.map +1 -1
  655. package/lib/typescript/components/TilesContainer.d.ts.map +1 -1
  656. package/lib/typescript/components/UnmountAfterDelay.d.ts +12 -0
  657. package/lib/typescript/components/UnmountAfterDelay.d.ts.map +1 -0
  658. package/lib/typescript/components/WebrtcView.d.ts +10 -0
  659. package/lib/typescript/components/WebrtcView.d.ts.map +1 -0
  660. package/lib/typescript/components/WelcomeInMeeting.d.ts +5 -0
  661. package/lib/typescript/components/WelcomeInMeeting.d.ts.map +1 -0
  662. package/lib/typescript/components/index.d.ts +0 -1
  663. package/lib/typescript/components/index.d.ts.map +1 -1
  664. package/lib/typescript/hooks-sdk-selectors.d.ts +2 -0
  665. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  666. package/lib/typescript/hooks-sdk.d.ts +1 -0
  667. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  668. package/lib/typescript/hooks-util-selectors.d.ts +2 -0
  669. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  670. package/lib/typescript/hooks-util.d.ts +24 -4
  671. package/lib/typescript/hooks-util.d.ts.map +1 -1
  672. package/lib/typescript/modules/HMSManager.d.ts +4 -0
  673. package/lib/typescript/modules/HMSManager.d.ts.map +1 -0
  674. package/lib/typescript/modules/parser.d.ts +3 -0
  675. package/lib/typescript/modules/parser.d.ts.map +1 -0
  676. package/lib/typescript/peerTrackNodeUtils.d.ts +1 -0
  677. package/lib/typescript/peerTrackNodeUtils.d.ts.map +1 -1
  678. package/lib/typescript/redux/actionTypes.d.ts +11 -1
  679. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  680. package/lib/typescript/redux/actions/index.d.ts +61 -3
  681. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  682. package/lib/typescript/redux/index.d.ts +10 -1
  683. package/lib/typescript/redux/index.d.ts.map +1 -1
  684. package/lib/typescript/redux/reducers/appState.d.ts +8 -0
  685. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  686. package/lib/typescript/redux/reducers/hmsStates.d.ts +7 -1
  687. package/lib/typescript/redux/reducers/hmsStates.d.ts.map +1 -1
  688. package/lib/typescript/redux/reducers/index.d.ts +10 -1
  689. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  690. package/lib/typescript/redux/reducers/userState.d.ts +3 -2
  691. package/lib/typescript/redux/reducers/userState.d.ts.map +1 -1
  692. package/lib/typescript/utils/functions.d.ts +14 -0
  693. package/lib/typescript/utils/functions.d.ts.map +1 -1
  694. package/lib/typescript/utils/theme.d.ts +7 -3
  695. package/lib/typescript/utils/theme.d.ts.map +1 -1
  696. package/lib/typescript/utils/types.d.ts +8 -4
  697. package/lib/typescript/utils/types.d.ts.map +1 -1
  698. package/package.json +11 -16
  699. package/src/HMSInstanceSetup.tsx +5 -31
  700. package/src/HMSPrebuilt.tsx +27 -8
  701. package/src/HMSRoomSetup.tsx +98 -23
  702. package/src/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  703. package/src/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  704. package/src/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  705. package/src/Icons/AlertTriangle/index.tsx +33 -0
  706. package/src/Icons/AnswerPhone/index.tsx +7 -1
  707. package/src/Icons/BRB/assets/BRB.png +0 -0
  708. package/src/Icons/BRB/assets/BRB@2x.png +0 -0
  709. package/src/Icons/BRB/assets/BRB@3x.png +0 -0
  710. package/src/Icons/BRB/index.tsx +31 -0
  711. package/src/Icons/Bluetooth/index.tsx +7 -1
  712. package/src/Icons/Camera/index.tsx +7 -1
  713. package/src/Icons/Chat/index.tsx +7 -1
  714. package/src/Icons/Check/assets/check.png +0 -0
  715. package/src/Icons/Check/assets/check@2x.png +0 -0
  716. package/src/Icons/Check/assets/check@3x.png +0 -0
  717. package/src/Icons/Check/index.tsx +33 -0
  718. package/src/Icons/Chevron/index.tsx +7 -1
  719. package/src/Icons/Close/index.tsx +7 -1
  720. package/src/Icons/Hamburger/assets/hamburger.png +0 -0
  721. package/src/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  722. package/src/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  723. package/src/Icons/Hamburger/index.tsx +33 -0
  724. package/src/Icons/Hand/index.tsx +6 -3
  725. package/src/Icons/Headphones/index.tsx +7 -1
  726. package/src/Icons/Maximize/assets/maximize.png +0 -0
  727. package/src/Icons/Maximize/assets/maximize@2x.png +0 -0
  728. package/src/Icons/Maximize/assets/maximize@3x.png +0 -0
  729. package/src/Icons/Maximize/index.tsx +33 -0
  730. package/src/Icons/Mic/index.tsx +7 -1
  731. package/src/Icons/Minimize/assets/minimize.png +0 -0
  732. package/src/Icons/Minimize/assets/minimize@2x.png +0 -0
  733. package/src/Icons/Minimize/assets/minimize@3x.png +0 -0
  734. package/src/Icons/Minimize/index.tsx +33 -0
  735. package/src/Icons/Participants/index.tsx +7 -1
  736. package/src/Icons/Pencil/assets/pencil.png +0 -0
  737. package/src/Icons/Pencil/assets/pencil@2x.png +0 -0
  738. package/src/Icons/Pencil/assets/pencil@3x.png +0 -0
  739. package/src/Icons/Pencil/index.tsx +33 -0
  740. package/src/Icons/Pin/assets/pin.png +0 -0
  741. package/src/Icons/Pin/assets/pin@2x.png +0 -0
  742. package/src/Icons/Pin/assets/pin@3x.png +0 -0
  743. package/src/Icons/Pin/index.tsx +30 -0
  744. package/src/Icons/Radio/assets/radio.png +0 -0
  745. package/src/Icons/Radio/assets/radio@2x.png +0 -0
  746. package/src/Icons/Radio/assets/radio@3x.png +0 -0
  747. package/src/Icons/Radio/index.tsx +27 -0
  748. package/src/Icons/Recording/assets/recording.png +0 -0
  749. package/src/Icons/Recording/assets/recording@2x.png +0 -0
  750. package/src/Icons/Recording/assets/recording@3x.png +0 -0
  751. package/src/Icons/Recording/index.tsx +33 -0
  752. package/src/Icons/RotateCamera/index.tsx +7 -1
  753. package/src/Icons/ScreenShare/index.tsx +7 -1
  754. package/src/Icons/Speaker/index.tsx +12 -1
  755. package/src/Icons/Star/assets/star.png +0 -0
  756. package/src/Icons/Star/assets/star@2x.png +0 -0
  757. package/src/Icons/Star/assets/star@3x.png +0 -0
  758. package/src/Icons/Star/index.tsx +30 -0
  759. package/src/Icons/Stop/assets/stop.png +0 -0
  760. package/src/Icons/Stop/assets/stop@2x.png +0 -0
  761. package/src/Icons/Stop/assets/stop@3x.png +0 -0
  762. package/src/Icons/Stop/index.tsx +33 -0
  763. package/src/Icons/ThreeDots/index.tsx +7 -1
  764. package/src/Icons/Wave/index.tsx +7 -1
  765. package/src/Icons/index.ts +12 -0
  766. package/src/components/AvatarView.tsx +1 -2
  767. package/src/components/BackButton.tsx +9 -6
  768. package/src/components/BottomSheet.tsx +191 -0
  769. package/src/components/ChangeNameModalContent.tsx +157 -0
  770. package/src/components/CompanyLogo.tsx +35 -0
  771. package/src/components/CustomInput.tsx +2 -3
  772. package/src/components/DisplayView.tsx +16 -75
  773. package/src/components/EndRoomModalContent.tsx +90 -0
  774. package/src/components/Footer.tsx +7 -7
  775. package/src/components/GridView.tsx +91 -20
  776. package/src/components/HLSView.tsx +1 -1
  777. package/src/components/HMSBaseButton.tsx +91 -0
  778. package/src/components/HMSDangerButton.tsx +65 -0
  779. package/src/components/HMSHLSStreamLoading.tsx +68 -0
  780. package/src/components/HMSLocalVideoView.tsx +42 -0
  781. package/src/components/{HMSSpeakerSettings.tsx → HMSManageAudioOutput.tsx} +99 -78
  782. package/src/components/HMSManageCameraRotation.tsx +11 -8
  783. package/src/components/HMSManageLeave.tsx +107 -183
  784. package/src/components/HMSManageLocalAudio.tsx +1 -10
  785. package/src/components/HMSManageLocalVideo.tsx +1 -10
  786. package/src/components/HMSMeetingEnded.tsx +28 -0
  787. package/src/components/HMSPreviewEditName.tsx +4 -45
  788. package/src/components/HMSPreviewHLSLiveIndicator.tsx +66 -0
  789. package/src/components/HMSPreviewJoinButton.tsx +36 -51
  790. package/src/components/HMSPreviewNetworkQuality.tsx +43 -0
  791. package/src/components/HMSPreviewPeersList.tsx +25 -54
  792. package/src/components/HMSPreviewSubtitle.tsx +46 -6
  793. package/src/components/HMSPreviewTile.tsx +20 -31
  794. package/src/components/HMSPreviewTitle.tsx +18 -5
  795. package/src/components/HMSPrimaryButton.tsx +63 -0
  796. package/src/components/HMSRecordingIndicator.tsx +37 -0
  797. package/src/components/HMSRoomOptions.tsx +30 -16
  798. package/src/components/HMSShowNetworkQuality.tsx +7 -6
  799. package/src/components/HMSTextInput.tsx +78 -0
  800. package/src/components/Header.tsx +37 -36
  801. package/src/components/LocalPeerRegularVideoView.tsx +28 -0
  802. package/src/components/LocalPeerScreenshareView.tsx +72 -0
  803. package/src/components/Meeting.tsx +21 -3
  804. package/src/components/MenuModal/Menu.tsx +1 -1
  805. package/src/components/MiniView.tsx +213 -0
  806. package/src/components/Modals.tsx +5 -409
  807. package/src/components/PaginationDots.tsx +65 -0
  808. package/src/components/Participants/ParticipantsList.tsx +0 -24
  809. package/src/components/ParticipantsCount.tsx +52 -0
  810. package/src/components/PeerMinimizedView.tsx +131 -0
  811. package/src/components/PeerSettingsModalContent.tsx +108 -66
  812. package/src/components/PeerVideoTile/AvatarView.tsx +79 -0
  813. package/src/components/PeerVideoTile/PeerAudioMutedIndicator.tsx +41 -0
  814. package/src/components/PeerVideoTile/PeerMetadata.tsx +46 -0
  815. package/src/components/PeerVideoTile/PeerNameAndNetwork.tsx +81 -0
  816. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +180 -0
  817. package/src/components/PeerVideoTile/VideoView.tsx +104 -0
  818. package/src/components/PeerVideoTile/index.ts +0 -0
  819. package/src/components/PressableIcon.tsx +15 -8
  820. package/src/components/Preview.tsx +150 -104
  821. package/src/components/RoomSettingsModalContent.tsx +234 -659
  822. package/src/components/RoomSettingsModalDebugModeContent.tsx +446 -0
  823. package/src/components/StopRecordingModalContent.tsx +109 -0
  824. package/src/components/Tile.tsx +49 -90
  825. package/src/components/TilesContainer.tsx +116 -14
  826. package/src/components/UnmountAfterDelay.tsx +61 -0
  827. package/src/components/WebrtcView.tsx +72 -0
  828. package/src/components/WelcomeInMeeting.tsx +52 -0
  829. package/src/components/index.ts +0 -1
  830. package/src/hooks/useHmsInstance.ts +0 -1
  831. package/src/hooks-sdk-selectors.tsx +7 -0
  832. package/src/hooks-sdk.ts +18 -0
  833. package/src/hooks-util-selectors.tsx +21 -0
  834. package/src/hooks-util.ts +548 -130
  835. package/src/modules/HMSManager.ts +25 -0
  836. package/src/modules/parser.ts +22 -0
  837. package/src/peerTrackNodeUtils.tsx +13 -10
  838. package/src/redux/actionTypes.ts +28 -0
  839. package/src/redux/actions/index.ts +64 -2
  840. package/src/redux/reducers/appState.ts +65 -0
  841. package/src/redux/reducers/hmsStates.ts +15 -1
  842. package/src/redux/reducers/userState.ts +5 -2
  843. package/src/utils/functions.ts +48 -0
  844. package/src/utils/theme.ts +75 -5
  845. package/src/utils/types.ts +9 -4
  846. package/src/utils.ts +2 -2
  847. package/lib/commonjs/components/HMSSpeakerSettings.js.map +0 -1
  848. package/lib/commonjs/components/ZoomableView.js +0 -84
  849. package/lib/commonjs/components/ZoomableView.js.map +0 -1
  850. package/lib/module/components/HMSSpeakerSettings.js.map +0 -1
  851. package/lib/module/components/ZoomableView.js +0 -76
  852. package/lib/module/components/ZoomableView.js.map +0 -1
  853. package/lib/typescript/components/HMSSpeakerSettings.d.ts +0 -3
  854. package/lib/typescript/components/HMSSpeakerSettings.d.ts.map +0 -1
  855. package/lib/typescript/components/ZoomableView.d.ts +0 -6
  856. package/lib/typescript/components/ZoomableView.d.ts.map +0 -1
  857. package/src/components/ZoomableView.tsx +0 -91
@@ -1,6 +1,6 @@
1
- import React, { useEffect, useMemo, useRef, useState } from 'react';
1
+ import React, { useRef, useState } from 'react';
2
2
  import { useSelector } from 'react-redux';
3
- import { View, Text, InteractionManager } from 'react-native';
3
+ import { InteractionManager } from 'react-native';
4
4
  import { HMSTrack, HMSCameraControl } from '@100mslive/react-native-hms';
5
5
  import Animated, {
6
6
  interpolate,
@@ -12,20 +12,17 @@ import { styles } from './styles';
12
12
  import { DefaultModal } from './DefaultModal';
13
13
  import { ModalTypes, PipModes } from '../utils/types';
14
14
  import type { PeerTrackNode } from '../utils/types';
15
- import { pairData, requestExternalStoragePermission } from '../utils/functions';
15
+ import { requestExternalStoragePermission } from '../utils/functions';
16
16
  import {
17
17
  ChangeAspectRatio,
18
- ChangeNameModal,
19
18
  ChangeRoleAccepteModal,
20
19
  ChangeRoleModal,
21
20
  ChangeTrackStateModal,
22
- ChangeVolumeModal,
23
21
  SaveScreenshot,
24
22
  } from './Modals';
25
23
  import type { RootState } from '../redux';
26
24
  import { GridView } from './GridView';
27
25
  import { HLSView } from './HLSView';
28
- import PIPView from './PIPView';
29
26
  import { PeerSettingsModalContent } from '../components/PeerSettingsModalContent';
30
27
  import { StreamingQualityModalContent } from '../components/StreamingQualityModalContent';
31
28
  import {
@@ -36,8 +33,9 @@ import {
36
33
  useIsHLSViewer,
37
34
  useModalType,
38
35
  } from '../hooks-util';
39
- import { useIsPortraitOrientation } from '../utils/dimension';
40
36
  import { ParticipantsModal } from './ParticipantsModal';
37
+ import { WebrtcView } from './WebrtcView';
38
+ import { BottomSheet } from './BottomSheet';
41
39
 
42
40
  type CapturedImagePath = { uri: string } | null;
43
41
 
@@ -52,8 +50,6 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
52
50
  }) => {
53
51
  // --- 100ms SDK Instance ---
54
52
  const hmsInstance = useHMSInstance();
55
-
56
- const isPortrait = useIsPortraitOrientation();
57
53
  const isHLSViewer = useIsHLSViewer();
58
54
 
59
55
  const {
@@ -69,9 +65,6 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
69
65
  const isPipModeActive = useSelector(
70
66
  (state: RootState) => state.app.pipModeStatus === PipModes.ACTIVE
71
67
  );
72
- const spotlightTrackId = useSelector(
73
- (state: RootState) => state.user.spotlightTrackId
74
- ); // State to track active spotlight trackId
75
68
 
76
69
  // --- Component Local States ---
77
70
  const [selectedPeerTrackNode, setSelectedPeerTrackNode] =
@@ -79,14 +72,8 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
79
72
  const [capturedImagePath, setCapturedImagePath] =
80
73
  useState<CapturedImagePath>(null);
81
74
 
82
- // --- Constants ---
83
- const pairedPeers = useMemo(
84
- () => pairData(peerTrackNodes, isPortrait ? 4 : 2, spotlightTrackId),
85
- [peerTrackNodes, spotlightTrackId, isPortrait]
86
- );
87
-
88
75
  // --- Listeners ---
89
- useHMSSessionStoreListeners();
76
+ useHMSSessionStoreListeners(gridViewRef);
90
77
 
91
78
  const trackStateChangeRequest = useHMSChangeTrackStateRequest(() => {
92
79
  setModalVisible(ModalTypes.CHANGE_TRACK, true);
@@ -96,16 +83,6 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
96
83
  setModalVisible(ModalTypes.CHANGE_ROLE_ACCEPT, true);
97
84
  });
98
85
 
99
- // --- Effects ---
100
- useEffect(() => {
101
- // Scroll to start of the list
102
- if (spotlightTrackId) {
103
- gridViewRef.current
104
- ?.getFlatlistRef()
105
- .current?.scrollToOffset({ animated: true, offset: 0 });
106
- }
107
- }, [spotlightTrackId]);
108
-
109
86
  // functions
110
87
 
111
88
  const handlePeerTileMorePress = React.useCallback(
@@ -165,42 +142,24 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
165
142
  <Animated.View style={[styles.container, animatedStyles]}>
166
143
  {isHLSViewer ? (
167
144
  <HLSView />
168
- ) : pairedPeers.length > 0 ? (
169
- <>
170
- {isPipModeActive ? (
171
- <PIPView pairedPeers={pairedPeers} />
172
- ) : (
173
- <GridView
174
- ref={gridViewRef}
175
- onPeerTileMorePress={handlePeerTileMorePress}
176
- pairedPeers={pairedPeers}
177
- />
178
- )}
179
- </>
180
145
  ) : (
181
- <View style={styles.welcomeContainer}>
182
- <Text style={styles.welcomeHeading}>Welcome!</Text>
183
- <Text style={styles.welcomeDescription}>
184
- You're the first one here.
185
- </Text>
186
- <Text style={styles.welcomeDescription}>
187
- Sit back and relax till the others join.
188
- </Text>
189
- </View>
146
+ <WebrtcView
147
+ ref={gridViewRef}
148
+ peerTrackNodes={peerTrackNodes}
149
+ handlePeerTileMorePress={handlePeerTileMorePress}
150
+ />
190
151
  )}
191
152
 
192
153
  {isPipModeActive ? null : (
193
154
  <>
194
- <DefaultModal
195
- backdrop={true}
196
- modalPosiion="center"
197
- viewStyle={{ minWidth: '70%', width: undefined }}
198
- modalVisible={modalVisible === ModalTypes.PEER_SETTINGS}
199
- setModalVisible={() => setModalVisible(ModalTypes.DEFAULT)}
155
+ <BottomSheet
156
+ isVisible={modalVisible === ModalTypes.PEER_SETTINGS}
157
+ dismissModal={() => setModalVisible(ModalTypes.DEFAULT)}
200
158
  >
201
159
  {selectedPeerTrackNode ? (
202
160
  <PeerSettingsModalContent
203
161
  peerTrackNode={selectedPeerTrackNode}
162
+ peerTrackNodesListEmpty={peerTrackNodes.length === 0}
204
163
  cancelModal={() => setModalVisible(ModalTypes.DEFAULT)}
205
164
  onCaptureScreenShotPress={handleCaptureScreenShotPress}
206
165
  onCaptureImageAtMaxSupportedResolutionPress={
@@ -209,7 +168,7 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
209
168
  onStreamingQualityPress={handleStreamingQualityPress}
210
169
  />
211
170
  ) : null}
212
- </DefaultModal>
171
+ </BottomSheet>
213
172
 
214
173
  <DefaultModal
215
174
  modalPosiion="center"
@@ -289,24 +248,6 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
289
248
  cancelModal={() => setModalVisible(ModalTypes.DEFAULT)}
290
249
  />
291
250
  </DefaultModal>
292
- <DefaultModal
293
- modalPosiion="center"
294
- modalVisible={modalVisible === ModalTypes.VOLUME}
295
- setModalVisible={() => setModalVisible(ModalTypes.DEFAULT)}
296
- >
297
- <ChangeVolumeModal
298
- cancelModal={() => setModalVisible(ModalTypes.DEFAULT)}
299
- />
300
- </DefaultModal>
301
- <DefaultModal
302
- modalPosiion="center"
303
- modalVisible={modalVisible === ModalTypes.CHANGE_NAME}
304
- setModalVisible={() => setModalVisible(ModalTypes.DEFAULT)}
305
- >
306
- <ChangeNameModal
307
- cancelModal={() => setModalVisible(ModalTypes.DEFAULT)}
308
- />
309
- </DefaultModal>
310
251
  </>
311
252
  )}
312
253
  </Animated.View>
@@ -0,0 +1,90 @@
1
+ import * as React from 'react';
2
+ import { View, Text, StyleSheet, TouchableOpacity } from 'react-native';
3
+
4
+ import { useHMSRoomStyleSheet, useLeaveMethods } from '../hooks-util';
5
+ import { AlertTriangleIcon, CloseIcon } from '../Icons';
6
+ import { HMSDangerButton } from './HMSDangerButton';
7
+
8
+ export interface EndRoomModalContentProps {
9
+ dismissModal(): void;
10
+ }
11
+
12
+ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
13
+ dismissModal,
14
+ }) => {
15
+ const { endRoom } = useLeaveMethods();
16
+
17
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
18
+ headerText: {
19
+ color: theme.palette.alert_error_default,
20
+ fontFamily: `${typography.font_family}-SemiBold`,
21
+ },
22
+ text: {
23
+ color: theme.palette.on_surface_medium,
24
+ fontFamily: `${typography.font_family}-Regular`,
25
+ },
26
+ }));
27
+
28
+ return (
29
+ <View style={styles.container}>
30
+ <View style={styles.header}>
31
+ <View style={styles.headerControls}>
32
+ <AlertTriangleIcon />
33
+
34
+ <Text style={[styles.headerText, hmsRoomStyles.headerText]}>
35
+ End Session
36
+ </Text>
37
+ </View>
38
+
39
+ <TouchableOpacity
40
+ onPress={dismissModal}
41
+ hitSlop={styles.closeIconHitSlop}
42
+ >
43
+ <CloseIcon />
44
+ </TouchableOpacity>
45
+ </View>
46
+
47
+ <Text style={[styles.text, hmsRoomStyles.text]}>
48
+ The session will end for everyone and all the activities will stop. You
49
+ can't undo this action.
50
+ </Text>
51
+
52
+ <HMSDangerButton loading={false} onPress={endRoom} title="End Session" />
53
+ </View>
54
+ );
55
+ };
56
+
57
+ const styles = StyleSheet.create({
58
+ container: {
59
+ marginTop: 24,
60
+ marginHorizontal: 24,
61
+ },
62
+ header: {
63
+ flexDirection: 'row',
64
+ alignItems: 'center',
65
+ justifyContent: 'space-between',
66
+ marginBottom: 8,
67
+ },
68
+ headerControls: {
69
+ flexDirection: 'row',
70
+ alignItems: 'center',
71
+ },
72
+ headerText: {
73
+ fontSize: 20,
74
+ lineHeight: 24,
75
+ letterSpacing: 0.15,
76
+ marginLeft: 8,
77
+ },
78
+ closeIconHitSlop: {
79
+ bottom: 16,
80
+ left: 16,
81
+ right: 16,
82
+ top: 16,
83
+ },
84
+ text: {
85
+ fontSize: 14,
86
+ lineHeight: 20,
87
+ letterSpacing: 0.25,
88
+ marginBottom: 24,
89
+ },
90
+ });
@@ -1,5 +1,5 @@
1
1
  import React, { memo, useMemo } from 'react';
2
- import { View, StyleSheet } from 'react-native';
2
+ import { View, StyleSheet, Platform } from 'react-native';
3
3
  import Animated, {
4
4
  interpolate,
5
5
  useAnimatedProps,
@@ -9,7 +9,6 @@ import type { SharedValue } from 'react-native-reanimated';
9
9
 
10
10
  import { COLORS } from '../utils/theme';
11
11
  import { useIsHLSViewer } from '../hooks-util';
12
- import { EndIcon } from '../Icons';
13
12
  import { HMSManageLeave } from './HMSManageLeave';
14
13
  import { HMSManageRaiseHand } from './HMSManageRaiseHand';
15
14
  import { HMSManageLocalAudio } from './HMSManageLocalAudio';
@@ -28,10 +27,10 @@ export const _Footer: React.FC<FooterProps> = ({ offset }) => {
28
27
  const canPublishVideo = useCanPublishVideo();
29
28
 
30
29
  const footerActionButtons = useMemo(() => {
31
- const actions = ['chat'];
30
+ const actions = ['chat', 'options'];
32
31
 
33
32
  if (isHLSViewer) {
34
- actions.unshift('leave');
33
+ actions.unshift('hand-raise');
35
34
  }
36
35
 
37
36
  if (canPublishVideo) {
@@ -42,7 +41,7 @@ export const _Footer: React.FC<FooterProps> = ({ offset }) => {
42
41
  actions.unshift('audio');
43
42
  }
44
43
 
45
- actions.push(isHLSViewer ? 'hand-raise' : 'options');
44
+ actions.unshift('leave');
46
45
 
47
46
  return actions;
48
47
  }, [isHLSViewer, canPublishAudio, canPublishVideo]);
@@ -72,7 +71,7 @@ export const _Footer: React.FC<FooterProps> = ({ offset }) => {
72
71
  style={index === 0 ? null : styles.iconWrapper}
73
72
  >
74
73
  {actionType === 'leave' ? (
75
- <HMSManageLeave leaveIconDelegate={<EndIcon />} />
74
+ <HMSManageLeave />
76
75
  ) : actionType === 'audio' ? (
77
76
  <HMSManageLocalAudio />
78
77
  ) : actionType === 'video' ? (
@@ -94,12 +93,13 @@ export const _Footer: React.FC<FooterProps> = ({ offset }) => {
94
93
 
95
94
  const styles = StyleSheet.create({
96
95
  container: {
97
- paddingVertical: 8,
96
+ paddingTop: 16,
98
97
  paddingHorizontal: 16,
99
98
  backgroundColor: COLORS.BACKGROUND.DIM,
100
99
  flexDirection: 'row',
101
100
  alignItems: 'center',
102
101
  justifyContent: 'center',
102
+ marginBottom: Platform.OS === 'android' ? 16 : 0, // TODO: need to correct hide aimation offsets because of this change
103
103
  },
104
104
  iconWrapper: {
105
105
  marginLeft: 24,
@@ -1,32 +1,51 @@
1
1
  import React, { useRef, useState, useImperativeHandle } from 'react';
2
2
  import type { ElementRef } from 'react';
3
- import { View, FlatList } from 'react-native';
3
+ import { View, FlatList, StyleSheet } from 'react-native';
4
+ import { useDispatch, useSelector } from 'react-redux';
5
+ import type {
6
+ LayoutChangeEvent,
7
+ LayoutRectangle,
8
+ ViewToken,
9
+ } from 'react-native';
4
10
  import type { HMSView, HMSPeer } from '@100mslive/react-native-hms';
5
11
 
6
12
  import { DefaultModal } from './DefaultModal';
7
13
  import { SaveScreenshot } from './Modals';
8
14
  import { TilesContainer } from './TilesContainer';
9
15
  import type { PeerTrackNode } from '../utils/types';
16
+ import { MiniView } from './MiniView';
17
+ import type { RootState } from '../redux';
18
+ import { PaginationDots } from './PaginationDots';
19
+ import { setGridViewActivePage } from '../redux/actions';
10
20
 
11
- type GridViewProps = {
21
+ export type GridViewProps = {
12
22
  onPeerTileMorePress(peerTrackNode: PeerTrackNode): void;
13
23
  pairedPeers: PeerTrackNode[][];
14
24
  };
15
25
 
16
- type GridViewRefAttrs = {
26
+ export type GridViewRefAttrs = {
17
27
  captureViewScreenshot(node: PeerTrackNode): any;
18
28
  getFlatlistRef(): React.RefObject<FlatList<any>>;
19
29
  };
20
30
 
21
- const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
31
+ const FLATLIST_VIEWABILITY_CONFIG = {
32
+ waitForInteraction: true,
33
+ itemVisiblePercentThreshold: 80,
34
+ };
35
+
36
+ export const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
22
37
  ({ pairedPeers, onPeerTileMorePress }, ref) => {
23
- // hooks
38
+ const dispatch = useDispatch();
24
39
  const [screenshotData, setScreenshotData] = useState<{
25
40
  peer: HMSPeer;
26
41
  source: { uri: string };
27
42
  } | null>(null);
28
43
  const hmsViewRefs = useRef<Record<string, ElementRef<typeof HMSView>>>({});
29
44
  const flatlistRef = useRef<FlatList>(null);
45
+ const insetTileBoundingBoxRef = useRef<LayoutRectangle | null>(null);
46
+ const miniviewPeerTrackNodeExists = useSelector(
47
+ (state: RootState) => !!state.app.miniviewPeerTrackNode
48
+ );
30
49
 
31
50
  // We are setting `captureViewScreenshot` method on ref passed to GridView component
32
51
  // `captureViewScreenshot` method can be called to with PeerTrackNode to capture the HmsView Snapshot
@@ -87,21 +106,60 @@ const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
87
106
 
88
107
  const _keyExtractor = React.useCallback((item) => item[0]?.id, []);
89
108
 
109
+ const _handleLayoutChange = React.useCallback(
110
+ ({ nativeEvent }: LayoutChangeEvent) => {
111
+ insetTileBoundingBoxRef.current = nativeEvent.layout;
112
+ },
113
+ []
114
+ );
115
+
116
+ const _handleViewableItemsChanged = React.useCallback(
117
+ (info: { viewableItems: ViewToken[]; changed: ViewToken[] }) => {
118
+ const firstViewable = info.viewableItems[0];
119
+
120
+ if (
121
+ firstViewable?.isViewable &&
122
+ typeof firstViewable.index === 'number'
123
+ ) {
124
+ dispatch(setGridViewActivePage(firstViewable.index));
125
+ }
126
+ },
127
+ []
128
+ );
129
+
90
130
  return (
91
- <View style={{ flex: 1 }}>
92
- <FlatList
93
- ref={flatlistRef}
94
- horizontal
95
- data={pairedPeers}
96
- initialNumToRender={1}
97
- maxToRenderPerBatch={1}
98
- windowSize={2}
99
- pagingEnabled
100
- showsHorizontalScrollIndicator={false}
101
- renderItem={_renderItem}
102
- numColumns={1}
103
- keyExtractor={_keyExtractor}
104
- />
131
+ <View style={styles.container}>
132
+ <View style={styles.tilesArea}>
133
+ <View
134
+ onLayout={_handleLayoutChange}
135
+ style={styles.measureLayoutView}
136
+ />
137
+
138
+ <FlatList
139
+ ref={flatlistRef}
140
+ horizontal={true}
141
+ data={pairedPeers}
142
+ initialNumToRender={1}
143
+ maxToRenderPerBatch={1}
144
+ windowSize={2}
145
+ pagingEnabled
146
+ showsHorizontalScrollIndicator={false}
147
+ renderItem={_renderItem}
148
+ numColumns={1}
149
+ keyExtractor={_keyExtractor}
150
+ onViewableItemsChanged={_handleViewableItemsChanged}
151
+ viewabilityConfig={FLATLIST_VIEWABILITY_CONFIG}
152
+ />
153
+
154
+ {pairedPeers.length > 0 && miniviewPeerTrackNodeExists ? (
155
+ <MiniView
156
+ boundingBoxRef={insetTileBoundingBoxRef}
157
+ onMoreOptionsPress={onPeerTileMorePress}
158
+ />
159
+ ) : null}
160
+ </View>
161
+
162
+ {pairedPeers.length > 1 ? <PaginationDots list={pairedPeers} /> : null}
105
163
 
106
164
  {/* Save Captured Screenshot of HMSView Modal */}
107
165
  <DefaultModal
@@ -121,4 +179,17 @@ const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
121
179
 
122
180
  GridView.displayName = 'GridView';
123
181
 
124
- export { GridView };
182
+ const styles = StyleSheet.create({
183
+ container: {
184
+ flex: 1,
185
+ },
186
+ tilesArea: {
187
+ flex: 1,
188
+ position: 'relative',
189
+ },
190
+ measureLayoutView: {
191
+ position: 'absolute',
192
+ width: '100%',
193
+ height: '100%',
194
+ },
195
+ });
@@ -46,7 +46,7 @@ export const HLSView: React.FC = () => {
46
46
  | 'seekForward'
47
47
  | 'seekBackward'
48
48
  | 'seekToLive'
49
- | 'setVolume',
49
+ | 'setVolume'
50
50
  >(
51
51
  action: T,
52
52
  ...args: any[]
@@ -0,0 +1,91 @@
1
+ import * as React from 'react';
2
+ import {
3
+ ActivityIndicator,
4
+ StyleSheet,
5
+ Text,
6
+ TouchableHighlight,
7
+ View,
8
+ } from 'react-native';
9
+ import type { StyleProp, ViewStyle, TextStyle, ColorValue } from 'react-native';
10
+
11
+ export interface HMSBaseButtonProps {
12
+ title: string;
13
+ loading: boolean;
14
+ onPress(): void;
15
+ underlayColor: ColorValue;
16
+ loaderColor: ColorValue;
17
+ style?: StyleProp<ViewStyle>;
18
+ textStyle?: StyleProp<TextStyle>;
19
+ disabled?: boolean;
20
+ leftComponent?: React.ReactElement | null;
21
+ }
22
+
23
+ export const HMSBaseButton: React.FC<HMSBaseButtonProps> = ({
24
+ underlayColor,
25
+ loaderColor,
26
+ title,
27
+ loading,
28
+ onPress,
29
+ style,
30
+ textStyle,
31
+ disabled,
32
+ leftComponent,
33
+ }) => {
34
+ return (
35
+ <TouchableHighlight
36
+ underlayColor={underlayColor}
37
+ style={[styles.button, style]}
38
+ onPress={onPress}
39
+ disabled={disabled}
40
+ >
41
+ <>
42
+ {loading ? (
43
+ <ActivityIndicator
44
+ size={'small'}
45
+ color={loaderColor}
46
+ style={styles.loader}
47
+ />
48
+ ) : null}
49
+
50
+ <View
51
+ style={[
52
+ styles.buttonContentWrapper,
53
+ loading ? styles.hiddenView : null,
54
+ ]}
55
+ >
56
+ {leftComponent}
57
+
58
+ <Text style={[styles.text, textStyle]}>{title}</Text>
59
+ </View>
60
+ </>
61
+ </TouchableHighlight>
62
+ );
63
+ };
64
+
65
+ const styles = StyleSheet.create({
66
+ button: {
67
+ flexDirection: 'row',
68
+ paddingHorizontal: 16,
69
+ paddingVertical: 8,
70
+ borderRadius: 8,
71
+ alignItems: 'center',
72
+ justifyContent: 'center',
73
+ },
74
+ buttonContentWrapper: {
75
+ flexDirection: 'row',
76
+ alignItems: 'center',
77
+ justifyContent: 'center',
78
+ },
79
+ text: {
80
+ fontSize: 16,
81
+ lineHeight: 24,
82
+ letterSpacing: 0.5,
83
+ marginHorizontal: 8,
84
+ },
85
+ loader: {
86
+ position: 'absolute',
87
+ },
88
+ hiddenView: {
89
+ opacity: 0,
90
+ },
91
+ });
@@ -0,0 +1,65 @@
1
+ import * as React from 'react';
2
+ import type { StyleProp, ViewStyle } from 'react-native';
3
+
4
+ import { useHMSRoomColorPalette, useHMSRoomStyleSheet } from '../hooks-util';
5
+ import { HMSBaseButton } from './HMSBaseButton';
6
+
7
+ export interface HMSDangerButtonProps {
8
+ title: string;
9
+ loading: boolean;
10
+ onPress(): void;
11
+ style?: StyleProp<ViewStyle>;
12
+ disabled?: boolean;
13
+ leftComponent?: React.ReactElement | null;
14
+ }
15
+
16
+ export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
17
+ title,
18
+ loading,
19
+ onPress,
20
+ style,
21
+ disabled,
22
+ leftComponent,
23
+ }) => {
24
+ const {
25
+ alert_error_dim: alertErrorDimColor,
26
+ alert_error_brighter: alertErrorBrighterColor,
27
+ } = useHMSRoomColorPalette();
28
+
29
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
30
+ button: {
31
+ backgroundColor: theme.palette.alert_error_default,
32
+ },
33
+ disabledButton: {
34
+ backgroundColor: theme.palette.alert_error_dim,
35
+ },
36
+ buttonText: {
37
+ color: theme.palette.alert_error_brighter,
38
+ fontFamily: `${typography.font_family}-SemiBold`,
39
+ },
40
+ disabledText: {
41
+ color: theme.palette.alert_error_bright,
42
+ },
43
+ }));
44
+
45
+ return (
46
+ <HMSBaseButton
47
+ loaderColor={alertErrorBrighterColor}
48
+ loading={loading}
49
+ onPress={onPress}
50
+ title={title}
51
+ underlayColor={alertErrorDimColor}
52
+ disabled={disabled}
53
+ leftComponent={leftComponent}
54
+ style={[
55
+ hmsRoomStyles.button,
56
+ disabled ? hmsRoomStyles.disabledButton : null,
57
+ style,
58
+ ]}
59
+ textStyle={[
60
+ hmsRoomStyles.buttonText,
61
+ disabled ? hmsRoomStyles.disabledText : null,
62
+ ]}
63
+ />
64
+ );
65
+ };