@100mslive/react-native-room-kit 1.0.6 → 1.0.8

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 (609) hide show
  1. package/lib/commonjs/HMSRoomSetup.js +4 -1
  2. package/lib/commonjs/HMSRoomSetup.js.map +1 -1
  3. package/lib/commonjs/Icons/Chat/assets/chat-on.png +0 -0
  4. package/lib/commonjs/Icons/Chat/assets/chat-on@2x.png +0 -0
  5. package/lib/commonjs/Icons/Chat/assets/chat-on@3x.png +0 -0
  6. package/lib/commonjs/Icons/Chat/index.js +4 -3
  7. package/lib/commonjs/Icons/Chat/index.js.map +1 -1
  8. package/lib/commonjs/Icons/NoEntry/assets/no-entry.png +0 -0
  9. package/lib/commonjs/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  10. package/lib/commonjs/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  11. package/lib/commonjs/Icons/NoEntry/index.js +33 -0
  12. package/lib/commonjs/Icons/NoEntry/index.js.map +1 -0
  13. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle.png +0 -0
  14. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  15. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  16. package/lib/commonjs/Icons/PauseCircle/index.js +29 -0
  17. package/lib/commonjs/Icons/PauseCircle/index.js.map +1 -0
  18. package/lib/commonjs/Icons/Pin/assets/unpin.png +0 -0
  19. package/lib/commonjs/Icons/Pin/assets/unpin@2x.png +0 -0
  20. package/lib/commonjs/Icons/Pin/assets/unpin@3x.png +0 -0
  21. package/lib/commonjs/Icons/Pin/index.js +2 -1
  22. package/lib/commonjs/Icons/Pin/index.js.map +1 -1
  23. package/lib/commonjs/Icons/Recording/assets/recording-pause.png +0 -0
  24. package/lib/commonjs/Icons/Recording/assets/recording-pause@2x.png +0 -0
  25. package/lib/commonjs/Icons/Recording/assets/recording-pause@3x.png +0 -0
  26. package/lib/commonjs/Icons/Recording/index.js +1 -1
  27. package/lib/commonjs/Icons/Recording/index.js.map +1 -1
  28. package/lib/commonjs/Icons/index.js +22 -0
  29. package/lib/commonjs/Icons/index.js.map +1 -1
  30. package/lib/commonjs/components/AnimatedFooter.js +5 -3
  31. package/lib/commonjs/components/AnimatedFooter.js.map +1 -1
  32. package/lib/commonjs/components/AnimatedHLSFooter.js +4 -9
  33. package/lib/commonjs/components/AnimatedHLSFooter.js.map +1 -1
  34. package/lib/commonjs/components/AnimatedHeader.js +17 -5
  35. package/lib/commonjs/components/AnimatedHeader.js.map +1 -1
  36. package/lib/commonjs/components/BottomSheet.js +11 -5
  37. package/lib/commonjs/components/BottomSheet.js.map +1 -1
  38. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js +36 -0
  39. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  40. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js +90 -23
  41. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  42. package/lib/commonjs/components/Chat/ChatFilterBottomSheetView.js +2 -1
  43. package/lib/commonjs/components/Chat/ChatFilterBottomSheetView.js.map +1 -1
  44. package/lib/commonjs/components/Chat/ChatFilterItem.js +10 -7
  45. package/lib/commonjs/components/Chat/ChatFilterItem.js.map +1 -1
  46. package/lib/commonjs/components/Chat/ChatFilterView.js +54 -45
  47. package/lib/commonjs/components/Chat/ChatFilterView.js.map +1 -1
  48. package/lib/commonjs/components/Chat/ChatList.js +13 -6
  49. package/lib/commonjs/components/Chat/ChatList.js.map +1 -1
  50. package/lib/commonjs/components/Chat/ChatMessage.js +79 -7
  51. package/lib/commonjs/components/Chat/ChatMessage.js.map +1 -1
  52. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js +61 -0
  53. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js.map +1 -0
  54. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js +63 -0
  55. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  56. package/lib/commonjs/components/Chat/ChatMoreActionsView.js +83 -0
  57. package/lib/commonjs/components/Chat/ChatMoreActionsView.js.map +1 -0
  58. package/lib/commonjs/components/Chat/ChatPaused.js +86 -0
  59. package/lib/commonjs/components/Chat/ChatPaused.js.map +1 -0
  60. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js +34 -0
  61. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  62. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js +66 -0
  63. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  64. package/lib/commonjs/components/Chat/MessageOptionsView.js +188 -0
  65. package/lib/commonjs/components/Chat/MessageOptionsView.js.map +1 -0
  66. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js +47 -0
  67. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js.map +1 -0
  68. package/lib/commonjs/components/Chat/PinnedMessages.js +297 -0
  69. package/lib/commonjs/components/Chat/PinnedMessages.js.map +1 -0
  70. package/lib/commonjs/components/Chat/index.js +4 -4
  71. package/lib/commonjs/components/Chat/index.js.map +1 -1
  72. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js +11 -10
  73. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  74. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js +21 -2
  75. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  76. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js +8 -4
  77. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  78. package/lib/commonjs/components/ChatAndParticipants/ChatView.js +21 -2
  79. package/lib/commonjs/components/ChatAndParticipants/ChatView.js.map +1 -1
  80. package/lib/commonjs/components/DisplayView.js +4 -11
  81. package/lib/commonjs/components/DisplayView.js.map +1 -1
  82. package/lib/commonjs/components/EndRoomModal.js +1 -2
  83. package/lib/commonjs/components/EndRoomModal.js.map +1 -1
  84. package/lib/commonjs/components/EndRoomModalContent.js +6 -8
  85. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -1
  86. package/lib/commonjs/components/Footer.js +12 -18
  87. package/lib/commonjs/components/Footer.js.map +1 -1
  88. package/lib/commonjs/components/GridView.js +31 -1
  89. package/lib/commonjs/components/GridView.js.map +1 -1
  90. package/lib/commonjs/components/HLSFooter.js +3 -1
  91. package/lib/commonjs/components/HLSFooter.js.map +1 -1
  92. package/lib/commonjs/components/HLSView.js +8 -6
  93. package/lib/commonjs/components/HLSView.js.map +1 -1
  94. package/lib/commonjs/components/HMSBaseButton.js +10 -2
  95. package/lib/commonjs/components/HMSBaseButton.js.map +1 -1
  96. package/lib/commonjs/components/HMSDangerButton.js +4 -2
  97. package/lib/commonjs/components/HMSDangerButton.js.map +1 -1
  98. package/lib/commonjs/components/HMSHLSMessage.js +86 -1
  99. package/lib/commonjs/components/HMSHLSMessage.js.map +1 -1
  100. package/lib/commonjs/components/HMSHLSMessageList.js +2 -2
  101. package/lib/commonjs/components/HMSHLSMessageList.js.map +1 -1
  102. package/lib/commonjs/components/HMSHandRaiseNotification.js +6 -3
  103. package/lib/commonjs/components/HMSHandRaiseNotification.js.map +1 -1
  104. package/lib/commonjs/components/HMSKeyboardAvoidingView.android.js +2 -0
  105. package/lib/commonjs/components/HMSKeyboardAvoidingView.android.js.map +1 -1
  106. package/lib/commonjs/components/HMSKeyboardAvoidingView.js +8 -2
  107. package/lib/commonjs/components/HMSKeyboardAvoidingView.js.map +1 -1
  108. package/lib/commonjs/components/HMSLiveIndicator.js +5 -60
  109. package/lib/commonjs/components/HMSLiveIndicator.js.map +1 -1
  110. package/lib/commonjs/components/HMSLiveViewerCount.js +79 -0
  111. package/lib/commonjs/components/HMSLiveViewerCount.js.map +1 -0
  112. package/lib/commonjs/components/HMSLocalScreenshareNotification.js +2 -1
  113. package/lib/commonjs/components/HMSLocalScreenshareNotification.js.map +1 -1
  114. package/lib/commonjs/components/HMSNotification.js +31 -4
  115. package/lib/commonjs/components/HMSNotification.js.map +1 -1
  116. package/lib/commonjs/components/HMSNotifications.js +9 -2
  117. package/lib/commonjs/components/HMSNotifications.js.map +1 -1
  118. package/lib/commonjs/components/HMSOverlayChatView.js +55 -4
  119. package/lib/commonjs/components/HMSOverlayChatView.js.map +1 -1
  120. package/lib/commonjs/components/HMSPreviewEditName.js +6 -1
  121. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  122. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +2 -5
  123. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  124. package/lib/commonjs/components/HMSPrimaryButton.js +4 -2
  125. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -1
  126. package/lib/commonjs/components/HMSRecordingIndicator.js +12 -7
  127. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -1
  128. package/lib/commonjs/components/HMSRoomOptions.js +3 -6
  129. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  130. package/lib/commonjs/components/HMSTerminalErrorNotification.js +6 -2
  131. package/lib/commonjs/components/HMSTerminalErrorNotification.js.map +1 -1
  132. package/lib/commonjs/components/Header.js +11 -3
  133. package/lib/commonjs/components/Header.js.map +1 -1
  134. package/lib/commonjs/components/LeaveRoomBottomSheet.js +5 -11
  135. package/lib/commonjs/components/LeaveRoomBottomSheet.js.map +1 -1
  136. package/lib/commonjs/components/Meeting.js +5 -13
  137. package/lib/commonjs/components/Meeting.js.map +1 -1
  138. package/lib/commonjs/components/MeetingScreenContent.js +46 -48
  139. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  140. package/lib/commonjs/components/MiniView.js.map +1 -1
  141. package/lib/commonjs/components/Modals.js +9 -12
  142. package/lib/commonjs/components/Modals.js.map +1 -1
  143. package/lib/commonjs/components/OverlayedViews.js +6 -2
  144. package/lib/commonjs/components/OverlayedViews.js.map +1 -1
  145. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js +5 -1
  146. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js.map +1 -1
  147. package/lib/commonjs/components/PeerSettingsModalContent.js +2 -1
  148. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  149. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js +2 -1
  150. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  151. package/lib/commonjs/components/PressableIcon.js +6 -2
  152. package/lib/commonjs/components/PressableIcon.js.map +1 -1
  153. package/lib/commonjs/components/Preview.js +14 -1
  154. package/lib/commonjs/components/Preview.js.map +1 -1
  155. package/lib/commonjs/components/PreviewForRoleChangeModal.js +5 -4
  156. package/lib/commonjs/components/PreviewForRoleChangeModal.js.map +1 -1
  157. package/lib/commonjs/components/RoomSettingsModalContent.js +34 -9
  158. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  159. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +2 -4
  160. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  161. package/lib/commonjs/components/WebrtcView.js +37 -2
  162. package/lib/commonjs/components/WebrtcView.js.map +1 -1
  163. package/lib/commonjs/hooks-sdk-selectors.js +16 -1
  164. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  165. package/lib/commonjs/hooks-sdk.js +27 -1
  166. package/lib/commonjs/hooks-sdk.js.map +1 -1
  167. package/lib/commonjs/hooks-util-selectors.js +3 -2
  168. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  169. package/lib/commonjs/hooks-util.js +466 -89
  170. package/lib/commonjs/hooks-util.js.map +1 -1
  171. package/lib/commonjs/redux/actionTypes.js +18 -3
  172. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  173. package/lib/commonjs/redux/actions/index.js +51 -4
  174. package/lib/commonjs/redux/actions/index.js.map +1 -1
  175. package/lib/commonjs/redux/reducers/appState.js +49 -1
  176. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  177. package/lib/commonjs/redux/reducers/chatWindow.js +1 -2
  178. package/lib/commonjs/redux/reducers/chatWindow.js.map +1 -1
  179. package/lib/commonjs/redux/reducers/message.js +17 -4
  180. package/lib/commonjs/redux/reducers/message.js.map +1 -1
  181. package/lib/commonjs/types.js +1 -0
  182. package/lib/commonjs/types.js.map +1 -1
  183. package/lib/commonjs/utils/types.js +6 -3
  184. package/lib/commonjs/utils/types.js.map +1 -1
  185. package/lib/commonjs/utils.js +2 -2
  186. package/lib/commonjs/utils.js.map +1 -1
  187. package/lib/module/HMSRoomSetup.js +5 -2
  188. package/lib/module/HMSRoomSetup.js.map +1 -1
  189. package/lib/module/Icons/Chat/assets/chat-on.png +0 -0
  190. package/lib/module/Icons/Chat/assets/chat-on@2x.png +0 -0
  191. package/lib/module/Icons/Chat/assets/chat-on@3x.png +0 -0
  192. package/lib/module/Icons/Chat/index.js +4 -3
  193. package/lib/module/Icons/Chat/index.js.map +1 -1
  194. package/lib/module/Icons/NoEntry/assets/no-entry.png +0 -0
  195. package/lib/module/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  196. package/lib/module/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  197. package/lib/module/Icons/NoEntry/index.js +25 -0
  198. package/lib/module/Icons/NoEntry/index.js.map +1 -0
  199. package/lib/module/Icons/PauseCircle/assets/pause-circle.png +0 -0
  200. package/lib/module/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  201. package/lib/module/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  202. package/lib/module/Icons/PauseCircle/index.js +21 -0
  203. package/lib/module/Icons/PauseCircle/index.js.map +1 -0
  204. package/lib/module/Icons/Pin/assets/unpin.png +0 -0
  205. package/lib/module/Icons/Pin/assets/unpin@2x.png +0 -0
  206. package/lib/module/Icons/Pin/assets/unpin@3x.png +0 -0
  207. package/lib/module/Icons/Pin/index.js +2 -1
  208. package/lib/module/Icons/Pin/index.js.map +1 -1
  209. package/lib/module/Icons/Recording/assets/recording-pause.png +0 -0
  210. package/lib/module/Icons/Recording/assets/recording-pause@2x.png +0 -0
  211. package/lib/module/Icons/Recording/assets/recording-pause@3x.png +0 -0
  212. package/lib/module/Icons/Recording/index.js +1 -1
  213. package/lib/module/Icons/Recording/index.js.map +1 -1
  214. package/lib/module/Icons/index.js +2 -0
  215. package/lib/module/Icons/index.js.map +1 -1
  216. package/lib/module/components/AnimatedFooter.js +5 -3
  217. package/lib/module/components/AnimatedFooter.js.map +1 -1
  218. package/lib/module/components/AnimatedHLSFooter.js +5 -10
  219. package/lib/module/components/AnimatedHLSFooter.js.map +1 -1
  220. package/lib/module/components/AnimatedHeader.js +18 -6
  221. package/lib/module/components/AnimatedHeader.js.map +1 -1
  222. package/lib/module/components/BottomSheet.js +12 -6
  223. package/lib/module/components/BottomSheet.js.map +1 -1
  224. package/lib/module/components/Chat/ChatFilterBottomSheet.js +28 -0
  225. package/lib/module/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  226. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js +93 -26
  227. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  228. package/lib/module/components/Chat/ChatFilterBottomSheetView.js +2 -1
  229. package/lib/module/components/Chat/ChatFilterBottomSheetView.js.map +1 -1
  230. package/lib/module/components/Chat/ChatFilterItem.js +11 -8
  231. package/lib/module/components/Chat/ChatFilterItem.js.map +1 -1
  232. package/lib/module/components/Chat/ChatFilterView.js +55 -46
  233. package/lib/module/components/Chat/ChatFilterView.js.map +1 -1
  234. package/lib/module/components/Chat/ChatList.js +14 -7
  235. package/lib/module/components/Chat/ChatList.js.map +1 -1
  236. package/lib/module/components/Chat/ChatMessage.js +81 -9
  237. package/lib/module/components/Chat/ChatMessage.js.map +1 -1
  238. package/lib/module/components/Chat/ChatMoreActionsModal.js +53 -0
  239. package/lib/module/components/Chat/ChatMoreActionsModal.js.map +1 -0
  240. package/lib/module/components/Chat/ChatMoreActionsSheetView.js +55 -0
  241. package/lib/module/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  242. package/lib/module/components/Chat/ChatMoreActionsView.js +75 -0
  243. package/lib/module/components/Chat/ChatMoreActionsView.js.map +1 -0
  244. package/lib/module/components/Chat/ChatPaused.js +77 -0
  245. package/lib/module/components/Chat/ChatPaused.js.map +1 -0
  246. package/lib/module/components/Chat/MessageOptionsBottomSheet.js +26 -0
  247. package/lib/module/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  248. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js +58 -0
  249. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  250. package/lib/module/components/Chat/MessageOptionsView.js +180 -0
  251. package/lib/module/components/Chat/MessageOptionsView.js.map +1 -0
  252. package/lib/module/components/Chat/PeerBlockedFromChat.js +38 -0
  253. package/lib/module/components/Chat/PeerBlockedFromChat.js.map +1 -0
  254. package/lib/module/components/Chat/PinnedMessages.js +288 -0
  255. package/lib/module/components/Chat/PinnedMessages.js.map +1 -0
  256. package/lib/module/components/Chat/index.js +1 -1
  257. package/lib/module/components/Chat/index.js.map +1 -1
  258. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js +13 -12
  259. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  260. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js +24 -5
  261. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  262. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js +9 -5
  263. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  264. package/lib/module/components/ChatAndParticipants/ChatView.js +22 -3
  265. package/lib/module/components/ChatAndParticipants/ChatView.js.map +1 -1
  266. package/lib/module/components/DisplayView.js +5 -12
  267. package/lib/module/components/DisplayView.js.map +1 -1
  268. package/lib/module/components/EndRoomModal.js +1 -2
  269. package/lib/module/components/EndRoomModal.js.map +1 -1
  270. package/lib/module/components/EndRoomModalContent.js +6 -8
  271. package/lib/module/components/EndRoomModalContent.js.map +1 -1
  272. package/lib/module/components/Footer.js +12 -18
  273. package/lib/module/components/Footer.js.map +1 -1
  274. package/lib/module/components/GridView.js +32 -2
  275. package/lib/module/components/GridView.js.map +1 -1
  276. package/lib/module/components/HLSFooter.js +3 -1
  277. package/lib/module/components/HLSFooter.js.map +1 -1
  278. package/lib/module/components/HLSView.js +8 -6
  279. package/lib/module/components/HLSView.js.map +1 -1
  280. package/lib/module/components/HMSBaseButton.js +10 -2
  281. package/lib/module/components/HMSBaseButton.js.map +1 -1
  282. package/lib/module/components/HMSDangerButton.js +4 -2
  283. package/lib/module/components/HMSDangerButton.js.map +1 -1
  284. package/lib/module/components/HMSHLSMessage.js +88 -3
  285. package/lib/module/components/HMSHLSMessage.js.map +1 -1
  286. package/lib/module/components/HMSHLSMessageList.js +2 -2
  287. package/lib/module/components/HMSHLSMessageList.js.map +1 -1
  288. package/lib/module/components/HMSHandRaiseNotification.js +6 -3
  289. package/lib/module/components/HMSHandRaiseNotification.js.map +1 -1
  290. package/lib/module/components/HMSKeyboardAvoidingView.android.js +2 -3
  291. package/lib/module/components/HMSKeyboardAvoidingView.android.js.map +1 -1
  292. package/lib/module/components/HMSKeyboardAvoidingView.js +9 -3
  293. package/lib/module/components/HMSKeyboardAvoidingView.js.map +1 -1
  294. package/lib/module/components/HMSLiveIndicator.js +8 -63
  295. package/lib/module/components/HMSLiveIndicator.js.map +1 -1
  296. package/lib/module/components/HMSLiveViewerCount.js +71 -0
  297. package/lib/module/components/HMSLiveViewerCount.js.map +1 -0
  298. package/lib/module/components/HMSLocalScreenshareNotification.js +2 -1
  299. package/lib/module/components/HMSLocalScreenshareNotification.js.map +1 -1
  300. package/lib/module/components/HMSNotification.js +32 -5
  301. package/lib/module/components/HMSNotification.js.map +1 -1
  302. package/lib/module/components/HMSNotifications.js +9 -2
  303. package/lib/module/components/HMSNotifications.js.map +1 -1
  304. package/lib/module/components/HMSOverlayChatView.js +56 -5
  305. package/lib/module/components/HMSOverlayChatView.js.map +1 -1
  306. package/lib/module/components/HMSPreviewEditName.js +6 -1
  307. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  308. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +2 -5
  309. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  310. package/lib/module/components/HMSPrimaryButton.js +4 -2
  311. package/lib/module/components/HMSPrimaryButton.js.map +1 -1
  312. package/lib/module/components/HMSRecordingIndicator.js +12 -7
  313. package/lib/module/components/HMSRecordingIndicator.js.map +1 -1
  314. package/lib/module/components/HMSRoomOptions.js +3 -6
  315. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  316. package/lib/module/components/HMSTerminalErrorNotification.js +6 -2
  317. package/lib/module/components/HMSTerminalErrorNotification.js.map +1 -1
  318. package/lib/module/components/Header.js +10 -3
  319. package/lib/module/components/Header.js.map +1 -1
  320. package/lib/module/components/LeaveRoomBottomSheet.js +5 -11
  321. package/lib/module/components/LeaveRoomBottomSheet.js.map +1 -1
  322. package/lib/module/components/Meeting.js +6 -14
  323. package/lib/module/components/Meeting.js.map +1 -1
  324. package/lib/module/components/MeetingScreenContent.js +51 -53
  325. package/lib/module/components/MeetingScreenContent.js.map +1 -1
  326. package/lib/module/components/MiniView.js.map +1 -1
  327. package/lib/module/components/Modals.js +10 -13
  328. package/lib/module/components/Modals.js.map +1 -1
  329. package/lib/module/components/OverlayedViews.js +6 -2
  330. package/lib/module/components/OverlayedViews.js.map +1 -1
  331. package/lib/module/components/Participants/ParticipantsItemOptions.js +5 -1
  332. package/lib/module/components/Participants/ParticipantsItemOptions.js.map +1 -1
  333. package/lib/module/components/PeerSettingsModalContent.js +2 -1
  334. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  335. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js +2 -1
  336. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  337. package/lib/module/components/PressableIcon.js +6 -2
  338. package/lib/module/components/PressableIcon.js.map +1 -1
  339. package/lib/module/components/Preview.js +13 -2
  340. package/lib/module/components/Preview.js.map +1 -1
  341. package/lib/module/components/PreviewForRoleChangeModal.js +5 -4
  342. package/lib/module/components/PreviewForRoleChangeModal.js.map +1 -1
  343. package/lib/module/components/RoomSettingsModalContent.js +36 -11
  344. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  345. package/lib/module/components/RoomSettingsModalDebugModeContent.js +2 -4
  346. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  347. package/lib/module/components/WebrtcView.js +37 -2
  348. package/lib/module/components/WebrtcView.js.map +1 -1
  349. package/lib/module/hooks-sdk-selectors.js +12 -0
  350. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  351. package/lib/module/hooks-sdk.js +23 -1
  352. package/lib/module/hooks-sdk.js.map +1 -1
  353. package/lib/module/hooks-util-selectors.js +3 -2
  354. package/lib/module/hooks-util-selectors.js.map +1 -1
  355. package/lib/module/hooks-util.js +455 -90
  356. package/lib/module/hooks-util.js.map +1 -1
  357. package/lib/module/redux/actionTypes.js +18 -3
  358. package/lib/module/redux/actionTypes.js.map +1 -1
  359. package/lib/module/redux/actions/index.js +42 -2
  360. package/lib/module/redux/actions/index.js.map +1 -1
  361. package/lib/module/redux/reducers/appState.js +49 -1
  362. package/lib/module/redux/reducers/appState.js.map +1 -1
  363. package/lib/module/redux/reducers/chatWindow.js +1 -2
  364. package/lib/module/redux/reducers/chatWindow.js.map +1 -1
  365. package/lib/module/redux/reducers/message.js +17 -4
  366. package/lib/module/redux/reducers/message.js.map +1 -1
  367. package/lib/module/types.js +1 -0
  368. package/lib/module/types.js.map +1 -1
  369. package/lib/module/utils/types.js +5 -2
  370. package/lib/module/utils/types.js.map +1 -1
  371. package/lib/module/utils.js +2 -2
  372. package/lib/module/utils.js.map +1 -1
  373. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  374. package/lib/typescript/Icons/Chat/index.d.ts +1 -0
  375. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  376. package/lib/typescript/Icons/NoEntry/index.d.ts +7 -0
  377. package/lib/typescript/Icons/NoEntry/index.d.ts.map +1 -0
  378. package/lib/typescript/Icons/PauseCircle/index.d.ts +7 -0
  379. package/lib/typescript/Icons/PauseCircle/index.d.ts.map +1 -0
  380. package/lib/typescript/Icons/Pin/index.d.ts +1 -0
  381. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -1
  382. package/lib/typescript/Icons/Recording/index.d.ts +1 -1
  383. package/lib/typescript/Icons/Recording/index.d.ts.map +1 -1
  384. package/lib/typescript/Icons/index.d.ts +2 -0
  385. package/lib/typescript/Icons/index.d.ts.map +1 -1
  386. package/lib/typescript/components/AnimatedFooter.d.ts.map +1 -1
  387. package/lib/typescript/components/AnimatedHLSFooter.d.ts.map +1 -1
  388. package/lib/typescript/components/AnimatedHeader.d.ts.map +1 -1
  389. package/lib/typescript/components/BottomSheet.d.ts +1 -0
  390. package/lib/typescript/components/BottomSheet.d.ts.map +1 -1
  391. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts +3 -0
  392. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts.map +1 -0
  393. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts +1 -0
  394. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts.map +1 -1
  395. package/lib/typescript/components/Chat/ChatFilterBottomSheetView.d.ts.map +1 -1
  396. package/lib/typescript/components/Chat/ChatFilterItem.d.ts +1 -0
  397. package/lib/typescript/components/Chat/ChatFilterItem.d.ts.map +1 -1
  398. package/lib/typescript/components/Chat/ChatFilterView.d.ts +1 -0
  399. package/lib/typescript/components/Chat/ChatFilterView.d.ts.map +1 -1
  400. package/lib/typescript/components/Chat/ChatList.d.ts.map +1 -1
  401. package/lib/typescript/components/Chat/ChatMessage.d.ts.map +1 -1
  402. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts +7 -0
  403. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts.map +1 -0
  404. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts +6 -0
  405. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts.map +1 -0
  406. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts +7 -0
  407. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts.map +1 -0
  408. package/lib/typescript/components/Chat/ChatPaused.d.ts +10 -0
  409. package/lib/typescript/components/Chat/ChatPaused.d.ts.map +1 -0
  410. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts +3 -0
  411. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts.map +1 -0
  412. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts +6 -0
  413. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts.map +1 -0
  414. package/lib/typescript/components/Chat/MessageOptionsView.d.ts +7 -0
  415. package/lib/typescript/components/Chat/MessageOptionsView.d.ts.map +1 -0
  416. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts +9 -0
  417. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts.map +1 -0
  418. package/lib/typescript/components/Chat/PinnedMessages.d.ts +8 -0
  419. package/lib/typescript/components/Chat/PinnedMessages.d.ts.map +1 -0
  420. package/lib/typescript/components/Chat/index.d.ts +1 -1
  421. package/lib/typescript/components/Chat/index.d.ts.map +1 -1
  422. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.d.ts.map +1 -1
  423. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsHeader.d.ts.map +1 -1
  424. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsView.d.ts.map +1 -1
  425. package/lib/typescript/components/ChatAndParticipants/ChatView.d.ts.map +1 -1
  426. package/lib/typescript/components/DisplayView.d.ts.map +1 -1
  427. package/lib/typescript/components/EndRoomModal.d.ts.map +1 -1
  428. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -1
  429. package/lib/typescript/components/Footer.d.ts +1 -1
  430. package/lib/typescript/components/Footer.d.ts.map +1 -1
  431. package/lib/typescript/components/GridView.d.ts.map +1 -1
  432. package/lib/typescript/components/HLSView.d.ts.map +1 -1
  433. package/lib/typescript/components/HMSBaseButton.d.ts +1 -0
  434. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -1
  435. package/lib/typescript/components/HMSDangerButton.d.ts +1 -0
  436. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -1
  437. package/lib/typescript/components/HMSHLSMessage.d.ts +1 -1
  438. package/lib/typescript/components/HMSHLSMessage.d.ts.map +1 -1
  439. package/lib/typescript/components/HMSHandRaiseNotification.d.ts.map +1 -1
  440. package/lib/typescript/components/HMSKeyboardAvoidingView.android.d.ts.map +1 -1
  441. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts +2 -1
  442. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts.map +1 -1
  443. package/lib/typescript/components/HMSLiveIndicator.d.ts.map +1 -1
  444. package/lib/typescript/components/HMSLiveViewerCount.d.ts +3 -0
  445. package/lib/typescript/components/HMSLiveViewerCount.d.ts.map +1 -0
  446. package/lib/typescript/components/HMSLocalScreenshareNotification.d.ts.map +1 -1
  447. package/lib/typescript/components/HMSNotification.d.ts +2 -1
  448. package/lib/typescript/components/HMSNotification.d.ts.map +1 -1
  449. package/lib/typescript/components/HMSNotifications.d.ts.map +1 -1
  450. package/lib/typescript/components/HMSOverlayChatView.d.ts +5 -1
  451. package/lib/typescript/components/HMSOverlayChatView.d.ts.map +1 -1
  452. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  453. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  454. package/lib/typescript/components/HMSPrimaryButton.d.ts +1 -0
  455. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -1
  456. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -1
  457. package/lib/typescript/components/HMSTerminalErrorNotification.d.ts.map +1 -1
  458. package/lib/typescript/components/Header.d.ts +1 -0
  459. package/lib/typescript/components/Header.d.ts.map +1 -1
  460. package/lib/typescript/components/LeaveRoomBottomSheet.d.ts.map +1 -1
  461. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  462. package/lib/typescript/components/MeetingScreenContent.d.ts.map +1 -1
  463. package/lib/typescript/components/Modals.d.ts.map +1 -1
  464. package/lib/typescript/components/OverlayedViews.d.ts +4 -1
  465. package/lib/typescript/components/OverlayedViews.d.ts.map +1 -1
  466. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts.map +1 -1
  467. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  468. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -1
  469. package/lib/typescript/components/PressableIcon.d.ts.map +1 -1
  470. package/lib/typescript/components/Preview.d.ts.map +1 -1
  471. package/lib/typescript/components/PreviewForRoleChangeModal.d.ts.map +1 -1
  472. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  473. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -1
  474. package/lib/typescript/components/WebrtcView.d.ts +2 -0
  475. package/lib/typescript/components/WebrtcView.d.ts.map +1 -1
  476. package/lib/typescript/hooks-sdk-selectors.d.ts +3 -0
  477. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  478. package/lib/typescript/hooks-sdk.d.ts +4 -0
  479. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  480. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  481. package/lib/typescript/hooks-util.d.ts +39 -3
  482. package/lib/typescript/hooks-util.d.ts.map +1 -1
  483. package/lib/typescript/redux/actionTypes.d.ts +10 -2
  484. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  485. package/lib/typescript/redux/actions/index.d.ts +43 -3
  486. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  487. package/lib/typescript/redux/index.d.ts +8 -2
  488. package/lib/typescript/redux/index.d.ts.map +1 -1
  489. package/lib/typescript/redux/reducers/appState.d.ts +8 -2
  490. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  491. package/lib/typescript/redux/reducers/chatWindow.d.ts +1 -1
  492. package/lib/typescript/redux/reducers/chatWindow.d.ts.map +1 -1
  493. package/lib/typescript/redux/reducers/index.d.ts +8 -2
  494. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  495. package/lib/typescript/redux/reducers/message.d.ts +3 -2
  496. package/lib/typescript/redux/reducers/message.d.ts.map +1 -1
  497. package/lib/typescript/types.d.ts +23 -3
  498. package/lib/typescript/types.d.ts.map +1 -1
  499. package/lib/typescript/utils/types.d.ts +4 -0
  500. package/lib/typescript/utils/types.d.ts.map +1 -1
  501. package/package.json +3 -3
  502. package/src/HMSRoomSetup.tsx +8 -3
  503. package/src/Icons/Chat/assets/chat-on.png +0 -0
  504. package/src/Icons/Chat/assets/chat-on@2x.png +0 -0
  505. package/src/Icons/Chat/assets/chat-on@3x.png +0 -0
  506. package/src/Icons/Chat/index.tsx +19 -6
  507. package/src/Icons/NoEntry/assets/no-entry.png +0 -0
  508. package/src/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  509. package/src/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  510. package/src/Icons/NoEntry/index.tsx +33 -0
  511. package/src/Icons/PauseCircle/assets/pause-circle.png +0 -0
  512. package/src/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  513. package/src/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  514. package/src/Icons/PauseCircle/index.tsx +27 -0
  515. package/src/Icons/Pin/assets/unpin.png +0 -0
  516. package/src/Icons/Pin/assets/unpin@2x.png +0 -0
  517. package/src/Icons/Pin/assets/unpin@3x.png +0 -0
  518. package/src/Icons/Pin/index.tsx +13 -3
  519. package/src/Icons/Recording/assets/recording-pause.png +0 -0
  520. package/src/Icons/Recording/assets/recording-pause@2x.png +0 -0
  521. package/src/Icons/Recording/assets/recording-pause@3x.png +0 -0
  522. package/src/Icons/Recording/index.tsx +4 -2
  523. package/src/Icons/index.ts +2 -0
  524. package/src/components/AnimatedFooter.tsx +9 -3
  525. package/src/components/AnimatedHLSFooter.tsx +8 -17
  526. package/src/components/AnimatedHeader.tsx +16 -5
  527. package/src/components/BottomSheet.tsx +21 -5
  528. package/src/components/Chat/ChatFilterBottomSheet.tsx +35 -0
  529. package/src/components/Chat/ChatFilterBottomSheetOpener.tsx +170 -42
  530. package/src/components/Chat/ChatFilterBottomSheetView.tsx +1 -0
  531. package/src/components/Chat/ChatFilterItem.tsx +8 -4
  532. package/src/components/Chat/ChatFilterView.tsx +102 -75
  533. package/src/components/Chat/ChatList.tsx +18 -6
  534. package/src/components/Chat/ChatMessage.tsx +111 -7
  535. package/src/components/Chat/ChatMoreActionsModal.tsx +75 -0
  536. package/src/components/Chat/ChatMoreActionsSheetView.tsx +77 -0
  537. package/src/components/Chat/ChatMoreActionsView.tsx +84 -0
  538. package/src/components/Chat/ChatPaused.tsx +103 -0
  539. package/src/components/Chat/MessageOptionsBottomSheet.tsx +33 -0
  540. package/src/components/Chat/MessageOptionsBottomSheetView.tsx +82 -0
  541. package/src/components/Chat/MessageOptionsView.tsx +248 -0
  542. package/src/components/Chat/PeerBlockedFromChat.tsx +49 -0
  543. package/src/components/Chat/PinnedMessages.tsx +422 -0
  544. package/src/components/Chat/index.ts +1 -1
  545. package/src/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.tsx +15 -7
  546. package/src/components/ChatAndParticipants/ChatAndParticipantsHeader.tsx +48 -12
  547. package/src/components/ChatAndParticipants/ChatAndParticipantsView.tsx +14 -5
  548. package/src/components/ChatAndParticipants/ChatView.tsx +37 -5
  549. package/src/components/DisplayView.tsx +4 -13
  550. package/src/components/EndRoomModal.tsx +0 -1
  551. package/src/components/EndRoomModalContent.tsx +11 -13
  552. package/src/components/Footer.tsx +20 -23
  553. package/src/components/GridView.tsx +44 -8
  554. package/src/components/HLSFooter.tsx +1 -1
  555. package/src/components/HLSView.tsx +45 -44
  556. package/src/components/HMSBaseButton.tsx +17 -2
  557. package/src/components/HMSDangerButton.tsx +3 -0
  558. package/src/components/HMSHLSMessage.tsx +130 -13
  559. package/src/components/HMSHLSMessageList.tsx +2 -2
  560. package/src/components/HMSHandRaiseNotification.tsx +17 -10
  561. package/src/components/HMSKeyboardAvoidingView.android.tsx +1 -5
  562. package/src/components/HMSKeyboardAvoidingView.tsx +12 -4
  563. package/src/components/HMSLiveIndicator.tsx +14 -83
  564. package/src/components/HMSLiveViewerCount.tsx +91 -0
  565. package/src/components/HMSLocalScreenshareNotification.tsx +1 -0
  566. package/src/components/HMSNotification.tsx +56 -13
  567. package/src/components/HMSNotifications.tsx +12 -2
  568. package/src/components/HMSOverlayChatView.tsx +91 -18
  569. package/src/components/HMSPreviewEditName.tsx +12 -1
  570. package/src/components/HMSPreviewHLSLiveIndicator.tsx +2 -5
  571. package/src/components/HMSPrimaryButton.tsx +3 -0
  572. package/src/components/HMSRecordingIndicator.tsx +10 -7
  573. package/src/components/HMSRoomOptions.tsx +4 -4
  574. package/src/components/HMSTerminalErrorNotification.tsx +15 -10
  575. package/src/components/Header.tsx +17 -3
  576. package/src/components/LeaveRoomBottomSheet.tsx +14 -15
  577. package/src/components/Meeting.tsx +6 -19
  578. package/src/components/MeetingScreenContent.tsx +70 -64
  579. package/src/components/MiniView.tsx +4 -4
  580. package/src/components/Modals.tsx +23 -25
  581. package/src/components/OverlayedViews.tsx +6 -3
  582. package/src/components/Participants/ParticipantsItemOptions.tsx +12 -7
  583. package/src/components/PeerSettingsModalContent.tsx +4 -1
  584. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +4 -1
  585. package/src/components/PressableIcon.tsx +22 -17
  586. package/src/components/Preview.tsx +15 -2
  587. package/src/components/PreviewForRoleChangeModal.tsx +4 -3
  588. package/src/components/RoomSettingsModalContent.tsx +74 -14
  589. package/src/components/RoomSettingsModalDebugModeContent.tsx +2 -4
  590. package/src/components/WebrtcView.tsx +63 -22
  591. package/src/hooks-sdk-selectors.tsx +19 -0
  592. package/src/hooks-sdk.ts +37 -0
  593. package/src/hooks-util-selectors.tsx +2 -2
  594. package/src/hooks-util.ts +639 -131
  595. package/src/redux/actionTypes.ts +25 -2
  596. package/src/redux/actions/index.ts +46 -4
  597. package/src/redux/reducers/appState.ts +60 -3
  598. package/src/redux/reducers/chatWindow.ts +2 -2
  599. package/src/redux/reducers/message.ts +20 -6
  600. package/src/types.ts +35 -6
  601. package/src/utils/types.ts +15 -3
  602. package/src/utils.ts +2 -2
  603. package/lib/commonjs/components/Chat/PinnedMessage.js +0 -81
  604. package/lib/commonjs/components/Chat/PinnedMessage.js.map +0 -1
  605. package/lib/module/components/Chat/PinnedMessage.js +0 -72
  606. package/lib/module/components/Chat/PinnedMessage.js.map +0 -1
  607. package/lib/typescript/components/Chat/PinnedMessage.d.ts +0 -3
  608. package/lib/typescript/components/Chat/PinnedMessage.d.ts.map +0 -1
  609. package/src/components/Chat/PinnedMessage.tsx +0 -89
@@ -1,14 +1,30 @@
1
1
  import * as React from 'react';
2
2
  import { StyleSheet } from 'react-native';
3
+ import { useSelector } from 'react-redux';
3
4
 
4
- import { useHMSRoomStyleSheet } from '../../hooks-util';
5
+ import {
6
+ useHMSChatState,
7
+ useHMSRoomStyleSheet,
8
+ useIsAllowedToSendMessage,
9
+ useIsLocalPeerBlockedFromChat,
10
+ } from '../../hooks-util';
5
11
  import { ChatList } from '../Chat/ChatList';
6
12
  import { HMSSendMessageInput } from '../HMSSendMessageInput';
7
13
  import { ChatFilterBottomSheetOpener } from '../Chat/ChatFilterBottomSheetOpener';
14
+ import { ChatPaused } from '../Chat/ChatPaused';
15
+ import type { RootState } from '../../redux';
16
+ import { PeerBlockedFromChat } from '../Chat/PeerBlockedFromChat';
8
17
 
9
18
  interface ChatViewProps {}
10
19
 
11
20
  const _ChatView: React.FC<ChatViewProps> = () => {
21
+ const { chatState } = useHMSChatState();
22
+ const isAllowedToSendMessage = useIsAllowedToSendMessage();
23
+ const isChatRecipientSelected = useSelector(
24
+ (state: RootState) => state.chatWindow.sendTo !== null
25
+ );
26
+ const isLocalPeerBlockedFromChat = useIsLocalPeerBlockedFromChat();
27
+
12
28
  const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
13
29
  input: {
14
30
  backgroundColor: theme.palette.surface_default,
@@ -20,11 +36,21 @@ const _ChatView: React.FC<ChatViewProps> = () => {
20
36
  <>
21
37
  <ChatList />
22
38
 
23
- <ChatFilterBottomSheetOpener />
39
+ {isLocalPeerBlockedFromChat ? (
40
+ <PeerBlockedFromChat style={styles.peerBlocked} />
41
+ ) : chatState.enabled ? (
42
+ <>
43
+ <ChatFilterBottomSheetOpener />
24
44
 
25
- <HMSSendMessageInput
26
- containerStyle={[styles.input, hmsRoomStyles.input]}
27
- />
45
+ {isAllowedToSendMessage && isChatRecipientSelected ? (
46
+ <HMSSendMessageInput
47
+ containerStyle={[styles.input, hmsRoomStyles.input]}
48
+ />
49
+ ) : null}
50
+ </>
51
+ ) : isAllowedToSendMessage ? (
52
+ <ChatPaused style={styles.chatPaused} />
53
+ ) : null}
28
54
  </>
29
55
  );
30
56
  };
@@ -37,6 +63,12 @@ const styles = StyleSheet.create({
37
63
  marginTop: 0,
38
64
  marginBottom: 0,
39
65
  },
66
+ chatPaused: {
67
+ marginTop: 18, // Applied margin so that content does not shift when this component mounts or unmounts
68
+ },
69
+ peerBlocked: {
70
+ marginTop: 18, // Applied margin so that content does not shift when this component mounts or unmounts
71
+ },
40
72
  });
41
73
 
42
74
  export const ChatView = React.memo(_ChatView);
@@ -1,11 +1,7 @@
1
1
  import React, { useRef, useState } from 'react';
2
2
  import { useSelector } from 'react-redux';
3
- import { InteractionManager } from 'react-native';
3
+ import { InteractionManager, View } from 'react-native';
4
4
  import { HMSTrack, HMSCameraControl } from '@100mslive/react-native-hms';
5
- import Animated, {
6
- interpolate,
7
- useAnimatedStyle,
8
- } from 'react-native-reanimated';
9
5
  import type { SharedValue } from 'react-native-reanimated';
10
6
 
11
7
  import { DefaultModal } from './DefaultModal';
@@ -132,19 +128,14 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
132
128
  setModalVisible(ModalTypes.STREAMING_QUALITY_SETTING, true);
133
129
  };
134
130
 
135
- const animatedStyles = useAnimatedStyle(() => {
136
- return {
137
- transform: [{ translateY: interpolate(offset.value, [0, 1], [4, 0]) }],
138
- };
139
- }, []);
140
-
141
131
  return (
142
- <Animated.View style={[{ flex: 1 }, animatedStyles]}>
132
+ <View style={{ flex: 1 }}>
143
133
  {isHLSViewer ? (
144
134
  <HLSView />
145
135
  ) : (
146
136
  <WebrtcView
147
137
  ref={gridViewRef}
138
+ offset={offset}
148
139
  peerTrackNodes={peerTrackNodes}
149
140
  handlePeerTileMorePress={handlePeerTileMorePress}
150
141
  />
@@ -239,6 +230,6 @@ export const DisplayView: React.FC<DisplayViewProps> = ({
239
230
  </DefaultModal>
240
231
  </>
241
232
  )}
242
- </Animated.View>
233
+ </View>
243
234
  );
244
235
  };
@@ -16,7 +16,6 @@ export const EndRoomModal: React.FC<EndRoomModalProps> = () => {
16
16
  <BottomSheet
17
17
  dismissModal={dismissModal}
18
18
  isVisible={modalVisibleType === ModalTypes.END_ROOM}
19
- animationOutTiming={700}
20
19
  >
21
20
  <EndRoomModalContent dismissModal={dismissModal} />
22
21
  </BottomSheet>
@@ -8,6 +8,7 @@ import { HMSDangerButton } from './HMSDangerButton';
8
8
  import type { RootState } from '../redux';
9
9
  import { OnLeaveReason } from '../utils/types';
10
10
  import { TestIds } from '../utils/constants';
11
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
11
12
 
12
13
  export interface EndRoomModalContentProps {
13
14
  dismissModal(): void;
@@ -38,10 +39,7 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
38
39
  state.hmsStates.localPeer?.role?.permissions?.hlsStreaming
39
40
  );
40
41
 
41
- const isStreaming = useSelector(
42
- (state: RootState) =>
43
- state.hmsStates.room?.hlsStreamingState?.running ?? false
44
- );
42
+ const isHLSStreaming = useIsHLSStreamingOn();
45
43
 
46
44
  return (
47
45
  <View style={styles.container}>
@@ -53,11 +51,11 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
53
51
  testID={TestIds.end_confirmation_heading}
54
52
  style={[styles.headerText, hmsRoomStyles.headerText]}
55
53
  >
56
- {canStream && isStreaming
54
+ {canStream && isHLSStreaming
57
55
  ? 'End Stream'
58
56
  : canEndRoom
59
- ? 'End Session'
60
- : 'Leave'}
57
+ ? 'End Session'
58
+ : 'Leave'}
61
59
  </Text>
62
60
  </View>
63
61
 
@@ -74,23 +72,23 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
74
72
  testID={TestIds.end_confirmation_description}
75
73
  style={[styles.text, hmsRoomStyles.text]}
76
74
  >
77
- {canStream && isStreaming
75
+ {canStream && isHLSStreaming
78
76
  ? 'The stream will end for everyone after they’ve watched it.'
79
77
  : canEndRoom
80
- ? 'The session will end for everyone in the room immediately. '
81
- : 'Others will continue after you leave. You can join the session again.'}
78
+ ? 'The session will end for everyone in the room immediately. '
79
+ : 'Others will continue after you leave. You can join the session again.'}
82
80
  </Text>
83
81
  <HMSDangerButton
84
82
  testID={TestIds.end_confirmation_cta}
85
83
  loading={false}
86
84
  onPress={() => {
87
- if (canStream && isStreaming) {
88
- leave(OnLeaveReason.LEAVE, true)
85
+ if (canStream && isHLSStreaming) {
86
+ leave(OnLeaveReason.LEAVE, true);
89
87
  } else {
90
88
  endRoom(OnLeaveReason.ROOM_END);
91
89
  }
92
90
  }}
93
- title={canStream && isStreaming ? 'End Stream' : 'End Session'}
91
+ title={canStream && isHLSStreaming ? 'End Stream' : 'End Session'}
94
92
  />
95
93
  </View>
96
94
  );
@@ -24,7 +24,6 @@ import {
24
24
  } from '../hooks-sdk';
25
25
  import { useSelector } from 'react-redux';
26
26
  import type { RootState } from '../redux';
27
- import { useIsLandscapeOrientation } from '../utils/dimension';
28
27
 
29
28
  interface FooterProps {}
30
29
 
@@ -33,7 +32,9 @@ export const _Footer: React.FC<FooterProps> = () => {
33
32
  const canPublishAudio = useCanPublishAudio();
34
33
  const canPublishVideo = useCanPublishVideo();
35
34
  const canPublishScreen = useCanPublishScreen();
36
- const isLandscapeOrientation = useIsLandscapeOrientation();
35
+ const editUsernameDisabled = useSelector(
36
+ (state: RootState) => state.app.editUsernameDisabled
37
+ );
37
38
 
38
39
  const isViewer = !(canPublishAudio || canPublishVideo || canPublishScreen);
39
40
 
@@ -54,12 +55,18 @@ export const _Footer: React.FC<FooterProps> = () => {
54
55
  !!state.hmsStates.localPeer?.role?.permissions?.browserRecording
55
56
  );
56
57
 
58
+ const canEditUsernameFromRoomModal = isViewer && !editUsernameDisabled;
59
+
60
+ const canShowHandRaiseInFooter = !isOnStage && isViewer; // on_stage_exp object undefined && viewer -> show in footer
61
+ const canShowHandRaiseInRoomModal = !isOnStage && !isViewer; // on_stage_exp object undefined && publisher -> show in room modal
62
+
57
63
  const canShowOptions =
58
- isViewer ||
59
- canPublishScreen ||
60
64
  canShowParticipants ||
65
+ canPublishScreen ||
61
66
  canShowBRB ||
62
- canStartRecording;
67
+ canShowHandRaiseInRoomModal ||
68
+ canStartRecording ||
69
+ canEditUsernameFromRoomModal;
63
70
 
64
71
  const footerActionButtons = useMemo(() => {
65
72
  const actions = [];
@@ -68,7 +75,7 @@ export const _Footer: React.FC<FooterProps> = () => {
68
75
  actions.push('chat');
69
76
  }
70
77
 
71
- if (!isOnStage && isViewer) {
78
+ if (canShowHandRaiseInFooter) {
72
79
  actions.unshift('hand-raise');
73
80
  }
74
81
 
@@ -88,10 +95,9 @@ export const _Footer: React.FC<FooterProps> = () => {
88
95
 
89
96
  return actions;
90
97
  }, [
91
- isOnStage,
98
+ canShowHandRaiseInFooter,
92
99
  canShowOptions,
93
100
  canShowChat,
94
- isViewer,
95
101
  canPublishAudio,
96
102
  canPublishVideo,
97
103
  ]);
@@ -103,11 +109,11 @@ export const _Footer: React.FC<FooterProps> = () => {
103
109
  return (
104
110
  <SafeAreaView
105
111
  style={isHLSViewer ? null : containerStyles}
106
- edges={['bottom']}
112
+ edges={['bottom', 'left', 'right']}
107
113
  >
108
114
  <View
109
115
  style={[
110
- isLandscapeOrientation ? styles.landscapeContainer : styles.container,
116
+ styles.container,
111
117
  isHLSViewer ? styles.hlsContainer : containerStyles,
112
118
  ]}
113
119
  >
@@ -138,15 +144,14 @@ export const _Footer: React.FC<FooterProps> = () => {
138
144
  );
139
145
  };
140
146
 
141
- export const useFooterHeight = () => {
147
+ export const useFooterHeight = (excludeSafeArea: boolean = false) => {
142
148
  const isHLSViewer = useIsHLSViewer();
143
- const isLandscapeOrientation = useIsLandscapeOrientation();
144
149
  const { bottom } = useSafeAreaInsets();
145
150
 
146
151
  return (
147
- bottom +
148
- (isHLSViewer ? 8 : isLandscapeOrientation ? 4 : 16) +
149
- (Platform.OS === 'android' ? (isLandscapeOrientation ? 4 : 16) : 0) +
152
+ (excludeSafeArea ? 0 : bottom) +
153
+ (isHLSViewer ? 8 : 16) +
154
+ (Platform.OS === 'android' ? 16 : 0) +
150
155
  40
151
156
  ); // bottomSafeArea + paddingTop + marginBottom + content
152
157
  };
@@ -160,14 +165,6 @@ const styles = StyleSheet.create({
160
165
  justifyContent: 'center',
161
166
  marginBottom: Platform.OS === 'android' ? 16 : 0, // TODO: need to correct hide animation offsets because of this change
162
167
  },
163
- landscapeContainer: {
164
- paddingTop: 4,
165
- paddingHorizontal: 4,
166
- flexDirection: 'row',
167
- alignItems: 'center',
168
- justifyContent: 'center',
169
- marginBottom: Platform.OS === 'android' ? 4 : 0,
170
- },
171
168
  hlsContainer: {
172
169
  paddingTop: 8,
173
170
  },
@@ -1,11 +1,14 @@
1
1
  import React, { useRef, useState, useImperativeHandle } from 'react';
2
2
  import type { ElementRef } from 'react';
3
- import { View, FlatList, StyleSheet, useWindowDimensions } from 'react-native';
4
- import { useDispatch, useSelector } from 'react-redux';
5
- import type {
6
- LayoutChangeEvent,
7
- ViewToken,
3
+ import {
4
+ View,
5
+ FlatList,
6
+ StyleSheet,
7
+ useWindowDimensions,
8
+ Platform,
8
9
  } from 'react-native';
10
+ import { useDispatch, useSelector } from 'react-redux';
11
+ import type { LayoutChangeEvent, ViewToken } from 'react-native';
9
12
  import type { HMSView, HMSPeer } from '@100mslive/react-native-hms';
10
13
 
11
14
  import { DefaultModal } from './DefaultModal';
@@ -18,6 +21,7 @@ import { PaginationDots } from './PaginationDots';
18
21
  import { setGridViewActivePage } from '../redux/actions';
19
22
  import { Tile } from './Tile';
20
23
  import { useIsLandscapeOrientation } from '../utils/dimension';
24
+ import { useSafeAreaFrame } from 'react-native-safe-area-context';
21
25
 
22
26
  export type GridViewProps = {
23
27
  onPeerTileMorePress(peerTrackNode: PeerTrackNode): void;
@@ -46,12 +50,38 @@ export const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
46
50
  const hmsViewRefs = useRef<Record<string, ElementRef<typeof HMSView>>>({});
47
51
  const regularTilesFlatlistRef = useRef<FlatList<PeerTrackNode[]>>(null);
48
52
  const screenshareTilesFlatlistRef = useRef<FlatList<PeerTrackNode>>(null);
49
- const [insetTileBoundingBox, setInsetTileBoundingBox] = useState<{ width: number | null, height: number | null }>({ width: null, height: null });
53
+ const [insetTileBoundingBox, setInsetTileBoundingBox] = useState<{
54
+ width: number | null;
55
+ height: number | null;
56
+ }>({ width: null, height: null });
50
57
 
51
- const isLandscapeOrientation = useIsLandscapeOrientation();
52
58
  const screenshareTilesAvailable = useSelector(
53
59
  (state: RootState) => state.app.screensharePeerTrackNodes.length > 0
54
60
  );
61
+ const regularTilesAvailable = pairedPeers.length > 0;
62
+
63
+ const isLandscapeOrientation = useIsLandscapeOrientation();
64
+
65
+ // On Orientation change, scroll to first page of list
66
+ React.useEffect(() => {
67
+ if (screenshareTilesAvailable) {
68
+ screenshareTilesFlatlistRef.current?.scrollToOffset({
69
+ offset: 0,
70
+ animated: false,
71
+ });
72
+ }
73
+ }, [screenshareTilesAvailable, isLandscapeOrientation]);
74
+
75
+ // On Orientation change, scroll to first page of list
76
+ React.useEffect(() => {
77
+ if (regularTilesAvailable) {
78
+ regularTilesFlatlistRef.current?.scrollToOffset({
79
+ offset: 0,
80
+ animated: false,
81
+ });
82
+ }
83
+ }, [regularTilesAvailable, isLandscapeOrientation]);
84
+
55
85
  const miniviewPeerTrackNodeExists = useSelector(
56
86
  (state: RootState) => !!state.app.miniviewPeerTrackNode
57
87
  );
@@ -105,7 +135,10 @@ export const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
105
135
 
106
136
  const _handleLayoutChange = React.useCallback(
107
137
  ({ nativeEvent }: LayoutChangeEvent) => {
108
- setInsetTileBoundingBox({ width: nativeEvent.layout.width, height: nativeEvent.layout.height });
138
+ setInsetTileBoundingBox({
139
+ width: nativeEvent.layout.width,
140
+ height: nativeEvent.layout.height,
141
+ });
109
142
  },
110
143
  []
111
144
  );
@@ -180,6 +213,8 @@ const RegularTiles = React.forwardRef<
180
213
  RegularTilesProps
181
214
  >(({ pairedPeers, onPeerTileMorePress, setHmsViewRefs }, flatlistRef) => {
182
215
  const dispatch = useDispatch();
216
+ const { height: safeHeight } = useSafeAreaFrame();
217
+
183
218
  const screenshareTilesAvailable = useSelector(
184
219
  (state: RootState) => state.app.screensharePeerTrackNodes.length > 0
185
220
  );
@@ -223,6 +258,7 @@ const RegularTiles = React.forwardRef<
223
258
  <FlatList
224
259
  ref={flatlistRef}
225
260
  horizontal={true}
261
+ style={Platform.OS === 'ios' ? { maxHeight: safeHeight - 16 } : null}
226
262
  data={pairedPeers}
227
263
  initialNumToRender={1}
228
264
  maxToRenderPerBatch={1}
@@ -17,7 +17,7 @@ export const HLSFooter: React.FC<HLSFooterProps> = ({ offset }) => {
17
17
 
18
18
  return (
19
19
  <AnimatedHLSFooter offset={offset} style={styles.animatedContainer}>
20
- {overlayChatVisible ? <HLSChatView /> : null}
20
+ {overlayChatVisible ? <HLSChatView offset={offset} /> : null}
21
21
 
22
22
  <HMSNotifications />
23
23
 
@@ -17,10 +17,15 @@ import { COLORS, hexToRgbA } from '../utils/theme';
17
17
  import { HMSHLSNotStarted } from './HMSHLSNotStarted';
18
18
  import { CrossCircleIcon } from '../Icons';
19
19
  import { useHMSRoomStyleSheet } from '../hooks-util';
20
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
20
21
 
21
22
  export const _HLSView: React.FC = () => {
22
23
  const dispatch = useDispatch();
23
- const room = useSelector((state: RootState) => state.hmsStates.room);
24
+ const isHLSStreaming = useIsHLSStreamingOn();
25
+ const isStreamUrlPresent = useSelector(
26
+ (state: RootState) =>
27
+ !!state.hmsStates.room?.hlsStreamingState.variants?.[0]?.hlsStreamUrl
28
+ );
24
29
  const hmsHlsPlayerRef = useRef<ComponentRef<typeof HMSHLSPlayer>>(null);
25
30
  const showHLSStats = useSelector(
26
31
  (state: RootState) => state.app.joinConfig.showHLSStats
@@ -128,49 +133,45 @@ export const _HLSView: React.FC = () => {
128
133
 
129
134
  return (
130
135
  <View style={styles.hlsView}>
131
- {room?.hlsStreamingState?.running ? (
132
- room?.hlsStreamingState?.variants?.slice(0, 1)?.map((variant, index) =>
133
- variant?.hlsStreamUrl ? (
134
- <View key={index} style={styles.hlsPlayerContainer}>
135
- <HMSHLSPlayer
136
- key={playerKey}
137
- ref={hmsHlsPlayerRef}
138
- enableStats={showHLSStats}
139
- enableControls={enableHLSPlayerControls}
140
- />
141
-
142
- <HLSPlayerEmoticons />
143
-
144
- {showHLSStats ? (
145
- <HLSPlayerStatsView onClosePress={handleClosePress} />
146
- ) : null}
147
-
148
- {showCustomHLSPlayerControls ? (
149
- <CustomControls handleControlPress={hlsPlayerActions} />
150
- ) : null}
151
-
152
- {isPlaybackFailed ? (
153
- <View
154
- style={[
155
- styles.playbackFailedContainer,
156
- hmsRoomStyles.failedContainer,
157
- ]}
158
- >
159
- <CrossCircleIcon />
160
-
161
- <Text
162
- style={[styles.playbackFailed, hmsRoomStyles.failedText]}
163
- >
164
- Playback Failed
165
- </Text>
166
- </View>
167
- ) : null}
168
- </View>
169
- ) : (
170
- <View key={index} style={styles.textContainer}>
171
- <Text style={styles.warningSubtitle}>Stream URL not found!</Text>
172
- </View>
173
- )
136
+ {isHLSStreaming ? (
137
+ isStreamUrlPresent ? (
138
+ <View style={styles.hlsPlayerContainer}>
139
+ <HMSHLSPlayer
140
+ key={playerKey}
141
+ ref={hmsHlsPlayerRef}
142
+ enableStats={showHLSStats}
143
+ enableControls={enableHLSPlayerControls}
144
+ />
145
+
146
+ <HLSPlayerEmoticons />
147
+
148
+ {showHLSStats ? (
149
+ <HLSPlayerStatsView onClosePress={handleClosePress} />
150
+ ) : null}
151
+
152
+ {showCustomHLSPlayerControls ? (
153
+ <CustomControls handleControlPress={hlsPlayerActions} />
154
+ ) : null}
155
+
156
+ {isPlaybackFailed ? (
157
+ <View
158
+ style={[
159
+ styles.playbackFailedContainer,
160
+ hmsRoomStyles.failedContainer,
161
+ ]}
162
+ >
163
+ <CrossCircleIcon />
164
+
165
+ <Text style={[styles.playbackFailed, hmsRoomStyles.failedText]}>
166
+ Playback Failed
167
+ </Text>
168
+ </View>
169
+ ) : null}
170
+ </View>
171
+ ) : (
172
+ <View style={styles.textContainer}>
173
+ <Text style={styles.warningSubtitle}>Stream URL not found!</Text>
174
+ </View>
174
175
  )
175
176
  ) : (
176
177
  <HMSHLSNotStarted />
@@ -6,12 +6,20 @@ import {
6
6
  TouchableHighlight,
7
7
  View,
8
8
  } from 'react-native';
9
- import type { StyleProp, ViewStyle, TextStyle, ColorValue, TouchableHighlightProps } from 'react-native';
9
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
10
+ import type {
11
+ StyleProp,
12
+ ViewStyle,
13
+ TextStyle,
14
+ ColorValue,
15
+ TouchableHighlightProps,
16
+ } from 'react-native';
10
17
 
11
18
  export interface HMSBaseButtonProps {
12
19
  title: string;
13
20
  loading: boolean;
14
21
  onPress(): void;
22
+ wrapWithGestureDetector?: boolean;
15
23
  testID?: TouchableHighlightProps['testID'];
16
24
  underlayColor?: ColorValue | undefined;
17
25
  loaderColor?: ColorValue | undefined;
@@ -32,8 +40,9 @@ export const HMSBaseButton: React.FC<HMSBaseButtonProps> = ({
32
40
  textStyle,
33
41
  disabled,
34
42
  leftComponent,
43
+ wrapWithGestureDetector,
35
44
  }) => {
36
- return (
45
+ const button = (
37
46
  <TouchableHighlight
38
47
  testID={testID}
39
48
  underlayColor={underlayColor}
@@ -63,6 +72,12 @@ export const HMSBaseButton: React.FC<HMSBaseButtonProps> = ({
63
72
  </>
64
73
  </TouchableHighlight>
65
74
  );
75
+
76
+ if (wrapWithGestureDetector) {
77
+ return <GestureDetector gesture={Gesture.Tap()}>{button}</GestureDetector>;
78
+ }
79
+
80
+ return button;
66
81
  };
67
82
 
68
83
  const styles = StyleSheet.create({
@@ -14,6 +14,7 @@ export interface HMSDangerButtonProps {
14
14
  style?: StyleProp<ViewStyle>;
15
15
  disabled?: boolean;
16
16
  leftComponent?: React.ReactElement | null;
17
+ wrapWithGestureDetector?: boolean;
17
18
  }
18
19
 
19
20
  export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
@@ -24,6 +25,7 @@ export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
24
25
  style,
25
26
  disabled,
26
27
  leftComponent,
28
+ wrapWithGestureDetector,
27
29
  }) => {
28
30
  const {
29
31
  alert_error_dim: alertErrorDimColor,
@@ -65,6 +67,7 @@ export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
65
67
  hmsRoomStyles.buttonText,
66
68
  disabled ? hmsRoomStyles.disabledText : null,
67
69
  ]}
70
+ wrapWithGestureDetector={wrapWithGestureDetector}
68
71
  />
69
72
  );
70
73
  };