@100mslive/react-native-room-kit 1.0.7 → 1.0.9

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 (526) hide show
  1. package/lib/commonjs/HMSContainer.js +26 -5
  2. package/lib/commonjs/HMSContainer.js.map +1 -1
  3. package/lib/commonjs/HMSRoomSetup.js +6 -8
  4. package/lib/commonjs/HMSRoomSetup.js.map +1 -1
  5. package/lib/commonjs/Icons/Chat/assets/chat-on.png +0 -0
  6. package/lib/commonjs/Icons/Chat/assets/chat-on@2x.png +0 -0
  7. package/lib/commonjs/Icons/Chat/assets/chat-on@3x.png +0 -0
  8. package/lib/commonjs/Icons/Chat/index.js +4 -3
  9. package/lib/commonjs/Icons/Chat/index.js.map +1 -1
  10. package/lib/commonjs/Icons/NoEntry/assets/no-entry.png +0 -0
  11. package/lib/commonjs/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  12. package/lib/commonjs/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  13. package/lib/commonjs/Icons/NoEntry/index.js +33 -0
  14. package/lib/commonjs/Icons/NoEntry/index.js.map +1 -0
  15. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle.png +0 -0
  16. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  17. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  18. package/lib/commonjs/Icons/PauseCircle/index.js +29 -0
  19. package/lib/commonjs/Icons/PauseCircle/index.js.map +1 -0
  20. package/lib/commonjs/Icons/Pin/assets/unpin.png +0 -0
  21. package/lib/commonjs/Icons/Pin/assets/unpin@2x.png +0 -0
  22. package/lib/commonjs/Icons/Pin/assets/unpin@3x.png +0 -0
  23. package/lib/commonjs/Icons/Pin/index.js +2 -1
  24. package/lib/commonjs/Icons/Pin/index.js.map +1 -1
  25. package/lib/commonjs/Icons/Recording/assets/recording-pause.png +0 -0
  26. package/lib/commonjs/Icons/Recording/assets/recording-pause@2x.png +0 -0
  27. package/lib/commonjs/Icons/Recording/assets/recording-pause@3x.png +0 -0
  28. package/lib/commonjs/Icons/Recording/index.js.map +1 -1
  29. package/lib/commonjs/Icons/index.js +22 -0
  30. package/lib/commonjs/Icons/index.js.map +1 -1
  31. package/lib/commonjs/components/BottomSheet.js.map +1 -1
  32. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js +36 -0
  33. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  34. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js +90 -23
  35. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  36. package/lib/commonjs/components/Chat/ChatFilterItem.js +10 -7
  37. package/lib/commonjs/components/Chat/ChatFilterItem.js.map +1 -1
  38. package/lib/commonjs/components/Chat/ChatFilterView.js +54 -45
  39. package/lib/commonjs/components/Chat/ChatFilterView.js.map +1 -1
  40. package/lib/commonjs/components/Chat/ChatList.js +13 -6
  41. package/lib/commonjs/components/Chat/ChatList.js.map +1 -1
  42. package/lib/commonjs/components/Chat/ChatMessage.js +79 -7
  43. package/lib/commonjs/components/Chat/ChatMessage.js.map +1 -1
  44. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js +61 -0
  45. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js.map +1 -0
  46. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js +63 -0
  47. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  48. package/lib/commonjs/components/Chat/ChatMoreActionsView.js +83 -0
  49. package/lib/commonjs/components/Chat/ChatMoreActionsView.js.map +1 -0
  50. package/lib/commonjs/components/Chat/ChatPaused.js +86 -0
  51. package/lib/commonjs/components/Chat/ChatPaused.js.map +1 -0
  52. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js +34 -0
  53. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  54. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js +66 -0
  55. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  56. package/lib/commonjs/components/Chat/MessageOptionsView.js +188 -0
  57. package/lib/commonjs/components/Chat/MessageOptionsView.js.map +1 -0
  58. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js +47 -0
  59. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js.map +1 -0
  60. package/lib/commonjs/components/Chat/PinnedMessages.js +297 -0
  61. package/lib/commonjs/components/Chat/PinnedMessages.js.map +1 -0
  62. package/lib/commonjs/components/Chat/index.js +4 -4
  63. package/lib/commonjs/components/Chat/index.js.map +1 -1
  64. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  65. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js +21 -2
  66. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  67. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  68. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  69. package/lib/commonjs/components/ChatAndParticipants/ChatView.js +21 -2
  70. package/lib/commonjs/components/ChatAndParticipants/ChatView.js.map +1 -1
  71. package/lib/commonjs/components/EndRoomModalContent.js +6 -9
  72. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -1
  73. package/lib/commonjs/components/Footer.js.map +1 -1
  74. package/lib/commonjs/components/GridView.js.map +1 -1
  75. package/lib/commonjs/components/HLSView.js +8 -6
  76. package/lib/commonjs/components/HLSView.js.map +1 -1
  77. package/lib/commonjs/components/HMSBaseButton.js +10 -2
  78. package/lib/commonjs/components/HMSBaseButton.js.map +1 -1
  79. package/lib/commonjs/components/HMSDangerButton.js +4 -2
  80. package/lib/commonjs/components/HMSDangerButton.js.map +1 -1
  81. package/lib/commonjs/components/HMSHLSMessage.js +86 -1
  82. package/lib/commonjs/components/HMSHLSMessage.js.map +1 -1
  83. package/lib/commonjs/components/HMSHLSMessageList.js +2 -2
  84. package/lib/commonjs/components/HMSHLSMessageList.js.map +1 -1
  85. package/lib/commonjs/components/HMSHandRaiseNotification.js +6 -3
  86. package/lib/commonjs/components/HMSHandRaiseNotification.js.map +1 -1
  87. package/lib/commonjs/components/HMSKeyboardAvoidingView.js +5 -1
  88. package/lib/commonjs/components/HMSKeyboardAvoidingView.js.map +1 -1
  89. package/lib/commonjs/components/HMSLiveIndicator.js +2 -6
  90. package/lib/commonjs/components/HMSLiveIndicator.js.map +1 -1
  91. package/lib/commonjs/components/HMSLiveViewerCount.js +8 -7
  92. package/lib/commonjs/components/HMSLiveViewerCount.js.map +1 -1
  93. package/lib/commonjs/components/HMSLocalScreenshareNotification.js +2 -1
  94. package/lib/commonjs/components/HMSLocalScreenshareNotification.js.map +1 -1
  95. package/lib/commonjs/components/HMSNotification.js +31 -4
  96. package/lib/commonjs/components/HMSNotification.js.map +1 -1
  97. package/lib/commonjs/components/HMSNotifications.js +9 -2
  98. package/lib/commonjs/components/HMSNotifications.js.map +1 -1
  99. package/lib/commonjs/components/HMSOverlayChatView.js +44 -2
  100. package/lib/commonjs/components/HMSOverlayChatView.js.map +1 -1
  101. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  102. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +2 -6
  103. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  104. package/lib/commonjs/components/HMSPrimaryButton.js +4 -2
  105. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -1
  106. package/lib/commonjs/components/HMSRecordingIndicator.js +11 -16
  107. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -1
  108. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  109. package/lib/commonjs/components/HMSTerminalErrorNotification.js +6 -2
  110. package/lib/commonjs/components/HMSTerminalErrorNotification.js.map +1 -1
  111. package/lib/commonjs/components/Header.js.map +1 -1
  112. package/lib/commonjs/components/LeaveRoomBottomSheet.js +3 -6
  113. package/lib/commonjs/components/LeaveRoomBottomSheet.js.map +1 -1
  114. package/lib/commonjs/components/Meeting.js +3 -0
  115. package/lib/commonjs/components/Meeting.js.map +1 -1
  116. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  117. package/lib/commonjs/components/Modals.js +9 -12
  118. package/lib/commonjs/components/Modals.js.map +1 -1
  119. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js +5 -1
  120. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js.map +1 -1
  121. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  122. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  123. package/lib/commonjs/components/Preview.js +14 -1
  124. package/lib/commonjs/components/Preview.js.map +1 -1
  125. package/lib/commonjs/components/PreviewForRoleChangeModal.js +5 -4
  126. package/lib/commonjs/components/PreviewForRoleChangeModal.js.map +1 -1
  127. package/lib/commonjs/components/RoomSettingsModalContent.js +15 -6
  128. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  129. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +2 -4
  130. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  131. package/lib/commonjs/components/WebrtcView.js.map +1 -1
  132. package/lib/commonjs/hooks-sdk-selectors.js +16 -1
  133. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  134. package/lib/commonjs/hooks-sdk.js +27 -1
  135. package/lib/commonjs/hooks-sdk.js.map +1 -1
  136. package/lib/commonjs/hooks-util-selectors.js +3 -3
  137. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  138. package/lib/commonjs/hooks-util.js +410 -64
  139. package/lib/commonjs/hooks-util.js.map +1 -1
  140. package/lib/commonjs/redux/actionTypes.js +16 -3
  141. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  142. package/lib/commonjs/redux/actions/index.js +44 -4
  143. package/lib/commonjs/redux/actions/index.js.map +1 -1
  144. package/lib/commonjs/redux/reducers/appState.js +41 -1
  145. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  146. package/lib/commonjs/redux/reducers/chatWindow.js +1 -2
  147. package/lib/commonjs/redux/reducers/chatWindow.js.map +1 -1
  148. package/lib/commonjs/redux/reducers/hmsStates.js +21 -8
  149. package/lib/commonjs/redux/reducers/hmsStates.js.map +1 -1
  150. package/lib/commonjs/redux/reducers/message.js +17 -4
  151. package/lib/commonjs/redux/reducers/message.js.map +1 -1
  152. package/lib/commonjs/types.js +4 -2
  153. package/lib/commonjs/types.js.map +1 -1
  154. package/lib/commonjs/utils/types.js +3 -0
  155. package/lib/commonjs/utils/types.js.map +1 -1
  156. package/lib/commonjs/utils.js +2 -2
  157. package/lib/commonjs/utils.js.map +1 -1
  158. package/lib/module/HMSContainer.js +23 -3
  159. package/lib/module/HMSContainer.js.map +1 -1
  160. package/lib/module/HMSRoomSetup.js +7 -9
  161. package/lib/module/HMSRoomSetup.js.map +1 -1
  162. package/lib/module/Icons/Chat/assets/chat-on.png +0 -0
  163. package/lib/module/Icons/Chat/assets/chat-on@2x.png +0 -0
  164. package/lib/module/Icons/Chat/assets/chat-on@3x.png +0 -0
  165. package/lib/module/Icons/Chat/index.js +4 -3
  166. package/lib/module/Icons/Chat/index.js.map +1 -1
  167. package/lib/module/Icons/NoEntry/assets/no-entry.png +0 -0
  168. package/lib/module/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  169. package/lib/module/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  170. package/lib/module/Icons/NoEntry/index.js +25 -0
  171. package/lib/module/Icons/NoEntry/index.js.map +1 -0
  172. package/lib/module/Icons/PauseCircle/assets/pause-circle.png +0 -0
  173. package/lib/module/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  174. package/lib/module/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  175. package/lib/module/Icons/PauseCircle/index.js +21 -0
  176. package/lib/module/Icons/PauseCircle/index.js.map +1 -0
  177. package/lib/module/Icons/Pin/assets/unpin.png +0 -0
  178. package/lib/module/Icons/Pin/assets/unpin@2x.png +0 -0
  179. package/lib/module/Icons/Pin/assets/unpin@3x.png +0 -0
  180. package/lib/module/Icons/Pin/index.js +2 -1
  181. package/lib/module/Icons/Pin/index.js.map +1 -1
  182. package/lib/module/Icons/Recording/assets/recording-pause.png +0 -0
  183. package/lib/module/Icons/Recording/assets/recording-pause@2x.png +0 -0
  184. package/lib/module/Icons/Recording/assets/recording-pause@3x.png +0 -0
  185. package/lib/module/Icons/Recording/index.js.map +1 -1
  186. package/lib/module/Icons/index.js +2 -0
  187. package/lib/module/Icons/index.js.map +1 -1
  188. package/lib/module/components/BottomSheet.js.map +1 -1
  189. package/lib/module/components/Chat/ChatFilterBottomSheet.js +28 -0
  190. package/lib/module/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  191. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js +93 -26
  192. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  193. package/lib/module/components/Chat/ChatFilterItem.js +11 -8
  194. package/lib/module/components/Chat/ChatFilterItem.js.map +1 -1
  195. package/lib/module/components/Chat/ChatFilterView.js +55 -46
  196. package/lib/module/components/Chat/ChatFilterView.js.map +1 -1
  197. package/lib/module/components/Chat/ChatList.js +14 -7
  198. package/lib/module/components/Chat/ChatList.js.map +1 -1
  199. package/lib/module/components/Chat/ChatMessage.js +81 -9
  200. package/lib/module/components/Chat/ChatMessage.js.map +1 -1
  201. package/lib/module/components/Chat/ChatMoreActionsModal.js +53 -0
  202. package/lib/module/components/Chat/ChatMoreActionsModal.js.map +1 -0
  203. package/lib/module/components/Chat/ChatMoreActionsSheetView.js +55 -0
  204. package/lib/module/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  205. package/lib/module/components/Chat/ChatMoreActionsView.js +75 -0
  206. package/lib/module/components/Chat/ChatMoreActionsView.js.map +1 -0
  207. package/lib/module/components/Chat/ChatPaused.js +77 -0
  208. package/lib/module/components/Chat/ChatPaused.js.map +1 -0
  209. package/lib/module/components/Chat/MessageOptionsBottomSheet.js +26 -0
  210. package/lib/module/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  211. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js +58 -0
  212. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  213. package/lib/module/components/Chat/MessageOptionsView.js +180 -0
  214. package/lib/module/components/Chat/MessageOptionsView.js.map +1 -0
  215. package/lib/module/components/Chat/PeerBlockedFromChat.js +38 -0
  216. package/lib/module/components/Chat/PeerBlockedFromChat.js.map +1 -0
  217. package/lib/module/components/Chat/PinnedMessages.js +288 -0
  218. package/lib/module/components/Chat/PinnedMessages.js.map +1 -0
  219. package/lib/module/components/Chat/index.js +1 -1
  220. package/lib/module/components/Chat/index.js.map +1 -1
  221. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  222. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js +24 -5
  223. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  224. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  225. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  226. package/lib/module/components/ChatAndParticipants/ChatView.js +22 -3
  227. package/lib/module/components/ChatAndParticipants/ChatView.js.map +1 -1
  228. package/lib/module/components/EndRoomModalContent.js +6 -9
  229. package/lib/module/components/EndRoomModalContent.js.map +1 -1
  230. package/lib/module/components/Footer.js.map +1 -1
  231. package/lib/module/components/GridView.js.map +1 -1
  232. package/lib/module/components/HLSView.js +9 -7
  233. package/lib/module/components/HLSView.js.map +1 -1
  234. package/lib/module/components/HMSBaseButton.js +10 -2
  235. package/lib/module/components/HMSBaseButton.js.map +1 -1
  236. package/lib/module/components/HMSDangerButton.js +4 -2
  237. package/lib/module/components/HMSDangerButton.js.map +1 -1
  238. package/lib/module/components/HMSHLSMessage.js +88 -3
  239. package/lib/module/components/HMSHLSMessage.js.map +1 -1
  240. package/lib/module/components/HMSHLSMessageList.js +2 -2
  241. package/lib/module/components/HMSHLSMessageList.js.map +1 -1
  242. package/lib/module/components/HMSHandRaiseNotification.js +6 -3
  243. package/lib/module/components/HMSHandRaiseNotification.js.map +1 -1
  244. package/lib/module/components/HMSKeyboardAvoidingView.js +6 -2
  245. package/lib/module/components/HMSKeyboardAvoidingView.js.map +1 -1
  246. package/lib/module/components/HMSLiveIndicator.js +2 -6
  247. package/lib/module/components/HMSLiveIndicator.js.map +1 -1
  248. package/lib/module/components/HMSLiveViewerCount.js +8 -7
  249. package/lib/module/components/HMSLiveViewerCount.js.map +1 -1
  250. package/lib/module/components/HMSLocalScreenshareNotification.js +2 -1
  251. package/lib/module/components/HMSLocalScreenshareNotification.js.map +1 -1
  252. package/lib/module/components/HMSNotification.js +32 -5
  253. package/lib/module/components/HMSNotification.js.map +1 -1
  254. package/lib/module/components/HMSNotifications.js +9 -2
  255. package/lib/module/components/HMSNotifications.js.map +1 -1
  256. package/lib/module/components/HMSOverlayChatView.js +45 -3
  257. package/lib/module/components/HMSOverlayChatView.js.map +1 -1
  258. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  259. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +2 -6
  260. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  261. package/lib/module/components/HMSPrimaryButton.js +4 -2
  262. package/lib/module/components/HMSPrimaryButton.js.map +1 -1
  263. package/lib/module/components/HMSRecordingIndicator.js +11 -16
  264. package/lib/module/components/HMSRecordingIndicator.js.map +1 -1
  265. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  266. package/lib/module/components/HMSTerminalErrorNotification.js +6 -2
  267. package/lib/module/components/HMSTerminalErrorNotification.js.map +1 -1
  268. package/lib/module/components/Header.js.map +1 -1
  269. package/lib/module/components/LeaveRoomBottomSheet.js +3 -6
  270. package/lib/module/components/LeaveRoomBottomSheet.js.map +1 -1
  271. package/lib/module/components/Meeting.js +4 -1
  272. package/lib/module/components/Meeting.js.map +1 -1
  273. package/lib/module/components/MeetingScreenContent.js.map +1 -1
  274. package/lib/module/components/Modals.js +10 -13
  275. package/lib/module/components/Modals.js.map +1 -1
  276. package/lib/module/components/Participants/ParticipantsItemOptions.js +5 -1
  277. package/lib/module/components/Participants/ParticipantsItemOptions.js.map +1 -1
  278. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  279. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  280. package/lib/module/components/Preview.js +13 -2
  281. package/lib/module/components/Preview.js.map +1 -1
  282. package/lib/module/components/PreviewForRoleChangeModal.js +5 -4
  283. package/lib/module/components/PreviewForRoleChangeModal.js.map +1 -1
  284. package/lib/module/components/RoomSettingsModalContent.js +16 -7
  285. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  286. package/lib/module/components/RoomSettingsModalDebugModeContent.js +3 -5
  287. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  288. package/lib/module/components/WebrtcView.js.map +1 -1
  289. package/lib/module/hooks-sdk-selectors.js +12 -0
  290. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  291. package/lib/module/hooks-sdk.js +23 -1
  292. package/lib/module/hooks-sdk.js.map +1 -1
  293. package/lib/module/hooks-util-selectors.js +3 -3
  294. package/lib/module/hooks-util-selectors.js.map +1 -1
  295. package/lib/module/hooks-util.js +400 -65
  296. package/lib/module/hooks-util.js.map +1 -1
  297. package/lib/module/redux/actionTypes.js +16 -3
  298. package/lib/module/redux/actionTypes.js.map +1 -1
  299. package/lib/module/redux/actions/index.js +36 -2
  300. package/lib/module/redux/actions/index.js.map +1 -1
  301. package/lib/module/redux/reducers/appState.js +41 -1
  302. package/lib/module/redux/reducers/appState.js.map +1 -1
  303. package/lib/module/redux/reducers/chatWindow.js +1 -2
  304. package/lib/module/redux/reducers/chatWindow.js.map +1 -1
  305. package/lib/module/redux/reducers/hmsStates.js +21 -8
  306. package/lib/module/redux/reducers/hmsStates.js.map +1 -1
  307. package/lib/module/redux/reducers/message.js +17 -4
  308. package/lib/module/redux/reducers/message.js.map +1 -1
  309. package/lib/module/types.js +4 -2
  310. package/lib/module/types.js.map +1 -1
  311. package/lib/module/utils/types.js +3 -0
  312. package/lib/module/utils/types.js.map +1 -1
  313. package/lib/module/utils.js +2 -2
  314. package/lib/module/utils.js.map +1 -1
  315. package/lib/typescript/HMSContainer.d.ts +1 -1
  316. package/lib/typescript/HMSContainer.d.ts.map +1 -1
  317. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  318. package/lib/typescript/Icons/Chat/index.d.ts +1 -0
  319. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  320. package/lib/typescript/Icons/NoEntry/index.d.ts +7 -0
  321. package/lib/typescript/Icons/NoEntry/index.d.ts.map +1 -0
  322. package/lib/typescript/Icons/PauseCircle/index.d.ts +7 -0
  323. package/lib/typescript/Icons/PauseCircle/index.d.ts.map +1 -0
  324. package/lib/typescript/Icons/Pin/index.d.ts +1 -0
  325. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -1
  326. package/lib/typescript/Icons/index.d.ts +2 -0
  327. package/lib/typescript/Icons/index.d.ts.map +1 -1
  328. package/lib/typescript/components/BottomSheet.d.ts.map +1 -1
  329. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts +3 -0
  330. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts.map +1 -0
  331. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts +1 -0
  332. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts.map +1 -1
  333. package/lib/typescript/components/Chat/ChatFilterItem.d.ts +1 -0
  334. package/lib/typescript/components/Chat/ChatFilterItem.d.ts.map +1 -1
  335. package/lib/typescript/components/Chat/ChatFilterView.d.ts +1 -0
  336. package/lib/typescript/components/Chat/ChatFilterView.d.ts.map +1 -1
  337. package/lib/typescript/components/Chat/ChatList.d.ts.map +1 -1
  338. package/lib/typescript/components/Chat/ChatMessage.d.ts.map +1 -1
  339. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts +7 -0
  340. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts.map +1 -0
  341. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts +6 -0
  342. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts.map +1 -0
  343. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts +7 -0
  344. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts.map +1 -0
  345. package/lib/typescript/components/Chat/ChatPaused.d.ts +10 -0
  346. package/lib/typescript/components/Chat/ChatPaused.d.ts.map +1 -0
  347. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts +3 -0
  348. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts.map +1 -0
  349. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts +6 -0
  350. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts.map +1 -0
  351. package/lib/typescript/components/Chat/MessageOptionsView.d.ts +7 -0
  352. package/lib/typescript/components/Chat/MessageOptionsView.d.ts.map +1 -0
  353. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts +9 -0
  354. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts.map +1 -0
  355. package/lib/typescript/components/Chat/PinnedMessages.d.ts +8 -0
  356. package/lib/typescript/components/Chat/PinnedMessages.d.ts.map +1 -0
  357. package/lib/typescript/components/Chat/index.d.ts +1 -1
  358. package/lib/typescript/components/Chat/index.d.ts.map +1 -1
  359. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.d.ts.map +1 -1
  360. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsHeader.d.ts.map +1 -1
  361. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsView.d.ts.map +1 -1
  362. package/lib/typescript/components/ChatAndParticipants/ChatView.d.ts.map +1 -1
  363. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -1
  364. package/lib/typescript/components/Footer.d.ts.map +1 -1
  365. package/lib/typescript/components/GridView.d.ts.map +1 -1
  366. package/lib/typescript/components/HMSBaseButton.d.ts +1 -0
  367. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -1
  368. package/lib/typescript/components/HMSDangerButton.d.ts +1 -0
  369. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -1
  370. package/lib/typescript/components/HMSHLSMessage.d.ts +1 -1
  371. package/lib/typescript/components/HMSHLSMessage.d.ts.map +1 -1
  372. package/lib/typescript/components/HMSHandRaiseNotification.d.ts.map +1 -1
  373. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts.map +1 -1
  374. package/lib/typescript/components/HMSLiveIndicator.d.ts.map +1 -1
  375. package/lib/typescript/components/HMSLiveViewerCount.d.ts.map +1 -1
  376. package/lib/typescript/components/HMSLocalScreenshareNotification.d.ts.map +1 -1
  377. package/lib/typescript/components/HMSNotification.d.ts +2 -1
  378. package/lib/typescript/components/HMSNotification.d.ts.map +1 -1
  379. package/lib/typescript/components/HMSNotifications.d.ts.map +1 -1
  380. package/lib/typescript/components/HMSOverlayChatView.d.ts.map +1 -1
  381. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  382. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  383. package/lib/typescript/components/HMSPrimaryButton.d.ts +1 -0
  384. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -1
  385. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -1
  386. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  387. package/lib/typescript/components/HMSTerminalErrorNotification.d.ts.map +1 -1
  388. package/lib/typescript/components/Header.d.ts.map +1 -1
  389. package/lib/typescript/components/LeaveRoomBottomSheet.d.ts.map +1 -1
  390. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  391. package/lib/typescript/components/MeetingScreenContent.d.ts.map +1 -1
  392. package/lib/typescript/components/Modals.d.ts.map +1 -1
  393. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts.map +1 -1
  394. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  395. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -1
  396. package/lib/typescript/components/Preview.d.ts.map +1 -1
  397. package/lib/typescript/components/PreviewForRoleChangeModal.d.ts.map +1 -1
  398. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  399. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -1
  400. package/lib/typescript/components/WebrtcView.d.ts.map +1 -1
  401. package/lib/typescript/hooks-sdk-selectors.d.ts +3 -0
  402. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  403. package/lib/typescript/hooks-sdk.d.ts +4 -0
  404. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  405. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  406. package/lib/typescript/hooks-util.d.ts +35 -3
  407. package/lib/typescript/hooks-util.d.ts.map +1 -1
  408. package/lib/typescript/redux/actionTypes.d.ts +9 -2
  409. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  410. package/lib/typescript/redux/actions/index.d.ts +37 -3
  411. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  412. package/lib/typescript/redux/index.d.ts +7 -2
  413. package/lib/typescript/redux/index.d.ts.map +1 -1
  414. package/lib/typescript/redux/reducers/appState.d.ts +7 -2
  415. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  416. package/lib/typescript/redux/reducers/chatWindow.d.ts +1 -1
  417. package/lib/typescript/redux/reducers/chatWindow.d.ts.map +1 -1
  418. package/lib/typescript/redux/reducers/hmsStates.d.ts.map +1 -1
  419. package/lib/typescript/redux/reducers/index.d.ts +7 -2
  420. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  421. package/lib/typescript/redux/reducers/message.d.ts +3 -2
  422. package/lib/typescript/redux/reducers/message.d.ts.map +1 -1
  423. package/lib/typescript/types.d.ts +26 -5
  424. package/lib/typescript/types.d.ts.map +1 -1
  425. package/lib/typescript/utils/types.d.ts +3 -0
  426. package/lib/typescript/utils/types.d.ts.map +1 -1
  427. package/package.json +179 -179
  428. package/src/HMSContainer.tsx +26 -5
  429. package/src/HMSRoomSetup.tsx +9 -9
  430. package/src/Icons/Chat/assets/chat-on.png +0 -0
  431. package/src/Icons/Chat/assets/chat-on@2x.png +0 -0
  432. package/src/Icons/Chat/assets/chat-on@3x.png +0 -0
  433. package/src/Icons/Chat/index.tsx +19 -6
  434. package/src/Icons/NoEntry/assets/no-entry.png +0 -0
  435. package/src/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  436. package/src/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  437. package/src/Icons/NoEntry/index.tsx +33 -0
  438. package/src/Icons/PauseCircle/assets/pause-circle.png +0 -0
  439. package/src/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  440. package/src/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  441. package/src/Icons/PauseCircle/index.tsx +27 -0
  442. package/src/Icons/Pin/assets/unpin.png +0 -0
  443. package/src/Icons/Pin/assets/unpin@2x.png +0 -0
  444. package/src/Icons/Pin/assets/unpin@3x.png +0 -0
  445. package/src/Icons/Pin/index.tsx +13 -3
  446. package/src/Icons/Recording/assets/recording-pause.png +0 -0
  447. package/src/Icons/Recording/assets/recording-pause@2x.png +0 -0
  448. package/src/Icons/Recording/assets/recording-pause@3x.png +0 -0
  449. package/src/Icons/Recording/index.tsx +2 -2
  450. package/src/Icons/index.ts +2 -0
  451. package/src/components/BottomSheet.tsx +13 -3
  452. package/src/components/Chat/ChatFilterBottomSheet.tsx +35 -0
  453. package/src/components/Chat/ChatFilterBottomSheetOpener.tsx +170 -42
  454. package/src/components/Chat/ChatFilterItem.tsx +8 -4
  455. package/src/components/Chat/ChatFilterView.tsx +102 -75
  456. package/src/components/Chat/ChatList.tsx +18 -6
  457. package/src/components/Chat/ChatMessage.tsx +111 -7
  458. package/src/components/Chat/ChatMoreActionsModal.tsx +75 -0
  459. package/src/components/Chat/ChatMoreActionsSheetView.tsx +77 -0
  460. package/src/components/Chat/ChatMoreActionsView.tsx +84 -0
  461. package/src/components/Chat/ChatPaused.tsx +103 -0
  462. package/src/components/Chat/MessageOptionsBottomSheet.tsx +33 -0
  463. package/src/components/Chat/MessageOptionsBottomSheetView.tsx +82 -0
  464. package/src/components/Chat/MessageOptionsView.tsx +248 -0
  465. package/src/components/Chat/PeerBlockedFromChat.tsx +49 -0
  466. package/src/components/Chat/PinnedMessages.tsx +422 -0
  467. package/src/components/Chat/index.ts +1 -1
  468. package/src/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.tsx +4 -1
  469. package/src/components/ChatAndParticipants/ChatAndParticipantsHeader.tsx +48 -12
  470. package/src/components/ChatAndParticipants/ChatAndParticipantsView.tsx +9 -1
  471. package/src/components/ChatAndParticipants/ChatView.tsx +37 -5
  472. package/src/components/EndRoomModalContent.tsx +11 -14
  473. package/src/components/Footer.tsx +3 -1
  474. package/src/components/GridView.tsx +17 -8
  475. package/src/components/HLSView.tsx +45 -45
  476. package/src/components/HMSBaseButton.tsx +17 -2
  477. package/src/components/HMSDangerButton.tsx +3 -0
  478. package/src/components/HMSHLSMessage.tsx +130 -13
  479. package/src/components/HMSHLSMessageList.tsx +2 -2
  480. package/src/components/HMSHandRaiseNotification.tsx +17 -10
  481. package/src/components/HMSKeyboardAvoidingView.tsx +6 -1
  482. package/src/components/HMSLiveIndicator.tsx +9 -13
  483. package/src/components/HMSLiveViewerCount.tsx +21 -20
  484. package/src/components/HMSLocalScreenshareNotification.tsx +1 -0
  485. package/src/components/HMSNotification.tsx +56 -13
  486. package/src/components/HMSNotifications.tsx +12 -2
  487. package/src/components/HMSOverlayChatView.tsx +74 -17
  488. package/src/components/HMSPreviewEditName.tsx +3 -1
  489. package/src/components/HMSPreviewHLSLiveIndicator.tsx +2 -6
  490. package/src/components/HMSPrimaryButton.tsx +3 -0
  491. package/src/components/HMSRecordingIndicator.tsx +8 -22
  492. package/src/components/HMSRoomOptions.tsx +4 -1
  493. package/src/components/HMSTerminalErrorNotification.tsx +15 -10
  494. package/src/components/Header.tsx +4 -1
  495. package/src/components/LeaveRoomBottomSheet.tsx +13 -11
  496. package/src/components/Meeting.tsx +4 -0
  497. package/src/components/MeetingScreenContent.tsx +24 -21
  498. package/src/components/Modals.tsx +23 -25
  499. package/src/components/Participants/ParticipantsItemOptions.tsx +12 -7
  500. package/src/components/PeerSettingsModalContent.tsx +3 -1
  501. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +3 -1
  502. package/src/components/Preview.tsx +15 -2
  503. package/src/components/PreviewForRoleChangeModal.tsx +4 -3
  504. package/src/components/RoomSettingsModalContent.tsx +62 -18
  505. package/src/components/RoomSettingsModalDebugModeContent.tsx +2 -5
  506. package/src/components/WebrtcView.tsx +6 -2
  507. package/src/hooks-sdk-selectors.tsx +19 -0
  508. package/src/hooks-sdk.ts +37 -0
  509. package/src/hooks-util-selectors.tsx +2 -3
  510. package/src/hooks-util.ts +580 -90
  511. package/src/redux/actionTypes.ts +22 -2
  512. package/src/redux/actions/index.ts +41 -4
  513. package/src/redux/reducers/appState.ts +54 -5
  514. package/src/redux/reducers/chatWindow.ts +2 -2
  515. package/src/redux/reducers/hmsStates.ts +36 -13
  516. package/src/redux/reducers/message.ts +20 -6
  517. package/src/types.ts +36 -6
  518. package/src/utils/types.ts +3 -0
  519. package/src/utils.ts +2 -2
  520. package/lib/commonjs/components/Chat/PinnedMessage.js +0 -81
  521. package/lib/commonjs/components/Chat/PinnedMessage.js.map +0 -1
  522. package/lib/module/components/Chat/PinnedMessage.js +0 -72
  523. package/lib/module/components/Chat/PinnedMessage.js.map +0 -1
  524. package/lib/typescript/components/Chat/PinnedMessage.d.ts +0 -3
  525. package/lib/typescript/components/Chat/PinnedMessage.d.ts.map +0 -1
  526. package/src/components/Chat/PinnedMessage.tsx +0 -89
@@ -39,3 +39,5 @@ export * from './Eye';
39
39
  export * from './Search';
40
40
  export * from './WelcomeHand';
41
41
  export * from './CrossCircle';
42
+ export * from './PauseCircle';
43
+ export * from './NoEntry';
@@ -1,7 +1,14 @@
1
1
  import * as React from 'react';
2
2
  import Modal from 'react-native-modal';
3
3
  import type { ReactNativeModal } from 'react-native-modal';
4
- import { KeyboardAvoidingView, Platform, StyleSheet, Text, TouchableOpacity, View } from 'react-native';
4
+ import {
5
+ KeyboardAvoidingView,
6
+ Platform,
7
+ StyleSheet,
8
+ Text,
9
+ TouchableOpacity,
10
+ View,
11
+ } from 'react-native';
5
12
  import type {
6
13
  StyleProp,
7
14
  TextProps,
@@ -52,7 +59,10 @@ export const BottomSheet: React.FC<BottomSheetProps> & {
52
59
 
53
60
  const isLandscapeOrientation = useIsLandscapeOrientation();
54
61
 
55
- const Container = resetProps.avoidKeyboard && Platform.OS === 'android' ? KeyboardAvoidingView : View;
62
+ const Container =
63
+ resetProps.avoidKeyboard && Platform.OS === 'android'
64
+ ? KeyboardAvoidingView
65
+ : View;
56
66
 
57
67
  return (
58
68
  <Modal
@@ -76,7 +86,7 @@ export const BottomSheet: React.FC<BottomSheetProps> & {
76
86
  statusBarTranslucent={true}
77
87
  >
78
88
  <Container
79
- behavior='padding'
89
+ behavior="padding"
80
90
  style={[
81
91
  isLandscapeOrientation && !fullWidth
82
92
  ? styles.landscapeContainer
@@ -0,0 +1,35 @@
1
+ import * as React from 'react';
2
+
3
+ import { BottomSheet } from '../BottomSheet';
4
+ import { useHMSRoomStyleSheet, useModalType } from '../../hooks-util';
5
+ import { ModalTypes } from '../../utils/types';
6
+ import { ChatFilterView } from './ChatFilterView';
7
+
8
+ const _ChatFilterBottomSheet = () => {
9
+ const { modalVisibleType, handleModalVisibleType } = useModalType();
10
+
11
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
12
+ contentContainer: {
13
+ flex: 0.7,
14
+ backgroundColor: theme.palette.surface_default,
15
+ },
16
+ }));
17
+
18
+ const dismissModal = React.useCallback(
19
+ () => handleModalVisibleType(ModalTypes.DEFAULT),
20
+ [handleModalVisibleType]
21
+ );
22
+
23
+ return (
24
+ <BottomSheet
25
+ dismissModal={dismissModal}
26
+ isVisible={modalVisibleType === ModalTypes.CHAT_FILTER}
27
+ animationOutTiming={400}
28
+ containerStyle={hmsRoomStyles.contentContainer}
29
+ >
30
+ <ChatFilterView onDismiss={dismissModal} />
31
+ </BottomSheet>
32
+ );
33
+ };
34
+
35
+ export const ChatFilterBottomSheet = React.memo(_ChatFilterBottomSheet);
@@ -1,54 +1,168 @@
1
1
  import * as React from 'react';
2
2
  import { useDispatch, useSelector } from 'react-redux';
3
3
  import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
4
+ import { GestureDetector, Gesture } from 'react-native-gesture-handler';
4
5
 
5
- import { ChevronIcon } from '../../Icons';
6
+ import {
7
+ ChevronIcon,
8
+ ParticipantsIcon,
9
+ PersonIcon,
10
+ SearchIcon,
11
+ ThreeDotsIcon,
12
+ } from '../../Icons';
6
13
  import type { RootState } from '../../redux';
7
- import { useHMSRoomStyleSheet } from '../../hooks-util';
8
- import { setChatFilterSheetVisible } from '../../redux/actions';
14
+ import {
15
+ useHMSCanDisableChat,
16
+ useHMSChatRecipientSelector,
17
+ useHMSRoomStyleSheet,
18
+ useIsAllowedToSendMessage,
19
+ useIsLocalPeerBlockedFromChat,
20
+ useModalType,
21
+ } from '../../hooks-util';
22
+ import {
23
+ setChatFilterSheetVisible,
24
+ setChatMoreActionsSheetVisible,
25
+ } from '../../redux/actions';
26
+ import { PressableIcon } from '../PressableIcon';
27
+ import { ChatBroadcastFilter, ModalTypes } from '../../utils/types';
28
+ import { hexToRgbA } from '../../utils/theme';
9
29
 
10
- interface ChatFilterBottomSheetOpenerProps {}
30
+ interface ChatFilterBottomSheetOpenerProps {
31
+ insetMode?: boolean;
32
+ }
11
33
 
12
34
  const _ChatFilterBottomSheetOpener: React.FC<
13
35
  ChatFilterBottomSheetOpenerProps
14
- > = () => {
36
+ > = ({ insetMode = false }) => {
15
37
  const dispatch = useDispatch();
16
- const filter = useSelector(
17
- (state: RootState) => state.chatWindow.sendTo.name as string
38
+ const canDisableChat = useHMSCanDisableChat();
39
+ const chatRecipients = useHMSChatRecipientSelector();
40
+ const allowedToSendMessage = useIsAllowedToSendMessage();
41
+ const isLocalPeerBlockedFromChat = useIsLocalPeerBlockedFromChat();
42
+ const selectedChatRecipient = useSelector(
43
+ (state: RootState) => state.chatWindow.sendTo
18
44
  );
45
+ const { handleModalVisibleType } = useModalType();
19
46
 
20
- const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
21
- label: {
22
- color: theme.palette.on_surface_medium,
23
- fontFamily: `${typography.font_family}-SemiBold`,
24
- },
25
- button: {
26
- borderColor: theme.palette.border_bright,
27
- },
28
- buttonText: {
29
- color: theme.palette.on_surface_high,
30
- fontFamily: `${typography.font_family}-SemiBold`,
31
- },
32
- }));
47
+ const hmsRoomStyles = useHMSRoomStyleSheet(
48
+ (theme, typography) => ({
49
+ label: {
50
+ color: theme.palette.on_surface_medium,
51
+ fontFamily: `${typography.font_family}-Regular`,
52
+ },
53
+ button: {
54
+ backgroundColor: insetMode
55
+ ? theme.palette.background_dim &&
56
+ hexToRgbA(theme.palette.background_dim, 0.64)
57
+ : theme.palette.primary_default,
58
+ },
59
+ buttonText: {
60
+ color: theme.palette.on_surface_high,
61
+ fontFamily: `${typography.font_family}-Regular`,
62
+ },
63
+ moreAction: {
64
+ backgroundColor:
65
+ theme.palette.background_dim &&
66
+ hexToRgbA(theme.palette.background_dim, 0.64),
67
+ },
68
+ moreActionIcon: {
69
+ tintColor: insetMode
70
+ ? theme.palette.on_surface_low
71
+ : theme.palette.on_surface_medium,
72
+ },
73
+ }),
74
+ [insetMode]
75
+ );
33
76
 
34
77
  const openChatFiltersSheet = () => {
35
- dispatch(setChatFilterSheetVisible(true));
78
+ if (insetMode) {
79
+ handleModalVisibleType(ModalTypes.CHAT_FILTER);
80
+ } else {
81
+ dispatch(setChatFilterSheetVisible(true));
82
+ }
83
+ };
84
+
85
+ const openChatMoreActionsSheet = () => {
86
+ if (insetMode) {
87
+ handleModalVisibleType(ModalTypes.CHAT_MORE_ACTIONS);
88
+ } else {
89
+ dispatch(setChatMoreActionsSheetVisible(true));
90
+ }
36
91
  };
37
92
 
93
+ const filterSheetDisabled =
94
+ !chatRecipients.privateChat && // filter Sheet can't be diabled when privateChat is 'on'
95
+ (chatRecipients.publicChat
96
+ ? chatRecipients.roles.length === 0
97
+ : chatRecipients.roles.length <= 1);
98
+
99
+ const showActionButtons =
100
+ (allowedToSendMessage && !isLocalPeerBlockedFromChat) || canDisableChat;
101
+
102
+ if (!showActionButtons) {
103
+ return null;
104
+ }
105
+
106
+ const tapGesture = Gesture.Tap();
107
+
38
108
  return (
39
109
  <View style={styles.container}>
40
- <Text style={[styles.label, hmsRoomStyles.label]}>SEND TO</Text>
41
-
42
- <TouchableOpacity
43
- onPress={openChatFiltersSheet}
44
- style={[styles.button, hmsRoomStyles.button]}
45
- >
46
- <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
47
- {filter}
48
- </Text>
49
-
50
- <ChevronIcon direction="down" style={styles.buttonIcon} />
51
- </TouchableOpacity>
110
+ {allowedToSendMessage && !isLocalPeerBlockedFromChat ? (
111
+ <View style={styles.sendToContainer}>
112
+ <Text style={[styles.label, hmsRoomStyles.label]}>
113
+ {selectedChatRecipient !== null
114
+ ? 'To'
115
+ : `Choose ${
116
+ chatRecipients.privateChat
117
+ ? 'Participant'
118
+ : chatRecipients.roles.length > 0
119
+ ? 'Role'
120
+ : ''
121
+ }`}
122
+ </Text>
123
+
124
+ <GestureDetector gesture={tapGesture}>
125
+ <TouchableOpacity
126
+ disabled={filterSheetDisabled}
127
+ onPress={openChatFiltersSheet}
128
+ style={[
129
+ styles.button,
130
+ { paddingRight: filterSheetDisabled ? 8 : undefined },
131
+ hmsRoomStyles.button,
132
+ ]}
133
+ >
134
+ {selectedChatRecipient ? (
135
+ selectedChatRecipient === ChatBroadcastFilter ? (
136
+ <ParticipantsIcon style={styles.buttonIcon} />
137
+ ) : (
138
+ <PersonIcon style={styles.buttonIcon} />
139
+ )
140
+ ) : (
141
+ <SearchIcon style={styles.buttonIcon} />
142
+ )}
143
+
144
+ <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
145
+ {selectedChatRecipient ? selectedChatRecipient.name : 'Search'}
146
+ </Text>
147
+
148
+ {filterSheetDisabled || !selectedChatRecipient ? null : (
149
+ <ChevronIcon direction="down" style={styles.buttonIcon} />
150
+ )}
151
+ </TouchableOpacity>
152
+ </GestureDetector>
153
+ </View>
154
+ ) : (
155
+ <View />
156
+ )}
157
+
158
+ {canDisableChat && insetMode ? (
159
+ <PressableIcon
160
+ onPress={openChatMoreActionsSheet}
161
+ style={[styles.moreAction, hmsRoomStyles.moreAction]}
162
+ >
163
+ <ThreeDotsIcon stack="vertical" style={styles.moreActionIcon} />
164
+ </PressableIcon>
165
+ ) : null}
52
166
  </View>
53
167
  );
54
168
  };
@@ -57,30 +171,44 @@ const styles = StyleSheet.create({
57
171
  container: {
58
172
  flexDirection: 'row',
59
173
  alignItems: 'center',
174
+ justifyContent: 'space-between',
60
175
  marginBottom: 8,
61
- marginLeft: 16,
176
+ },
177
+ sendToContainer: {
178
+ flexDirection: 'row',
179
+ alignItems: 'center',
180
+ },
181
+ moreAction: {
182
+ padding: 4,
183
+ borderRadius: 4,
184
+ },
185
+ moreActionIcon: {
186
+ width: 16,
187
+ height: 16,
62
188
  },
63
189
  label: {
64
- fontSize: 10,
190
+ fontSize: 12,
65
191
  lineHeight: 16,
66
- letterSpacing: 1.5,
192
+ letterSpacing: 0.4,
67
193
  },
68
194
  button: {
69
195
  padding: 4,
70
- paddingLeft: 8,
71
196
  flexDirection: 'row',
72
197
  marginLeft: 8,
73
- borderWidth: 1,
74
198
  borderRadius: 4,
75
199
  alignItems: 'center',
76
200
  },
77
201
  buttonText: {
78
- fontSize: 10,
79
- textTransform: 'uppercase',
202
+ fontSize: 12,
203
+ textTransform: 'capitalize',
80
204
  lineHeight: 16,
81
- letterSpacing: 1.5,
205
+ letterSpacing: 0.4,
206
+ marginHorizontal: 4,
207
+ },
208
+ buttonIcon: {
209
+ width: 16,
210
+ height: 16,
82
211
  },
83
- buttonIcon: { width: 16, height: 16, marginLeft: 4 },
84
212
  });
85
213
 
86
214
  export const ChatFilterBottomSheetOpener = React.memo(
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import { batch, useDispatch } from 'react-redux';
2
+ import { useDispatch } from 'react-redux';
3
3
  import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
4
4
  import type { HMSRemotePeer, HMSRole } from '@100mslive/react-native-hms';
5
5
 
@@ -13,6 +13,7 @@ interface ChatFilterItemProps {
13
13
  disabled?: boolean;
14
14
  active?: boolean;
15
15
  icon?: React.ReactElement;
16
+ onDismiss?: () => void;
16
17
  }
17
18
 
18
19
  const _ChatFilterItem: React.FC<ChatFilterItemProps> = ({
@@ -20,6 +21,7 @@ const _ChatFilterItem: React.FC<ChatFilterItemProps> = ({
20
21
  disabled,
21
22
  active,
22
23
  icon,
24
+ onDismiss,
23
25
  }) => {
24
26
  const dispatch = useDispatch();
25
27
 
@@ -29,10 +31,12 @@ const _ChatFilterItem: React.FC<ChatFilterItemProps> = ({
29
31
  }));
30
32
 
31
33
  const handleFilterSelect = () => {
32
- batch(() => {
34
+ dispatch({ type: 'SET_SENDTO', sendTo: item });
35
+ if (onDismiss) {
36
+ onDismiss();
37
+ } else {
33
38
  dispatch(setChatFilterSheetVisible(false));
34
- dispatch({ type: 'SET_SENDTO', sendTo: item });
35
- });
39
+ }
36
40
  };
37
41
 
38
42
  return (
@@ -5,6 +5,7 @@ import { StyleSheet, Text, View } from 'react-native';
5
5
  import { useDispatch, useSelector } from 'react-redux';
6
6
 
7
7
  import {
8
+ useHMSChatRecipientSelector,
8
9
  useHMSInstance,
9
10
  useHMSRoomColorPalette,
10
11
  useHMSRoomStyleSheet,
@@ -17,16 +18,22 @@ import { ChatFilterItem } from './ChatFilterItem';
17
18
  import { setChatFilterSheetVisible } from '../../redux/actions';
18
19
  import { ChatBroadcastFilter } from '../../utils/types';
19
20
 
20
- interface ChatFilterViewProps {}
21
+ interface ChatFilterViewProps {
22
+ onDismiss?: () => void;
23
+ }
21
24
 
22
- const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
25
+ const _ChatFilterView: React.FC<ChatFilterViewProps> = ({ onDismiss }) => {
23
26
  const hmsInstance = useHMSInstance();
24
27
  const dispatch = useDispatch();
25
28
  const filter = useSelector((state: RootState) => state.chatWindow.sendTo);
26
- const roles = useSelector((state: RootState) => state.hmsStates.roles);
27
29
  const [loadingPeersList, setLoadingPeersList] = React.useState(false);
28
30
  const [remotePeers, setRemotePeers] = React.useState<HMSRemotePeer[]>([]);
29
31
  const [filterText, setFilterText] = React.useState('');
32
+ const {
33
+ privateChat,
34
+ publicChat,
35
+ roles: rolesSpecificChat,
36
+ } = useHMSChatRecipientSelector();
30
37
 
31
38
  const { on_surface_medium: onSurfaceMediumColor } = useHMSRoomColorPalette();
32
39
 
@@ -46,23 +53,25 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
46
53
  }));
47
54
 
48
55
  React.useEffect(() => {
49
- let mounted = true;
56
+ if (privateChat) {
57
+ let mounted = true;
50
58
 
51
- const fetchRemotePeers = async () => {
52
- setLoadingPeersList(true);
53
- const fetchedRemotePeers = await hmsInstance.getRemotePeers();
54
- if (mounted) {
55
- setLoadingPeersList(false);
56
- setRemotePeers(fetchedRemotePeers);
57
- }
58
- };
59
+ const fetchRemotePeers = async () => {
60
+ setLoadingPeersList(true);
61
+ const fetchedRemotePeers = await hmsInstance.getRemotePeers();
62
+ if (mounted) {
63
+ setLoadingPeersList(false);
64
+ setRemotePeers(fetchedRemotePeers);
65
+ }
66
+ };
59
67
 
60
- fetchRemotePeers();
68
+ fetchRemotePeers();
61
69
 
62
- return () => {
63
- mounted = false;
64
- };
65
- }, [hmsInstance]);
70
+ return () => {
71
+ mounted = false;
72
+ };
73
+ }
74
+ }, [privateChat, hmsInstance]);
66
75
 
67
76
  const _keyExtractor = React.useCallback(
68
77
  (item: HMSRemotePeer) => item.peerID,
@@ -73,15 +82,20 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
73
82
  ({ item, extraData }) => (
74
83
  <ChatFilterItem
75
84
  item={item}
76
- active={extraData.name === item.name}
77
- disabled={extraData.name === item.name}
85
+ active={extraData && extraData.name === item.name}
86
+ disabled={extraData && extraData.name === item.name}
87
+ onDismiss={onDismiss}
78
88
  />
79
89
  ),
80
- []
90
+ [onDismiss]
81
91
  );
82
92
 
83
93
  const closeFiltersBottomSheet = () => {
84
- dispatch(setChatFilterSheetVisible(false));
94
+ if (onDismiss) {
95
+ onDismiss();
96
+ } else {
97
+ dispatch(setChatFilterSheetVisible(false));
98
+ }
85
99
  };
86
100
 
87
101
  const formattedFilterText = filterText.trim().toLowerCase();
@@ -98,23 +112,14 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
98
112
  }, [formattedFilterText, remotePeers]);
99
113
 
100
114
  // Filtering Broadcast option
101
- const showBroadcastOption =
102
- formattedFilterText.length > 0
115
+ const showBroadcastOption = publicChat
116
+ ? formattedFilterText.length > 0
103
117
  ? ChatBroadcastFilter.name.includes(formattedFilterText)
104
- : true;
105
-
106
- // Filtering Roles
107
- const foundRoles = roles.filter((role) => {
108
- if (!role.name || role.name.startsWith('_')) {
109
- return false;
110
- }
111
-
112
- return formattedFilterText.length > 0
113
- ? role.name.toLowerCase().includes(formattedFilterText)
114
- : true;
115
- });
118
+ : true
119
+ : false;
116
120
 
117
121
  const isBroadcastFilterSelected =
122
+ filter !== null &&
118
123
  !('publishSettings' in filter || 'peerId' in filter) && // filter is not HMSRole and HMSRemotePeer
119
124
  filter.name === ChatBroadcastFilter.name;
120
125
 
@@ -127,18 +132,20 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
127
132
 
128
133
  <BottomSheet.Divider style={styles.headerDivider} />
129
134
 
130
- <HMSTextInput
131
- value={filterText}
132
- onChangeText={setFilterText}
133
- placeholder="Search for participants"
134
- containerStyle={[
135
- styles.textInputContainer,
136
- hmsRoomStyles.textInputContainer,
137
- ]}
138
- focusedContainerStyle={styles.textInputFocusedContainer}
139
- placeholderTextColor={onSurfaceMediumColor}
140
- leftIcon={<SearchIcon style={styles.textInputSearchIcon} />}
141
- />
135
+ {privateChat ? (
136
+ <HMSTextInput
137
+ value={filterText}
138
+ onChangeText={setFilterText}
139
+ placeholder="Search for participants"
140
+ containerStyle={[
141
+ styles.textInputContainer,
142
+ hmsRoomStyles.textInputContainer,
143
+ ]}
144
+ focusedContainerStyle={styles.textInputFocusedContainer}
145
+ placeholderTextColor={onSurfaceMediumColor}
146
+ leftIcon={<SearchIcon style={styles.textInputSearchIcon} />}
147
+ />
148
+ ) : null}
142
149
 
143
150
  <FlashList
144
151
  data={filteredRemotePeers}
@@ -149,38 +156,46 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
149
156
  keyExtractor={_keyExtractor}
150
157
  renderItem={_renderItem}
151
158
  ListEmptyComponent={
152
- <View style={styles.placeholderContainer}>
153
- <Text
154
- style={[styles.placeholderText, hmsRoomStyles.placeholderText]}
155
- >
156
- {loadingPeersList
157
- ? 'Loading Participants...'
158
- : formattedFilterText.length > 0
159
- ? 'No participants found!'
160
- : 'There is no one in the session!'}
161
- </Text>
162
- </View>
159
+ privateChat ? (
160
+ <View style={styles.placeholderContainer}>
161
+ <Text
162
+ style={[styles.placeholderText, hmsRoomStyles.placeholderText]}
163
+ >
164
+ {loadingPeersList
165
+ ? 'Loading Participants...'
166
+ : formattedFilterText.length > 0
167
+ ? 'No participants found!'
168
+ : 'There is no one in the session!'}
169
+ </Text>
170
+ </View>
171
+ ) : null
163
172
  }
164
173
  ListHeaderComponent={
165
174
  <View>
166
175
  {showBroadcastOption ? (
167
- <>
168
- <ChatFilterItem
169
- item={ChatBroadcastFilter}
170
- active={isBroadcastFilterSelected}
171
- disabled={isBroadcastFilterSelected}
172
- icon={<ParticipantsIcon />}
173
- />
174
- <BottomSheet.Divider style={styles.divider} />
175
- </>
176
+ <ChatFilterItem
177
+ item={ChatBroadcastFilter}
178
+ active={isBroadcastFilterSelected}
179
+ disabled={isBroadcastFilterSelected}
180
+ icon={<ParticipantsIcon />}
181
+ onDismiss={onDismiss}
182
+ />
183
+ ) : null}
184
+
185
+ {showBroadcastOption && rolesSpecificChat.length > 0 ? (
186
+ <BottomSheet.Divider style={styles.divider} />
176
187
  ) : null}
177
188
 
178
- {foundRoles.length > 0 ? (
189
+ {rolesSpecificChat.length > 0 ? (
179
190
  <View>
180
191
  <Text style={[styles.label, hmsRoomStyles.label]}>ROLES</Text>
181
- {foundRoles.map((role) => {
182
- const isRoleSelected = 'publishSettings' in filter;
183
- const isActive = isRoleSelected && filter.name === role.name;
192
+ {rolesSpecificChat.map((role) => {
193
+ const isRoleSelected =
194
+ filter !== null && 'publishSettings' in filter;
195
+ const isActive =
196
+ filter !== null &&
197
+ isRoleSelected &&
198
+ filter.name === role.name;
184
199
 
185
200
  return (
186
201
  <ChatFilterItem
@@ -188,16 +203,28 @@ const _ChatFilterView: React.FC<ChatFilterViewProps> = () => {
188
203
  item={role}
189
204
  active={isActive}
190
205
  disabled={isActive}
206
+ onDismiss={onDismiss}
191
207
  />
192
208
  );
193
209
  })}
194
- <BottomSheet.Divider style={styles.divider} />
195
210
  </View>
196
211
  ) : null}
197
212
 
198
- <Text style={[styles.label, hmsRoomStyles.label]}>
199
- PARTICIPANTS
200
- </Text>
213
+ {rolesSpecificChat.length > 0 && privateChat ? (
214
+ <BottomSheet.Divider style={styles.divider} />
215
+ ) : null}
216
+
217
+ {rolesSpecificChat.length <= 0 &&
218
+ privateChat &&
219
+ showBroadcastOption ? (
220
+ <BottomSheet.Divider style={styles.divider} />
221
+ ) : null}
222
+
223
+ {privateChat ? (
224
+ <Text style={[styles.label, hmsRoomStyles.label]}>
225
+ PARTICIPANTS
226
+ </Text>
227
+ ) : null}
201
228
  </View>
202
229
  }
203
230
  />