@100mslive/react-native-room-kit 0.0.4 → 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 (777) 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/Recording/assets/recording.png +0 -0
  66. package/lib/commonjs/Icons/Recording/assets/recording@2x.png +0 -0
  67. package/lib/commonjs/Icons/Recording/assets/recording@3x.png +0 -0
  68. package/lib/commonjs/Icons/Recording/index.js +34 -0
  69. package/lib/commonjs/Icons/Recording/index.js.map +1 -0
  70. package/lib/commonjs/Icons/RotateCamera/index.js +5 -1
  71. package/lib/commonjs/Icons/RotateCamera/index.js.map +1 -1
  72. package/lib/commonjs/Icons/ScreenShare/index.js +5 -1
  73. package/lib/commonjs/Icons/ScreenShare/index.js.map +1 -1
  74. package/lib/commonjs/Icons/Speaker/index.js +5 -1
  75. package/lib/commonjs/Icons/Speaker/index.js.map +1 -1
  76. package/lib/commonjs/Icons/Star/assets/star.png +0 -0
  77. package/lib/commonjs/Icons/Star/assets/star@2x.png +0 -0
  78. package/lib/commonjs/Icons/Star/assets/star@3x.png +0 -0
  79. package/lib/commonjs/Icons/Star/index.js +34 -0
  80. package/lib/commonjs/Icons/Star/index.js.map +1 -0
  81. package/lib/commonjs/Icons/Stop/assets/stop.png +0 -0
  82. package/lib/commonjs/Icons/Stop/assets/stop@2x.png +0 -0
  83. package/lib/commonjs/Icons/Stop/assets/stop@3x.png +0 -0
  84. package/lib/commonjs/Icons/Stop/index.js +34 -0
  85. package/lib/commonjs/Icons/Stop/index.js.map +1 -0
  86. package/lib/commonjs/Icons/ThreeDots/index.js +5 -1
  87. package/lib/commonjs/Icons/ThreeDots/index.js.map +1 -1
  88. package/lib/commonjs/Icons/Wave/index.js +5 -1
  89. package/lib/commonjs/Icons/Wave/index.js.map +1 -1
  90. package/lib/commonjs/Icons/index.js +110 -0
  91. package/lib/commonjs/Icons/index.js.map +1 -1
  92. package/lib/commonjs/components/AvatarView.js +1 -2
  93. package/lib/commonjs/components/AvatarView.js.map +1 -1
  94. package/lib/commonjs/components/BackButton.js +6 -4
  95. package/lib/commonjs/components/BackButton.js.map +1 -1
  96. package/lib/commonjs/components/BottomSheet.js +157 -0
  97. package/lib/commonjs/components/BottomSheet.js.map +1 -0
  98. package/lib/commonjs/components/ChangeNameModalContent.js +131 -0
  99. package/lib/commonjs/components/ChangeNameModalContent.js.map +1 -0
  100. package/lib/commonjs/components/CompanyLogo.js +38 -0
  101. package/lib/commonjs/components/CompanyLogo.js.map +1 -0
  102. package/lib/commonjs/components/CustomInput.js +2 -3
  103. package/lib/commonjs/components/CustomInput.js.map +1 -1
  104. package/lib/commonjs/components/DisplayView.js +12 -52
  105. package/lib/commonjs/components/DisplayView.js.map +1 -1
  106. package/lib/commonjs/components/EndRoomModalContent.js +85 -0
  107. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -0
  108. package/lib/commonjs/components/Footer.js +8 -9
  109. package/lib/commonjs/components/Footer.js.map +1 -1
  110. package/lib/commonjs/components/GridView.js +53 -7
  111. package/lib/commonjs/components/GridView.js.map +1 -1
  112. package/lib/commonjs/components/HMSBaseButton.js +66 -0
  113. package/lib/commonjs/components/HMSBaseButton.js.map +1 -0
  114. package/lib/commonjs/components/HMSDangerButton.js +53 -0
  115. package/lib/commonjs/components/HMSDangerButton.js.map +1 -0
  116. package/lib/commonjs/components/HMSHLSStreamLoading.js +17 -8
  117. package/lib/commonjs/components/HMSHLSStreamLoading.js.map +1 -1
  118. package/lib/commonjs/components/HMSManageAudioOutput.js +41 -75
  119. package/lib/commonjs/components/HMSManageAudioOutput.js.map +1 -1
  120. package/lib/commonjs/components/HMSManageCameraRotation.js +5 -4
  121. package/lib/commonjs/components/HMSManageCameraRotation.js.map +1 -1
  122. package/lib/commonjs/components/HMSManageLeave.js +91 -106
  123. package/lib/commonjs/components/HMSManageLeave.js.map +1 -1
  124. package/lib/commonjs/components/HMSManageLocalAudio.js +1 -9
  125. package/lib/commonjs/components/HMSManageLocalAudio.js.map +1 -1
  126. package/lib/commonjs/components/HMSManageLocalVideo.js +1 -9
  127. package/lib/commonjs/components/HMSManageLocalVideo.js.map +1 -1
  128. package/lib/commonjs/components/HMSMeetingEnded.js +1 -2
  129. package/lib/commonjs/components/HMSMeetingEnded.js.map +1 -1
  130. package/lib/commonjs/components/HMSPreviewEditName.js +3 -37
  131. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  132. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +17 -10
  133. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  134. package/lib/commonjs/components/HMSPreviewJoinButton.js +23 -46
  135. package/lib/commonjs/components/HMSPreviewJoinButton.js.map +1 -1
  136. package/lib/commonjs/components/HMSPreviewNetworkQuality.js +5 -3
  137. package/lib/commonjs/components/HMSPreviewNetworkQuality.js.map +1 -1
  138. package/lib/commonjs/components/HMSPreviewPeersList.js +21 -10
  139. package/lib/commonjs/components/HMSPreviewPeersList.js.map +1 -1
  140. package/lib/commonjs/components/HMSPreviewSubtitle.js +22 -9
  141. package/lib/commonjs/components/HMSPreviewSubtitle.js.map +1 -1
  142. package/lib/commonjs/components/HMSPreviewTile.js +16 -8
  143. package/lib/commonjs/components/HMSPreviewTile.js.map +1 -1
  144. package/lib/commonjs/components/HMSPreviewTitle.js +14 -6
  145. package/lib/commonjs/components/HMSPreviewTitle.js.map +1 -1
  146. package/lib/commonjs/components/HMSPrimaryButton.js +53 -0
  147. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -0
  148. package/lib/commonjs/components/HMSRecordingIndicator.js +46 -0
  149. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -0
  150. package/lib/commonjs/components/HMSRoomOptions.js +20 -7
  151. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  152. package/lib/commonjs/components/HMSShowNetworkQuality.js +5 -4
  153. package/lib/commonjs/components/HMSShowNetworkQuality.js.map +1 -1
  154. package/lib/commonjs/components/HMSTextInput.js +66 -0
  155. package/lib/commonjs/components/HMSTextInput.js.map +1 -0
  156. package/lib/commonjs/components/Header.js +30 -30
  157. package/lib/commonjs/components/Header.js.map +1 -1
  158. package/lib/commonjs/components/LocalPeerRegularVideoView.js +26 -0
  159. package/lib/commonjs/components/LocalPeerRegularVideoView.js.map +1 -0
  160. package/lib/commonjs/components/LocalPeerScreenshareView.js +76 -0
  161. package/lib/commonjs/components/LocalPeerScreenshareView.js.map +1 -0
  162. package/lib/commonjs/components/Meeting.js +7 -3
  163. package/lib/commonjs/components/Meeting.js.map +1 -1
  164. package/lib/commonjs/components/MiniView.js +163 -0
  165. package/lib/commonjs/components/MiniView.js.map +1 -0
  166. package/lib/commonjs/components/Modals.js +31 -116
  167. package/lib/commonjs/components/Modals.js.map +1 -1
  168. package/lib/commonjs/components/PaginationDots.js +56 -0
  169. package/lib/commonjs/components/PaginationDots.js.map +1 -0
  170. package/lib/commonjs/components/ParticipantsCount.js +55 -0
  171. package/lib/commonjs/components/ParticipantsCount.js.map +1 -0
  172. package/lib/commonjs/components/PeerMinimizedView.js +114 -0
  173. package/lib/commonjs/components/PeerMinimizedView.js.map +1 -0
  174. package/lib/commonjs/components/PeerSettingsModalContent.js +68 -51
  175. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  176. package/lib/commonjs/components/PeerVideoTile/AvatarView.js +76 -0
  177. package/lib/commonjs/components/PeerVideoTile/AvatarView.js.map +1 -0
  178. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js +44 -0
  179. package/lib/commonjs/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  180. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js +44 -0
  181. package/lib/commonjs/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  182. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js +74 -0
  183. package/lib/commonjs/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  184. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js +146 -0
  185. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  186. package/lib/commonjs/components/PeerVideoTile/VideoView.js +84 -0
  187. package/lib/commonjs/components/PeerVideoTile/VideoView.js.map +1 -0
  188. package/lib/commonjs/components/PeerVideoTile/index.js +2 -0
  189. package/lib/commonjs/components/PeerVideoTile/index.js.map +1 -0
  190. package/lib/commonjs/components/PressableIcon.js +15 -8
  191. package/lib/commonjs/components/PressableIcon.js.map +1 -1
  192. package/lib/commonjs/components/Preview.js +19 -6
  193. package/lib/commonjs/components/Preview.js.map +1 -1
  194. package/lib/commonjs/components/RoomSettingsModalContent.js +232 -362
  195. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  196. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +295 -0
  197. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  198. package/lib/commonjs/components/StopRecordingModalContent.js +97 -0
  199. package/lib/commonjs/components/StopRecordingModalContent.js.map +1 -0
  200. package/lib/commonjs/components/Tile.js +29 -90
  201. package/lib/commonjs/components/Tile.js.map +1 -1
  202. package/lib/commonjs/components/TilesContainer.js +99 -10
  203. package/lib/commonjs/components/TilesContainer.js.map +1 -1
  204. package/lib/commonjs/components/UnmountAfterDelay.js +48 -0
  205. package/lib/commonjs/components/UnmountAfterDelay.js.map +1 -0
  206. package/lib/commonjs/components/WebrtcView.js +51 -0
  207. package/lib/commonjs/components/WebrtcView.js.map +1 -0
  208. package/lib/commonjs/components/WelcomeInMeeting.js +54 -0
  209. package/lib/commonjs/components/WelcomeInMeeting.js.map +1 -0
  210. package/lib/commonjs/hooks-sdk-selectors.js +6 -1
  211. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  212. package/lib/commonjs/hooks-sdk.js +16 -1
  213. package/lib/commonjs/hooks-sdk.js.map +1 -1
  214. package/lib/commonjs/hooks-util-selectors.js +8 -2
  215. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  216. package/lib/commonjs/hooks-util.js +315 -93
  217. package/lib/commonjs/hooks-util.js.map +1 -1
  218. package/lib/commonjs/modules/HMSManager.js +23 -0
  219. package/lib/commonjs/modules/HMSManager.js.map +1 -0
  220. package/lib/commonjs/modules/parser.js +22 -0
  221. package/lib/commonjs/modules/parser.js.map +1 -0
  222. package/lib/commonjs/peerTrackNodeUtils.js +8 -3
  223. package/lib/commonjs/peerTrackNodeUtils.js.map +1 -1
  224. package/lib/commonjs/redux/actionTypes.js +16 -1
  225. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  226. package/lib/commonjs/redux/actions/index.js +51 -1
  227. package/lib/commonjs/redux/actions/index.js.map +1 -1
  228. package/lib/commonjs/redux/reducers/appState.js +57 -1
  229. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  230. package/lib/commonjs/redux/reducers/hmsStates.js +7 -1
  231. package/lib/commonjs/redux/reducers/hmsStates.js.map +1 -1
  232. package/lib/commonjs/redux/reducers/userState.js +3 -1
  233. package/lib/commonjs/redux/reducers/userState.js.map +1 -1
  234. package/lib/commonjs/utils/functions.js +51 -1
  235. package/lib/commonjs/utils/functions.js.map +1 -1
  236. package/lib/commonjs/utils/theme.js +62 -8
  237. package/lib/commonjs/utils/theme.js.map +1 -1
  238. package/lib/commonjs/utils/types.js +8 -1
  239. package/lib/commonjs/utils/types.js.map +1 -1
  240. package/lib/module/HMSInstanceSetup.js +2 -1
  241. package/lib/module/HMSInstanceSetup.js.map +1 -1
  242. package/lib/module/HMSPrebuilt.js +4 -2
  243. package/lib/module/HMSPrebuilt.js.map +1 -1
  244. package/lib/module/HMSRoomSetup.js +41 -10
  245. package/lib/module/HMSRoomSetup.js.map +1 -1
  246. package/lib/module/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  247. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  248. package/lib/module/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  249. package/lib/module/Icons/AlertTriangle/index.js +26 -0
  250. package/lib/module/Icons/AlertTriangle/index.js.map +1 -0
  251. package/lib/module/Icons/AnswerPhone/index.js +5 -1
  252. package/lib/module/Icons/AnswerPhone/index.js.map +1 -1
  253. package/lib/module/Icons/BRB/assets/BRB.png +0 -0
  254. package/lib/module/Icons/BRB/assets/BRB@2x.png +0 -0
  255. package/lib/module/Icons/BRB/assets/BRB@3x.png +0 -0
  256. package/lib/module/Icons/BRB/index.js +27 -0
  257. package/lib/module/Icons/BRB/index.js.map +1 -0
  258. package/lib/module/Icons/Bluetooth/index.js +5 -1
  259. package/lib/module/Icons/Bluetooth/index.js.map +1 -1
  260. package/lib/module/Icons/Camera/index.js +5 -1
  261. package/lib/module/Icons/Camera/index.js.map +1 -1
  262. package/lib/module/Icons/Chat/index.js +5 -1
  263. package/lib/module/Icons/Chat/index.js.map +1 -1
  264. package/lib/module/Icons/Check/index.js +5 -1
  265. package/lib/module/Icons/Check/index.js.map +1 -1
  266. package/lib/module/Icons/Chevron/index.js +5 -1
  267. package/lib/module/Icons/Chevron/index.js.map +1 -1
  268. package/lib/module/Icons/Close/index.js +5 -1
  269. package/lib/module/Icons/Close/index.js.map +1 -1
  270. package/lib/module/Icons/Hamburger/assets/hamburger.png +0 -0
  271. package/lib/module/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  272. package/lib/module/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  273. package/lib/module/Icons/Hamburger/index.js +26 -0
  274. package/lib/module/Icons/Hamburger/index.js.map +1 -0
  275. package/lib/module/Icons/Hand/index.js +6 -4
  276. package/lib/module/Icons/Hand/index.js.map +1 -1
  277. package/lib/module/Icons/Headphones/index.js +5 -1
  278. package/lib/module/Icons/Headphones/index.js.map +1 -1
  279. package/lib/module/Icons/Maximize/assets/maximize.png +0 -0
  280. package/lib/module/Icons/Maximize/assets/maximize@2x.png +0 -0
  281. package/lib/module/Icons/Maximize/assets/maximize@3x.png +0 -0
  282. package/lib/module/Icons/Maximize/index.js +26 -0
  283. package/lib/module/Icons/Maximize/index.js.map +1 -0
  284. package/lib/module/Icons/Mic/index.js +5 -1
  285. package/lib/module/Icons/Mic/index.js.map +1 -1
  286. package/lib/module/Icons/Minimize/assets/minimize.png +0 -0
  287. package/lib/module/Icons/Minimize/assets/minimize@2x.png +0 -0
  288. package/lib/module/Icons/Minimize/assets/minimize@3x.png +0 -0
  289. package/lib/module/Icons/Minimize/index.js +26 -0
  290. package/lib/module/Icons/Minimize/index.js.map +1 -0
  291. package/lib/module/Icons/Participants/index.js +5 -1
  292. package/lib/module/Icons/Participants/index.js.map +1 -1
  293. package/lib/module/Icons/Pencil/assets/pencil.png +0 -0
  294. package/lib/module/Icons/Pencil/assets/pencil@2x.png +0 -0
  295. package/lib/module/Icons/Pencil/assets/pencil@3x.png +0 -0
  296. package/lib/module/Icons/Pencil/index.js +26 -0
  297. package/lib/module/Icons/Pencil/index.js.map +1 -0
  298. package/lib/module/Icons/Pin/assets/pin.png +0 -0
  299. package/lib/module/Icons/Pin/assets/pin@2x.png +0 -0
  300. package/lib/module/Icons/Pin/assets/pin@3x.png +0 -0
  301. package/lib/module/Icons/Pin/index.js +26 -0
  302. package/lib/module/Icons/Pin/index.js.map +1 -0
  303. package/lib/module/Icons/Recording/assets/recording.png +0 -0
  304. package/lib/module/Icons/Recording/assets/recording@2x.png +0 -0
  305. package/lib/module/Icons/Recording/assets/recording@3x.png +0 -0
  306. package/lib/module/Icons/Recording/index.js +26 -0
  307. package/lib/module/Icons/Recording/index.js.map +1 -0
  308. package/lib/module/Icons/RotateCamera/index.js +5 -1
  309. package/lib/module/Icons/RotateCamera/index.js.map +1 -1
  310. package/lib/module/Icons/ScreenShare/index.js +5 -1
  311. package/lib/module/Icons/ScreenShare/index.js.map +1 -1
  312. package/lib/module/Icons/Speaker/index.js +5 -1
  313. package/lib/module/Icons/Speaker/index.js.map +1 -1
  314. package/lib/module/Icons/Star/assets/star.png +0 -0
  315. package/lib/module/Icons/Star/assets/star@2x.png +0 -0
  316. package/lib/module/Icons/Star/assets/star@3x.png +0 -0
  317. package/lib/module/Icons/Star/index.js +26 -0
  318. package/lib/module/Icons/Star/index.js.map +1 -0
  319. package/lib/module/Icons/Stop/assets/stop.png +0 -0
  320. package/lib/module/Icons/Stop/assets/stop@2x.png +0 -0
  321. package/lib/module/Icons/Stop/assets/stop@3x.png +0 -0
  322. package/lib/module/Icons/Stop/index.js +26 -0
  323. package/lib/module/Icons/Stop/index.js.map +1 -0
  324. package/lib/module/Icons/ThreeDots/index.js +5 -1
  325. package/lib/module/Icons/ThreeDots/index.js.map +1 -1
  326. package/lib/module/Icons/Wave/index.js +5 -1
  327. package/lib/module/Icons/Wave/index.js.map +1 -1
  328. package/lib/module/Icons/index.js +10 -0
  329. package/lib/module/Icons/index.js.map +1 -1
  330. package/lib/module/components/AvatarView.js +1 -2
  331. package/lib/module/components/AvatarView.js.map +1 -1
  332. package/lib/module/components/BackButton.js +6 -4
  333. package/lib/module/components/BackButton.js.map +1 -1
  334. package/lib/module/components/BottomSheet.js +146 -0
  335. package/lib/module/components/BottomSheet.js.map +1 -0
  336. package/lib/module/components/ChangeNameModalContent.js +122 -0
  337. package/lib/module/components/ChangeNameModalContent.js.map +1 -0
  338. package/lib/module/components/CompanyLogo.js +30 -0
  339. package/lib/module/components/CompanyLogo.js.map +1 -0
  340. package/lib/module/components/CustomInput.js +2 -3
  341. package/lib/module/components/CustomInput.js.map +1 -1
  342. package/lib/module/components/DisplayView.js +16 -55
  343. package/lib/module/components/DisplayView.js.map +1 -1
  344. package/lib/module/components/EndRoomModalContent.js +76 -0
  345. package/lib/module/components/EndRoomModalContent.js.map +1 -0
  346. package/lib/module/components/Footer.js +9 -10
  347. package/lib/module/components/Footer.js.map +1 -1
  348. package/lib/module/components/GridView.js +55 -10
  349. package/lib/module/components/GridView.js.map +1 -1
  350. package/lib/module/components/HMSBaseButton.js +57 -0
  351. package/lib/module/components/HMSBaseButton.js.map +1 -0
  352. package/lib/module/components/HMSDangerButton.js +44 -0
  353. package/lib/module/components/HMSDangerButton.js.map +1 -0
  354. package/lib/module/components/HMSHLSStreamLoading.js +17 -8
  355. package/lib/module/components/HMSHLSStreamLoading.js.map +1 -1
  356. package/lib/module/components/HMSManageAudioOutput.js +42 -77
  357. package/lib/module/components/HMSManageAudioOutput.js.map +1 -1
  358. package/lib/module/components/HMSManageCameraRotation.js +5 -4
  359. package/lib/module/components/HMSManageCameraRotation.js.map +1 -1
  360. package/lib/module/components/HMSManageLeave.js +94 -107
  361. package/lib/module/components/HMSManageLeave.js.map +1 -1
  362. package/lib/module/components/HMSManageLocalAudio.js +1 -9
  363. package/lib/module/components/HMSManageLocalAudio.js.map +1 -1
  364. package/lib/module/components/HMSManageLocalVideo.js +1 -9
  365. package/lib/module/components/HMSManageLocalVideo.js.map +1 -1
  366. package/lib/module/components/HMSMeetingEnded.js +1 -2
  367. package/lib/module/components/HMSMeetingEnded.js.map +1 -1
  368. package/lib/module/components/HMSPreviewEditName.js +3 -37
  369. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  370. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +17 -10
  371. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  372. package/lib/module/components/HMSPreviewJoinButton.js +26 -49
  373. package/lib/module/components/HMSPreviewJoinButton.js.map +1 -1
  374. package/lib/module/components/HMSPreviewNetworkQuality.js +6 -4
  375. package/lib/module/components/HMSPreviewNetworkQuality.js.map +1 -1
  376. package/lib/module/components/HMSPreviewPeersList.js +21 -10
  377. package/lib/module/components/HMSPreviewPeersList.js.map +1 -1
  378. package/lib/module/components/HMSPreviewSubtitle.js +22 -9
  379. package/lib/module/components/HMSPreviewSubtitle.js.map +1 -1
  380. package/lib/module/components/HMSPreviewTile.js +16 -8
  381. package/lib/module/components/HMSPreviewTile.js.map +1 -1
  382. package/lib/module/components/HMSPreviewTitle.js +14 -6
  383. package/lib/module/components/HMSPreviewTitle.js.map +1 -1
  384. package/lib/module/components/HMSPrimaryButton.js +44 -0
  385. package/lib/module/components/HMSPrimaryButton.js.map +1 -0
  386. package/lib/module/components/HMSRecordingIndicator.js +37 -0
  387. package/lib/module/components/HMSRecordingIndicator.js.map +1 -0
  388. package/lib/module/components/HMSRoomOptions.js +21 -8
  389. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  390. package/lib/module/components/HMSShowNetworkQuality.js +6 -5
  391. package/lib/module/components/HMSShowNetworkQuality.js.map +1 -1
  392. package/lib/module/components/HMSTextInput.js +57 -0
  393. package/lib/module/components/HMSTextInput.js.map +1 -0
  394. package/lib/module/components/Header.js +32 -32
  395. package/lib/module/components/Header.js.map +1 -1
  396. package/lib/module/components/LocalPeerRegularVideoView.js +17 -0
  397. package/lib/module/components/LocalPeerRegularVideoView.js.map +1 -0
  398. package/lib/module/components/LocalPeerScreenshareView.js +66 -0
  399. package/lib/module/components/LocalPeerScreenshareView.js.map +1 -0
  400. package/lib/module/components/Meeting.js +8 -4
  401. package/lib/module/components/Meeting.js.map +1 -1
  402. package/lib/module/components/MiniView.js +154 -0
  403. package/lib/module/components/MiniView.js.map +1 -0
  404. package/lib/module/components/Modals.js +31 -114
  405. package/lib/module/components/Modals.js.map +1 -1
  406. package/lib/module/components/PaginationDots.js +47 -0
  407. package/lib/module/components/PaginationDots.js.map +1 -0
  408. package/lib/module/components/ParticipantsCount.js +46 -0
  409. package/lib/module/components/ParticipantsCount.js.map +1 -0
  410. package/lib/module/components/PeerMinimizedView.js +104 -0
  411. package/lib/module/components/PeerMinimizedView.js.map +1 -0
  412. package/lib/module/components/PeerSettingsModalContent.js +71 -54
  413. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  414. package/lib/module/components/PeerVideoTile/AvatarView.js +66 -0
  415. package/lib/module/components/PeerVideoTile/AvatarView.js.map +1 -0
  416. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js +35 -0
  417. package/lib/module/components/PeerVideoTile/PeerAudioMutedIndicator.js.map +1 -0
  418. package/lib/module/components/PeerVideoTile/PeerMetadata.js +35 -0
  419. package/lib/module/components/PeerVideoTile/PeerMetadata.js.map +1 -0
  420. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js +65 -0
  421. package/lib/module/components/PeerVideoTile/PeerNameAndNetwork.js.map +1 -0
  422. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js +136 -0
  423. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -0
  424. package/lib/module/components/PeerVideoTile/VideoView.js +75 -0
  425. package/lib/module/components/PeerVideoTile/VideoView.js.map +1 -0
  426. package/lib/module/components/PeerVideoTile/index.js +2 -0
  427. package/lib/module/components/PeerVideoTile/index.js.map +1 -0
  428. package/lib/module/components/PressableIcon.js +15 -8
  429. package/lib/module/components/PressableIcon.js.map +1 -1
  430. package/lib/module/components/Preview.js +19 -6
  431. package/lib/module/components/Preview.js.map +1 -1
  432. package/lib/module/components/RoomSettingsModalContent.js +233 -364
  433. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  434. package/lib/module/components/RoomSettingsModalDebugModeContent.js +287 -0
  435. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -0
  436. package/lib/module/components/StopRecordingModalContent.js +88 -0
  437. package/lib/module/components/StopRecordingModalContent.js.map +1 -0
  438. package/lib/module/components/Tile.js +30 -91
  439. package/lib/module/components/Tile.js.map +1 -1
  440. package/lib/module/components/TilesContainer.js +100 -10
  441. package/lib/module/components/TilesContainer.js.map +1 -1
  442. package/lib/module/components/UnmountAfterDelay.js +39 -0
  443. package/lib/module/components/UnmountAfterDelay.js.map +1 -0
  444. package/lib/module/components/WebrtcView.js +41 -0
  445. package/lib/module/components/WebrtcView.js.map +1 -0
  446. package/lib/module/components/WelcomeInMeeting.js +45 -0
  447. package/lib/module/components/WelcomeInMeeting.js.map +1 -0
  448. package/lib/module/hooks-sdk-selectors.js +4 -0
  449. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  450. package/lib/module/hooks-sdk.js +16 -1
  451. package/lib/module/hooks-sdk.js.map +1 -1
  452. package/lib/module/hooks-util-selectors.js +8 -2
  453. package/lib/module/hooks-util-selectors.js.map +1 -1
  454. package/lib/module/hooks-util.js +310 -96
  455. package/lib/module/hooks-util.js.map +1 -1
  456. package/lib/module/modules/HMSManager.js +17 -0
  457. package/lib/module/modules/HMSManager.js.map +1 -0
  458. package/lib/module/modules/parser.js +16 -0
  459. package/lib/module/modules/parser.js.map +1 -0
  460. package/lib/module/peerTrackNodeUtils.js +6 -2
  461. package/lib/module/peerTrackNodeUtils.js.map +1 -1
  462. package/lib/module/redux/actionTypes.js +16 -1
  463. package/lib/module/redux/actionTypes.js.map +1 -1
  464. package/lib/module/redux/actions/index.js +42 -0
  465. package/lib/module/redux/actions/index.js.map +1 -1
  466. package/lib/module/redux/reducers/appState.js +57 -1
  467. package/lib/module/redux/reducers/appState.js.map +1 -1
  468. package/lib/module/redux/reducers/hmsStates.js +7 -1
  469. package/lib/module/redux/reducers/hmsStates.js.map +1 -1
  470. package/lib/module/redux/reducers/userState.js +3 -1
  471. package/lib/module/redux/reducers/userState.js.map +1 -1
  472. package/lib/module/utils/functions.js +47 -0
  473. package/lib/module/utils/functions.js.map +1 -1
  474. package/lib/module/utils/theme.js +57 -5
  475. package/lib/module/utils/theme.js.map +1 -1
  476. package/lib/module/utils/types.js +6 -0
  477. package/lib/module/utils/types.js.map +1 -1
  478. package/lib/typescript/HMSInstanceSetup.d.ts.map +1 -1
  479. package/lib/typescript/HMSPrebuilt.d.ts +1 -0
  480. package/lib/typescript/HMSPrebuilt.d.ts.map +1 -1
  481. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  482. package/lib/typescript/Icons/AlertTriangle/index.d.ts +7 -0
  483. package/lib/typescript/Icons/AlertTriangle/index.d.ts.map +1 -0
  484. package/lib/typescript/Icons/AnswerPhone/index.d.ts.map +1 -1
  485. package/lib/typescript/Icons/BRB/index.d.ts +7 -0
  486. package/lib/typescript/Icons/BRB/index.d.ts.map +1 -0
  487. package/lib/typescript/Icons/Bluetooth/index.d.ts.map +1 -1
  488. package/lib/typescript/Icons/Camera/index.d.ts.map +1 -1
  489. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  490. package/lib/typescript/Icons/Check/index.d.ts.map +1 -1
  491. package/lib/typescript/Icons/Chevron/index.d.ts.map +1 -1
  492. package/lib/typescript/Icons/Close/index.d.ts.map +1 -1
  493. package/lib/typescript/Icons/Hamburger/index.d.ts +7 -0
  494. package/lib/typescript/Icons/Hamburger/index.d.ts.map +1 -0
  495. package/lib/typescript/Icons/Hand/index.d.ts.map +1 -1
  496. package/lib/typescript/Icons/Headphones/index.d.ts.map +1 -1
  497. package/lib/typescript/Icons/Maximize/index.d.ts +7 -0
  498. package/lib/typescript/Icons/Maximize/index.d.ts.map +1 -0
  499. package/lib/typescript/Icons/Mic/index.d.ts.map +1 -1
  500. package/lib/typescript/Icons/Minimize/index.d.ts +7 -0
  501. package/lib/typescript/Icons/Minimize/index.d.ts.map +1 -0
  502. package/lib/typescript/Icons/Participants/index.d.ts.map +1 -1
  503. package/lib/typescript/Icons/Pencil/index.d.ts +7 -0
  504. package/lib/typescript/Icons/Pencil/index.d.ts.map +1 -0
  505. package/lib/typescript/Icons/Pin/index.d.ts +7 -0
  506. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -0
  507. package/lib/typescript/Icons/Recording/index.d.ts +7 -0
  508. package/lib/typescript/Icons/Recording/index.d.ts.map +1 -0
  509. package/lib/typescript/Icons/RotateCamera/index.d.ts.map +1 -1
  510. package/lib/typescript/Icons/ScreenShare/index.d.ts.map +1 -1
  511. package/lib/typescript/Icons/Speaker/index.d.ts.map +1 -1
  512. package/lib/typescript/Icons/Star/index.d.ts +7 -0
  513. package/lib/typescript/Icons/Star/index.d.ts.map +1 -0
  514. package/lib/typescript/Icons/Stop/index.d.ts +7 -0
  515. package/lib/typescript/Icons/Stop/index.d.ts.map +1 -0
  516. package/lib/typescript/Icons/ThreeDots/index.d.ts.map +1 -1
  517. package/lib/typescript/Icons/Wave/index.d.ts.map +1 -1
  518. package/lib/typescript/Icons/index.d.ts +10 -0
  519. package/lib/typescript/Icons/index.d.ts.map +1 -1
  520. package/lib/typescript/components/BackButton.d.ts.map +1 -1
  521. package/lib/typescript/components/BottomSheet.d.ts +25 -0
  522. package/lib/typescript/components/BottomSheet.d.ts.map +1 -0
  523. package/lib/typescript/components/ChangeNameModalContent.d.ts +6 -0
  524. package/lib/typescript/components/ChangeNameModalContent.d.ts.map +1 -0
  525. package/lib/typescript/components/CompanyLogo.d.ts +7 -0
  526. package/lib/typescript/components/CompanyLogo.d.ts.map +1 -0
  527. package/lib/typescript/components/CustomInput.d.ts +1 -1
  528. package/lib/typescript/components/CustomInput.d.ts.map +1 -1
  529. package/lib/typescript/components/DisplayView.d.ts.map +1 -1
  530. package/lib/typescript/components/EndRoomModalContent.d.ts +6 -0
  531. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -0
  532. package/lib/typescript/components/Footer.d.ts.map +1 -1
  533. package/lib/typescript/components/GridView.d.ts +3 -4
  534. package/lib/typescript/components/GridView.d.ts.map +1 -1
  535. package/lib/typescript/components/HMSBaseButton.d.ts +15 -0
  536. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -0
  537. package/lib/typescript/components/HMSDangerButton.d.ts +12 -0
  538. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -0
  539. package/lib/typescript/components/HMSHLSStreamLoading.d.ts.map +1 -1
  540. package/lib/typescript/components/HMSManageAudioOutput.d.ts.map +1 -1
  541. package/lib/typescript/components/HMSManageLeave.d.ts.map +1 -1
  542. package/lib/typescript/components/HMSManageLocalAudio.d.ts.map +1 -1
  543. package/lib/typescript/components/HMSManageLocalVideo.d.ts.map +1 -1
  544. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  545. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  546. package/lib/typescript/components/HMSPreviewJoinButton.d.ts.map +1 -1
  547. package/lib/typescript/components/HMSPreviewNetworkQuality.d.ts.map +1 -1
  548. package/lib/typescript/components/HMSPreviewPeersList.d.ts.map +1 -1
  549. package/lib/typescript/components/HMSPreviewSubtitle.d.ts.map +1 -1
  550. package/lib/typescript/components/HMSPreviewTile.d.ts.map +1 -1
  551. package/lib/typescript/components/HMSPreviewTitle.d.ts.map +1 -1
  552. package/lib/typescript/components/HMSPrimaryButton.d.ts +12 -0
  553. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -0
  554. package/lib/typescript/components/HMSRecordingIndicator.d.ts +3 -0
  555. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -0
  556. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  557. package/lib/typescript/components/HMSShowNetworkQuality.d.ts.map +1 -1
  558. package/lib/typescript/components/HMSTextInput.d.ts +10 -0
  559. package/lib/typescript/components/HMSTextInput.d.ts.map +1 -0
  560. package/lib/typescript/components/Header.d.ts.map +1 -1
  561. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts +6 -0
  562. package/lib/typescript/components/LocalPeerRegularVideoView.d.ts.map +1 -0
  563. package/lib/typescript/components/LocalPeerScreenshareView.d.ts +3 -0
  564. package/lib/typescript/components/LocalPeerScreenshareView.d.ts.map +1 -0
  565. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  566. package/lib/typescript/components/MiniView.d.ts +9 -0
  567. package/lib/typescript/components/MiniView.d.ts.map +1 -0
  568. package/lib/typescript/components/Modals.d.ts +0 -7
  569. package/lib/typescript/components/Modals.d.ts.map +1 -1
  570. package/lib/typescript/components/PaginationDots.d.ts +6 -0
  571. package/lib/typescript/components/PaginationDots.d.ts.map +1 -0
  572. package/lib/typescript/components/ParticipantsCount.d.ts +3 -0
  573. package/lib/typescript/components/ParticipantsCount.d.ts.map +1 -0
  574. package/lib/typescript/components/PeerMinimizedView.d.ts +12 -0
  575. package/lib/typescript/components/PeerMinimizedView.d.ts.map +1 -0
  576. package/lib/typescript/components/PeerSettingsModalContent.d.ts +1 -0
  577. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  578. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts +9 -0
  579. package/lib/typescript/components/PeerVideoTile/AvatarView.d.ts.map +1 -0
  580. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts +6 -0
  581. package/lib/typescript/components/PeerVideoTile/PeerAudioMutedIndicator.d.ts.map +1 -0
  582. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts +6 -0
  583. package/lib/typescript/components/PeerVideoTile/PeerMetadata.d.ts.map +1 -0
  584. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts +10 -0
  585. package/lib/typescript/components/PeerVideoTile/PeerNameAndNetwork.d.ts.map +1 -0
  586. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts +10 -0
  587. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -0
  588. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts +13 -0
  589. package/lib/typescript/components/PeerVideoTile/VideoView.d.ts.map +1 -0
  590. package/lib/typescript/components/PeerVideoTile/index.d.ts +1 -0
  591. package/lib/typescript/components/PeerVideoTile/index.d.ts.map +1 -0
  592. package/lib/typescript/components/PressableIcon.d.ts.map +1 -1
  593. package/lib/typescript/components/Preview.d.ts.map +1 -1
  594. package/lib/typescript/components/RoomSettingsModalContent.d.ts +2 -2
  595. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  596. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts +17 -0
  597. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -0
  598. package/lib/typescript/components/StopRecordingModalContent.d.ts +6 -0
  599. package/lib/typescript/components/StopRecordingModalContent.d.ts.map +1 -0
  600. package/lib/typescript/components/Tile.d.ts +12 -3
  601. package/lib/typescript/components/Tile.d.ts.map +1 -1
  602. package/lib/typescript/components/TilesContainer.d.ts.map +1 -1
  603. package/lib/typescript/components/UnmountAfterDelay.d.ts +12 -0
  604. package/lib/typescript/components/UnmountAfterDelay.d.ts.map +1 -0
  605. package/lib/typescript/components/WebrtcView.d.ts +10 -0
  606. package/lib/typescript/components/WebrtcView.d.ts.map +1 -0
  607. package/lib/typescript/components/WelcomeInMeeting.d.ts +5 -0
  608. package/lib/typescript/components/WelcomeInMeeting.d.ts.map +1 -0
  609. package/lib/typescript/hooks-sdk-selectors.d.ts +2 -0
  610. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  611. package/lib/typescript/hooks-sdk.d.ts +1 -0
  612. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  613. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  614. package/lib/typescript/hooks-util.d.ts +15 -2
  615. package/lib/typescript/hooks-util.d.ts.map +1 -1
  616. package/lib/typescript/modules/HMSManager.d.ts +4 -0
  617. package/lib/typescript/modules/HMSManager.d.ts.map +1 -0
  618. package/lib/typescript/modules/parser.d.ts +3 -0
  619. package/lib/typescript/modules/parser.d.ts.map +1 -0
  620. package/lib/typescript/peerTrackNodeUtils.d.ts +1 -0
  621. package/lib/typescript/peerTrackNodeUtils.d.ts.map +1 -1
  622. package/lib/typescript/redux/actionTypes.d.ts +9 -1
  623. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  624. package/lib/typescript/redux/actions/index.d.ts +45 -0
  625. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  626. package/lib/typescript/redux/index.d.ts +7 -0
  627. package/lib/typescript/redux/index.d.ts.map +1 -1
  628. package/lib/typescript/redux/reducers/appState.d.ts +5 -0
  629. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  630. package/lib/typescript/redux/reducers/hmsStates.d.ts +7 -1
  631. package/lib/typescript/redux/reducers/hmsStates.d.ts.map +1 -1
  632. package/lib/typescript/redux/reducers/index.d.ts +7 -0
  633. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  634. package/lib/typescript/redux/reducers/userState.d.ts +1 -0
  635. package/lib/typescript/redux/reducers/userState.d.ts.map +1 -1
  636. package/lib/typescript/utils/functions.d.ts +14 -0
  637. package/lib/typescript/utils/functions.d.ts.map +1 -1
  638. package/lib/typescript/utils/theme.d.ts +6 -3
  639. package/lib/typescript/utils/theme.d.ts.map +1 -1
  640. package/lib/typescript/utils/types.d.ts +5 -0
  641. package/lib/typescript/utils/types.d.ts.map +1 -1
  642. package/package.json +3 -1
  643. package/src/HMSInstanceSetup.tsx +1 -0
  644. package/src/HMSPrebuilt.tsx +3 -2
  645. package/src/HMSRoomSetup.tsx +45 -8
  646. package/src/Icons/AlertTriangle/assets/alert-triangle.png +0 -0
  647. package/src/Icons/AlertTriangle/assets/alert-triangle@2x.png +0 -0
  648. package/src/Icons/AlertTriangle/assets/alert-triangle@3x.png +0 -0
  649. package/src/Icons/AlertTriangle/index.tsx +33 -0
  650. package/src/Icons/AnswerPhone/index.tsx +7 -1
  651. package/src/Icons/BRB/assets/BRB.png +0 -0
  652. package/src/Icons/BRB/assets/BRB@2x.png +0 -0
  653. package/src/Icons/BRB/assets/BRB@3x.png +0 -0
  654. package/src/Icons/BRB/index.tsx +31 -0
  655. package/src/Icons/Bluetooth/index.tsx +7 -1
  656. package/src/Icons/Camera/index.tsx +7 -1
  657. package/src/Icons/Chat/index.tsx +7 -1
  658. package/src/Icons/Check/index.tsx +7 -1
  659. package/src/Icons/Chevron/index.tsx +7 -1
  660. package/src/Icons/Close/index.tsx +7 -1
  661. package/src/Icons/Hamburger/assets/hamburger.png +0 -0
  662. package/src/Icons/Hamburger/assets/hamburger@2x.png +0 -0
  663. package/src/Icons/Hamburger/assets/hamburger@3x.png +0 -0
  664. package/src/Icons/Hamburger/index.tsx +33 -0
  665. package/src/Icons/Hand/index.tsx +6 -3
  666. package/src/Icons/Headphones/index.tsx +7 -1
  667. package/src/Icons/Maximize/assets/maximize.png +0 -0
  668. package/src/Icons/Maximize/assets/maximize@2x.png +0 -0
  669. package/src/Icons/Maximize/assets/maximize@3x.png +0 -0
  670. package/src/Icons/Maximize/index.tsx +33 -0
  671. package/src/Icons/Mic/index.tsx +7 -1
  672. package/src/Icons/Minimize/assets/minimize.png +0 -0
  673. package/src/Icons/Minimize/assets/minimize@2x.png +0 -0
  674. package/src/Icons/Minimize/assets/minimize@3x.png +0 -0
  675. package/src/Icons/Minimize/index.tsx +33 -0
  676. package/src/Icons/Participants/index.tsx +7 -1
  677. package/src/Icons/Pencil/assets/pencil.png +0 -0
  678. package/src/Icons/Pencil/assets/pencil@2x.png +0 -0
  679. package/src/Icons/Pencil/assets/pencil@3x.png +0 -0
  680. package/src/Icons/Pencil/index.tsx +33 -0
  681. package/src/Icons/Pin/assets/pin.png +0 -0
  682. package/src/Icons/Pin/assets/pin@2x.png +0 -0
  683. package/src/Icons/Pin/assets/pin@3x.png +0 -0
  684. package/src/Icons/Pin/index.tsx +30 -0
  685. package/src/Icons/Recording/assets/recording.png +0 -0
  686. package/src/Icons/Recording/assets/recording@2x.png +0 -0
  687. package/src/Icons/Recording/assets/recording@3x.png +0 -0
  688. package/src/Icons/Recording/index.tsx +33 -0
  689. package/src/Icons/RotateCamera/index.tsx +7 -1
  690. package/src/Icons/ScreenShare/index.tsx +7 -1
  691. package/src/Icons/Speaker/index.tsx +12 -1
  692. package/src/Icons/Star/assets/star.png +0 -0
  693. package/src/Icons/Star/assets/star@2x.png +0 -0
  694. package/src/Icons/Star/assets/star@3x.png +0 -0
  695. package/src/Icons/Star/index.tsx +30 -0
  696. package/src/Icons/Stop/assets/stop.png +0 -0
  697. package/src/Icons/Stop/assets/stop@2x.png +0 -0
  698. package/src/Icons/Stop/assets/stop@3x.png +0 -0
  699. package/src/Icons/Stop/index.tsx +33 -0
  700. package/src/Icons/ThreeDots/index.tsx +7 -1
  701. package/src/Icons/Wave/index.tsx +7 -1
  702. package/src/Icons/index.ts +10 -0
  703. package/src/components/AvatarView.tsx +1 -2
  704. package/src/components/BackButton.tsx +6 -3
  705. package/src/components/BottomSheet.tsx +191 -0
  706. package/src/components/ChangeNameModalContent.tsx +157 -0
  707. package/src/components/CompanyLogo.tsx +35 -0
  708. package/src/components/CustomInput.tsx +2 -3
  709. package/src/components/DisplayView.tsx +16 -65
  710. package/src/components/EndRoomModalContent.tsx +90 -0
  711. package/src/components/Footer.tsx +7 -7
  712. package/src/components/GridView.tsx +91 -20
  713. package/src/components/HLSView.tsx +1 -1
  714. package/src/components/HMSBaseButton.tsx +91 -0
  715. package/src/components/HMSDangerButton.tsx +65 -0
  716. package/src/components/HMSHLSStreamLoading.tsx +18 -7
  717. package/src/components/HMSManageAudioOutput.tsx +59 -90
  718. package/src/components/HMSManageCameraRotation.tsx +11 -8
  719. package/src/components/HMSManageLeave.tsx +104 -109
  720. package/src/components/HMSManageLocalAudio.tsx +1 -10
  721. package/src/components/HMSManageLocalVideo.tsx +1 -10
  722. package/src/components/HMSMeetingEnded.tsx +1 -2
  723. package/src/components/HMSPreviewEditName.tsx +2 -44
  724. package/src/components/HMSPreviewHLSLiveIndicator.tsx +17 -9
  725. package/src/components/HMSPreviewJoinButton.tsx +33 -71
  726. package/src/components/HMSPreviewNetworkQuality.tsx +7 -4
  727. package/src/components/HMSPreviewPeersList.tsx +23 -13
  728. package/src/components/HMSPreviewSubtitle.tsx +27 -11
  729. package/src/components/HMSPreviewTile.tsx +19 -8
  730. package/src/components/HMSPreviewTitle.tsx +18 -5
  731. package/src/components/HMSPrimaryButton.tsx +63 -0
  732. package/src/components/HMSRecordingIndicator.tsx +37 -0
  733. package/src/components/HMSRoomOptions.tsx +28 -8
  734. package/src/components/HMSShowNetworkQuality.tsx +7 -5
  735. package/src/components/HMSTextInput.tsx +78 -0
  736. package/src/components/Header.tsx +37 -36
  737. package/src/components/LocalPeerRegularVideoView.tsx +28 -0
  738. package/src/components/LocalPeerScreenshareView.tsx +72 -0
  739. package/src/components/Meeting.tsx +10 -3
  740. package/src/components/MiniView.tsx +213 -0
  741. package/src/components/Modals.tsx +1 -110
  742. package/src/components/PaginationDots.tsx +65 -0
  743. package/src/components/ParticipantsCount.tsx +52 -0
  744. package/src/components/PeerMinimizedView.tsx +131 -0
  745. package/src/components/PeerSettingsModalContent.tsx +110 -54
  746. package/src/components/PeerVideoTile/AvatarView.tsx +79 -0
  747. package/src/components/PeerVideoTile/PeerAudioMutedIndicator.tsx +41 -0
  748. package/src/components/PeerVideoTile/PeerMetadata.tsx +46 -0
  749. package/src/components/PeerVideoTile/PeerNameAndNetwork.tsx +81 -0
  750. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +180 -0
  751. package/src/components/PeerVideoTile/VideoView.tsx +104 -0
  752. package/src/components/PeerVideoTile/index.ts +0 -0
  753. package/src/components/PressableIcon.tsx +15 -8
  754. package/src/components/Preview.tsx +24 -6
  755. package/src/components/RoomSettingsModalContent.tsx +236 -524
  756. package/src/components/RoomSettingsModalDebugModeContent.tsx +446 -0
  757. package/src/components/StopRecordingModalContent.tsx +109 -0
  758. package/src/components/Tile.tsx +49 -90
  759. package/src/components/TilesContainer.tsx +116 -14
  760. package/src/components/UnmountAfterDelay.tsx +61 -0
  761. package/src/components/WebrtcView.tsx +72 -0
  762. package/src/components/WelcomeInMeeting.tsx +52 -0
  763. package/src/hooks-sdk-selectors.tsx +7 -0
  764. package/src/hooks-sdk.ts +18 -0
  765. package/src/hooks-util-selectors.tsx +12 -1
  766. package/src/hooks-util.ts +420 -115
  767. package/src/modules/HMSManager.ts +25 -0
  768. package/src/modules/parser.ts +22 -0
  769. package/src/peerTrackNodeUtils.tsx +13 -10
  770. package/src/redux/actionTypes.ts +22 -0
  771. package/src/redux/actions/index.ts +51 -0
  772. package/src/redux/reducers/appState.ts +56 -0
  773. package/src/redux/reducers/hmsStates.ts +15 -1
  774. package/src/redux/reducers/userState.ts +3 -0
  775. package/src/utils/functions.ts +48 -0
  776. package/src/utils/theme.ts +74 -5
  777. package/src/utils/types.ts +6 -0
@@ -0,0 +1,131 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, Text, View } from 'react-native';
3
+
4
+ import { CameraIcon, MaximizeIcon, MicIcon } from '../Icons';
5
+ import { PressableIcon } from './PressableIcon';
6
+ import { useCanPublishAudio, useCanPublishVideo } from '../hooks-sdk';
7
+ import type { PeerTrackNode } from '../utils/types';
8
+ import { selectCanPublishTrackForRole } from '../hooks-sdk-selectors';
9
+ import { useHMSRoomStyleSheet } from '../hooks-util';
10
+
11
+ export const usePeerMinimizedViewDimensions = () => {
12
+ const canPublishAudio = useCanPublishAudio();
13
+ const canPublishVideo = useCanPublishVideo();
14
+
15
+ const iconTakesSpace = 20 + 6; // Width + Right Margin
16
+ const totalWidth = 148;
17
+ const widthLessIconsWidth = totalWidth - 2 * iconTakesSpace;
18
+
19
+ return {
20
+ width:
21
+ widthLessIconsWidth +
22
+ (canPublishAudio ? iconTakesSpace : 0) +
23
+ (canPublishVideo ? iconTakesSpace : 0),
24
+ height: 36,
25
+ };
26
+ };
27
+
28
+ export interface PeerMinimizedViewProps {
29
+ peerTrackNode: PeerTrackNode;
30
+ onMaximizePress(): void;
31
+ }
32
+
33
+ const _PeerMinimizedView: React.FC<PeerMinimizedViewProps> = ({
34
+ peerTrackNode,
35
+ onMaximizePress,
36
+ }) => {
37
+ const peerCanPublishAudio = selectCanPublishTrackForRole(
38
+ peerTrackNode.peer.role,
39
+ 'audio'
40
+ );
41
+ const peerCanPublishVideo = selectCanPublishTrackForRole(
42
+ peerTrackNode.peer.role,
43
+ 'video'
44
+ );
45
+
46
+ const isAudioMuted = peerTrackNode.peer.audioTrack?.isMute();
47
+ const isVideoMuted = peerTrackNode.track?.isMute();
48
+
49
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
50
+ container: {
51
+ backgroundColor: theme.palette.surface_default,
52
+ },
53
+ iconWrapper: {
54
+ backgroundColor: theme.palette.surface_bright,
55
+ },
56
+ name: {
57
+ color: theme.palette.on_surface_high,
58
+ fontFamily: `${typography.font_family}-Regular`,
59
+ },
60
+ }));
61
+
62
+ return (
63
+ <View style={[styles.container, hmsRoomStyles.container]}>
64
+ <View style={styles.wrapper}>
65
+ {peerCanPublishAudio ? (
66
+ <View style={[styles.iconWrapper, hmsRoomStyles.iconWrapper]}>
67
+ <MicIcon muted={!!isAudioMuted} style={styles.icon} />
68
+ </View>
69
+ ) : null}
70
+
71
+ {peerCanPublishVideo ? (
72
+ <View style={[styles.iconWrapper, hmsRoomStyles.iconWrapper]}>
73
+ <CameraIcon muted={!!isVideoMuted} style={styles.icon} />
74
+ </View>
75
+ ) : null}
76
+
77
+ <Text style={[styles.name, hmsRoomStyles.name]} numberOfLines={1}>
78
+ {peerTrackNode.peer.isLocal ? 'You' : peerTrackNode.peer.name}
79
+ </Text>
80
+ </View>
81
+
82
+ <PressableIcon
83
+ border={false}
84
+ style={styles.maximizeBtn}
85
+ onPress={onMaximizePress}
86
+ >
87
+ <MaximizeIcon style={styles.maximizeIcon} />
88
+ </PressableIcon>
89
+ </View>
90
+ );
91
+ };
92
+
93
+ const styles = StyleSheet.create({
94
+ container: {
95
+ flex: 1,
96
+ flexDirection: 'row',
97
+ padding: 8,
98
+ alignItems: 'center',
99
+ justifyContent: 'space-between',
100
+ borderRadius: 8,
101
+ },
102
+ wrapper: {
103
+ flexDirection: 'row',
104
+ alignItems: 'center',
105
+ },
106
+ iconWrapper: {
107
+ padding: 2,
108
+ marginRight: 6,
109
+ borderRadius: 4,
110
+ },
111
+ icon: {
112
+ width: 16,
113
+ height: 16,
114
+ },
115
+ name: {
116
+ maxWidth: 48,
117
+ fontSize: 14,
118
+ lineHeight: 20,
119
+ letterSpacing: 0.25,
120
+ marginRight: 12,
121
+ },
122
+ maximizeBtn: {
123
+ padding: 0,
124
+ },
125
+ maximizeIcon: {
126
+ width: 20,
127
+ height: 20,
128
+ },
129
+ });
130
+
131
+ export const PeerMinimizedView = React.memo(_PeerMinimizedView);
@@ -1,5 +1,12 @@
1
1
  import React from 'react';
2
- import { View, TouchableOpacity, Text, StyleSheet } from 'react-native';
2
+ import {
3
+ View,
4
+ TouchableOpacity,
5
+ Text,
6
+ StyleSheet,
7
+ LayoutAnimation,
8
+ InteractionManager,
9
+ } from 'react-native';
3
10
  import { batch, useDispatch, useSelector } from 'react-redux';
4
11
  import { HMSTrack, HMSTrackSource } from '@100mslive/react-native-hms';
5
12
  import Ionicons from 'react-native-vector-icons/Ionicons';
@@ -10,11 +17,15 @@ import { COLORS } from '../utils/theme';
10
17
  import { ModalTypes } from '../utils/types';
11
18
  import type { PeerTrackNode } from '../utils/types';
12
19
  import { isTileOnSpotlight } from '../utils/functions';
13
- import { setPeerToUpdate } from '../redux/actions';
14
- import { useModalType } from '../hooks-util';
20
+ import { setInsetViewMinimized, setPeerToUpdate } from '../redux/actions';
21
+ import { useHMSRoomStyle, useModalType } from '../hooks-util';
22
+ import { MinimizeIcon, PinIcon, StarIcon } from '../Icons';
23
+ import { useCanPublishVideo } from '../hooks-sdk';
24
+ import { BottomSheet } from './BottomSheet';
15
25
 
16
26
  interface PeerSettingsModalContentProps {
17
27
  peerTrackNode: PeerTrackNode;
28
+ peerTrackNodesListEmpty: boolean;
18
29
  cancelModal(): void;
19
30
  onCaptureScreenShotPress(node: PeerTrackNode): void;
20
31
  onCaptureImageAtMaxSupportedResolutionPress(node: PeerTrackNode): void;
@@ -25,6 +36,7 @@ export const PeerSettingsModalContent: React.FC<
25
36
  PeerSettingsModalContentProps
26
37
  > = ({
27
38
  peerTrackNode,
39
+ peerTrackNodesListEmpty,
28
40
  cancelModal,
29
41
  onCaptureScreenShotPress,
30
42
  onCaptureImageAtMaxSupportedResolutionPress,
@@ -43,6 +55,7 @@ export const PeerSettingsModalContent: React.FC<
43
55
  );
44
56
  const debugMode = useSelector((state: RootState) => state.user.debugMode);
45
57
  const { handleModalVisibleType: setModalVisible } = useModalType();
58
+ const localPeerCanPublishVideo = useCanPublishVideo();
46
59
 
47
60
  const removePeer = () => {
48
61
  hmsInstance
@@ -79,10 +92,18 @@ export const PeerSettingsModalContent: React.FC<
79
92
  );
80
93
  };
81
94
 
82
- const changeName = () => {
83
- batch(() => {
84
- dispatch(setPeerToUpdate(peerTrackNode.peer));
85
- setModalVisible(ModalTypes.CHANGE_NAME, true);
95
+ // const changeName = () => {
96
+ // batch(() => {
97
+ // dispatch(setPeerToUpdate(peerTrackNode.peer));
98
+ // setModalVisible(ModalTypes.CHANGE_NAME, true);
99
+ // });
100
+ // };
101
+
102
+ const handleMinimizeVideoPress = () => {
103
+ cancelModal();
104
+ InteractionManager.runAfterInteractions(() => {
105
+ LayoutAnimation.configureNext(LayoutAnimation.Presets.easeInEaseOut);
106
+ dispatch(setInsetViewMinimized(true));
86
107
  });
87
108
  };
88
109
 
@@ -132,21 +153,46 @@ export const PeerSettingsModalContent: React.FC<
132
153
  const isPeerVideoMute = peer.isLocal ? null : peer.videoTrack?.isMute();
133
154
 
134
155
  return (
135
- <View style={styles.container}>
136
- <Text style={styles.roleChangeModalHeading}>
137
- {peer.name}
138
- {peer.isLocal ? ' (You)' : ''}
139
- </Text>
140
- <Text style={styles.participantRole}>{peer.role?.name}</Text>
156
+ <View>
157
+ <BottomSheet.Header
158
+ dismissModal={cancelModal}
159
+ heading={peer.name + (peer.isLocal ? ' (You)' : '')}
160
+ subheading={peer.role?.name}
161
+ />
162
+
163
+ <BottomSheet.Divider />
141
164
 
165
+ {/* Content */}
142
166
  <View style={styles.contentContainer}>
143
- {debugMode ? (
167
+ {peer.isLocal ? ( // TODO: Remove this condition later
144
168
  <SettingItem
145
- text={onSpotlight ? 'Remove from Spotlight' : 'Add to Spotlight'}
146
- IconType={Ionicons}
147
- iconName={onSpotlight ? 'ios-star' : 'ios-star-outline'}
148
- onPress={handleSpotlightPress}
149
- disabled={!peerTrackNode.track?.trackId}
169
+ customIcon={true}
170
+ text={true ? 'Pin Tile for Myself' : 'Unpin Tile for Myself'}
171
+ icon={<PinIcon style={styles.customIcon} />}
172
+ disabled={true}
173
+ onPress={() => {}}
174
+ />
175
+ ) : null}
176
+
177
+ <SettingItem
178
+ customIcon={true}
179
+ text={
180
+ onSpotlight
181
+ ? 'Remove Spotlight for Everyone'
182
+ : 'Spotlight Tile for Everyone'
183
+ }
184
+ icon={<StarIcon style={styles.customIcon} />}
185
+ onPress={handleSpotlightPress}
186
+ disabled={!peerTrackNode.track?.trackId}
187
+ />
188
+
189
+ {peer.isLocal && localPeerCanPublishVideo ? (
190
+ <SettingItem
191
+ customIcon={true}
192
+ text={'Minimize Your Video'}
193
+ icon={<MinimizeIcon style={styles.customIcon} />}
194
+ onPress={handleMinimizeVideoPress}
195
+ disabled={peerTrackNodesListEmpty}
150
196
  />
151
197
  ) : null}
152
198
 
@@ -209,16 +255,16 @@ export const PeerSettingsModalContent: React.FC<
209
255
  />
210
256
  ) : null}
211
257
 
212
- {peer.isLocal ? (
258
+ {/* {peer.isLocal ? (
213
259
  <SettingItem
214
260
  text="Change Name"
215
261
  IconType={MaterialCommunityIcons}
216
262
  iconName={'account-edit-outline'}
217
263
  onPress={() => changeName()}
218
264
  />
219
- ) : null}
265
+ ) : null} */}
220
266
 
221
- {localPeerPermissions?.changeRole ? (
267
+ {!peer.isLocal && localPeerPermissions?.changeRole ? (
222
268
  <SettingItem
223
269
  text="Change Role"
224
270
  IconType={Ionicons}
@@ -273,68 +319,78 @@ export const PeerSettingsModalContent: React.FC<
273
319
  );
274
320
  };
275
321
 
276
- interface SettingItemProps {
322
+ type SettingItemBaseProps = {
277
323
  onPress(): void;
278
324
  text: string;
325
+ disabled?: boolean;
326
+ };
327
+
328
+ type SettingItemWithCustomIconProps = {
329
+ customIcon: true;
330
+ icon: React.ReactElement;
331
+ };
332
+
333
+ type SettingItemWithIconProps = {
334
+ customIcon?: false;
279
335
  iconName: string;
280
336
  IconType: any;
281
- disabled?: boolean;
282
- }
337
+ };
338
+
339
+ type SettingItemProps = SettingItemBaseProps &
340
+ (SettingItemWithCustomIconProps | SettingItemWithIconProps);
283
341
 
284
342
  const SettingItem: React.FC<SettingItemProps> = ({
285
343
  onPress,
286
344
  text,
287
- iconName,
288
- IconType,
289
345
  disabled = false,
346
+ ...resetProps
290
347
  }) => {
348
+ const textStyles = useHMSRoomStyle((theme, typography) => ({
349
+ color: theme.palette.on_surface_high,
350
+ fontFamily: `${typography.font_family}-SemiBold`,
351
+ }));
352
+
291
353
  return (
292
354
  <TouchableOpacity
293
355
  disabled={disabled}
294
356
  style={[styles.button, disabled ? { opacity: 0.6 } : null]}
295
357
  onPress={onPress}
296
358
  >
297
- <IconType name={iconName} size={24} style={styles.icon} />
298
-
299
- <Text style={styles.text}>{text}</Text>
359
+ {resetProps.customIcon ? (
360
+ resetProps.icon
361
+ ) : (
362
+ <resetProps.IconType
363
+ name={resetProps.iconName}
364
+ size={24}
365
+ style={styles.icon}
366
+ />
367
+ )}
368
+
369
+ <Text style={[styles.text, textStyles]}>{text}</Text>
300
370
  </TouchableOpacity>
301
371
  );
302
372
  };
303
373
 
304
374
  const styles = StyleSheet.create({
305
- container: {
306
- padding: 24,
307
- },
308
375
  contentContainer: {
309
- marginTop: 16,
310
- },
311
- roleChangeModalHeading: {
312
- color: COLORS.TEXT.HIGH_EMPHASIS,
313
- fontSize: 20,
314
- lineHeight: 24,
315
- letterSpacing: 0.15,
316
- fontFamily: 'Inter-Medium',
317
- textTransform: 'capitalize',
376
+ marginBottom: 8,
318
377
  },
319
- participantRole: {
320
- color: COLORS.TEXT.MEDIUM_EMPHASIS,
321
- fontSize: 12,
322
- lineHeight: 16,
323
- letterSpacing: 0.4,
324
- marginTop: 4,
325
- fontFamily: 'Inter-Regular',
326
- textTransform: 'capitalize',
378
+ customIcon: {
379
+ width: 20,
380
+ height: 20,
381
+ marginRight: 8,
327
382
  },
328
383
  button: {
329
384
  flexDirection: 'row',
330
385
  alignItems: 'center',
331
- marginVertical: 12,
386
+ paddingVertical: 16,
387
+ paddingHorizontal: 24,
388
+ marginBottom: 8,
332
389
  },
333
390
  text: {
334
- fontFamily: 'Inter-Medium',
335
391
  fontSize: 14,
336
- lineHeight: 24,
337
- color: COLORS.TEXT.HIGH_EMPHASIS,
392
+ lineHeight: 20,
393
+ letterSpacing: 0.1,
338
394
  },
339
395
  icon: {
340
396
  color: COLORS.WHITE,
@@ -0,0 +1,79 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, Text, View } from 'react-native';
3
+
4
+ import { PersonIcon } from '../../Icons';
5
+ import { getInitials } from '../../utils/functions';
6
+ import { COLORS } from '../../utils/theme';
7
+ import type { VideoView } from './VideoView';
8
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
9
+
10
+ export interface AvatarViewProps {
11
+ name: string;
12
+ videoView: React.ReactElement<typeof VideoView> | null;
13
+ }
14
+
15
+ export const _AvatarView: React.FC<AvatarViewProps> = ({ name, videoView }) => {
16
+ const showInitials = !!name && name.length > 0;
17
+
18
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
19
+ avatarContainer: {
20
+ backgroundColor: theme.palette.surface_default,
21
+ },
22
+ avatar: {
23
+ backgroundColor: COLORS.EXTENDED.PURPLE,
24
+ },
25
+ avatarText: {
26
+ color: theme.palette.on_surface_high,
27
+ fontFamily: `${typography.font_family}-SemiBold`,
28
+ },
29
+ }));
30
+
31
+ return (
32
+ <View style={styles.container}>
33
+ {videoView || (
34
+ <View style={[styles.avatarContainer, hmsRoomStyles.avatarContainer]}>
35
+ <View style={[styles.avatar, hmsRoomStyles.avatar]}>
36
+ {showInitials ? (
37
+ <Text style={[styles.avatarText, hmsRoomStyles.avatarText]}>
38
+ {getInitials(name)}
39
+ </Text>
40
+ ) : (
41
+ <PersonIcon style={styles.avatarIcon} />
42
+ )}
43
+ </View>
44
+ </View>
45
+ )}
46
+ </View>
47
+ );
48
+ };
49
+
50
+ const styles = StyleSheet.create({
51
+ container: {
52
+ flex: 1,
53
+ position: 'relative',
54
+ overflow: 'hidden',
55
+ },
56
+ avatarContainer: {
57
+ flex: 1,
58
+ alignItems: 'center',
59
+ justifyContent: 'center',
60
+ },
61
+ avatar: {
62
+ width: 88,
63
+ aspectRatio: 1,
64
+ borderRadius: 44,
65
+ justifyContent: 'center',
66
+ alignItems: 'center',
67
+ },
68
+ avatarIcon: {
69
+ width: 40,
70
+ height: 40,
71
+ },
72
+ avatarText: {
73
+ fontSize: 34,
74
+ lineHeight: 40,
75
+ letterSpacing: 0.25,
76
+ },
77
+ });
78
+
79
+ export const AvatarView = React.memo(_AvatarView);
@@ -0,0 +1,41 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, View } from 'react-native';
3
+
4
+ import { MicIcon } from '../../Icons';
5
+ import { useHMSRoomStyle } from '../../hooks-util';
6
+
7
+ export interface PeerAudioMutedIndicatorProps {
8
+ isMuted: boolean | undefined;
9
+ }
10
+
11
+ export const PeerAudioMutedIndicator: React.FC<
12
+ PeerAudioMutedIndicatorProps
13
+ > = ({ isMuted }) => {
14
+ const iconWrapperStyles = useHMSRoomStyle((theme) => ({
15
+ backgroundColor: theme.palette.secondary_dim,
16
+ }));
17
+
18
+ if (isMuted) {
19
+ return (
20
+ <View style={[styles.iconWrapper, iconWrapperStyles]}>
21
+ <MicIcon muted={true} style={styles.icon} />
22
+ </View>
23
+ );
24
+ }
25
+
26
+ return null;
27
+ };
28
+
29
+ const styles = StyleSheet.create({
30
+ iconWrapper: {
31
+ position: 'absolute',
32
+ top: 8,
33
+ right: 8,
34
+ padding: 8,
35
+ borderRadius: 16,
36
+ },
37
+ icon: {
38
+ width: 16,
39
+ height: 16,
40
+ },
41
+ });
@@ -0,0 +1,46 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, View } from 'react-native';
3
+
4
+ import { parseMetadata } from '../../utils/functions';
5
+ import { BRBIcon, HandIcon } from '../../Icons';
6
+ import { useHMSRoomStyle } from '../../hooks-util';
7
+
8
+ export interface PeerMetadataProps {
9
+ metadata: string | undefined;
10
+ }
11
+
12
+ export const PeerMetadata: React.FC<PeerMetadataProps> = ({ metadata }) => {
13
+ const parsedMetadata = parseMetadata(metadata);
14
+
15
+ const iconWrapperStyles = useHMSRoomStyle((theme) => ({
16
+ backgroundColor: theme.palette.secondary_dim,
17
+ }));
18
+
19
+ if (parsedMetadata.isBRBOn) {
20
+ return (
21
+ <View style={[styles.iconWrapper, iconWrapperStyles]}>
22
+ <BRBIcon />
23
+ </View>
24
+ );
25
+ }
26
+
27
+ if (parsedMetadata.isHandRaised) {
28
+ return (
29
+ <View style={[styles.iconWrapper, iconWrapperStyles]}>
30
+ <HandIcon />
31
+ </View>
32
+ );
33
+ }
34
+
35
+ return null;
36
+ };
37
+
38
+ const styles = StyleSheet.create({
39
+ iconWrapper: {
40
+ position: 'absolute',
41
+ top: 8,
42
+ left: 8,
43
+ padding: 4,
44
+ borderRadius: 16,
45
+ },
46
+ });
@@ -0,0 +1,81 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, Text, View } from 'react-native';
3
+ import { HMSTrackSource } from '@100mslive/react-native-hms';
4
+
5
+ import { hexToRgbA } from '../../utils/theme';
6
+ import { NetworkQualityIcon } from '../../Icons';
7
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
8
+
9
+ export interface PeerNameAndNetworkProps {
10
+ name: string;
11
+ isLocal: boolean | undefined;
12
+ trackSource: HMSTrackSource | undefined;
13
+ networkQuality: number | undefined;
14
+ }
15
+
16
+ export const PeerNameAndNetwork: React.FC<PeerNameAndNetworkProps> = ({
17
+ name,
18
+ isLocal,
19
+ trackSource,
20
+ networkQuality,
21
+ }) => {
22
+ const showTrackSource = trackSource && trackSource !== HMSTrackSource.REGULAR;
23
+
24
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
25
+ contentContainer: {
26
+ backgroundColor: hexToRgbA(theme.palette.background_dim, 0.64),
27
+ },
28
+ name: {
29
+ color: theme.palette.on_surface_high,
30
+ fontFamily: `${typography.font_family}-Regular`,
31
+ },
32
+ }));
33
+
34
+ return (
35
+ <View style={styles.container}>
36
+ <View style={[styles.contentContainer, hmsRoomStyles.contentContainer]}>
37
+ <Text
38
+ style={[styles.name, hmsRoomStyles.name]}
39
+ numberOfLines={1}
40
+ ellipsizeMode={showTrackSource ? 'middle' : 'tail'}
41
+ >
42
+ {name}
43
+ {isLocal ? ' (You)' : ''}
44
+ {showTrackSource ? `'s ${trackSource}` : ''}
45
+ </Text>
46
+
47
+ <NetworkQualityIcon
48
+ quality={networkQuality}
49
+ style={styles.networkIcon}
50
+ />
51
+ </View>
52
+ </View>
53
+ );
54
+ };
55
+
56
+ const styles = StyleSheet.create({
57
+ container: {
58
+ position: 'absolute',
59
+ bottom: 8,
60
+ width: '100%',
61
+ flexDirection: 'row',
62
+ },
63
+ contentContainer: {
64
+ flexDirection: 'row',
65
+ paddingVertical: 4,
66
+ paddingHorizontal: 8,
67
+ borderRadius: 8,
68
+ marginLeft: 8, // left offset
69
+ marginRight: 20 + 4 + 44, // network icon width + network icon left margin + 3 dots button width and horizontal margins
70
+ },
71
+ name: {
72
+ flexGrow: 1,
73
+ flexShrink: 1,
74
+ fontSize: 14,
75
+ lineHeight: 20,
76
+ letterSpacing: 0.25,
77
+ },
78
+ networkIcon: {
79
+ marginLeft: 4,
80
+ },
81
+ });