@100mslive/react-native-room-kit 1.0.7 → 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 (513) 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.map +1 -1
  27. package/lib/commonjs/Icons/index.js +22 -0
  28. package/lib/commonjs/Icons/index.js.map +1 -1
  29. package/lib/commonjs/components/BottomSheet.js.map +1 -1
  30. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js +36 -0
  31. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  32. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js +90 -23
  33. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  34. package/lib/commonjs/components/Chat/ChatFilterItem.js +10 -7
  35. package/lib/commonjs/components/Chat/ChatFilterItem.js.map +1 -1
  36. package/lib/commonjs/components/Chat/ChatFilterView.js +54 -45
  37. package/lib/commonjs/components/Chat/ChatFilterView.js.map +1 -1
  38. package/lib/commonjs/components/Chat/ChatList.js +13 -6
  39. package/lib/commonjs/components/Chat/ChatList.js.map +1 -1
  40. package/lib/commonjs/components/Chat/ChatMessage.js +79 -7
  41. package/lib/commonjs/components/Chat/ChatMessage.js.map +1 -1
  42. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js +61 -0
  43. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js.map +1 -0
  44. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js +63 -0
  45. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  46. package/lib/commonjs/components/Chat/ChatMoreActionsView.js +83 -0
  47. package/lib/commonjs/components/Chat/ChatMoreActionsView.js.map +1 -0
  48. package/lib/commonjs/components/Chat/ChatPaused.js +86 -0
  49. package/lib/commonjs/components/Chat/ChatPaused.js.map +1 -0
  50. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js +34 -0
  51. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  52. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js +66 -0
  53. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  54. package/lib/commonjs/components/Chat/MessageOptionsView.js +188 -0
  55. package/lib/commonjs/components/Chat/MessageOptionsView.js.map +1 -0
  56. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js +47 -0
  57. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js.map +1 -0
  58. package/lib/commonjs/components/Chat/PinnedMessages.js +297 -0
  59. package/lib/commonjs/components/Chat/PinnedMessages.js.map +1 -0
  60. package/lib/commonjs/components/Chat/index.js +4 -4
  61. package/lib/commonjs/components/Chat/index.js.map +1 -1
  62. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  63. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js +21 -2
  64. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  65. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  66. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  67. package/lib/commonjs/components/ChatAndParticipants/ChatView.js +21 -2
  68. package/lib/commonjs/components/ChatAndParticipants/ChatView.js.map +1 -1
  69. package/lib/commonjs/components/EndRoomModalContent.js +6 -9
  70. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -1
  71. package/lib/commonjs/components/Footer.js.map +1 -1
  72. package/lib/commonjs/components/GridView.js.map +1 -1
  73. package/lib/commonjs/components/HLSView.js +8 -6
  74. package/lib/commonjs/components/HLSView.js.map +1 -1
  75. package/lib/commonjs/components/HMSBaseButton.js +10 -2
  76. package/lib/commonjs/components/HMSBaseButton.js.map +1 -1
  77. package/lib/commonjs/components/HMSDangerButton.js +4 -2
  78. package/lib/commonjs/components/HMSDangerButton.js.map +1 -1
  79. package/lib/commonjs/components/HMSHLSMessage.js +86 -1
  80. package/lib/commonjs/components/HMSHLSMessage.js.map +1 -1
  81. package/lib/commonjs/components/HMSHLSMessageList.js +2 -2
  82. package/lib/commonjs/components/HMSHLSMessageList.js.map +1 -1
  83. package/lib/commonjs/components/HMSHandRaiseNotification.js +6 -3
  84. package/lib/commonjs/components/HMSHandRaiseNotification.js.map +1 -1
  85. package/lib/commonjs/components/HMSKeyboardAvoidingView.js +5 -1
  86. package/lib/commonjs/components/HMSKeyboardAvoidingView.js.map +1 -1
  87. package/lib/commonjs/components/HMSLiveIndicator.js +2 -6
  88. package/lib/commonjs/components/HMSLiveIndicator.js.map +1 -1
  89. package/lib/commonjs/components/HMSLiveViewerCount.js +8 -7
  90. package/lib/commonjs/components/HMSLiveViewerCount.js.map +1 -1
  91. package/lib/commonjs/components/HMSLocalScreenshareNotification.js +2 -1
  92. package/lib/commonjs/components/HMSLocalScreenshareNotification.js.map +1 -1
  93. package/lib/commonjs/components/HMSNotification.js +31 -4
  94. package/lib/commonjs/components/HMSNotification.js.map +1 -1
  95. package/lib/commonjs/components/HMSNotifications.js +9 -2
  96. package/lib/commonjs/components/HMSNotifications.js.map +1 -1
  97. package/lib/commonjs/components/HMSOverlayChatView.js +44 -2
  98. package/lib/commonjs/components/HMSOverlayChatView.js.map +1 -1
  99. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  100. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +2 -6
  101. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  102. package/lib/commonjs/components/HMSPrimaryButton.js +4 -2
  103. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -1
  104. package/lib/commonjs/components/HMSRecordingIndicator.js +11 -16
  105. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -1
  106. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  107. package/lib/commonjs/components/HMSTerminalErrorNotification.js +6 -2
  108. package/lib/commonjs/components/HMSTerminalErrorNotification.js.map +1 -1
  109. package/lib/commonjs/components/Header.js.map +1 -1
  110. package/lib/commonjs/components/LeaveRoomBottomSheet.js +3 -6
  111. package/lib/commonjs/components/LeaveRoomBottomSheet.js.map +1 -1
  112. package/lib/commonjs/components/Meeting.js +3 -0
  113. package/lib/commonjs/components/Meeting.js.map +1 -1
  114. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  115. package/lib/commonjs/components/Modals.js +9 -12
  116. package/lib/commonjs/components/Modals.js.map +1 -1
  117. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js +5 -1
  118. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js.map +1 -1
  119. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  120. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  121. package/lib/commonjs/components/Preview.js +14 -1
  122. package/lib/commonjs/components/Preview.js.map +1 -1
  123. package/lib/commonjs/components/PreviewForRoleChangeModal.js +5 -4
  124. package/lib/commonjs/components/PreviewForRoleChangeModal.js.map +1 -1
  125. package/lib/commonjs/components/RoomSettingsModalContent.js +15 -6
  126. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  127. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +2 -4
  128. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  129. package/lib/commonjs/components/WebrtcView.js.map +1 -1
  130. package/lib/commonjs/hooks-sdk-selectors.js +16 -1
  131. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  132. package/lib/commonjs/hooks-sdk.js +27 -1
  133. package/lib/commonjs/hooks-sdk.js.map +1 -1
  134. package/lib/commonjs/hooks-util-selectors.js +3 -3
  135. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  136. package/lib/commonjs/hooks-util.js +408 -61
  137. package/lib/commonjs/hooks-util.js.map +1 -1
  138. package/lib/commonjs/redux/actionTypes.js +16 -3
  139. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  140. package/lib/commonjs/redux/actions/index.js +44 -4
  141. package/lib/commonjs/redux/actions/index.js.map +1 -1
  142. package/lib/commonjs/redux/reducers/appState.js +41 -1
  143. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  144. package/lib/commonjs/redux/reducers/chatWindow.js +1 -2
  145. package/lib/commonjs/redux/reducers/chatWindow.js.map +1 -1
  146. package/lib/commonjs/redux/reducers/message.js +17 -4
  147. package/lib/commonjs/redux/reducers/message.js.map +1 -1
  148. package/lib/commonjs/types.js +1 -0
  149. package/lib/commonjs/types.js.map +1 -1
  150. package/lib/commonjs/utils/types.js +3 -0
  151. package/lib/commonjs/utils/types.js.map +1 -1
  152. package/lib/commonjs/utils.js +2 -2
  153. package/lib/commonjs/utils.js.map +1 -1
  154. package/lib/module/HMSRoomSetup.js +5 -2
  155. package/lib/module/HMSRoomSetup.js.map +1 -1
  156. package/lib/module/Icons/Chat/assets/chat-on.png +0 -0
  157. package/lib/module/Icons/Chat/assets/chat-on@2x.png +0 -0
  158. package/lib/module/Icons/Chat/assets/chat-on@3x.png +0 -0
  159. package/lib/module/Icons/Chat/index.js +4 -3
  160. package/lib/module/Icons/Chat/index.js.map +1 -1
  161. package/lib/module/Icons/NoEntry/assets/no-entry.png +0 -0
  162. package/lib/module/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  163. package/lib/module/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  164. package/lib/module/Icons/NoEntry/index.js +25 -0
  165. package/lib/module/Icons/NoEntry/index.js.map +1 -0
  166. package/lib/module/Icons/PauseCircle/assets/pause-circle.png +0 -0
  167. package/lib/module/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  168. package/lib/module/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  169. package/lib/module/Icons/PauseCircle/index.js +21 -0
  170. package/lib/module/Icons/PauseCircle/index.js.map +1 -0
  171. package/lib/module/Icons/Pin/assets/unpin.png +0 -0
  172. package/lib/module/Icons/Pin/assets/unpin@2x.png +0 -0
  173. package/lib/module/Icons/Pin/assets/unpin@3x.png +0 -0
  174. package/lib/module/Icons/Pin/index.js +2 -1
  175. package/lib/module/Icons/Pin/index.js.map +1 -1
  176. package/lib/module/Icons/Recording/assets/recording-pause.png +0 -0
  177. package/lib/module/Icons/Recording/assets/recording-pause@2x.png +0 -0
  178. package/lib/module/Icons/Recording/assets/recording-pause@3x.png +0 -0
  179. package/lib/module/Icons/Recording/index.js.map +1 -1
  180. package/lib/module/Icons/index.js +2 -0
  181. package/lib/module/Icons/index.js.map +1 -1
  182. package/lib/module/components/BottomSheet.js.map +1 -1
  183. package/lib/module/components/Chat/ChatFilterBottomSheet.js +28 -0
  184. package/lib/module/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  185. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js +93 -26
  186. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  187. package/lib/module/components/Chat/ChatFilterItem.js +11 -8
  188. package/lib/module/components/Chat/ChatFilterItem.js.map +1 -1
  189. package/lib/module/components/Chat/ChatFilterView.js +55 -46
  190. package/lib/module/components/Chat/ChatFilterView.js.map +1 -1
  191. package/lib/module/components/Chat/ChatList.js +14 -7
  192. package/lib/module/components/Chat/ChatList.js.map +1 -1
  193. package/lib/module/components/Chat/ChatMessage.js +81 -9
  194. package/lib/module/components/Chat/ChatMessage.js.map +1 -1
  195. package/lib/module/components/Chat/ChatMoreActionsModal.js +53 -0
  196. package/lib/module/components/Chat/ChatMoreActionsModal.js.map +1 -0
  197. package/lib/module/components/Chat/ChatMoreActionsSheetView.js +55 -0
  198. package/lib/module/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  199. package/lib/module/components/Chat/ChatMoreActionsView.js +75 -0
  200. package/lib/module/components/Chat/ChatMoreActionsView.js.map +1 -0
  201. package/lib/module/components/Chat/ChatPaused.js +77 -0
  202. package/lib/module/components/Chat/ChatPaused.js.map +1 -0
  203. package/lib/module/components/Chat/MessageOptionsBottomSheet.js +26 -0
  204. package/lib/module/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  205. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js +58 -0
  206. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  207. package/lib/module/components/Chat/MessageOptionsView.js +180 -0
  208. package/lib/module/components/Chat/MessageOptionsView.js.map +1 -0
  209. package/lib/module/components/Chat/PeerBlockedFromChat.js +38 -0
  210. package/lib/module/components/Chat/PeerBlockedFromChat.js.map +1 -0
  211. package/lib/module/components/Chat/PinnedMessages.js +288 -0
  212. package/lib/module/components/Chat/PinnedMessages.js.map +1 -0
  213. package/lib/module/components/Chat/index.js +1 -1
  214. package/lib/module/components/Chat/index.js.map +1 -1
  215. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  216. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js +24 -5
  217. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  218. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  219. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  220. package/lib/module/components/ChatAndParticipants/ChatView.js +22 -3
  221. package/lib/module/components/ChatAndParticipants/ChatView.js.map +1 -1
  222. package/lib/module/components/EndRoomModalContent.js +6 -9
  223. package/lib/module/components/EndRoomModalContent.js.map +1 -1
  224. package/lib/module/components/Footer.js.map +1 -1
  225. package/lib/module/components/GridView.js.map +1 -1
  226. package/lib/module/components/HLSView.js +9 -7
  227. package/lib/module/components/HLSView.js.map +1 -1
  228. package/lib/module/components/HMSBaseButton.js +10 -2
  229. package/lib/module/components/HMSBaseButton.js.map +1 -1
  230. package/lib/module/components/HMSDangerButton.js +4 -2
  231. package/lib/module/components/HMSDangerButton.js.map +1 -1
  232. package/lib/module/components/HMSHLSMessage.js +88 -3
  233. package/lib/module/components/HMSHLSMessage.js.map +1 -1
  234. package/lib/module/components/HMSHLSMessageList.js +2 -2
  235. package/lib/module/components/HMSHLSMessageList.js.map +1 -1
  236. package/lib/module/components/HMSHandRaiseNotification.js +6 -3
  237. package/lib/module/components/HMSHandRaiseNotification.js.map +1 -1
  238. package/lib/module/components/HMSKeyboardAvoidingView.js +6 -2
  239. package/lib/module/components/HMSKeyboardAvoidingView.js.map +1 -1
  240. package/lib/module/components/HMSLiveIndicator.js +2 -6
  241. package/lib/module/components/HMSLiveIndicator.js.map +1 -1
  242. package/lib/module/components/HMSLiveViewerCount.js +8 -7
  243. package/lib/module/components/HMSLiveViewerCount.js.map +1 -1
  244. package/lib/module/components/HMSLocalScreenshareNotification.js +2 -1
  245. package/lib/module/components/HMSLocalScreenshareNotification.js.map +1 -1
  246. package/lib/module/components/HMSNotification.js +32 -5
  247. package/lib/module/components/HMSNotification.js.map +1 -1
  248. package/lib/module/components/HMSNotifications.js +9 -2
  249. package/lib/module/components/HMSNotifications.js.map +1 -1
  250. package/lib/module/components/HMSOverlayChatView.js +45 -3
  251. package/lib/module/components/HMSOverlayChatView.js.map +1 -1
  252. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  253. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +2 -6
  254. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  255. package/lib/module/components/HMSPrimaryButton.js +4 -2
  256. package/lib/module/components/HMSPrimaryButton.js.map +1 -1
  257. package/lib/module/components/HMSRecordingIndicator.js +11 -16
  258. package/lib/module/components/HMSRecordingIndicator.js.map +1 -1
  259. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  260. package/lib/module/components/HMSTerminalErrorNotification.js +6 -2
  261. package/lib/module/components/HMSTerminalErrorNotification.js.map +1 -1
  262. package/lib/module/components/Header.js.map +1 -1
  263. package/lib/module/components/LeaveRoomBottomSheet.js +3 -6
  264. package/lib/module/components/LeaveRoomBottomSheet.js.map +1 -1
  265. package/lib/module/components/Meeting.js +4 -1
  266. package/lib/module/components/Meeting.js.map +1 -1
  267. package/lib/module/components/MeetingScreenContent.js.map +1 -1
  268. package/lib/module/components/Modals.js +10 -13
  269. package/lib/module/components/Modals.js.map +1 -1
  270. package/lib/module/components/Participants/ParticipantsItemOptions.js +5 -1
  271. package/lib/module/components/Participants/ParticipantsItemOptions.js.map +1 -1
  272. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  273. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  274. package/lib/module/components/Preview.js +13 -2
  275. package/lib/module/components/Preview.js.map +1 -1
  276. package/lib/module/components/PreviewForRoleChangeModal.js +5 -4
  277. package/lib/module/components/PreviewForRoleChangeModal.js.map +1 -1
  278. package/lib/module/components/RoomSettingsModalContent.js +16 -7
  279. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  280. package/lib/module/components/RoomSettingsModalDebugModeContent.js +3 -5
  281. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  282. package/lib/module/components/WebrtcView.js.map +1 -1
  283. package/lib/module/hooks-sdk-selectors.js +12 -0
  284. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  285. package/lib/module/hooks-sdk.js +23 -1
  286. package/lib/module/hooks-sdk.js.map +1 -1
  287. package/lib/module/hooks-util-selectors.js +3 -3
  288. package/lib/module/hooks-util-selectors.js.map +1 -1
  289. package/lib/module/hooks-util.js +398 -62
  290. package/lib/module/hooks-util.js.map +1 -1
  291. package/lib/module/redux/actionTypes.js +16 -3
  292. package/lib/module/redux/actionTypes.js.map +1 -1
  293. package/lib/module/redux/actions/index.js +36 -2
  294. package/lib/module/redux/actions/index.js.map +1 -1
  295. package/lib/module/redux/reducers/appState.js +41 -1
  296. package/lib/module/redux/reducers/appState.js.map +1 -1
  297. package/lib/module/redux/reducers/chatWindow.js +1 -2
  298. package/lib/module/redux/reducers/chatWindow.js.map +1 -1
  299. package/lib/module/redux/reducers/message.js +17 -4
  300. package/lib/module/redux/reducers/message.js.map +1 -1
  301. package/lib/module/types.js +1 -0
  302. package/lib/module/types.js.map +1 -1
  303. package/lib/module/utils/types.js +3 -0
  304. package/lib/module/utils/types.js.map +1 -1
  305. package/lib/module/utils.js +2 -2
  306. package/lib/module/utils.js.map +1 -1
  307. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  308. package/lib/typescript/Icons/Chat/index.d.ts +1 -0
  309. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  310. package/lib/typescript/Icons/NoEntry/index.d.ts +7 -0
  311. package/lib/typescript/Icons/NoEntry/index.d.ts.map +1 -0
  312. package/lib/typescript/Icons/PauseCircle/index.d.ts +7 -0
  313. package/lib/typescript/Icons/PauseCircle/index.d.ts.map +1 -0
  314. package/lib/typescript/Icons/Pin/index.d.ts +1 -0
  315. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -1
  316. package/lib/typescript/Icons/index.d.ts +2 -0
  317. package/lib/typescript/Icons/index.d.ts.map +1 -1
  318. package/lib/typescript/components/BottomSheet.d.ts.map +1 -1
  319. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts +3 -0
  320. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts.map +1 -0
  321. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts +1 -0
  322. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts.map +1 -1
  323. package/lib/typescript/components/Chat/ChatFilterItem.d.ts +1 -0
  324. package/lib/typescript/components/Chat/ChatFilterItem.d.ts.map +1 -1
  325. package/lib/typescript/components/Chat/ChatFilterView.d.ts +1 -0
  326. package/lib/typescript/components/Chat/ChatFilterView.d.ts.map +1 -1
  327. package/lib/typescript/components/Chat/ChatList.d.ts.map +1 -1
  328. package/lib/typescript/components/Chat/ChatMessage.d.ts.map +1 -1
  329. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts +7 -0
  330. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts.map +1 -0
  331. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts +6 -0
  332. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts.map +1 -0
  333. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts +7 -0
  334. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts.map +1 -0
  335. package/lib/typescript/components/Chat/ChatPaused.d.ts +10 -0
  336. package/lib/typescript/components/Chat/ChatPaused.d.ts.map +1 -0
  337. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts +3 -0
  338. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts.map +1 -0
  339. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts +6 -0
  340. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts.map +1 -0
  341. package/lib/typescript/components/Chat/MessageOptionsView.d.ts +7 -0
  342. package/lib/typescript/components/Chat/MessageOptionsView.d.ts.map +1 -0
  343. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts +9 -0
  344. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts.map +1 -0
  345. package/lib/typescript/components/Chat/PinnedMessages.d.ts +8 -0
  346. package/lib/typescript/components/Chat/PinnedMessages.d.ts.map +1 -0
  347. package/lib/typescript/components/Chat/index.d.ts +1 -1
  348. package/lib/typescript/components/Chat/index.d.ts.map +1 -1
  349. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.d.ts.map +1 -1
  350. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsHeader.d.ts.map +1 -1
  351. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsView.d.ts.map +1 -1
  352. package/lib/typescript/components/ChatAndParticipants/ChatView.d.ts.map +1 -1
  353. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -1
  354. package/lib/typescript/components/Footer.d.ts.map +1 -1
  355. package/lib/typescript/components/GridView.d.ts.map +1 -1
  356. package/lib/typescript/components/HMSBaseButton.d.ts +1 -0
  357. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -1
  358. package/lib/typescript/components/HMSDangerButton.d.ts +1 -0
  359. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -1
  360. package/lib/typescript/components/HMSHLSMessage.d.ts +1 -1
  361. package/lib/typescript/components/HMSHLSMessage.d.ts.map +1 -1
  362. package/lib/typescript/components/HMSHandRaiseNotification.d.ts.map +1 -1
  363. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts.map +1 -1
  364. package/lib/typescript/components/HMSLiveIndicator.d.ts.map +1 -1
  365. package/lib/typescript/components/HMSLiveViewerCount.d.ts.map +1 -1
  366. package/lib/typescript/components/HMSLocalScreenshareNotification.d.ts.map +1 -1
  367. package/lib/typescript/components/HMSNotification.d.ts +2 -1
  368. package/lib/typescript/components/HMSNotification.d.ts.map +1 -1
  369. package/lib/typescript/components/HMSNotifications.d.ts.map +1 -1
  370. package/lib/typescript/components/HMSOverlayChatView.d.ts.map +1 -1
  371. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  372. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  373. package/lib/typescript/components/HMSPrimaryButton.d.ts +1 -0
  374. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -1
  375. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -1
  376. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  377. package/lib/typescript/components/HMSTerminalErrorNotification.d.ts.map +1 -1
  378. package/lib/typescript/components/Header.d.ts.map +1 -1
  379. package/lib/typescript/components/LeaveRoomBottomSheet.d.ts.map +1 -1
  380. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  381. package/lib/typescript/components/MeetingScreenContent.d.ts.map +1 -1
  382. package/lib/typescript/components/Modals.d.ts.map +1 -1
  383. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts.map +1 -1
  384. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  385. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -1
  386. package/lib/typescript/components/Preview.d.ts.map +1 -1
  387. package/lib/typescript/components/PreviewForRoleChangeModal.d.ts.map +1 -1
  388. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  389. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -1
  390. package/lib/typescript/components/WebrtcView.d.ts.map +1 -1
  391. package/lib/typescript/hooks-sdk-selectors.d.ts +3 -0
  392. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  393. package/lib/typescript/hooks-sdk.d.ts +4 -0
  394. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  395. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  396. package/lib/typescript/hooks-util.d.ts +35 -3
  397. package/lib/typescript/hooks-util.d.ts.map +1 -1
  398. package/lib/typescript/redux/actionTypes.d.ts +9 -2
  399. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  400. package/lib/typescript/redux/actions/index.d.ts +37 -3
  401. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  402. package/lib/typescript/redux/index.d.ts +7 -2
  403. package/lib/typescript/redux/index.d.ts.map +1 -1
  404. package/lib/typescript/redux/reducers/appState.d.ts +7 -2
  405. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  406. package/lib/typescript/redux/reducers/chatWindow.d.ts +1 -1
  407. package/lib/typescript/redux/reducers/chatWindow.d.ts.map +1 -1
  408. package/lib/typescript/redux/reducers/index.d.ts +7 -2
  409. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  410. package/lib/typescript/redux/reducers/message.d.ts +3 -2
  411. package/lib/typescript/redux/reducers/message.d.ts.map +1 -1
  412. package/lib/typescript/types.d.ts +23 -3
  413. package/lib/typescript/types.d.ts.map +1 -1
  414. package/lib/typescript/utils/types.d.ts +3 -0
  415. package/lib/typescript/utils/types.d.ts.map +1 -1
  416. package/package.json +179 -179
  417. package/src/HMSRoomSetup.tsx +7 -2
  418. package/src/Icons/Chat/assets/chat-on.png +0 -0
  419. package/src/Icons/Chat/assets/chat-on@2x.png +0 -0
  420. package/src/Icons/Chat/assets/chat-on@3x.png +0 -0
  421. package/src/Icons/Chat/index.tsx +19 -6
  422. package/src/Icons/NoEntry/assets/no-entry.png +0 -0
  423. package/src/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  424. package/src/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  425. package/src/Icons/NoEntry/index.tsx +33 -0
  426. package/src/Icons/PauseCircle/assets/pause-circle.png +0 -0
  427. package/src/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  428. package/src/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  429. package/src/Icons/PauseCircle/index.tsx +27 -0
  430. package/src/Icons/Pin/assets/unpin.png +0 -0
  431. package/src/Icons/Pin/assets/unpin@2x.png +0 -0
  432. package/src/Icons/Pin/assets/unpin@3x.png +0 -0
  433. package/src/Icons/Pin/index.tsx +13 -3
  434. package/src/Icons/Recording/assets/recording-pause.png +0 -0
  435. package/src/Icons/Recording/assets/recording-pause@2x.png +0 -0
  436. package/src/Icons/Recording/assets/recording-pause@3x.png +0 -0
  437. package/src/Icons/Recording/index.tsx +2 -2
  438. package/src/Icons/index.ts +2 -0
  439. package/src/components/BottomSheet.tsx +13 -3
  440. package/src/components/Chat/ChatFilterBottomSheet.tsx +35 -0
  441. package/src/components/Chat/ChatFilterBottomSheetOpener.tsx +170 -42
  442. package/src/components/Chat/ChatFilterItem.tsx +8 -4
  443. package/src/components/Chat/ChatFilterView.tsx +102 -75
  444. package/src/components/Chat/ChatList.tsx +18 -6
  445. package/src/components/Chat/ChatMessage.tsx +111 -7
  446. package/src/components/Chat/ChatMoreActionsModal.tsx +75 -0
  447. package/src/components/Chat/ChatMoreActionsSheetView.tsx +77 -0
  448. package/src/components/Chat/ChatMoreActionsView.tsx +84 -0
  449. package/src/components/Chat/ChatPaused.tsx +103 -0
  450. package/src/components/Chat/MessageOptionsBottomSheet.tsx +33 -0
  451. package/src/components/Chat/MessageOptionsBottomSheetView.tsx +82 -0
  452. package/src/components/Chat/MessageOptionsView.tsx +248 -0
  453. package/src/components/Chat/PeerBlockedFromChat.tsx +49 -0
  454. package/src/components/Chat/PinnedMessages.tsx +422 -0
  455. package/src/components/Chat/index.ts +1 -1
  456. package/src/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.tsx +4 -1
  457. package/src/components/ChatAndParticipants/ChatAndParticipantsHeader.tsx +48 -12
  458. package/src/components/ChatAndParticipants/ChatAndParticipantsView.tsx +9 -1
  459. package/src/components/ChatAndParticipants/ChatView.tsx +37 -5
  460. package/src/components/EndRoomModalContent.tsx +11 -14
  461. package/src/components/Footer.tsx +3 -1
  462. package/src/components/GridView.tsx +17 -8
  463. package/src/components/HLSView.tsx +45 -45
  464. package/src/components/HMSBaseButton.tsx +17 -2
  465. package/src/components/HMSDangerButton.tsx +3 -0
  466. package/src/components/HMSHLSMessage.tsx +130 -13
  467. package/src/components/HMSHLSMessageList.tsx +2 -2
  468. package/src/components/HMSHandRaiseNotification.tsx +17 -10
  469. package/src/components/HMSKeyboardAvoidingView.tsx +6 -1
  470. package/src/components/HMSLiveIndicator.tsx +9 -13
  471. package/src/components/HMSLiveViewerCount.tsx +21 -20
  472. package/src/components/HMSLocalScreenshareNotification.tsx +1 -0
  473. package/src/components/HMSNotification.tsx +56 -13
  474. package/src/components/HMSNotifications.tsx +12 -2
  475. package/src/components/HMSOverlayChatView.tsx +74 -17
  476. package/src/components/HMSPreviewEditName.tsx +3 -1
  477. package/src/components/HMSPreviewHLSLiveIndicator.tsx +2 -6
  478. package/src/components/HMSPrimaryButton.tsx +3 -0
  479. package/src/components/HMSRecordingIndicator.tsx +8 -22
  480. package/src/components/HMSRoomOptions.tsx +4 -1
  481. package/src/components/HMSTerminalErrorNotification.tsx +15 -10
  482. package/src/components/Header.tsx +4 -1
  483. package/src/components/LeaveRoomBottomSheet.tsx +13 -11
  484. package/src/components/Meeting.tsx +4 -0
  485. package/src/components/MeetingScreenContent.tsx +24 -21
  486. package/src/components/Modals.tsx +23 -25
  487. package/src/components/Participants/ParticipantsItemOptions.tsx +12 -7
  488. package/src/components/PeerSettingsModalContent.tsx +3 -1
  489. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +3 -1
  490. package/src/components/Preview.tsx +15 -2
  491. package/src/components/PreviewForRoleChangeModal.tsx +4 -3
  492. package/src/components/RoomSettingsModalContent.tsx +62 -18
  493. package/src/components/RoomSettingsModalDebugModeContent.tsx +2 -5
  494. package/src/components/WebrtcView.tsx +6 -2
  495. package/src/hooks-sdk-selectors.tsx +19 -0
  496. package/src/hooks-sdk.ts +37 -0
  497. package/src/hooks-util-selectors.tsx +2 -3
  498. package/src/hooks-util.ts +578 -87
  499. package/src/redux/actionTypes.ts +22 -2
  500. package/src/redux/actions/index.ts +41 -4
  501. package/src/redux/reducers/appState.ts +54 -5
  502. package/src/redux/reducers/chatWindow.ts +2 -2
  503. package/src/redux/reducers/message.ts +20 -6
  504. package/src/types.ts +35 -6
  505. package/src/utils/types.ts +3 -0
  506. package/src/utils.ts +2 -2
  507. package/lib/commonjs/components/Chat/PinnedMessage.js +0 -81
  508. package/lib/commonjs/components/Chat/PinnedMessage.js.map +0 -1
  509. package/lib/module/components/Chat/PinnedMessage.js +0 -72
  510. package/lib/module/components/Chat/PinnedMessage.js.map +0 -1
  511. package/lib/typescript/components/Chat/PinnedMessage.d.ts +0 -3
  512. package/lib/typescript/components/Chat/PinnedMessage.d.ts.map +0 -1
  513. package/src/components/Chat/PinnedMessage.tsx +0 -89
@@ -1,12 +1,7 @@
1
1
  import * as React from 'react';
2
- import {
3
- StyleSheet,
4
- Text,
5
- Platform,
6
- TouchableOpacity,
7
- } from 'react-native';
2
+ import { StyleSheet, Text, Platform, TouchableOpacity } from 'react-native';
8
3
  import { useSelector } from 'react-redux';
9
- import { HMSStreamingState } from '@100mslive/react-native-hms';
4
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
10
5
 
11
6
  import {
12
7
  useHMSRoomStyleSheet,
@@ -17,15 +12,14 @@ import { EyeIcon } from '../Icons';
17
12
  import { hexToRgbA } from '../utils/theme';
18
13
  import type { RootState } from '../redux';
19
14
  import { TestIds } from '../utils/constants';
15
+ import { useIsAnyStreamingOn } from '../hooks-sdk';
20
16
 
21
17
  const _HMSLiveViewerCount = () => {
22
18
  const isHLSViewer = useIsHLSViewer();
23
19
  const previewPeerCount = useSelector(
24
20
  (state: RootState) => state.hmsStates.room?.peerCount
25
21
  );
26
- const live = useSelector(
27
- (state: RootState) => state.hmsStates.room?.hlsStreamingState?.state === HMSStreamingState.STARTED
28
- );
22
+ const live = useIsAnyStreamingOn();
29
23
 
30
24
  const hmsRoomStyles = useHMSRoomStyleSheet((theme, typograhy) => ({
31
25
  viewers: {
@@ -44,6 +38,8 @@ const _HMSLiveViewerCount = () => {
44
38
 
45
39
  const { canShowParticipants, show } = useShowChatAndParticipants();
46
40
 
41
+ const tapGesture = React.useMemo(() => Gesture.Tap(), []);
42
+
47
43
  const showParticipantsSheet = () => {
48
44
  show('participants');
49
45
  };
@@ -53,17 +49,22 @@ const _HMSLiveViewerCount = () => {
53
49
  }
54
50
 
55
51
  return (
56
- <TouchableOpacity
57
- style={[styles.viewers, hmsRoomStyles.viewers]}
58
- onPress={showParticipantsSheet}
59
- disabled={!canShowParticipants}
60
- >
61
- <EyeIcon testID={TestIds.peer_count_icon} />
52
+ <GestureDetector gesture={tapGesture}>
53
+ <TouchableOpacity
54
+ style={[styles.viewers, hmsRoomStyles.viewers]}
55
+ onPress={showParticipantsSheet}
56
+ disabled={!canShowParticipants}
57
+ >
58
+ <EyeIcon testID={TestIds.peer_count_icon} />
62
59
 
63
- <Text testID={TestIds.peer_count} style={[styles.count, hmsRoomStyles.count]}>
64
- {previewPeerCount}
65
- </Text>
66
- </TouchableOpacity>
60
+ <Text
61
+ testID={TestIds.peer_count}
62
+ style={[styles.count, hmsRoomStyles.count]}
63
+ >
64
+ {previewPeerCount}
65
+ </Text>
66
+ </TouchableOpacity>
67
+ </GestureDetector>
67
68
  );
68
69
  };
69
70
 
@@ -37,6 +37,7 @@ export const HMSLocalScreenshareNotification: React.FC<
37
37
  loading={false}
38
38
  onPress={stopScreenshare}
39
39
  title="Stop"
40
+ wrapWithGestureDetector={true}
40
41
  />
41
42
  }
42
43
  />
@@ -2,19 +2,21 @@ import * as React from 'react';
2
2
  import { useDispatch } from 'react-redux';
3
3
  import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
4
4
  import type { StyleProp, ViewStyle, TextStyle, TextProps } from 'react-native';
5
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
5
6
 
6
7
  import { useHMSRoomStyleSheet } from '../hooks-util';
7
- import { CloseIcon } from '../Icons';
8
+ import { ChatIcon, CloseIcon } from '../Icons';
8
9
  import { UnmountAfterDelay } from './UnmountAfterDelay';
9
10
  import { removeNotification } from '../redux/actions';
10
11
 
11
12
  export interface HMSNotificationProps {
12
13
  id: string;
13
14
  text: string | React.ReactElement;
15
+ description?: string | React.ReactElement;
14
16
  textTestID?: TextProps['testID'];
15
17
  style?: StyleProp<ViewStyle>;
16
18
  textStyle?: StyleProp<TextStyle>;
17
- icon?: React.ReactElement;
19
+ icon?: string | React.ReactElement;
18
20
  onDismiss?: () => void;
19
21
  autoDismiss?: boolean;
20
22
  dismissDelay?: number;
@@ -25,6 +27,7 @@ export interface HMSNotificationProps {
25
27
  export const HMSNotification: React.FC<HMSNotificationProps> = ({
26
28
  id,
27
29
  text,
30
+ description = null,
28
31
  icon,
29
32
  style,
30
33
  textStyle,
@@ -45,6 +48,10 @@ export const HMSNotification: React.FC<HMSNotificationProps> = ({
45
48
  color: theme.palette.on_surface_high,
46
49
  fontFamily: `${typography.font_family}-SemiBold`,
47
50
  },
51
+ description: {
52
+ color: theme.palette.on_surface_medium,
53
+ fontFamily: `${typography.font_family}-Regular`,
54
+ },
48
55
  }));
49
56
 
50
57
  const dismissNotification =
@@ -55,27 +62,47 @@ export const HMSNotification: React.FC<HMSNotificationProps> = ({
55
62
  }
56
63
  : null);
57
64
 
65
+ const tapGesture = Gesture.Tap();
66
+
58
67
  const notification = (
59
68
  <View style={[styles.container, hmsRoomStyles.container, style]}>
60
69
  <View style={styles.leftWrapper}>
61
- {icon ? <View style={styles.icon}>{icon}</View> : null}
70
+ {icon ? (
71
+ <View style={styles.icon}>
72
+ {typeof icon === 'string' ? getIcon(icon) : icon}
73
+ </View>
74
+ ) : null}
62
75
 
63
- {typeof text === 'string' ? (
64
- <Text testID={textTestID} style={[styles.text, hmsRoomStyles.text, textStyle]}>
65
- {text}
66
- </Text>
67
- ) : (
68
- text
69
- )}
76
+ <View>
77
+ {typeof text === 'string' ? (
78
+ <Text
79
+ testID={textTestID}
80
+ style={[styles.text, hmsRoomStyles.text, textStyle]}
81
+ >
82
+ {text}
83
+ </Text>
84
+ ) : (
85
+ text
86
+ )}
87
+ {typeof description === 'string' ? (
88
+ <Text style={[styles.description, hmsRoomStyles.description]}>
89
+ {description}
90
+ </Text>
91
+ ) : (
92
+ description
93
+ )}
94
+ </View>
70
95
  </View>
71
96
 
72
97
  <View style={styles.rightWrapper}>
73
98
  {cta}
74
99
 
75
100
  {dismissNotification ? (
76
- <TouchableOpacity onPress={dismissNotification}>
77
- <CloseIcon />
78
- </TouchableOpacity>
101
+ <GestureDetector gesture={tapGesture}>
102
+ <TouchableOpacity onPress={dismissNotification}>
103
+ <CloseIcon />
104
+ </TouchableOpacity>
105
+ </GestureDetector>
79
106
  ) : null}
80
107
  </View>
81
108
  </View>
@@ -127,4 +154,20 @@ const styles = StyleSheet.create({
127
154
  lineHeight: 20,
128
155
  letterSpacing: 0.1,
129
156
  },
157
+ description: {
158
+ flexShrink: 1,
159
+ fontSize: 12,
160
+ lineHeight: 16,
161
+ },
130
162
  });
163
+
164
+ function getIcon(icon: string) {
165
+ switch (icon) {
166
+ case 'chat-off':
167
+ case 'chat-on':
168
+ return <ChatIcon type={icon === 'chat-on' ? 'on' : 'off'} />;
169
+
170
+ default:
171
+ return null;
172
+ }
173
+ }
@@ -131,14 +131,24 @@ export const HMSNotifications: React.FC<HMSNotificationsProps> = () => {
131
131
  autoDismiss={false}
132
132
  />
133
133
  ) : notification.type === NotificationTypes.ERROR &&
134
- 'message' in notification ? (
134
+ ('message' in notification || 'title' in notification) ? (
135
135
  <HMSNotification
136
136
  icon={<AlertTriangleIcon type="line" />}
137
137
  id={notification.id}
138
- text={notification.message}
138
+ text={notification.title}
139
139
  autoDismiss={false}
140
140
  dismissable={true}
141
141
  />
142
+ ) : notification.type === NotificationTypes.INFO &&
143
+ ('message' in notification || 'title' in notification) ? (
144
+ <HMSNotification
145
+ id={notification.id}
146
+ icon={notification.icon}
147
+ description={notification.message}
148
+ text={notification.title}
149
+ autoDismiss={true}
150
+ dismissable={true}
151
+ />
142
152
  ) : null}
143
153
  </View>
144
154
  );
@@ -1,15 +1,29 @@
1
1
  import * as React from 'react';
2
- import { StyleSheet } from 'react-native';
2
+ import { useSelector } from 'react-redux';
3
+ import { StyleSheet, View } from 'react-native';
3
4
  import LinearGradient from 'react-native-linear-gradient';
4
5
  import MaskedView from '@react-native-masked-view/masked-view';
5
6
  import { useDerivedValue, interpolate } from 'react-native-reanimated';
6
7
  import type { SharedValue } from 'react-native-reanimated';
7
8
 
9
+ import type { RootState } from '../redux';
8
10
  import { HMSKeyboardAvoidingView } from './HMSKeyboardAvoidingView';
9
11
  import { HMSSendMessageInput } from './HMSSendMessageInput';
10
12
  import { HMSHLSMessageList } from './HMSHLSMessageList';
11
13
  import { useFooterHeight } from './Footer';
12
14
  import { useHMSNotificationsHeight } from './HMSNotifications';
15
+ import { ChatFilterBottomSheetOpener } from './Chat/ChatFilterBottomSheetOpener';
16
+ import { ChatMoreActionsModal } from './Chat/ChatMoreActionsModal';
17
+ import { ChatFilterBottomSheet } from './Chat/ChatFilterBottomSheet';
18
+ import { ChatPaused } from './Chat/ChatPaused';
19
+ import {
20
+ useHMSChatState,
21
+ useIsAllowedToSendMessage,
22
+ useIsLocalPeerBlockedFromChat,
23
+ } from '../hooks-util';
24
+ import { PinnedMessages } from './Chat';
25
+ import { MessageOptionsBottomSheet } from './Chat/MessageOptionsBottomSheet';
26
+ import { PeerBlockedFromChat } from './Chat/PeerBlockedFromChat';
13
27
 
14
28
  const colors = [
15
29
  'rgba(0, 0, 0, 0)',
@@ -25,6 +39,12 @@ export interface HLSChatViewProps {
25
39
  export const HLSChatView: React.FC<HLSChatViewProps> = ({ offset }) => {
26
40
  const footerHeight = useFooterHeight();
27
41
  const hmsNotificationsHeight = useHMSNotificationsHeight();
42
+ const { chatState } = useHMSChatState();
43
+ const isAllowedToSendMessage = useIsAllowedToSendMessage();
44
+ const isLocalPeerBlockedFromChat = useIsLocalPeerBlockedFromChat();
45
+ const isSelectedChatRecipient = useSelector(
46
+ (state: RootState) => state.chatWindow.sendTo !== null
47
+ );
28
48
 
29
49
  const chatBottomOffset = useDerivedValue(() => {
30
50
  if (offset) {
@@ -37,21 +57,58 @@ export const HLSChatView: React.FC<HLSChatViewProps> = ({ offset }) => {
37
57
  }, [offset, footerHeight, hmsNotificationsHeight]);
38
58
 
39
59
  return (
40
- <HMSKeyboardAvoidingView bottomOffset={chatBottomOffset}>
41
- <MaskedView
42
- maskElement={
43
- <LinearGradient
44
- pointerEvents="box-none"
45
- style={StyleSheet.absoluteFill}
46
- colors={colors}
47
- locations={colorLocations}
48
- />
49
- }
50
- >
51
- <HMSHLSMessageList />
52
- </MaskedView>
53
-
54
- <HMSSendMessageInput />
55
- </HMSKeyboardAvoidingView>
60
+ <>
61
+ <HMSKeyboardAvoidingView bottomOffset={chatBottomOffset}>
62
+ <MaskedView
63
+ maskElement={
64
+ <LinearGradient
65
+ pointerEvents="box-none"
66
+ style={StyleSheet.absoluteFill}
67
+ colors={colors}
68
+ locations={colorLocations}
69
+ />
70
+ }
71
+ >
72
+ <HMSHLSMessageList />
73
+ </MaskedView>
74
+
75
+ <PinnedMessages insetMode={true} />
76
+
77
+ {chatState.enabled ? (
78
+ <>
79
+ <View style={styles.filterSheetWrapper}>
80
+ <ChatFilterBottomSheetOpener insetMode={true} />
81
+ </View>
82
+
83
+ {isLocalPeerBlockedFromChat ? (
84
+ <PeerBlockedFromChat style={styles.peerBlocked} />
85
+ ) : isAllowedToSendMessage && isSelectedChatRecipient ? (
86
+ <HMSSendMessageInput />
87
+ ) : null}
88
+ </>
89
+ ) : (
90
+ <ChatPaused insetMode={true} style={styles.chatPaused} />
91
+ )}
92
+ </HMSKeyboardAvoidingView>
93
+
94
+ <MessageOptionsBottomSheet />
95
+ <ChatFilterBottomSheet />
96
+ <ChatMoreActionsModal offset={offset} />
97
+ </>
56
98
  );
57
99
  };
100
+
101
+ const styles = StyleSheet.create({
102
+ filterSheetWrapper: {
103
+ marginHorizontal: 8,
104
+ marginTop: 8,
105
+ },
106
+ chatPaused: {
107
+ marginHorizontal: 8,
108
+ marginBottom: 38,
109
+ },
110
+ peerBlocked: {
111
+ marginHorizontal: 8,
112
+ marginBottom: 8,
113
+ },
114
+ });
@@ -13,7 +13,9 @@ export const HMSPreviewEditName: React.FC<HMSPreviewEditNameProps> = () => {
13
13
  const dispatch = useDispatch();
14
14
  const { updateConfig } = useHMSConfig();
15
15
  const userName = useSelector((state: RootState) => state.user.userName);
16
- const editUsernameDisabled = useSelector((state: RootState) => state.app.editUsernameDisabled);
16
+ const editUsernameDisabled = useSelector(
17
+ (state: RootState) => state.app.editUsernameDisabled
18
+ );
17
19
 
18
20
  const handleNameChange = (name: string) => {
19
21
  dispatch(changeUsername(name));
@@ -1,16 +1,12 @@
1
1
  import * as React from 'react';
2
2
  import { View, Text, StyleSheet } from 'react-native';
3
- import { useSelector } from 'react-redux';
4
- import { HMSStreamingState } from '@100mslive/react-native-hms';
5
3
 
6
- import type { RootState } from '../redux';
7
4
  import { useHMSRoomStyleSheet } from '../hooks-util';
8
5
  import { COLORS } from '../utils/theme';
6
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
9
7
 
10
8
  export const HMSPreviewHLSLiveIndicator = () => {
11
- const isHLSStreaming = useSelector(
12
- (state: RootState) => state.hmsStates.room?.hlsStreamingState?.state === HMSStreamingState.STARTED
13
- );
9
+ const isHLSStreaming = useIsHLSStreamingOn();
14
10
 
15
11
  const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
16
12
  container: {
@@ -13,6 +13,7 @@ export interface HMSPrimaryButtonProps {
13
13
  style?: StyleProp<ViewStyle>;
14
14
  disabled?: boolean;
15
15
  leftComponent?: React.ReactElement | null;
16
+ wrapWithGestureDetector?: boolean;
16
17
  }
17
18
 
18
19
  export const HMSPrimaryButton: React.FC<HMSPrimaryButtonProps> = ({
@@ -23,6 +24,7 @@ export const HMSPrimaryButton: React.FC<HMSPrimaryButtonProps> = ({
23
24
  style,
24
25
  disabled,
25
26
  leftComponent,
27
+ wrapWithGestureDetector,
26
28
  }) => {
27
29
  const { primary_dim: primaryDarkColor, on_primary_high: onPrimaryHighColor } =
28
30
  useHMSRoomColorPalette();
@@ -62,6 +64,7 @@ export const HMSPrimaryButton: React.FC<HMSPrimaryButtonProps> = ({
62
64
  hmsRoomStyles.buttonText,
63
65
  disabled ? hmsRoomStyles.disabledText : null,
64
66
  ]}
67
+ wrapWithGestureDetector={wrapWithGestureDetector}
65
68
  />
66
69
  );
67
70
  };
@@ -1,30 +1,16 @@
1
1
  import * as React from 'react';
2
2
  import { useSelector } from 'react-redux';
3
3
  import { ActivityIndicator, StyleSheet } from 'react-native';
4
+ import { HMSRecordingState } from '@100mslive/react-native-hms';
4
5
 
5
6
  import type { RootState } from '../redux';
6
7
  import { RecordingIcon } from '../Icons';
7
8
  import { useHMSRoomColorPalette, useHMSRoomStyle } from '../hooks-util';
8
- import { HMSRecordingState } from '@100mslive/react-native-hms';
9
+ import { useIsAnyRecordingOn, useIsAnyRecordingPaused } from '../hooks-sdk';
9
10
 
10
11
  export const HMSRecordingIndicator = () => {
11
- const isRecordingOn = useSelector(
12
- (state: RootState) =>
13
- state.hmsStates.room?.browserRecordingState?.state === HMSRecordingState.STARTED ||
14
- state.hmsStates.room?.browserRecordingState?.state === HMSRecordingState.RESUMED ||
15
-
16
- state.hmsStates.room?.serverRecordingState?.state === HMSRecordingState.STARTED ||
17
- state.hmsStates.room?.serverRecordingState?.state === HMSRecordingState.RESUMED ||
18
-
19
- state.hmsStates.room?.hlsRecordingState?.state === HMSRecordingState.STARTED ||
20
- state.hmsStates.room?.hlsRecordingState?.state === HMSRecordingState.RESUMED
21
- );
22
- const isRecordingPaused = useSelector(
23
- (state: RootState) =>
24
- state.hmsStates.room?.browserRecordingState?.state === HMSRecordingState.PAUSED ||
25
- state.hmsStates.room?.serverRecordingState?.state === HMSRecordingState.PAUSED ||
26
- state.hmsStates.room?.hlsRecordingState?.state === HMSRecordingState.PAUSED
27
- );
12
+ const isRecordingOn = useIsAnyRecordingOn();
13
+ const isRecordingPaused = useIsAnyRecordingPaused();
28
14
  const startingOrStoppingRecording = useSelector(
29
15
  (state: RootState) =>
30
16
  state.app.startingOrStoppingRecording ||
@@ -52,15 +38,15 @@ export const HMSRecordingIndicator = () => {
52
38
  );
53
39
  }
54
40
 
55
- if (isRecordingOn) {
41
+ if (isRecordingPaused) {
56
42
  return (
57
- <RecordingIcon style={[styles.icon, styles.rightSpace, iconStyles]} />
43
+ <RecordingIcon type="pause" style={[styles.icon, styles.rightSpace]} />
58
44
  );
59
45
  }
60
46
 
61
- if (isRecordingPaused) {
47
+ if (isRecordingOn) {
62
48
  return (
63
- <RecordingIcon type='pause' style={[styles.icon, styles.rightSpace]} />
49
+ <RecordingIcon style={[styles.icon, styles.rightSpace, iconStyles]} />
64
50
  );
65
51
  }
66
52
 
@@ -47,7 +47,10 @@ export const HMSRoomOptions: React.FC<HMSRoomOptionsProps> = () => {
47
47
 
48
48
  return (
49
49
  <View>
50
- <PressableIcon testID={TestIds.room_options_btn} onPress={onSettingsPress}>
50
+ <PressableIcon
51
+ testID={TestIds.room_options_btn}
52
+ onPress={onSettingsPress}
53
+ >
51
54
  <HamburgerIcon />
52
55
  </PressableIcon>
53
56
 
@@ -1,6 +1,7 @@
1
1
  import * as React from 'react';
2
2
  import type { HMSException } from '@100mslive/react-native-hms';
3
3
  import { StyleSheet, Text, TouchableOpacity } from 'react-native';
4
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
4
5
 
5
6
  import { HMSNotification } from './HMSNotification';
6
7
  import { AlertTriangleIcon } from '../Icons';
@@ -34,6 +35,8 @@ export const HMSTerminalErrorNotification: React.FC<
34
35
  leave(OnLeaveReason.NETWORK_ISSUES);
35
36
  };
36
37
 
38
+ const tapGesture = Gesture.Tap();
39
+
37
40
  return (
38
41
  <HMSNotification
39
42
  id={id}
@@ -41,16 +44,18 @@ export const HMSTerminalErrorNotification: React.FC<
41
44
  text={exception.description || 'Something went wrong!'}
42
45
  dismissDelay={dismissDelay}
43
46
  autoDismiss={autoDismiss}
44
- cta={(
45
- <TouchableOpacity
46
- style={[styles.button, hmsRoomStyles.button]}
47
- onPress={handleLeaveRoomPress}
48
- >
49
- <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
50
- Leave
51
- </Text>
52
- </TouchableOpacity>
53
- )}
47
+ cta={
48
+ <GestureDetector gesture={tapGesture}>
49
+ <TouchableOpacity
50
+ style={[styles.button, hmsRoomStyles.button]}
51
+ onPress={handleLeaveRoomPress}
52
+ >
53
+ <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
54
+ Leave
55
+ </Text>
56
+ </TouchableOpacity>
57
+ </GestureDetector>
58
+ }
54
59
  />
55
60
  );
56
61
  };
@@ -37,7 +37,10 @@ export const _Header: React.FC<HeaderProps> = ({
37
37
  }));
38
38
 
39
39
  return (
40
- <SafeAreaView style={transparent ? null : containerStyles} edges={['top','left','right']}>
40
+ <SafeAreaView
41
+ style={transparent ? null : containerStyles}
42
+ edges={['top', 'left', 'right']}
43
+ >
41
44
  <View style={[styles.container, transparent ? null : containerStyles]}>
42
45
  <View style={styles.logoContainer}>
43
46
  <CompanyLogo style={styles.logo} />
@@ -1,15 +1,19 @@
1
1
  import * as React from 'react';
2
2
  import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
3
3
  import { useSelector } from 'react-redux';
4
- import { HMSStreamingState } from '@100mslive/react-native-hms';
5
4
 
6
5
  import { LeaveIcon } from '../Icons';
7
- import { useHMSRoomStyleSheet, useLeaveMethods, useModalType } from '../hooks-util';
6
+ import {
7
+ useHMSRoomStyleSheet,
8
+ useLeaveMethods,
9
+ useModalType,
10
+ } from '../hooks-util';
8
11
  import type { RootState } from '../redux';
9
12
  import { BottomSheet } from './BottomSheet';
10
13
  import { StopIcon } from '../Icons';
11
14
  import { ModalTypes, OnLeaveReason } from '../utils/types';
12
15
  import { TestIds } from '../utils/constants';
16
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
13
17
 
14
18
  // const HEADER_CONTENT_HEIGHT = 24 + 8 + 8 + 2; // ICON_SIZE + TOP_PADDING + BOTTOM_PADDING + TOP&BOTTOM_BORDER_WIDTH
15
19
  // const HEADER_HEIGHT = 8 + HEADER_CONTENT_HEIGHT + 8; // TOP_HEADER_PADDING + HEADER_CONTENT_HEIGHT + BOTTOM_HEADER_PADDING
@@ -25,10 +29,7 @@ export const LeaveRoomBottomSheet: React.FC<LeaveRoomBottomSheetProps> = () => {
25
29
  state.hmsStates.localPeer?.role?.permissions?.hlsStreaming
26
30
  );
27
31
 
28
- const isStreaming = useSelector(
29
- (state: RootState) =>
30
- state.hmsStates.room?.hlsStreamingState?.state === HMSStreamingState.STARTED ?? false
31
- );
32
+ const isHLSStreaming = useIsHLSStreamingOn();
32
33
 
33
34
  const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
34
35
  text: {
@@ -119,17 +120,18 @@ export const LeaveRoomBottomSheet: React.FC<LeaveRoomBottomSheetProps> = () => {
119
120
  <LeaveIcon style={styles.icon} />
120
121
 
121
122
  <View style={styles.textContainer}>
122
- <Text style={[styles.text, hmsRoomStyles.text]}>
123
- Leave
124
- </Text>
125
- <Text testID={TestIds.leave_description} style={[styles.subtext, hmsRoomStyles.subtext]}>
123
+ <Text style={[styles.text, hmsRoomStyles.text]}>Leave</Text>
124
+ <Text
125
+ testID={TestIds.leave_description}
126
+ style={[styles.subtext, hmsRoomStyles.subtext]}
127
+ >
126
128
  Others will continue after you leave. You can join the session
127
129
  again.
128
130
  </Text>
129
131
  </View>
130
132
  </TouchableOpacity>
131
133
 
132
- {canStream && isStreaming ? (
134
+ {canStream && isHLSStreaming ? (
133
135
  <TouchableOpacity
134
136
  testID={TestIds.end_stream_cta}
135
137
  style={[styles.button, hmsRoomStyles.endButton]}
@@ -16,6 +16,7 @@ import {
16
16
  useHMSRemovedFromRoomUpdate,
17
17
  useHMSRoomStyle,
18
18
  usePIPListener,
19
+ useSetDefaultChatRecipient,
19
20
  } from '../hooks-util';
20
21
  import { MeetingScreenContent } from './MeetingScreenContent';
21
22
  import { HMSHLSStreamLoading } from './HMSHLSStreamLoading';
@@ -34,6 +35,9 @@ export const Meeting: React.FC<MeetingProps> = ({ peerTrackNodes }) => {
34
35
 
35
36
  useFetchHMSRoles();
36
37
 
38
+ // Handle selected (default) Chat Recipient as per dashboard config
39
+ useSetDefaultChatRecipient();
40
+
37
41
  useHMSMessages();
38
42
 
39
43
  useHMSReconnection();
@@ -51,28 +51,31 @@ export const MeetingScreenContent: React.FC<MeetingScreenContentProps> = ({
51
51
  }
52
52
  }, []);
53
53
 
54
- const toggleControls = useCallback((fromTimeout: boolean = false) => {
55
- 'worklet';
56
- if (
57
- fromTimeout !== true &&
58
- (keyboardState.value === KeyboardState.OPEN ||
59
- keyboardState.value === KeyboardState.OPENING)
60
- ) {
61
- runOnJS(dismissKeyboard)();
62
- } else {
63
- runOnJS(clearTimer)();
64
- cancelAnimation(offset);
65
- offset.value = withTiming(
66
- offset.value === 1 ? 0 : 1,
67
- { duration: 200, easing: Easing.ease },
68
- (finished) => {
69
- if (finished) {
70
- runOnJS(setControlsHidden)(offset.value === 0);
54
+ const toggleControls = useCallback(
55
+ (fromTimeout: boolean = false) => {
56
+ 'worklet';
57
+ if (
58
+ fromTimeout !== true &&
59
+ (keyboardState.value === KeyboardState.OPEN ||
60
+ keyboardState.value === KeyboardState.OPENING)
61
+ ) {
62
+ runOnJS(dismissKeyboard)();
63
+ } else {
64
+ runOnJS(clearTimer)();
65
+ cancelAnimation(offset);
66
+ offset.value = withTiming(
67
+ offset.value === 1 ? 0 : 1,
68
+ { duration: 200, easing: Easing.ease },
69
+ (finished) => {
70
+ if (finished) {
71
+ runOnJS(setControlsHidden)(offset.value === 0);
72
+ }
71
73
  }
72
- }
73
- );
74
- }
75
- }, [dismissKeyboard, clearTimer]);
74
+ );
75
+ }
76
+ },
77
+ [dismissKeyboard, clearTimer]
78
+ );
76
79
 
77
80
  // Handles Auto hiding the controls for the first time
78
81
  // to make this feature discoverable