@100mslive/react-native-room-kit 0.0.4 → 0.2.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 (816) hide show
  1. package/README.md +413 -11
  2. package/lib/commonjs/HMSInstanceSetup.js +2 -1
  3. package/lib/commonjs/HMSInstanceSetup.js.map +1 -1
  4. package/lib/commonjs/HMSPrebuilt.js +4 -2
  5. package/lib/commonjs/HMSPrebuilt.js.map +1 -1
  6. package/lib/commonjs/HMSRoomSetup.js +39 -8
  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/index.js +5 -1
  27. package/lib/commonjs/Icons/Check/index.js.map +1 -1
  28. package/lib/commonjs/Icons/Chevron/index.js +5 -1
  29. package/lib/commonjs/Icons/Chevron/index.js.map +1 -1
  30. package/lib/commonjs/Icons/Close/index.js +5 -1
  31. package/lib/commonjs/Icons/Close/index.js.map +1 -1
  32. package/lib/commonjs/Icons/Hamburger/assets/hamburger.png +0 -0
  33. package/lib/commonjs/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  34. package/lib/commonjs/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  35. package/lib/commonjs/Icons/Hamburger/index.js +34 -0
  36. package/lib/commonjs/Icons/Hamburger/index.js.map +1 -0
  37. package/lib/commonjs/Icons/Hand/index.js +6 -4
  38. package/lib/commonjs/Icons/Hand/index.js.map +1 -1
  39. package/lib/commonjs/Icons/Headphones/index.js +5 -1
  40. package/lib/commonjs/Icons/Headphones/index.js.map +1 -1
  41. package/lib/commonjs/Icons/Maximize/assets/maximize.png +0 -0
  42. package/lib/commonjs/Icons/Maximize/assets/maximize@2x.png +0 -0
  43. package/lib/commonjs/Icons/Maximize/assets/maximize@3x.png +0 -0
  44. package/lib/commonjs/Icons/Maximize/index.js +34 -0
  45. package/lib/commonjs/Icons/Maximize/index.js.map +1 -0
  46. package/lib/commonjs/Icons/Mic/index.js +5 -1
  47. package/lib/commonjs/Icons/Mic/index.js.map +1 -1
  48. package/lib/commonjs/Icons/Minimize/assets/minimize.png +0 -0
  49. package/lib/commonjs/Icons/Minimize/assets/minimize@2x.png +0 -0
  50. package/lib/commonjs/Icons/Minimize/assets/minimize@3x.png +0 -0
  51. package/lib/commonjs/Icons/Minimize/index.js +34 -0
  52. package/lib/commonjs/Icons/Minimize/index.js.map +1 -0
  53. package/lib/commonjs/Icons/Participants/index.js +5 -1
  54. package/lib/commonjs/Icons/Participants/index.js.map +1 -1
  55. package/lib/commonjs/Icons/Pencil/assets/pencil.png +0 -0
  56. package/lib/commonjs/Icons/Pencil/assets/pencil@2x.png +0 -0
  57. package/lib/commonjs/Icons/Pencil/assets/pencil@3x.png +0 -0
  58. package/lib/commonjs/Icons/Pencil/index.js +34 -0
  59. package/lib/commonjs/Icons/Pencil/index.js.map +1 -0
  60. package/lib/commonjs/Icons/Pin/assets/pin.png +0 -0
  61. package/lib/commonjs/Icons/Pin/assets/pin@2x.png +0 -0
  62. package/lib/commonjs/Icons/Pin/assets/pin@3x.png +0 -0
  63. package/lib/commonjs/Icons/Pin/index.js +34 -0
  64. package/lib/commonjs/Icons/Pin/index.js.map +1 -0
  65. package/lib/commonjs/Icons/Radio/assets/radio-xlarge.png +0 -0
  66. package/lib/commonjs/Icons/Radio/assets/radio-xlarge@2x.png +0 -0
  67. package/lib/commonjs/Icons/Radio/assets/radio-xlarge@3x.png +0 -0
  68. package/lib/commonjs/Icons/Radio/index.js +29 -1
  69. package/lib/commonjs/Icons/Radio/index.js.map +1 -1
  70. package/lib/commonjs/Icons/Recording/assets/recording.png +0 -0
  71. package/lib/commonjs/Icons/Recording/assets/recording@2x.png +0 -0
  72. package/lib/commonjs/Icons/Recording/assets/recording@3x.png +0 -0
  73. package/lib/commonjs/Icons/Recording/index.js +34 -0
  74. package/lib/commonjs/Icons/Recording/index.js.map +1 -0
  75. package/lib/commonjs/Icons/RotateCamera/index.js +5 -1
  76. package/lib/commonjs/Icons/RotateCamera/index.js.map +1 -1
  77. package/lib/commonjs/Icons/ScreenShare/index.js +5 -1
  78. package/lib/commonjs/Icons/ScreenShare/index.js.map +1 -1
  79. package/lib/commonjs/Icons/Speaker/index.js +5 -1
  80. package/lib/commonjs/Icons/Speaker/index.js.map +1 -1
  81. package/lib/commonjs/Icons/Star/assets/star.png +0 -0
  82. package/lib/commonjs/Icons/Star/assets/star@2x.png +0 -0
  83. package/lib/commonjs/Icons/Star/assets/star@3x.png +0 -0
  84. package/lib/commonjs/Icons/Star/index.js +34 -0
  85. package/lib/commonjs/Icons/Star/index.js.map +1 -0
  86. package/lib/commonjs/Icons/Stop/assets/stop.png +0 -0
  87. package/lib/commonjs/Icons/Stop/assets/stop@2x.png +0 -0
  88. package/lib/commonjs/Icons/Stop/assets/stop@3x.png +0 -0
  89. package/lib/commonjs/Icons/Stop/index.js +34 -0
  90. package/lib/commonjs/Icons/Stop/index.js.map +1 -0
  91. package/lib/commonjs/Icons/ThreeDots/index.js +5 -1
  92. package/lib/commonjs/Icons/ThreeDots/index.js.map +1 -1
  93. package/lib/commonjs/Icons/Wave/index.js +5 -1
  94. package/lib/commonjs/Icons/Wave/index.js.map +1 -1
  95. package/lib/commonjs/Icons/index.js +110 -0
  96. package/lib/commonjs/Icons/index.js.map +1 -1
  97. package/lib/commonjs/components/AvatarView.js +1 -2
  98. package/lib/commonjs/components/AvatarView.js.map +1 -1
  99. package/lib/commonjs/components/BackButton.js +6 -4
  100. package/lib/commonjs/components/BackButton.js.map +1 -1
  101. package/lib/commonjs/components/BottomSheet.js +157 -0
  102. package/lib/commonjs/components/BottomSheet.js.map +1 -0
  103. package/lib/commonjs/components/ChangeNameModalContent.js +131 -0
  104. package/lib/commonjs/components/ChangeNameModalContent.js.map +1 -0
  105. package/lib/commonjs/components/CompanyLogo.js +38 -0
  106. package/lib/commonjs/components/CompanyLogo.js.map +1 -0
  107. package/lib/commonjs/components/CustomInput.js +2 -3
  108. package/lib/commonjs/components/CustomInput.js.map +1 -1
  109. package/lib/commonjs/components/DisplayView.js +15 -54
  110. package/lib/commonjs/components/DisplayView.js.map +1 -1
  111. package/lib/commonjs/components/EndRoomModalContent.js +85 -0
  112. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -0
  113. package/lib/commonjs/components/Footer.js +17 -13
  114. package/lib/commonjs/components/Footer.js.map +1 -1
  115. package/lib/commonjs/components/GridView.js +53 -7
  116. package/lib/commonjs/components/GridView.js.map +1 -1
  117. package/lib/commonjs/components/HMSBaseButton.js +66 -0
  118. package/lib/commonjs/components/HMSBaseButton.js.map +1 -0
  119. package/lib/commonjs/components/HMSDangerButton.js +53 -0
  120. package/lib/commonjs/components/HMSDangerButton.js.map +1 -0
  121. package/lib/commonjs/components/HMSHLSNotStarted.js +27 -19
  122. package/lib/commonjs/components/HMSHLSNotStarted.js.map +1 -1
  123. package/lib/commonjs/components/HMSHLSStreamLoading.js +17 -8
  124. package/lib/commonjs/components/HMSHLSStreamLoading.js.map +1 -1
  125. package/lib/commonjs/components/HMSManageAudioOutput.js +41 -75
  126. package/lib/commonjs/components/HMSManageAudioOutput.js.map +1 -1
  127. package/lib/commonjs/components/HMSManageCameraRotation.js +5 -4
  128. package/lib/commonjs/components/HMSManageCameraRotation.js.map +1 -1
  129. package/lib/commonjs/components/HMSManageLeave.js +101 -128
  130. package/lib/commonjs/components/HMSManageLeave.js.map +1 -1
  131. package/lib/commonjs/components/HMSManageLocalAudio.js +1 -9
  132. package/lib/commonjs/components/HMSManageLocalAudio.js.map +1 -1
  133. package/lib/commonjs/components/HMSManageLocalVideo.js +1 -9
  134. package/lib/commonjs/components/HMSManageLocalVideo.js.map +1 -1
  135. package/lib/commonjs/components/HMSManageRaiseHand.js +2 -15
  136. package/lib/commonjs/components/HMSManageRaiseHand.js.map +1 -1
  137. package/lib/commonjs/components/HMSMeetingEnded.js +1 -2
  138. package/lib/commonjs/components/HMSMeetingEnded.js.map +1 -1
  139. package/lib/commonjs/components/HMSPreviewEditName.js +3 -37
  140. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  141. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +17 -10
  142. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  143. package/lib/commonjs/components/HMSPreviewJoinButton.js +23 -46
  144. package/lib/commonjs/components/HMSPreviewJoinButton.js.map +1 -1
  145. package/lib/commonjs/components/HMSPreviewNetworkQuality.js +5 -3
  146. package/lib/commonjs/components/HMSPreviewNetworkQuality.js.map +1 -1
  147. package/lib/commonjs/components/HMSPreviewPeersList.js +21 -10
  148. package/lib/commonjs/components/HMSPreviewPeersList.js.map +1 -1
  149. package/lib/commonjs/components/HMSPreviewSubtitle.js +22 -9
  150. package/lib/commonjs/components/HMSPreviewSubtitle.js.map +1 -1
  151. package/lib/commonjs/components/HMSPreviewTile.js +16 -8
  152. package/lib/commonjs/components/HMSPreviewTile.js.map +1 -1
  153. package/lib/commonjs/components/HMSPreviewTitle.js +14 -6
  154. package/lib/commonjs/components/HMSPreviewTitle.js.map +1 -1
  155. package/lib/commonjs/components/HMSPrimaryButton.js +53 -0
  156. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -0
  157. package/lib/commonjs/components/HMSRecordingIndicator.js +46 -0
  158. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -0
  159. package/lib/commonjs/components/HMSRoomOptions.js +20 -7
  160. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  161. package/lib/commonjs/components/HMSShowNetworkQuality.js +5 -4
  162. package/lib/commonjs/components/HMSShowNetworkQuality.js.map +1 -1
  163. package/lib/commonjs/components/HMSTextInput.js +66 -0
  164. package/lib/commonjs/components/HMSTextInput.js.map +1 -0
  165. package/lib/commonjs/components/Header.js +30 -30
  166. package/lib/commonjs/components/Header.js.map +1 -1
  167. package/lib/commonjs/components/LocalPeerRegularVideoView.js +26 -0
  168. package/lib/commonjs/components/LocalPeerRegularVideoView.js.map +1 -0
  169. package/lib/commonjs/components/LocalPeerScreenshareView.js +76 -0
  170. package/lib/commonjs/components/LocalPeerScreenshareView.js.map +1 -0
  171. package/lib/commonjs/components/Meeting.js +8 -3
  172. package/lib/commonjs/components/Meeting.js.map +1 -1
  173. package/lib/commonjs/components/MeetingScreenContent.js +2 -1
  174. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  175. package/lib/commonjs/components/MiniView.js +163 -0
  176. package/lib/commonjs/components/MiniView.js.map +1 -0
  177. package/lib/commonjs/components/Modals.js +31 -116
  178. package/lib/commonjs/components/Modals.js.map +1 -1
  179. package/lib/commonjs/components/PaginationDots.js +56 -0
  180. package/lib/commonjs/components/PaginationDots.js.map +1 -0
  181. package/lib/commonjs/components/ParticipantsCount.js +55 -0
  182. package/lib/commonjs/components/ParticipantsCount.js.map +1 -0
  183. package/lib/commonjs/components/PeerMinimizedView.js +114 -0
  184. package/lib/commonjs/components/PeerMinimizedView.js.map +1 -0
  185. package/lib/commonjs/components/PeerSettingsModalContent.js +68 -51
  186. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  187. package/lib/commonjs/components/PeerVideoTile/AvatarView.js +76 -0
  188. package/lib/commonjs/components/PeerVideoTile/AvatarView.js.map +1 -0
  189. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js +44 -0
  190. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  191. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js +44 -0
  192. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  193. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js +74 -0
  194. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  195. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js +146 -0
  196. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  197. package/lib/commonjs/components/PeerVideoTile/VideoView.js +84 -0
  198. package/lib/commonjs/components/PeerVideoTile/VideoView.js.map +1 -0
  199. package/lib/commonjs/components/PeerVideoTile/index.js +2 -0
  200. package/lib/commonjs/components/PeerVideoTile/index.js.map +1 -0
  201. package/lib/commonjs/components/PressableIcon.js +15 -8
  202. package/lib/commonjs/components/PressableIcon.js.map +1 -1
  203. package/lib/commonjs/components/Preview.js +19 -6
  204. package/lib/commonjs/components/Preview.js.map +1 -1
  205. package/lib/commonjs/components/RoomSettingsModalContent.js +233 -362
  206. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  207. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +295 -0
  208. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  209. package/lib/commonjs/components/StatusBar.js +7 -5
  210. package/lib/commonjs/components/StatusBar.js.map +1 -1
  211. package/lib/commonjs/components/StopRecordingModalContent.js +97 -0
  212. package/lib/commonjs/components/StopRecordingModalContent.js.map +1 -0
  213. package/lib/commonjs/components/Tile.js +29 -90
  214. package/lib/commonjs/components/Tile.js.map +1 -1
  215. package/lib/commonjs/components/TilesContainer.js +99 -10
  216. package/lib/commonjs/components/TilesContainer.js.map +1 -1
  217. package/lib/commonjs/components/UnmountAfterDelay.js +48 -0
  218. package/lib/commonjs/components/UnmountAfterDelay.js.map +1 -0
  219. package/lib/commonjs/components/WebrtcView.js +51 -0
  220. package/lib/commonjs/components/WebrtcView.js.map +1 -0
  221. package/lib/commonjs/components/WelcomeInMeeting.js +54 -0
  222. package/lib/commonjs/components/WelcomeInMeeting.js.map +1 -0
  223. package/lib/commonjs/hooks-sdk-selectors.js +6 -1
  224. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  225. package/lib/commonjs/hooks-sdk.js +16 -1
  226. package/lib/commonjs/hooks-sdk.js.map +1 -1
  227. package/lib/commonjs/hooks-util-selectors.js +8 -2
  228. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  229. package/lib/commonjs/hooks-util.js +315 -93
  230. package/lib/commonjs/hooks-util.js.map +1 -1
  231. package/lib/commonjs/modules/HMSManager.js +23 -0
  232. package/lib/commonjs/modules/HMSManager.js.map +1 -0
  233. package/lib/commonjs/modules/parser.js +22 -0
  234. package/lib/commonjs/modules/parser.js.map +1 -0
  235. package/lib/commonjs/peerTrackNodeUtils.js +8 -3
  236. package/lib/commonjs/peerTrackNodeUtils.js.map +1 -1
  237. package/lib/commonjs/redux/actionTypes.js +16 -1
  238. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  239. package/lib/commonjs/redux/actions/index.js +51 -1
  240. package/lib/commonjs/redux/actions/index.js.map +1 -1
  241. package/lib/commonjs/redux/reducers/appState.js +57 -1
  242. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  243. package/lib/commonjs/redux/reducers/hmsStates.js +7 -1
  244. package/lib/commonjs/redux/reducers/hmsStates.js.map +1 -1
  245. package/lib/commonjs/redux/reducers/userState.js +3 -1
  246. package/lib/commonjs/redux/reducers/userState.js.map +1 -1
  247. package/lib/commonjs/utils/functions.js +51 -1
  248. package/lib/commonjs/utils/functions.js.map +1 -1
  249. package/lib/commonjs/utils/theme.js +62 -8
  250. package/lib/commonjs/utils/theme.js.map +1 -1
  251. package/lib/commonjs/utils/types.js +8 -1
  252. package/lib/commonjs/utils/types.js.map +1 -1
  253. package/lib/module/HMSInstanceSetup.js +2 -1
  254. package/lib/module/HMSInstanceSetup.js.map +1 -1
  255. package/lib/module/HMSPrebuilt.js +4 -2
  256. package/lib/module/HMSPrebuilt.js.map +1 -1
  257. package/lib/module/HMSRoomSetup.js +41 -10
  258. package/lib/module/HMSRoomSetup.js.map +1 -1
  259. package/lib/module/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  260. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  261. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  262. package/lib/module/Icons/AlertTriangle/index.js +26 -0
  263. package/lib/module/Icons/AlertTriangle/index.js.map +1 -0
  264. package/lib/module/Icons/AnswerPhone/index.js +5 -1
  265. package/lib/module/Icons/AnswerPhone/index.js.map +1 -1
  266. package/lib/module/Icons/BRB/assets/BRB.png +0 -0
  267. package/lib/module/Icons/BRB/assets/BRB@2x.png +0 -0
  268. package/lib/module/Icons/BRB/assets/BRB@3x.png +0 -0
  269. package/lib/module/Icons/BRB/index.js +27 -0
  270. package/lib/module/Icons/BRB/index.js.map +1 -0
  271. package/lib/module/Icons/Bluetooth/index.js +5 -1
  272. package/lib/module/Icons/Bluetooth/index.js.map +1 -1
  273. package/lib/module/Icons/Camera/index.js +5 -1
  274. package/lib/module/Icons/Camera/index.js.map +1 -1
  275. package/lib/module/Icons/Chat/index.js +5 -1
  276. package/lib/module/Icons/Chat/index.js.map +1 -1
  277. package/lib/module/Icons/Check/index.js +5 -1
  278. package/lib/module/Icons/Check/index.js.map +1 -1
  279. package/lib/module/Icons/Chevron/index.js +5 -1
  280. package/lib/module/Icons/Chevron/index.js.map +1 -1
  281. package/lib/module/Icons/Close/index.js +5 -1
  282. package/lib/module/Icons/Close/index.js.map +1 -1
  283. package/lib/module/Icons/Hamburger/assets/hamburger.png +0 -0
  284. package/lib/module/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  285. package/lib/module/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  286. package/lib/module/Icons/Hamburger/index.js +26 -0
  287. package/lib/module/Icons/Hamburger/index.js.map +1 -0
  288. package/lib/module/Icons/Hand/index.js +6 -4
  289. package/lib/module/Icons/Hand/index.js.map +1 -1
  290. package/lib/module/Icons/Headphones/index.js +5 -1
  291. package/lib/module/Icons/Headphones/index.js.map +1 -1
  292. package/lib/module/Icons/Maximize/assets/maximize.png +0 -0
  293. package/lib/module/Icons/Maximize/assets/maximize@2x.png +0 -0
  294. package/lib/module/Icons/Maximize/assets/maximize@3x.png +0 -0
  295. package/lib/module/Icons/Maximize/index.js +26 -0
  296. package/lib/module/Icons/Maximize/index.js.map +1 -0
  297. package/lib/module/Icons/Mic/index.js +5 -1
  298. package/lib/module/Icons/Mic/index.js.map +1 -1
  299. package/lib/module/Icons/Minimize/assets/minimize.png +0 -0
  300. package/lib/module/Icons/Minimize/assets/minimize@2x.png +0 -0
  301. package/lib/module/Icons/Minimize/assets/minimize@3x.png +0 -0
  302. package/lib/module/Icons/Minimize/index.js +26 -0
  303. package/lib/module/Icons/Minimize/index.js.map +1 -0
  304. package/lib/module/Icons/Participants/index.js +5 -1
  305. package/lib/module/Icons/Participants/index.js.map +1 -1
  306. package/lib/module/Icons/Pencil/assets/pencil.png +0 -0
  307. package/lib/module/Icons/Pencil/assets/pencil@2x.png +0 -0
  308. package/lib/module/Icons/Pencil/assets/pencil@3x.png +0 -0
  309. package/lib/module/Icons/Pencil/index.js +26 -0
  310. package/lib/module/Icons/Pencil/index.js.map +1 -0
  311. package/lib/module/Icons/Pin/assets/pin.png +0 -0
  312. package/lib/module/Icons/Pin/assets/pin@2x.png +0 -0
  313. package/lib/module/Icons/Pin/assets/pin@3x.png +0 -0
  314. package/lib/module/Icons/Pin/index.js +26 -0
  315. package/lib/module/Icons/Pin/index.js.map +1 -0
  316. package/lib/module/Icons/Radio/assets/radio-xlarge.png +0 -0
  317. package/lib/module/Icons/Radio/assets/radio-xlarge@2x.png +0 -0
  318. package/lib/module/Icons/Radio/assets/radio-xlarge@3x.png +0 -0
  319. package/lib/module/Icons/Radio/index.js +30 -2
  320. package/lib/module/Icons/Radio/index.js.map +1 -1
  321. package/lib/module/Icons/Recording/assets/recording.png +0 -0
  322. package/lib/module/Icons/Recording/assets/recording@2x.png +0 -0
  323. package/lib/module/Icons/Recording/assets/recording@3x.png +0 -0
  324. package/lib/module/Icons/Recording/index.js +26 -0
  325. package/lib/module/Icons/Recording/index.js.map +1 -0
  326. package/lib/module/Icons/RotateCamera/index.js +5 -1
  327. package/lib/module/Icons/RotateCamera/index.js.map +1 -1
  328. package/lib/module/Icons/ScreenShare/index.js +5 -1
  329. package/lib/module/Icons/ScreenShare/index.js.map +1 -1
  330. package/lib/module/Icons/Speaker/index.js +5 -1
  331. package/lib/module/Icons/Speaker/index.js.map +1 -1
  332. package/lib/module/Icons/Star/assets/star.png +0 -0
  333. package/lib/module/Icons/Star/assets/star@2x.png +0 -0
  334. package/lib/module/Icons/Star/assets/star@3x.png +0 -0
  335. package/lib/module/Icons/Star/index.js +26 -0
  336. package/lib/module/Icons/Star/index.js.map +1 -0
  337. package/lib/module/Icons/Stop/assets/stop.png +0 -0
  338. package/lib/module/Icons/Stop/assets/stop@2x.png +0 -0
  339. package/lib/module/Icons/Stop/assets/stop@3x.png +0 -0
  340. package/lib/module/Icons/Stop/index.js +26 -0
  341. package/lib/module/Icons/Stop/index.js.map +1 -0
  342. package/lib/module/Icons/ThreeDots/index.js +5 -1
  343. package/lib/module/Icons/ThreeDots/index.js.map +1 -1
  344. package/lib/module/Icons/Wave/index.js +5 -1
  345. package/lib/module/Icons/Wave/index.js.map +1 -1
  346. package/lib/module/Icons/index.js +10 -0
  347. package/lib/module/Icons/index.js.map +1 -1
  348. package/lib/module/components/AvatarView.js +1 -2
  349. package/lib/module/components/AvatarView.js.map +1 -1
  350. package/lib/module/components/BackButton.js +6 -4
  351. package/lib/module/components/BackButton.js.map +1 -1
  352. package/lib/module/components/BottomSheet.js +146 -0
  353. package/lib/module/components/BottomSheet.js.map +1 -0
  354. package/lib/module/components/ChangeNameModalContent.js +122 -0
  355. package/lib/module/components/ChangeNameModalContent.js.map +1 -0
  356. package/lib/module/components/CompanyLogo.js +30 -0
  357. package/lib/module/components/CompanyLogo.js.map +1 -0
  358. package/lib/module/components/CustomInput.js +2 -3
  359. package/lib/module/components/CustomInput.js.map +1 -1
  360. package/lib/module/components/DisplayView.js +19 -57
  361. package/lib/module/components/DisplayView.js.map +1 -1
  362. package/lib/module/components/EndRoomModalContent.js +76 -0
  363. package/lib/module/components/EndRoomModalContent.js.map +1 -0
  364. package/lib/module/components/Footer.js +19 -15
  365. package/lib/module/components/Footer.js.map +1 -1
  366. package/lib/module/components/GridView.js +55 -10
  367. package/lib/module/components/GridView.js.map +1 -1
  368. package/lib/module/components/HMSBaseButton.js +57 -0
  369. package/lib/module/components/HMSBaseButton.js.map +1 -0
  370. package/lib/module/components/HMSDangerButton.js +44 -0
  371. package/lib/module/components/HMSDangerButton.js.map +1 -0
  372. package/lib/module/components/HMSHLSNotStarted.js +29 -21
  373. package/lib/module/components/HMSHLSNotStarted.js.map +1 -1
  374. package/lib/module/components/HMSHLSStreamLoading.js +17 -8
  375. package/lib/module/components/HMSHLSStreamLoading.js.map +1 -1
  376. package/lib/module/components/HMSManageAudioOutput.js +42 -77
  377. package/lib/module/components/HMSManageAudioOutput.js.map +1 -1
  378. package/lib/module/components/HMSManageCameraRotation.js +5 -4
  379. package/lib/module/components/HMSManageCameraRotation.js.map +1 -1
  380. package/lib/module/components/HMSManageLeave.js +104 -129
  381. package/lib/module/components/HMSManageLeave.js.map +1 -1
  382. package/lib/module/components/HMSManageLocalAudio.js +1 -9
  383. package/lib/module/components/HMSManageLocalAudio.js.map +1 -1
  384. package/lib/module/components/HMSManageLocalVideo.js +1 -9
  385. package/lib/module/components/HMSManageLocalVideo.js.map +1 -1
  386. package/lib/module/components/HMSManageRaiseHand.js +2 -15
  387. package/lib/module/components/HMSManageRaiseHand.js.map +1 -1
  388. package/lib/module/components/HMSMeetingEnded.js +1 -2
  389. package/lib/module/components/HMSMeetingEnded.js.map +1 -1
  390. package/lib/module/components/HMSPreviewEditName.js +3 -37
  391. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  392. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +17 -10
  393. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  394. package/lib/module/components/HMSPreviewJoinButton.js +26 -49
  395. package/lib/module/components/HMSPreviewJoinButton.js.map +1 -1
  396. package/lib/module/components/HMSPreviewNetworkQuality.js +6 -4
  397. package/lib/module/components/HMSPreviewNetworkQuality.js.map +1 -1
  398. package/lib/module/components/HMSPreviewPeersList.js +21 -10
  399. package/lib/module/components/HMSPreviewPeersList.js.map +1 -1
  400. package/lib/module/components/HMSPreviewSubtitle.js +22 -9
  401. package/lib/module/components/HMSPreviewSubtitle.js.map +1 -1
  402. package/lib/module/components/HMSPreviewTile.js +16 -8
  403. package/lib/module/components/HMSPreviewTile.js.map +1 -1
  404. package/lib/module/components/HMSPreviewTitle.js +14 -6
  405. package/lib/module/components/HMSPreviewTitle.js.map +1 -1
  406. package/lib/module/components/HMSPrimaryButton.js +44 -0
  407. package/lib/module/components/HMSPrimaryButton.js.map +1 -0
  408. package/lib/module/components/HMSRecordingIndicator.js +37 -0
  409. package/lib/module/components/HMSRecordingIndicator.js.map +1 -0
  410. package/lib/module/components/HMSRoomOptions.js +21 -8
  411. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  412. package/lib/module/components/HMSShowNetworkQuality.js +6 -5
  413. package/lib/module/components/HMSShowNetworkQuality.js.map +1 -1
  414. package/lib/module/components/HMSTextInput.js +57 -0
  415. package/lib/module/components/HMSTextInput.js.map +1 -0
  416. package/lib/module/components/Header.js +32 -32
  417. package/lib/module/components/Header.js.map +1 -1
  418. package/lib/module/components/LocalPeerRegularVideoView.js +17 -0
  419. package/lib/module/components/LocalPeerRegularVideoView.js.map +1 -0
  420. package/lib/module/components/LocalPeerScreenshareView.js +66 -0
  421. package/lib/module/components/LocalPeerScreenshareView.js.map +1 -0
  422. package/lib/module/components/Meeting.js +9 -4
  423. package/lib/module/components/Meeting.js.map +1 -1
  424. package/lib/module/components/MeetingScreenContent.js +2 -1
  425. package/lib/module/components/MeetingScreenContent.js.map +1 -1
  426. package/lib/module/components/MiniView.js +154 -0
  427. package/lib/module/components/MiniView.js.map +1 -0
  428. package/lib/module/components/Modals.js +31 -114
  429. package/lib/module/components/Modals.js.map +1 -1
  430. package/lib/module/components/PaginationDots.js +47 -0
  431. package/lib/module/components/PaginationDots.js.map +1 -0
  432. package/lib/module/components/ParticipantsCount.js +46 -0
  433. package/lib/module/components/ParticipantsCount.js.map +1 -0
  434. package/lib/module/components/PeerMinimizedView.js +104 -0
  435. package/lib/module/components/PeerMinimizedView.js.map +1 -0
  436. package/lib/module/components/PeerSettingsModalContent.js +71 -54
  437. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  438. package/lib/module/components/PeerVideoTile/AvatarView.js +66 -0
  439. package/lib/module/components/PeerVideoTile/AvatarView.js.map +1 -0
  440. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js +35 -0
  441. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  442. package/lib/module/components/PeerVideoTile/PeerMetadata.js +35 -0
  443. package/lib/module/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  444. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js +65 -0
  445. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  446. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js +136 -0
  447. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  448. package/lib/module/components/PeerVideoTile/VideoView.js +75 -0
  449. package/lib/module/components/PeerVideoTile/VideoView.js.map +1 -0
  450. package/lib/module/components/PeerVideoTile/index.js +2 -0
  451. package/lib/module/components/PeerVideoTile/index.js.map +1 -0
  452. package/lib/module/components/PressableIcon.js +15 -8
  453. package/lib/module/components/PressableIcon.js.map +1 -1
  454. package/lib/module/components/Preview.js +19 -6
  455. package/lib/module/components/Preview.js.map +1 -1
  456. package/lib/module/components/RoomSettingsModalContent.js +234 -364
  457. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  458. package/lib/module/components/RoomSettingsModalDebugModeContent.js +287 -0
  459. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  460. package/lib/module/components/StatusBar.js +7 -5
  461. package/lib/module/components/StatusBar.js.map +1 -1
  462. package/lib/module/components/StopRecordingModalContent.js +88 -0
  463. package/lib/module/components/StopRecordingModalContent.js.map +1 -0
  464. package/lib/module/components/Tile.js +30 -91
  465. package/lib/module/components/Tile.js.map +1 -1
  466. package/lib/module/components/TilesContainer.js +100 -10
  467. package/lib/module/components/TilesContainer.js.map +1 -1
  468. package/lib/module/components/UnmountAfterDelay.js +39 -0
  469. package/lib/module/components/UnmountAfterDelay.js.map +1 -0
  470. package/lib/module/components/WebrtcView.js +41 -0
  471. package/lib/module/components/WebrtcView.js.map +1 -0
  472. package/lib/module/components/WelcomeInMeeting.js +45 -0
  473. package/lib/module/components/WelcomeInMeeting.js.map +1 -0
  474. package/lib/module/hooks-sdk-selectors.js +4 -0
  475. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  476. package/lib/module/hooks-sdk.js +16 -1
  477. package/lib/module/hooks-sdk.js.map +1 -1
  478. package/lib/module/hooks-util-selectors.js +8 -2
  479. package/lib/module/hooks-util-selectors.js.map +1 -1
  480. package/lib/module/hooks-util.js +310 -96
  481. package/lib/module/hooks-util.js.map +1 -1
  482. package/lib/module/modules/HMSManager.js +17 -0
  483. package/lib/module/modules/HMSManager.js.map +1 -0
  484. package/lib/module/modules/parser.js +16 -0
  485. package/lib/module/modules/parser.js.map +1 -0
  486. package/lib/module/peerTrackNodeUtils.js +6 -2
  487. package/lib/module/peerTrackNodeUtils.js.map +1 -1
  488. package/lib/module/redux/actionTypes.js +16 -1
  489. package/lib/module/redux/actionTypes.js.map +1 -1
  490. package/lib/module/redux/actions/index.js +42 -0
  491. package/lib/module/redux/actions/index.js.map +1 -1
  492. package/lib/module/redux/reducers/appState.js +57 -1
  493. package/lib/module/redux/reducers/appState.js.map +1 -1
  494. package/lib/module/redux/reducers/hmsStates.js +7 -1
  495. package/lib/module/redux/reducers/hmsStates.js.map +1 -1
  496. package/lib/module/redux/reducers/userState.js +3 -1
  497. package/lib/module/redux/reducers/userState.js.map +1 -1
  498. package/lib/module/utils/functions.js +47 -0
  499. package/lib/module/utils/functions.js.map +1 -1
  500. package/lib/module/utils/theme.js +57 -5
  501. package/lib/module/utils/theme.js.map +1 -1
  502. package/lib/module/utils/types.js +6 -0
  503. package/lib/module/utils/types.js.map +1 -1
  504. package/lib/typescript/HMSInstanceSetup.d.ts.map +1 -1
  505. package/lib/typescript/HMSPrebuilt.d.ts +1 -0
  506. package/lib/typescript/HMSPrebuilt.d.ts.map +1 -1
  507. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  508. package/lib/typescript/Icons/AlertTriangle/index.d.ts +7 -0
  509. package/lib/typescript/Icons/AlertTriangle/index.d.ts.map +1 -0
  510. package/lib/typescript/Icons/AnswerPhone/index.d.ts.map +1 -1
  511. package/lib/typescript/Icons/BRB/index.d.ts +7 -0
  512. package/lib/typescript/Icons/BRB/index.d.ts.map +1 -0
  513. package/lib/typescript/Icons/Bluetooth/index.d.ts.map +1 -1
  514. package/lib/typescript/Icons/Camera/index.d.ts.map +1 -1
  515. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  516. package/lib/typescript/Icons/Check/index.d.ts.map +1 -1
  517. package/lib/typescript/Icons/Chevron/index.d.ts.map +1 -1
  518. package/lib/typescript/Icons/Close/index.d.ts.map +1 -1
  519. package/lib/typescript/Icons/Hamburger/index.d.ts +7 -0
  520. package/lib/typescript/Icons/Hamburger/index.d.ts.map +1 -0
  521. package/lib/typescript/Icons/Hand/index.d.ts.map +1 -1
  522. package/lib/typescript/Icons/Headphones/index.d.ts.map +1 -1
  523. package/lib/typescript/Icons/Maximize/index.d.ts +7 -0
  524. package/lib/typescript/Icons/Maximize/index.d.ts.map +1 -0
  525. package/lib/typescript/Icons/Mic/index.d.ts.map +1 -1
  526. package/lib/typescript/Icons/Minimize/index.d.ts +7 -0
  527. package/lib/typescript/Icons/Minimize/index.d.ts.map +1 -0
  528. package/lib/typescript/Icons/Participants/index.d.ts.map +1 -1
  529. package/lib/typescript/Icons/Pencil/index.d.ts +7 -0
  530. package/lib/typescript/Icons/Pencil/index.d.ts.map +1 -0
  531. package/lib/typescript/Icons/Pin/index.d.ts +7 -0
  532. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -0
  533. package/lib/typescript/Icons/Radio/index.d.ts +7 -3
  534. package/lib/typescript/Icons/Radio/index.d.ts.map +1 -1
  535. package/lib/typescript/Icons/Recording/index.d.ts +7 -0
  536. package/lib/typescript/Icons/Recording/index.d.ts.map +1 -0
  537. package/lib/typescript/Icons/RotateCamera/index.d.ts.map +1 -1
  538. package/lib/typescript/Icons/ScreenShare/index.d.ts.map +1 -1
  539. package/lib/typescript/Icons/Speaker/index.d.ts.map +1 -1
  540. package/lib/typescript/Icons/Star/index.d.ts +7 -0
  541. package/lib/typescript/Icons/Star/index.d.ts.map +1 -0
  542. package/lib/typescript/Icons/Stop/index.d.ts +7 -0
  543. package/lib/typescript/Icons/Stop/index.d.ts.map +1 -0
  544. package/lib/typescript/Icons/ThreeDots/index.d.ts.map +1 -1
  545. package/lib/typescript/Icons/Wave/index.d.ts.map +1 -1
  546. package/lib/typescript/Icons/index.d.ts +10 -0
  547. package/lib/typescript/Icons/index.d.ts.map +1 -1
  548. package/lib/typescript/components/BackButton.d.ts.map +1 -1
  549. package/lib/typescript/components/BottomSheet.d.ts +25 -0
  550. package/lib/typescript/components/BottomSheet.d.ts.map +1 -0
  551. package/lib/typescript/components/ChangeNameModalContent.d.ts +6 -0
  552. package/lib/typescript/components/ChangeNameModalContent.d.ts.map +1 -0
  553. package/lib/typescript/components/CompanyLogo.d.ts +7 -0
  554. package/lib/typescript/components/CompanyLogo.d.ts.map +1 -0
  555. package/lib/typescript/components/CustomInput.d.ts +1 -1
  556. package/lib/typescript/components/CustomInput.d.ts.map +1 -1
  557. package/lib/typescript/components/DisplayView.d.ts.map +1 -1
  558. package/lib/typescript/components/EndRoomModalContent.d.ts +6 -0
  559. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -0
  560. package/lib/typescript/components/Footer.d.ts.map +1 -1
  561. package/lib/typescript/components/GridView.d.ts +3 -4
  562. package/lib/typescript/components/GridView.d.ts.map +1 -1
  563. package/lib/typescript/components/HMSBaseButton.d.ts +15 -0
  564. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -0
  565. package/lib/typescript/components/HMSDangerButton.d.ts +12 -0
  566. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -0
  567. package/lib/typescript/components/HMSHLSNotStarted.d.ts.map +1 -1
  568. package/lib/typescript/components/HMSHLSStreamLoading.d.ts.map +1 -1
  569. package/lib/typescript/components/HMSManageAudioOutput.d.ts.map +1 -1
  570. package/lib/typescript/components/HMSManageLeave.d.ts.map +1 -1
  571. package/lib/typescript/components/HMSManageLocalAudio.d.ts.map +1 -1
  572. package/lib/typescript/components/HMSManageLocalVideo.d.ts.map +1 -1
  573. package/lib/typescript/components/HMSManageRaiseHand.d.ts.map +1 -1
  574. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  575. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  576. package/lib/typescript/components/HMSPreviewJoinButton.d.ts.map +1 -1
  577. package/lib/typescript/components/HMSPreviewNetworkQuality.d.ts.map +1 -1
  578. package/lib/typescript/components/HMSPreviewPeersList.d.ts.map +1 -1
  579. package/lib/typescript/components/HMSPreviewSubtitle.d.ts.map +1 -1
  580. package/lib/typescript/components/HMSPreviewTile.d.ts.map +1 -1
  581. package/lib/typescript/components/HMSPreviewTitle.d.ts.map +1 -1
  582. package/lib/typescript/components/HMSPrimaryButton.d.ts +12 -0
  583. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -0
  584. package/lib/typescript/components/HMSRecordingIndicator.d.ts +3 -0
  585. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -0
  586. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  587. package/lib/typescript/components/HMSShowNetworkQuality.d.ts.map +1 -1
  588. package/lib/typescript/components/HMSTextInput.d.ts +10 -0
  589. package/lib/typescript/components/HMSTextInput.d.ts.map +1 -0
  590. package/lib/typescript/components/Header.d.ts.map +1 -1
  591. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts +6 -0
  592. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts.map +1 -0
  593. package/lib/typescript/components/LocalPeerScreenshareView.d.ts +3 -0
  594. package/lib/typescript/components/LocalPeerScreenshareView.d.ts.map +1 -0
  595. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  596. package/lib/typescript/components/MiniView.d.ts +9 -0
  597. package/lib/typescript/components/MiniView.d.ts.map +1 -0
  598. package/lib/typescript/components/Modals.d.ts +0 -7
  599. package/lib/typescript/components/Modals.d.ts.map +1 -1
  600. package/lib/typescript/components/PaginationDots.d.ts +6 -0
  601. package/lib/typescript/components/PaginationDots.d.ts.map +1 -0
  602. package/lib/typescript/components/ParticipantsCount.d.ts +3 -0
  603. package/lib/typescript/components/ParticipantsCount.d.ts.map +1 -0
  604. package/lib/typescript/components/PeerMinimizedView.d.ts +12 -0
  605. package/lib/typescript/components/PeerMinimizedView.d.ts.map +1 -0
  606. package/lib/typescript/components/PeerSettingsModalContent.d.ts +1 -0
  607. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  608. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts +9 -0
  609. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts.map +1 -0
  610. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts +6 -0
  611. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts.map +1 -0
  612. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts +6 -0
  613. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts.map +1 -0
  614. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts +10 -0
  615. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts.map +1 -0
  616. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts +10 -0
  617. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -0
  618. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts +13 -0
  619. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts.map +1 -0
  620. package/lib/typescript/components/PeerVideoTile/index.d.ts +1 -0
  621. package/lib/typescript/components/PeerVideoTile/index.d.ts.map +1 -0
  622. package/lib/typescript/components/PressableIcon.d.ts.map +1 -1
  623. package/lib/typescript/components/Preview.d.ts.map +1 -1
  624. package/lib/typescript/components/RoomSettingsModalContent.d.ts +2 -2
  625. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  626. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts +17 -0
  627. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -0
  628. package/lib/typescript/components/StatusBar.d.ts +2 -1
  629. package/lib/typescript/components/StatusBar.d.ts.map +1 -1
  630. package/lib/typescript/components/StopRecordingModalContent.d.ts +6 -0
  631. package/lib/typescript/components/StopRecordingModalContent.d.ts.map +1 -0
  632. package/lib/typescript/components/Tile.d.ts +12 -3
  633. package/lib/typescript/components/Tile.d.ts.map +1 -1
  634. package/lib/typescript/components/TilesContainer.d.ts.map +1 -1
  635. package/lib/typescript/components/UnmountAfterDelay.d.ts +12 -0
  636. package/lib/typescript/components/UnmountAfterDelay.d.ts.map +1 -0
  637. package/lib/typescript/components/WebrtcView.d.ts +10 -0
  638. package/lib/typescript/components/WebrtcView.d.ts.map +1 -0
  639. package/lib/typescript/components/WelcomeInMeeting.d.ts +5 -0
  640. package/lib/typescript/components/WelcomeInMeeting.d.ts.map +1 -0
  641. package/lib/typescript/hooks-sdk-selectors.d.ts +2 -0
  642. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  643. package/lib/typescript/hooks-sdk.d.ts +1 -0
  644. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  645. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  646. package/lib/typescript/hooks-util.d.ts +15 -2
  647. package/lib/typescript/hooks-util.d.ts.map +1 -1
  648. package/lib/typescript/modules/HMSManager.d.ts +4 -0
  649. package/lib/typescript/modules/HMSManager.d.ts.map +1 -0
  650. package/lib/typescript/modules/parser.d.ts +3 -0
  651. package/lib/typescript/modules/parser.d.ts.map +1 -0
  652. package/lib/typescript/peerTrackNodeUtils.d.ts +1 -0
  653. package/lib/typescript/peerTrackNodeUtils.d.ts.map +1 -1
  654. package/lib/typescript/redux/actionTypes.d.ts +9 -1
  655. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  656. package/lib/typescript/redux/actions/index.d.ts +45 -0
  657. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  658. package/lib/typescript/redux/index.d.ts +7 -0
  659. package/lib/typescript/redux/index.d.ts.map +1 -1
  660. package/lib/typescript/redux/reducers/appState.d.ts +5 -0
  661. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  662. package/lib/typescript/redux/reducers/hmsStates.d.ts +7 -1
  663. package/lib/typescript/redux/reducers/hmsStates.d.ts.map +1 -1
  664. package/lib/typescript/redux/reducers/index.d.ts +7 -0
  665. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  666. package/lib/typescript/redux/reducers/userState.d.ts +1 -0
  667. package/lib/typescript/redux/reducers/userState.d.ts.map +1 -1
  668. package/lib/typescript/utils/functions.d.ts +14 -0
  669. package/lib/typescript/utils/functions.d.ts.map +1 -1
  670. package/lib/typescript/utils/theme.d.ts +6 -3
  671. package/lib/typescript/utils/theme.d.ts.map +1 -1
  672. package/lib/typescript/utils/types.d.ts +5 -0
  673. package/lib/typescript/utils/types.d.ts.map +1 -1
  674. package/package.json +4 -2
  675. package/src/HMSInstanceSetup.tsx +1 -0
  676. package/src/HMSPrebuilt.tsx +3 -2
  677. package/src/HMSRoomSetup.tsx +45 -8
  678. package/src/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  679. package/src/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  680. package/src/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  681. package/src/Icons/AlertTriangle/index.tsx +33 -0
  682. package/src/Icons/AnswerPhone/index.tsx +7 -1
  683. package/src/Icons/BRB/assets/BRB.png +0 -0
  684. package/src/Icons/BRB/assets/BRB@2x.png +0 -0
  685. package/src/Icons/BRB/assets/BRB@3x.png +0 -0
  686. package/src/Icons/BRB/index.tsx +31 -0
  687. package/src/Icons/Bluetooth/index.tsx +7 -1
  688. package/src/Icons/Camera/index.tsx +7 -1
  689. package/src/Icons/Chat/index.tsx +7 -1
  690. package/src/Icons/Check/index.tsx +7 -1
  691. package/src/Icons/Chevron/index.tsx +7 -1
  692. package/src/Icons/Close/index.tsx +7 -1
  693. package/src/Icons/Hamburger/assets/hamburger.png +0 -0
  694. package/src/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  695. package/src/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  696. package/src/Icons/Hamburger/index.tsx +33 -0
  697. package/src/Icons/Hand/index.tsx +6 -3
  698. package/src/Icons/Headphones/index.tsx +7 -1
  699. package/src/Icons/Maximize/assets/maximize.png +0 -0
  700. package/src/Icons/Maximize/assets/maximize@2x.png +0 -0
  701. package/src/Icons/Maximize/assets/maximize@3x.png +0 -0
  702. package/src/Icons/Maximize/index.tsx +33 -0
  703. package/src/Icons/Mic/index.tsx +7 -1
  704. package/src/Icons/Minimize/assets/minimize.png +0 -0
  705. package/src/Icons/Minimize/assets/minimize@2x.png +0 -0
  706. package/src/Icons/Minimize/assets/minimize@3x.png +0 -0
  707. package/src/Icons/Minimize/index.tsx +33 -0
  708. package/src/Icons/Participants/index.tsx +7 -1
  709. package/src/Icons/Pencil/assets/pencil.png +0 -0
  710. package/src/Icons/Pencil/assets/pencil@2x.png +0 -0
  711. package/src/Icons/Pencil/assets/pencil@3x.png +0 -0
  712. package/src/Icons/Pencil/index.tsx +33 -0
  713. package/src/Icons/Pin/assets/pin.png +0 -0
  714. package/src/Icons/Pin/assets/pin@2x.png +0 -0
  715. package/src/Icons/Pin/assets/pin@3x.png +0 -0
  716. package/src/Icons/Pin/index.tsx +30 -0
  717. package/src/Icons/Radio/assets/radio-xlarge.png +0 -0
  718. package/src/Icons/Radio/assets/radio-xlarge@2x.png +0 -0
  719. package/src/Icons/Radio/assets/radio-xlarge@3x.png +0 -0
  720. package/src/Icons/Radio/index.tsx +53 -4
  721. package/src/Icons/Recording/assets/recording.png +0 -0
  722. package/src/Icons/Recording/assets/recording@2x.png +0 -0
  723. package/src/Icons/Recording/assets/recording@3x.png +0 -0
  724. package/src/Icons/Recording/index.tsx +33 -0
  725. package/src/Icons/RotateCamera/index.tsx +7 -1
  726. package/src/Icons/ScreenShare/index.tsx +7 -1
  727. package/src/Icons/Speaker/index.tsx +12 -1
  728. package/src/Icons/Star/assets/star.png +0 -0
  729. package/src/Icons/Star/assets/star@2x.png +0 -0
  730. package/src/Icons/Star/assets/star@3x.png +0 -0
  731. package/src/Icons/Star/index.tsx +30 -0
  732. package/src/Icons/Stop/assets/stop.png +0 -0
  733. package/src/Icons/Stop/assets/stop@2x.png +0 -0
  734. package/src/Icons/Stop/assets/stop@3x.png +0 -0
  735. package/src/Icons/Stop/index.tsx +30 -0
  736. package/src/Icons/ThreeDots/index.tsx +7 -1
  737. package/src/Icons/Wave/index.tsx +7 -1
  738. package/src/Icons/index.ts +10 -0
  739. package/src/components/AvatarView.tsx +1 -2
  740. package/src/components/BackButton.tsx +6 -3
  741. package/src/components/BottomSheet.tsx +191 -0
  742. package/src/components/ChangeNameModalContent.tsx +157 -0
  743. package/src/components/CompanyLogo.tsx +35 -0
  744. package/src/components/CustomInput.tsx +2 -3
  745. package/src/components/DisplayView.tsx +17 -67
  746. package/src/components/EndRoomModalContent.tsx +90 -0
  747. package/src/components/Footer.tsx +38 -33
  748. package/src/components/GridView.tsx +91 -20
  749. package/src/components/HMSBaseButton.tsx +91 -0
  750. package/src/components/HMSDangerButton.tsx +65 -0
  751. package/src/components/HMSHLSNotStarted.tsx +26 -20
  752. package/src/components/HMSHLSStreamLoading.tsx +18 -7
  753. package/src/components/HMSManageAudioOutput.tsx +59 -90
  754. package/src/components/HMSManageCameraRotation.tsx +11 -8
  755. package/src/components/HMSManageLeave.tsx +115 -126
  756. package/src/components/HMSManageLocalAudio.tsx +1 -10
  757. package/src/components/HMSManageLocalVideo.tsx +1 -10
  758. package/src/components/HMSManageRaiseHand.tsx +2 -16
  759. package/src/components/HMSMeetingEnded.tsx +1 -2
  760. package/src/components/HMSPreviewEditName.tsx +2 -44
  761. package/src/components/HMSPreviewHLSLiveIndicator.tsx +17 -9
  762. package/src/components/HMSPreviewJoinButton.tsx +33 -71
  763. package/src/components/HMSPreviewNetworkQuality.tsx +7 -4
  764. package/src/components/HMSPreviewPeersList.tsx +23 -13
  765. package/src/components/HMSPreviewSubtitle.tsx +27 -11
  766. package/src/components/HMSPreviewTile.tsx +19 -8
  767. package/src/components/HMSPreviewTitle.tsx +18 -5
  768. package/src/components/HMSPrimaryButton.tsx +63 -0
  769. package/src/components/HMSRecordingIndicator.tsx +39 -0
  770. package/src/components/HMSRoomOptions.tsx +28 -8
  771. package/src/components/HMSShowNetworkQuality.tsx +7 -5
  772. package/src/components/HMSTextInput.tsx +78 -0
  773. package/src/components/Header.tsx +37 -36
  774. package/src/components/LocalPeerRegularVideoView.tsx +28 -0
  775. package/src/components/LocalPeerScreenshareView.tsx +72 -0
  776. package/src/components/Meeting.tsx +10 -3
  777. package/src/components/MeetingScreenContent.tsx +1 -1
  778. package/src/components/MiniView.tsx +213 -0
  779. package/src/components/Modals.tsx +1 -110
  780. package/src/components/PaginationDots.tsx +65 -0
  781. package/src/components/ParticipantsCount.tsx +52 -0
  782. package/src/components/PeerMinimizedView.tsx +131 -0
  783. package/src/components/PeerSettingsModalContent.tsx +110 -54
  784. package/src/components/PeerVideoTile/AvatarView.tsx +79 -0
  785. package/src/components/PeerVideoTile/PeerAudioMutedIndicator.tsx +41 -0
  786. package/src/components/PeerVideoTile/PeerMetadata.tsx +46 -0
  787. package/src/components/PeerVideoTile/PeerNameAndNetwork.tsx +81 -0
  788. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +180 -0
  789. package/src/components/PeerVideoTile/VideoView.tsx +104 -0
  790. package/src/components/PeerVideoTile/index.ts +0 -0
  791. package/src/components/PressableIcon.tsx +15 -8
  792. package/src/components/Preview.tsx +24 -6
  793. package/src/components/RoomSettingsModalContent.tsx +237 -524
  794. package/src/components/RoomSettingsModalDebugModeContent.tsx +446 -0
  795. package/src/components/StatusBar.tsx +6 -4
  796. package/src/components/StopRecordingModalContent.tsx +111 -0
  797. package/src/components/Tile.tsx +49 -90
  798. package/src/components/TilesContainer.tsx +116 -14
  799. package/src/components/UnmountAfterDelay.tsx +61 -0
  800. package/src/components/WebrtcView.tsx +72 -0
  801. package/src/components/WelcomeInMeeting.tsx +52 -0
  802. package/src/hooks-sdk-selectors.tsx +7 -0
  803. package/src/hooks-sdk.ts +18 -0
  804. package/src/hooks-util-selectors.tsx +12 -1
  805. package/src/hooks-util.ts +420 -114
  806. package/src/modules/HMSManager.ts +25 -0
  807. package/src/modules/parser.ts +22 -0
  808. package/src/peerTrackNodeUtils.tsx +13 -10
  809. package/src/redux/actionTypes.ts +22 -0
  810. package/src/redux/actions/index.ts +53 -0
  811. package/src/redux/reducers/appState.ts +59 -0
  812. package/src/redux/reducers/hmsStates.ts +15 -1
  813. package/src/redux/reducers/userState.ts +3 -0
  814. package/src/utils/functions.ts +48 -0
  815. package/src/utils/theme.ts +74 -5
  816. package/src/utils/types.ts +6 -0
@@ -3,17 +3,19 @@ import { HMSConfig, HMSPIPListenerActions, HMSPeerUpdate, HMSRoomUpdate, HMSTrac
3
3
  } from '@100mslive/react-native-hms';
4
4
  import Toast from 'react-native-simple-toast';
5
5
  import { useRef, useCallback, useEffect, useState, useMemo, useContext } from 'react';
6
- import { ModalTypes, PipModes } from './utils/types';
6
+ import { MaxTilesInOnePage, ModalTypes, PipModes } from './utils/types';
7
7
  import { createPeerTrackNode, parseMetadata } from './utils/functions';
8
- import { batch, useDispatch, useSelector, useStore } from 'react-redux';
9
- import { addMessage, addPinnedMessage, addToPreviewPeersList, changeMeetingState, changePipModeStatus, changeStartingHLSStream, clearStore, removeFromPreviewPeersList, saveUserData, setHMSLocalPeerState, setHMSRoleState, setHMSRoomState, setIsLocalAudioMutedState, setIsLocalVideoMutedState, setModalType } from './redux/actions';
10
- import { degradeOrRestorePeerTrackNodes, peerTrackNodeExistForPeer, peerTrackNodeExistForPeerAndTrack, removePeerTrackNodes, removePeerTrackNodesWithTrack, replacePeerTrackNodes, replacePeerTrackNodesWithTrack } from './peerTrackNodeUtils';
8
+ import { batch, shallowEqual, useDispatch, useSelector, useStore } from 'react-redux';
9
+ import { addMessage, addPinnedMessage, changeMeetingState, changePipModeStatus, changeStartingHLSStream, clearStore, saveUserData, setHMSLocalPeerState, setHMSRoleState, setHMSRoomState, setIsLocalAudioMutedState, setIsLocalVideoMutedState, setLayoutConfig, setLocalPeerTrackNode, setMiniViewPeerTrackNode, setModalType, setStartingOrStoppingRecording, updateLocalPeerTrackNode, updateMiniViewPeerTrackNode } from './redux/actions';
10
+ import { createPeerTrackNodeUniqueId, degradeOrRestorePeerTrackNodes, peerTrackNodeExistForPeer, peerTrackNodeExistForPeerAndTrack, removePeerTrackNodes, removePeerTrackNodesWithTrack, replacePeerTrackNodes, replacePeerTrackNodesWithTrack } from './peerTrackNodeUtils';
11
11
  import { MeetingState } from './types';
12
12
  import { AppState, InteractionManager, LayoutAnimation, Platform } from 'react-native';
13
13
  import { NavigationContext } from '@react-navigation/native';
14
14
  import { useIsLandscapeOrientation, useIsPortraitOrientation } from './utils/dimension';
15
15
  import { useSafeAreaFrame, useSafeAreaInsets } from 'react-native-safe-area-context';
16
16
  import { selectIsHLSViewer, selectShouldGoLive } from './hooks-util-selectors';
17
+ import { getRoomLayout } from './modules/HMSManager';
18
+ import { DEFAULT_THEME, DEFAULT_TYPOGRAPHY } from './utils/theme';
17
19
  export const useHMSListeners = setPeerTrackNodes => {
18
20
  const hmsInstance = useHMSInstance();
19
21
  const updateLocalPeer = useUpdateHMSLocalPeer(hmsInstance);
@@ -48,6 +50,10 @@ const useHMSRoomUpdate = hmsInstance => {
48
50
  }
49
51
  if (type === HMSRoomUpdate.BROWSER_RECORDING_STATE_UPDATED) {
50
52
  var _room$browserRecordin, _room$browserRecordin2;
53
+ const startingOrStoppingRecording = reduxStore.getState().app.startingOrStoppingRecording;
54
+ if (startingOrStoppingRecording) {
55
+ dispatch(setStartingOrStoppingRecording(false));
56
+ }
51
57
  let streaming = room === null || room === void 0 || (_room$browserRecordin = room.browserRecordingState) === null || _room$browserRecordin === void 0 ? void 0 : _room$browserRecordin.running;
52
58
  const startAtDate = room === null || room === void 0 || (_room$browserRecordin2 = room.browserRecordingState) === null || _room$browserRecordin2 === void 0 ? void 0 : _room$browserRecordin2.startedAt;
53
59
  let startTime = null;
@@ -97,7 +103,11 @@ const useHMSRoomUpdate = hmsInstance => {
97
103
  };
98
104
  const useHMSPeersUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
99
105
  const dispatch = useDispatch();
100
- const inMeeting = useSelector(state => state.app.meetingState === MeetingState.IN_MEETING);
106
+ const store = useStore();
107
+ // const inMeeting = useSelector(
108
+ // (state: RootState) => state.app.meetingState === MeetingState.IN_MEETING
109
+ // );
110
+
101
111
  useEffect(() => {
102
112
  const peerUpdateHandler = _ref => {
103
113
  let {
@@ -105,13 +115,14 @@ const useHMSPeersUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
105
115
  type
106
116
  } = _ref;
107
117
  // Handle State from Preview screen
108
- if (!inMeeting) {
109
- if (type === HMSPeerUpdate.PEER_JOINED) {
110
- dispatch(addToPreviewPeersList(peer));
111
- } else if (type === HMSPeerUpdate.PEER_LEFT) {
112
- dispatch(removeFromPreviewPeersList(peer));
113
- }
114
- }
118
+ // TODO: When `inMeeting` becomes true Peer Update is resubscribed, we might lose some events during that time
119
+ // if (!inMeeting) {
120
+ // if (type === HMSPeerUpdate.PEER_JOINED) {
121
+ // dispatch(addToPreviewPeersList(peer));
122
+ // } else if (type === HMSPeerUpdate.PEER_LEFT) {
123
+ // dispatch(removeFromPreviewPeersList(peer));
124
+ // }
125
+ // }
115
126
 
116
127
  // Handle State for Meeting screen
117
128
  if (type === HMSPeerUpdate.PEER_JOINED) {
@@ -128,6 +139,25 @@ const useHMSPeersUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
128
139
  }
129
140
  return prevPeerTrackNodes;
130
141
  });
142
+ const reduxState = store.getState();
143
+ const miniviewPeerTrackNode = reduxState.app.miniviewPeerTrackNode;
144
+ const localPeerTrackNode = reduxState.app.localPeerTrackNode;
145
+ batch(() => {
146
+ if (localPeerTrackNode) {
147
+ dispatch(updateLocalPeerTrackNode({
148
+ peer
149
+ }));
150
+ } else {
151
+ dispatch(setLocalPeerTrackNode(createPeerTrackNode(peer, peer.videoTrack)));
152
+ }
153
+
154
+ // only set `localPeerTrackNode` as miniview peer track node when we are already using it.
155
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.peer.peerID === peer.peerID) {
156
+ dispatch(updateMiniViewPeerTrackNode({
157
+ peer
158
+ }));
159
+ }
160
+ });
131
161
 
132
162
  // - TODO: update local localPeer state
133
163
  // - Pass this updated data to Meeting component -> DisplayView component
@@ -160,11 +190,11 @@ const useHMSPeersUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
160
190
  return () => {
161
191
  hmsInstance.removeEventListener(HMSUpdateListenerActions.ON_PEER_UPDATE);
162
192
  };
163
- }, [inMeeting, hmsInstance]); // TODO: When `inMeeting` becomes true Peer Update is resubscribed, we might lose some events during that time
193
+ }, [hmsInstance]);
164
194
  };
165
-
166
195
  const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
167
196
  const dispatch = useDispatch();
197
+ const store = useStore();
168
198
  useEffect(() => {
169
199
  const trackUpdateHandler = _ref2 => {
170
200
  let {
@@ -172,7 +202,12 @@ const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
172
202
  track,
173
203
  type
174
204
  } = _ref2;
205
+ const reduxState = store.getState();
206
+ const miniviewPeerTrackNode = reduxState.app.miniviewPeerTrackNode;
207
+ const localPeerTrackNode = reduxState.app.localPeerTrackNode;
175
208
  if (type === HMSTrackUpdate.TRACK_ADDED) {
209
+ const newPeerTrackNode = createPeerTrackNode(peer, track);
210
+ const willCreateMiniviewPeerTrackNode = !miniviewPeerTrackNode && peer.isLocal && track.source === HMSTrackSource.REGULAR;
176
211
  setPeerTrackNodes(prevPeerTrackNodes => {
177
212
  if (peerTrackNodeExistForPeerAndTrack(prevPeerTrackNodes, peer, track)) {
178
213
  if (track.type === HMSTrackType.VIDEO) {
@@ -180,14 +215,59 @@ const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
180
215
  }
181
216
  return replacePeerTrackNodes(prevPeerTrackNodes, peer);
182
217
  }
183
- const newPeerTrackNode = createPeerTrackNode(peer, track);
184
- return [...prevPeerTrackNodes, newPeerTrackNode];
218
+ if (miniviewPeerTrackNode ? newPeerTrackNode.id !== miniviewPeerTrackNode.id : !willCreateMiniviewPeerTrackNode) {
219
+ return [...prevPeerTrackNodes, newPeerTrackNode];
220
+ }
221
+ return prevPeerTrackNodes;
185
222
  });
186
223
 
187
224
  // - TODO: update local localPeer state
188
225
  // - Pass this updated data to Meeting component -> DisplayView component
189
226
  if (peer.isLocal) {
227
+ if (track.source === HMSTrackSource.REGULAR) {
228
+ if (!localPeerTrackNode) {
229
+ dispatch(setLocalPeerTrackNode(newPeerTrackNode));
230
+ } else {
231
+ dispatch(updateLocalPeerTrackNode(track.type === HMSTrackType.VIDEO ? {
232
+ peer,
233
+ track
234
+ } : {
235
+ peer
236
+ }));
237
+ }
238
+
239
+ // only setting `miniviewPeerTrackNode`, when:
240
+ // - there is no `miniviewPeerTrackNode`
241
+ // - if there is, then it is of regular track
242
+ if (!miniviewPeerTrackNode) {
243
+ dispatch(setMiniViewPeerTrackNode(newPeerTrackNode));
244
+ } else if (miniviewPeerTrackNode.id === newPeerTrackNode.id) {
245
+ dispatch(updateMiniViewPeerTrackNode(track.type === HMSTrackType.VIDEO ? {
246
+ peer,
247
+ track
248
+ } : {
249
+ peer
250
+ }));
251
+ }
252
+ }
253
+ // else -> {
254
+ // should `localPeerTrackNode` be created/updated for non-regular track addition?
255
+ // should `miniviewPeerTrackNode` be created/updated for non-regular track addition?
256
+ // }
257
+
190
258
  updateLocalPeer();
259
+ } else {
260
+ // only setting `miniviewPeerTrackNode`, when:
261
+ // - there is already `miniviewPeerTrackNode`
262
+ // - and it is of same peer's regular track
263
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.id === newPeerTrackNode.id) {
264
+ dispatch(updateMiniViewPeerTrackNode(track.type === HMSTrackType.VIDEO ? {
265
+ peer,
266
+ track
267
+ } : {
268
+ peer
269
+ }));
270
+ }
191
271
  }
192
272
  return;
193
273
  }
@@ -200,7 +280,53 @@ const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
200
280
  // - TODO: update local localPeer state
201
281
  // - Pass this updated data to Meeting component -> DisplayView component
202
282
  if (peer.isLocal) {
283
+ if (track.source === HMSTrackSource.REGULAR) {
284
+ var _peer$audioTrack2, _peer$videoTrack2;
285
+ if (!((_peer$audioTrack2 = peer.audioTrack) !== null && _peer$audioTrack2 !== void 0 && _peer$audioTrack2.trackId) && !((_peer$videoTrack2 = peer.videoTrack) !== null && _peer$videoTrack2 !== void 0 && _peer$videoTrack2.trackId)) {
286
+ dispatch(setLocalPeerTrackNode(null));
287
+
288
+ // removing `miniviewPeerTrackNode`, when:
289
+ // - `localPeerTrack` was used as `miniviewPeerTrackNode`
290
+ // - and now local peer doesn't have any tracks
291
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.peer.peerID === peer.peerID) {
292
+ dispatch(setMiniViewPeerTrackNode(null));
293
+ }
294
+ } else {
295
+ if (track.type === HMSTrackType.VIDEO) {
296
+ dispatch(updateLocalPeerTrackNode({
297
+ peer,
298
+ track: undefined
299
+ }));
300
+ } else {
301
+ dispatch(updateLocalPeerTrackNode({
302
+ peer
303
+ }));
304
+ }
305
+
306
+ // updating `miniviewPeerTrackNode`
307
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.peer.peerID === peer.peerID) {
308
+ if (track.type === HMSTrackType.VIDEO) {
309
+ dispatch(updateMiniViewPeerTrackNode({
310
+ peer,
311
+ track: undefined
312
+ }));
313
+ } else {
314
+ dispatch(updateMiniViewPeerTrackNode({
315
+ peer
316
+ }));
317
+ }
318
+ }
319
+ }
320
+ }
203
321
  updateLocalPeer();
322
+ } else {
323
+ // only removing `miniviewPeerTrackNode`, when:
324
+ // - there is already `miniviewPeerTrackNode`
325
+ // - and it is of same peer's regular track
326
+ const uniqueId = createPeerTrackNodeUniqueId(peer, track);
327
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.id === uniqueId) {
328
+ dispatch(setMiniViewPeerTrackNode(null));
329
+ }
204
330
  }
205
331
  return;
206
332
  }
@@ -223,11 +349,34 @@ const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
223
349
  }
224
350
  return prevPeerTrackNodes;
225
351
  });
352
+ const uniqueId = createPeerTrackNodeUniqueId(peer, track);
226
353
 
227
354
  // - TODO: update local localPeer state
228
355
  // - Pass this updated data to Meeting component -> DisplayView component
229
356
  if (peer.isLocal) {
357
+ const updatePayload = track.type === HMSTrackType.VIDEO ? {
358
+ peer,
359
+ track
360
+ } : {
361
+ peer
362
+ };
363
+ dispatch(updateLocalPeerTrackNode(updatePayload));
364
+
365
+ // Take care of miniviewPeerTrackNode
366
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.id === uniqueId) {
367
+ dispatch(updateMiniViewPeerTrackNode(updatePayload));
368
+ }
230
369
  updateLocalPeer();
370
+ } else {
371
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.id === uniqueId) {
372
+ const updatePayload = track.type === HMSTrackType.VIDEO ? {
373
+ peer,
374
+ track
375
+ } : {
376
+ peer
377
+ };
378
+ dispatch(updateMiniViewPeerTrackNode(updatePayload));
379
+ }
231
380
  }
232
381
  return;
233
382
  }
@@ -238,6 +387,12 @@ const useHMSTrackUpdate = (hmsInstance, updateLocalPeer, setPeerTrackNodes) => {
238
387
  }
239
388
  return prevPeerTrackNodes;
240
389
  });
390
+ const uniqueId = createPeerTrackNodeUniqueId(peer, track);
391
+ if (miniviewPeerTrackNode && miniviewPeerTrackNode.id === uniqueId) {
392
+ dispatch(updateMiniViewPeerTrackNode({
393
+ isDegraded: type === HMSTrackUpdate.TRACK_DEGRADED
394
+ }));
395
+ }
241
396
  return;
242
397
  }
243
398
  };
@@ -319,7 +474,7 @@ export const useHMSRoleChangeRequest = (callback, deps) => {
319
474
  }, [...(deps || []), hmsInstance]);
320
475
  return roleChangeRequest;
321
476
  };
322
- export const useHMSSessionStoreListeners = () => {
477
+ export const useHMSSessionStoreListeners = gridViewRef => {
323
478
  const dispatch = useDispatch();
324
479
  const hmsSessionStore = useSelector(state => state.user.hmsSessionStore);
325
480
  const sessionStoreListenersRef = useRef([]);
@@ -331,10 +486,16 @@ export const useHMSSessionStoreListeners = () => {
331
486
  const addSessionStoreListeners = () => {
332
487
  // Handle 'spotlight' key values
333
488
  const handleSpotlightIdChange = id => {
489
+ var _gridViewRef$current;
334
490
  // set value to the state to rerender the component to reflect changes
335
491
  dispatch(saveUserData({
336
492
  spotlightTrackId: id
337
493
  }));
494
+ // Scroll to start of the list
495
+ (_gridViewRef$current = gridViewRef.current) === null || _gridViewRef$current === void 0 || (_gridViewRef$current = _gridViewRef$current.getFlatlistRef().current) === null || _gridViewRef$current === void 0 ? void 0 : _gridViewRef$current.scrollToOffset({
496
+ animated: true,
497
+ offset: 0
498
+ });
338
499
  };
339
500
 
340
501
  // Handle 'pinnedMessage' key values
@@ -463,101 +624,33 @@ export const useHMSMessages = () => {
463
624
  };
464
625
  export const useHMSPIPRoomLeave = () => {
465
626
  const hmsInstance = useHMSInstance();
466
- const dispatch = useDispatch();
467
- // TODO: What if this is undefined?
468
- const navigation = useContext(NavigationContext);
627
+ const {
628
+ destroy
629
+ } = useLeaveMethods();
469
630
  useEffect(() => {
470
631
  const pipRoomLeaveHandler = () => {
471
- hmsInstance.destroy().then(s => {
472
- console.log('Destroy Success: ', s);
473
- // TODOS:
474
- // - If show `Meeting_Ended` is true, show Meeting screen by setting state to MEETING_ENDED
475
- // - Reset Redux States
476
- // - HMSInstance will not be available now
477
- // - When your presses "Re Join" Action button, restart process from root component
478
- // - When your presses "Done" Action button
479
- // - If we have callback fn, call it
480
- // - Otherwise try our best to navigate away from current screen
481
- //
482
- // - No screen to show
483
- // - No need to reset redux state?
484
- // - HMSInstance will be available till this point
485
- // - If we have callback fn, call it
486
- // - Otherwise try our best to navigate away from current screen
487
- // - When we are navigated away from screen, HMSInstance will be not available
488
-
489
- // dispatch(clearMessageData());
490
- // dispatch(clearPeerData());
491
- // dispatch(clearHmsReference());
492
-
493
- if (navigation && navigation.canGoBack()) {
494
- navigation.goBack();
495
- dispatch(clearStore());
496
- } else {
497
- // TODO: call onLeave Callback if provided
498
- // Otherwise default action is to show "Meeting Ended" screen
499
- dispatch(clearStore()); // TODO: We need different clearStore for MeetingEnded
500
- dispatch(changeMeetingState(MeetingState.MEETING_ENDED));
501
- }
502
- }).catch(e => {
503
- console.log(`Destroy HMS instance Error: ${e}`);
504
- Toast.showWithGravity(`Destroy HMS instance Error: ${e}`, Toast.LONG, Toast.TOP);
505
- });
632
+ destroy();
506
633
  };
507
634
  hmsInstance.addEventListener(HMSPIPListenerActions.ON_PIP_ROOM_LEAVE, pipRoomLeaveHandler);
508
635
  return () => {
509
636
  hmsInstance.removeEventListener(HMSPIPListenerActions.ON_PIP_ROOM_LEAVE);
510
637
  };
511
- }, [hmsInstance]);
638
+ }, [destroy, hmsInstance]);
512
639
  };
513
640
  export const useHMSRemovedFromRoomUpdate = () => {
514
641
  const hmsInstance = useHMSInstance();
515
- const dispatch = useDispatch();
516
- // TODO: What if this is undefined?
517
- const navigation = useContext(NavigationContext);
642
+ const {
643
+ destroy
644
+ } = useLeaveMethods();
518
645
  useEffect(() => {
519
646
  const removedFromRoomHandler = () => {
520
- hmsInstance.destroy().then(s => {
521
- console.log('Destroy Success: ', s);
522
- // TODOS:
523
- // - If show `Meeting_Ended` is true, show Meeting screen by setting state to MEETING_ENDED
524
- // - Reset Redux States
525
- // - HMSInstance will not be available now
526
- // - When your presses "Re Join" Action button, restart process from root component
527
- // - When your presses "Done" Action button
528
- // - If we have callback fn, call it
529
- // - Otherwise try our best to navigate away from current screen
530
- //
531
- // - No screen to show
532
- // - No need to reset redux state?
533
- // - HMSInstance will be available till this point
534
- // - If we have callback fn, call it
535
- // - Otherwise try our best to navigate away from current screen
536
- // - When we are navigated away from screen, HMSInstance will be not available
537
-
538
- // dispatch(clearMessageData());
539
- // dispatch(clearPeerData());
540
- // dispatch(clearHmsReference());
541
-
542
- if (navigation && navigation.canGoBack()) {
543
- navigation.goBack();
544
- dispatch(clearStore());
545
- } else {
546
- // TODO: call onLeave Callback if provided
547
- // Otherwise default action is to show "Meeting Ended" screen
548
- dispatch(clearStore()); // TODO: We need different clearStore for MeetingEnded
549
- dispatch(changeMeetingState(MeetingState.MEETING_ENDED));
550
- }
551
- }).catch(e => {
552
- console.log(`Destroy HMS instance Error: ${e}`);
553
- Toast.showWithGravity(`Destroy HMS instance Error: ${e}`, Toast.LONG, Toast.TOP);
554
- });
647
+ destroy();
555
648
  };
556
649
  hmsInstance.addEventListener(HMSUpdateListenerActions.ON_REMOVED_FROM_ROOM, removedFromRoomHandler);
557
650
  return () => {
558
651
  hmsInstance.removeEventListener(HMSUpdateListenerActions.ON_REMOVED_FROM_ROOM);
559
652
  };
560
- }, [hmsInstance]);
653
+ }, [destroy, hmsInstance]);
561
654
  };
562
655
  export const usePIPListener = () => {
563
656
  const hmsInstance = useHMSInstance();
@@ -595,6 +688,65 @@ export const usePIPListener = () => {
595
688
  }
596
689
  }, [isPipModeActive, hmsInstance]);
597
690
  };
691
+ export const useHMSNetworkQualityUpdate = () => {
692
+ const hmsInstance = useHMSInstance();
693
+ useEffect(() => {
694
+ hmsInstance.enableNetworkQualityUpdates();
695
+ return () => hmsInstance.disableNetworkQualityUpdates();
696
+ }, [hmsInstance]);
697
+ };
698
+ export const useHMSActiveSpeakerUpdates = (setPeerTrackNodes, active) => {
699
+ const hmsInstance = useHMSInstance();
700
+ const reduxStore = useStore();
701
+ const isPortraitOrientation = useIsPortraitOrientation();
702
+ useEffect(() => {
703
+ if (!active) {
704
+ return;
705
+ }
706
+ const handleActiveSpeaker = data => {
707
+ const activePage = reduxStore.getState().app.gridViewActivePage;
708
+ if (activePage !== 0) {
709
+ return;
710
+ }
711
+ setPeerTrackNodes(prevPeerTrackNodes => {
712
+ // list of active speakers which are not in first page
713
+ const activeSpeakers = data.filter(speaker => {
714
+ const uniquePeerTrackNodeId = createPeerTrackNodeUniqueId(speaker.peer, speaker.track);
715
+ const inFirstPage = prevPeerTrackNodes.some((prevPeerTrackNode, _idx) => {
716
+ // we are on index which is not in current page
717
+ if (_idx >= (isPortraitOrientation ? MaxTilesInOnePage.IN_PORTRAIT : MaxTilesInOnePage.IN_LANDSCAPE)) {
718
+ return false;
719
+ }
720
+ return prevPeerTrackNode.id === uniquePeerTrackNodeId;
721
+ });
722
+ return !inFirstPage;
723
+ });
724
+
725
+ // All active speakers are in first page already, Do nothing
726
+ if (activeSpeakers.length === 0) {
727
+ return prevPeerTrackNodes;
728
+ }
729
+
730
+ // Updated list with all Active Speakers in first page
731
+ return prevPeerTrackNodes.reduce((accumulated, current) => {
732
+ if (activeSpeakers.findIndex(activeSpeaker => createPeerTrackNodeUniqueId(activeSpeaker.peer, activeSpeaker.track) === current.id) >= 0) {
733
+ // return [current, ...accumulated];
734
+ accumulated.unshift(current);
735
+ return accumulated;
736
+ }
737
+
738
+ // return [...accumulated, current];
739
+ accumulated.push(current);
740
+ return accumulated;
741
+ }, []);
742
+ });
743
+ };
744
+ hmsInstance.addEventListener(HMSUpdateListenerActions.ON_SPEAKER, handleActiveSpeaker);
745
+ return () => {
746
+ hmsInstance.removeEventListener(HMSUpdateListenerActions.ON_SPEAKER);
747
+ };
748
+ }, [isPortraitOrientation, active, hmsInstance]);
749
+ };
598
750
  let modalTaskRef = {
599
751
  current: null
600
752
  };
@@ -666,12 +818,21 @@ export const clearConfig = () => {
666
818
  };
667
819
  export const useHMSConfig = () => {
668
820
  const hmsInstance = useHMSInstance();
821
+ const dispatch = useDispatch();
669
822
  const store = useStore();
670
823
  const getConfig = useCallback(async () => {
671
824
  var _storeState$user$endP, _storeState$user$endP2;
672
825
  if (hmsConfig) return hmsConfig;
673
826
  const storeState = store.getState();
674
827
  const token = await hmsInstance.getAuthTokenByRoomCode(storeState.user.roomCode, storeState.user.userId, (_storeState$user$endP = storeState.user.endPoints) === null || _storeState$user$endP === void 0 ? void 0 : _storeState$user$endP.token);
828
+
829
+ // TODO: [REMOVE LATER] added trycatch block so that we can join rooms where we are getting error from Layout API
830
+ try {
831
+ const roomLayout = await getRoomLayout(hmsInstance, token, 'https://api-nonprod.100ms.live');
832
+ dispatch(setLayoutConfig(roomLayout));
833
+ } catch (error) {
834
+ console.warn('# getRoomLayout error: ', error);
835
+ }
675
836
  hmsConfig = new HMSConfig({
676
837
  authToken: token,
677
838
  username: storeState.user.userName,
@@ -805,6 +966,7 @@ export const useLeaveMethods = () => {
805
966
  const navigation = useContext(NavigationContext);
806
967
  const hmsInstance = useHMSInstance();
807
968
  const dispatch = useDispatch();
969
+ const reduxStore = useStore();
808
970
  const destroy = useCallback(async () => {
809
971
  try {
810
972
  const s = await hmsInstance.destroy();
@@ -829,7 +991,11 @@ export const useLeaveMethods = () => {
829
991
  // dispatch(clearPeerData());
830
992
  // dispatch(clearHmsReference());
831
993
 
832
- if (navigation && navigation.canGoBack()) {
994
+ const onLeave = reduxStore.getState().user.onLeave;
995
+ if (typeof onLeave === 'function') {
996
+ onLeave();
997
+ dispatch(clearStore());
998
+ } else if (navigation && navigation.canGoBack()) {
833
999
  navigation.goBack();
834
1000
  dispatch(clearStore());
835
1001
  } else {
@@ -879,4 +1045,52 @@ export const useLeaveMethods = () => {
879
1045
  goToPreview
880
1046
  };
881
1047
  };
1048
+ export const useHMSLayoutConfig = () => {
1049
+ return useSelector(state => state.hmsStates.layoutConfig);
1050
+ };
1051
+ export const useHMSRoomTheme = selector => {
1052
+ return useSelector(state => {
1053
+ const layoutConfig = state.hmsStates.layoutConfig;
1054
+ const roomTheme = layoutConfig === null || layoutConfig === void 0 ? void 0 : layoutConfig.themes.find(theme => theme.default);
1055
+ const defaultTheme = roomTheme ? roomTheme.palette ? roomTheme : {
1056
+ ...roomTheme,
1057
+ palette: DEFAULT_THEME.palette
1058
+ } : DEFAULT_THEME;
1059
+ if (!selector) {
1060
+ return defaultTheme;
1061
+ }
1062
+ return selector(defaultTheme);
1063
+ }, shallowEqual);
1064
+ };
1065
+ export const useHMSRoomColorPalette = () => {
1066
+ return useHMSRoomTheme(theme => theme.palette);
1067
+ };
1068
+ export const useHMSRoomTypography = () => {
1069
+ return useSelector(state => {
1070
+ const layoutConfig = state.hmsStates.layoutConfig;
1071
+ const typography = layoutConfig === null || layoutConfig === void 0 ? void 0 : layoutConfig.typography;
1072
+ if (!typography) {
1073
+ return DEFAULT_TYPOGRAPHY;
1074
+ }
1075
+ if (!typography.font_family) {
1076
+ return {
1077
+ ...DEFAULT_TYPOGRAPHY,
1078
+ ...typography
1079
+ };
1080
+ }
1081
+ return typography;
1082
+ }, shallowEqual);
1083
+ };
1084
+ export const useHMSRoomStyleSheet = function (updater) {
1085
+ let deps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
1086
+ const theme = useHMSRoomTheme();
1087
+ const typography = useHMSRoomTypography();
1088
+ return useMemo(() => updater(theme, typography), [theme, typography, ...deps]);
1089
+ };
1090
+ export const useHMSRoomStyle = function (updater) {
1091
+ let deps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
1092
+ return useHMSRoomStyleSheet((theme, typography) => ({
1093
+ default: updater(theme, typography)
1094
+ }), deps).default;
1095
+ };
882
1096
  //# sourceMappingURL=hooks-util.js.map