@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
@@ -0,0 +1,84 @@
1
+ import * as React from 'react';
2
+ import { useDispatch } from 'react-redux';
3
+ import { StyleSheet, TouchableOpacity, View, Text } from 'react-native';
4
+
5
+ import { PauseCircleIcon } from '../../Icons';
6
+ import { useHMSChatState, useHMSRoomStyleSheet } from '../../hooks-util';
7
+ import { setChatMoreActionsSheetVisible } from '../../redux/actions';
8
+
9
+ interface ChatMoreActionsViewProps {
10
+ onDismiss?: () => void;
11
+ }
12
+
13
+ const _ChatMoreActionsView: React.FC<ChatMoreActionsViewProps> = ({
14
+ onDismiss,
15
+ }) => {
16
+ const dispatch = useDispatch();
17
+ const { chatState, setChatState } = useHMSChatState();
18
+
19
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
20
+ container: {
21
+ backgroundColor: theme.palette.surface_default,
22
+ borderColor: theme.palette.border_default,
23
+ },
24
+ // --- Button Item Styles ---
25
+ buttonText: {
26
+ color: theme.palette.on_surface_high,
27
+ fontFamily: `${typography.font_family}-SemiBold`,
28
+ },
29
+ }));
30
+
31
+ const pauseChatHandler = () => {
32
+ setChatState(!chatState.enabled);
33
+ if (onDismiss) {
34
+ onDismiss();
35
+ } else {
36
+ dispatch(setChatMoreActionsSheetVisible(false));
37
+ }
38
+ };
39
+
40
+ return (
41
+ <View style={[styles.container, hmsRoomStyles.container]}>
42
+ <TouchableOpacity onPress={pauseChatHandler} style={styles.button}>
43
+ <View style={styles.buttonWrapper}>
44
+ {chatState.enabled ? (
45
+ <PauseCircleIcon style={styles.buttonIcon} />
46
+ ) : null}
47
+ <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
48
+ {chatState.enabled ? 'Pause Chat' : 'Resume Chat'}
49
+ </Text>
50
+ </View>
51
+ </TouchableOpacity>
52
+ </View>
53
+ );
54
+ };
55
+
56
+ const styles = StyleSheet.create({
57
+ container: {
58
+ borderWidth: 1,
59
+ borderRadius: 8,
60
+ overflow: 'hidden',
61
+ },
62
+ // --- Button Item Styles ---
63
+ button: {
64
+ paddingHorizontal: 8,
65
+ paddingVertical: 16,
66
+ },
67
+ buttonWrapper: {
68
+ paddingHorizontal: 8,
69
+ flexDirection: 'row',
70
+ alignItems: 'center',
71
+ },
72
+ buttonIcon: {
73
+ width: 20,
74
+ height: 20,
75
+ marginRight: 8,
76
+ },
77
+ buttonText: {
78
+ fontSize: 14,
79
+ lineHeight: 20,
80
+ letterSpacing: 0.1,
81
+ },
82
+ });
83
+
84
+ export const ChatMoreActionsView = React.memo(_ChatMoreActionsView);
@@ -0,0 +1,103 @@
1
+ import * as React from 'react';
2
+ import { View, StyleSheet, Text } from 'react-native';
3
+ import type { StyleProp, ViewStyle } from 'react-native';
4
+
5
+ import {
6
+ useHMSCanDisableChat,
7
+ useHMSChatState,
8
+ useHMSRoomStyleSheet,
9
+ } from '../../hooks-util';
10
+ import { HMSPrimaryButton } from '../HMSPrimaryButton';
11
+ import { hexToRgbA } from '../../utils/theme';
12
+
13
+ interface ChatPausedProps {
14
+ insetMode?: boolean;
15
+ style?: StyleProp<ViewStyle>;
16
+ }
17
+
18
+ export const _ChatPaused: React.FC<ChatPausedProps> = ({
19
+ insetMode = false,
20
+ style,
21
+ }) => {
22
+ const canDisableChat = useHMSCanDisableChat();
23
+ const { chatState, setChatState } = useHMSChatState();
24
+
25
+ const hmsRoomStyles = useHMSRoomStyleSheet(
26
+ (theme, typography) => ({
27
+ container: {
28
+ backgroundColor: insetMode
29
+ ? theme.palette.background_dim &&
30
+ hexToRgbA(theme.palette.background_dim, 0.64)
31
+ : theme.palette.surface_default,
32
+ },
33
+ title: {
34
+ color: theme.palette.on_surface_high,
35
+ fontFamily: `${typography.font_family}-SemiBold`,
36
+ },
37
+ subtitle: {
38
+ color: theme.palette.on_surface_medium,
39
+ fontFamily: `${typography.font_family}-Regular`,
40
+ },
41
+ }),
42
+ [insetMode]
43
+ );
44
+
45
+ const resumeChatHandler = () => {
46
+ setChatState(true);
47
+ };
48
+
49
+ return (
50
+ <View style={[styles.container, hmsRoomStyles.container, style]}>
51
+ <View style={styles.textContainer}>
52
+ <Text style={[styles.title, hmsRoomStyles.title]}>Chat Paused</Text>
53
+
54
+ <Text
55
+ numberOfLines={1}
56
+ style={[styles.subtitle, hmsRoomStyles.subtitle]}
57
+ >
58
+ Chat has been paused by{' '}
59
+ {!chatState.enabled ? chatState.updatedBy.userName : null}
60
+ </Text>
61
+ </View>
62
+
63
+ {canDisableChat ? (
64
+ <HMSPrimaryButton
65
+ title="Resume"
66
+ loading={false}
67
+ onPress={resumeChatHandler}
68
+ style={styles.resumeBtn}
69
+ wrapWithGestureDetector={true}
70
+ />
71
+ ) : null}
72
+ </View>
73
+ );
74
+ };
75
+
76
+ const styles = StyleSheet.create({
77
+ container: {
78
+ flexDirection: 'row',
79
+ paddingVertical: 8,
80
+ paddingRight: 8,
81
+ paddingLeft: 16,
82
+ borderRadius: 8,
83
+ alignItems: 'center',
84
+ justifyContent: 'space-between',
85
+ },
86
+ textContainer: {
87
+ flexGrow: 1,
88
+ flexShrink: 1,
89
+ },
90
+ title: {
91
+ fontSize: 14,
92
+ lineHeight: 20,
93
+ letterSpacing: 0.1,
94
+ },
95
+ subtitle: {
96
+ fontSize: 12,
97
+ lineHeight: 16,
98
+ letterSpacing: 0.4,
99
+ },
100
+ resumeBtn: { marginLeft: 16 },
101
+ });
102
+
103
+ export const ChatPaused = React.memo(_ChatPaused);
@@ -0,0 +1,33 @@
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 { MessageOptionsView } from './MessageOptionsView';
7
+
8
+ const _MessageOptionsBottomSheet = () => {
9
+ const { modalVisibleType, handleModalVisibleType } = useModalType();
10
+
11
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
12
+ contentContainer: {
13
+ backgroundColor: theme.palette.surface_default,
14
+ },
15
+ }));
16
+
17
+ const dismissModal = React.useCallback(
18
+ () => handleModalVisibleType(ModalTypes.DEFAULT),
19
+ [handleModalVisibleType]
20
+ );
21
+
22
+ return (
23
+ <BottomSheet
24
+ dismissModal={dismissModal}
25
+ isVisible={modalVisibleType === ModalTypes.MESSAGE_OPTIONS}
26
+ containerStyle={hmsRoomStyles.contentContainer}
27
+ >
28
+ <MessageOptionsView onDismiss={dismissModal} />
29
+ </BottomSheet>
30
+ );
31
+ };
32
+
33
+ export const MessageOptionsBottomSheet = React.memo(_MessageOptionsBottomSheet);
@@ -0,0 +1,82 @@
1
+ import * as React from 'react';
2
+ import { Pressable, StyleSheet, View } from 'react-native';
3
+ import { useDispatch, useSelector } from 'react-redux';
4
+ import Animated, { SlideInDown, SlideOutDown } from 'react-native-reanimated';
5
+
6
+ import { hexToRgbA } from '../../utils/theme';
7
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
8
+ import type { RootState } from '../../redux';
9
+ import { setSelectedMessageForAction } from '../../redux/actions';
10
+ import { MessageOptionsView } from './MessageOptionsView';
11
+
12
+ interface MessageOptionsBottomSheetViewProps {}
13
+
14
+ const _MessageOptionsBottomSheetView: React.FC<
15
+ MessageOptionsBottomSheetViewProps
16
+ > = ({}) => {
17
+ const dispatch = useDispatch();
18
+ const selectedMessageForAction = useSelector(
19
+ (state: RootState) => state.app.selectedMessageForAction
20
+ );
21
+
22
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme) => ({
23
+ backdrop: {
24
+ backgroundColor:
25
+ theme.palette.background_dim &&
26
+ hexToRgbA(theme.palette.background_dim, 0.1),
27
+ },
28
+ contentContainer: {
29
+ backgroundColor: theme.palette.surface_default,
30
+ },
31
+ }));
32
+
33
+ const closeMessageOptionsBottomSheet = () => {
34
+ dispatch(setSelectedMessageForAction(null));
35
+ };
36
+
37
+ if (!selectedMessageForAction) {
38
+ return null;
39
+ }
40
+
41
+ return (
42
+ <View style={styles.container}>
43
+ <Pressable
44
+ onPress={closeMessageOptionsBottomSheet}
45
+ style={[styles.backdrop, hmsRoomStyles.backdrop]}
46
+ />
47
+
48
+ <Animated.View
49
+ entering={SlideInDown}
50
+ exiting={SlideOutDown}
51
+ style={[styles.contentContainer, hmsRoomStyles.contentContainer]}
52
+ >
53
+ <MessageOptionsView />
54
+ </Animated.View>
55
+ </View>
56
+ );
57
+ };
58
+
59
+ const styles = StyleSheet.create({
60
+ container: {
61
+ position: 'absolute',
62
+ width: '100%',
63
+ height: '100%',
64
+ zIndex: 1,
65
+ justifyContent: 'flex-end',
66
+ alignSelf: 'center',
67
+ },
68
+ backdrop: {
69
+ position: 'absolute',
70
+ width: '100%',
71
+ height: '100%',
72
+ },
73
+ contentContainer: {
74
+ width: '100%',
75
+ borderTopLeftRadius: 16,
76
+ borderTopRightRadius: 16,
77
+ },
78
+ });
79
+
80
+ export const MessageOptionsBottomSheetView = React.memo(
81
+ _MessageOptionsBottomSheetView
82
+ );
@@ -0,0 +1,248 @@
1
+ import * as React from 'react';
2
+ import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
3
+ import type { StyleProp, ViewStyle, TextStyle } from 'react-native';
4
+ import { useDispatch, useSelector } from 'react-redux';
5
+
6
+ import {
7
+ useAllowBlockingPeerFromChat,
8
+ useAllowPinningMessage,
9
+ useBlockPeerActions,
10
+ useHMSInstance,
11
+ useHMSMessagePinningActions,
12
+ useHMSRoomStyle,
13
+ useHMSRoomStyleSheet,
14
+ useIsMessagePinned,
15
+ useIsPeerBlocked,
16
+ useModalType,
17
+ } from '../../hooks-util';
18
+ import type { RootState } from '../../redux';
19
+ import { BottomSheet } from '../BottomSheet';
20
+ import { NoEntryIcon, PersonIcon, PinIcon } from '../../Icons';
21
+ import {
22
+ addNotification,
23
+ setSelectedMessageForAction,
24
+ } from '../../redux/actions';
25
+ import { ModalTypes } from '../../utils/types';
26
+ import { NotificationTypes } from '../../types';
27
+
28
+ interface MessageOptionsViewProps {
29
+ onDismiss?: () => void;
30
+ }
31
+
32
+ const _MessageOptionsView: React.FC<MessageOptionsViewProps> = ({
33
+ onDismiss,
34
+ }) => {
35
+ const dispatch = useDispatch();
36
+ const hmsInstance = useHMSInstance();
37
+ const localPeerPermissions = useSelector(
38
+ (state: RootState) => state.hmsStates.localPeer?.role?.permissions
39
+ );
40
+ const localPeerId = useSelector(
41
+ (state: RootState) => state.hmsStates.localPeer?.peerID
42
+ );
43
+ const selectedMessageForAction = useSelector(
44
+ (state: RootState) => state.app.selectedMessageForAction
45
+ );
46
+
47
+ const allowPinningMessage = useAllowPinningMessage();
48
+ const isPinned = useIsMessagePinned(selectedMessageForAction);
49
+ const { pinMessage, unpinMessage } = useHMSMessagePinningActions();
50
+
51
+ const allowPeerBlocking = useAllowBlockingPeerFromChat();
52
+ const isPeerBlocked = useIsPeerBlocked(
53
+ selectedMessageForAction?.sender ?? null
54
+ );
55
+ const { blockPeer, unblockPeer } = useBlockPeerActions();
56
+
57
+ const { handleModalVisibleType } = useModalType();
58
+
59
+ const hmsRoomStyle = useHMSRoomStyleSheet((theme) => ({
60
+ blockLabel: {
61
+ color: theme.palette.alert_error_default,
62
+ },
63
+ blockIcon: {
64
+ tintColor: theme.palette.alert_error_default,
65
+ },
66
+ }));
67
+
68
+ const closeMessageOptionsBottomSheet = () => {
69
+ if (onDismiss) {
70
+ onDismiss();
71
+ } else {
72
+ dispatch(setSelectedMessageForAction(null));
73
+ }
74
+ };
75
+
76
+ const showError = (error: any) => {
77
+ if (!onDismiss) {
78
+ handleModalVisibleType(ModalTypes.DEFAULT);
79
+ }
80
+ dispatch(
81
+ addNotification({
82
+ id: Math.random().toString(16).slice(2),
83
+ type: NotificationTypes.ERROR,
84
+ title: error.message,
85
+ })
86
+ );
87
+ };
88
+
89
+ const handleMessagePin = async () => {
90
+ try {
91
+ if (selectedMessageForAction) {
92
+ if (isPinned) {
93
+ await unpinMessage(selectedMessageForAction);
94
+ } else {
95
+ await pinMessage(selectedMessageForAction);
96
+ }
97
+ }
98
+ closeMessageOptionsBottomSheet();
99
+ } catch (error) {
100
+ closeMessageOptionsBottomSheet();
101
+ showError(error);
102
+ }
103
+ };
104
+
105
+ const handleBlockPeerFromChat = async () => {
106
+ try {
107
+ if (selectedMessageForAction?.sender) {
108
+ if (isPeerBlocked) {
109
+ await unblockPeer(selectedMessageForAction.sender);
110
+ } else {
111
+ await blockPeer(selectedMessageForAction.sender);
112
+ }
113
+ }
114
+ closeMessageOptionsBottomSheet();
115
+ } catch (error) {
116
+ closeMessageOptionsBottomSheet();
117
+ showError(error);
118
+ }
119
+ };
120
+
121
+ const handleRemoveParticipant = async () => {
122
+ if (selectedMessageForAction?.sender) {
123
+ await hmsInstance.removePeer(
124
+ selectedMessageForAction.sender,
125
+ 'Removed from chat'
126
+ );
127
+ }
128
+ closeMessageOptionsBottomSheet();
129
+ };
130
+
131
+ const hidePinItem = !(selectedMessageForAction && allowPinningMessage);
132
+ const hideBlockItem = !(
133
+ selectedMessageForAction &&
134
+ selectedMessageForAction.sender &&
135
+ allowPeerBlocking &&
136
+ selectedMessageForAction.sender.peerID !== localPeerId
137
+ );
138
+ const hideRemoveItem = !(
139
+ localPeerPermissions?.removeOthers &&
140
+ selectedMessageForAction?.sender &&
141
+ !selectedMessageForAction.sender.isLocal
142
+ );
143
+
144
+ return (
145
+ <View>
146
+ <BottomSheet.Header
147
+ heading="Message Options"
148
+ dismissModal={closeMessageOptionsBottomSheet}
149
+ />
150
+
151
+ <BottomSheet.Divider style={styles.headerDivider} />
152
+
153
+ {hidePinItem ? null : (
154
+ <MessageOptionsItem
155
+ label={isPinned ? 'Unpin' : 'Pin'}
156
+ icon={
157
+ <PinIcon type={isPinned ? 'unpin' : 'pin'} style={styles.icon} />
158
+ }
159
+ onPress={handleMessagePin}
160
+ />
161
+ )}
162
+
163
+ {hideBlockItem ? null : (
164
+ <MessageOptionsItem
165
+ label={isPeerBlocked ? 'Unblock from Chat' : 'Block from Chat'}
166
+ labelStyle={hmsRoomStyle.blockLabel}
167
+ icon={<NoEntryIcon style={[styles.icon, hmsRoomStyle.blockIcon]} />}
168
+ onPress={handleBlockPeerFromChat}
169
+ />
170
+ )}
171
+
172
+ {hideRemoveItem ? null : (
173
+ <MessageOptionsItem
174
+ label="Remove Participant"
175
+ labelStyle={hmsRoomStyle.blockLabel}
176
+ icon={
177
+ <PersonIcon
178
+ type="left"
179
+ style={[styles.icon, hmsRoomStyle.blockIcon]}
180
+ />
181
+ }
182
+ onPress={handleRemoveParticipant}
183
+ />
184
+ )}
185
+
186
+ <View style={styles.bottomSpacer} />
187
+ </View>
188
+ );
189
+ };
190
+
191
+ interface MessageOptionsItemProps {
192
+ label: string;
193
+ onPress(): void;
194
+ icon?: React.ReactElement;
195
+ style?: StyleProp<ViewStyle>;
196
+ labelStyle?: StyleProp<TextStyle>;
197
+ }
198
+
199
+ const MessageOptionsItem: React.FC<MessageOptionsItemProps> = ({
200
+ label,
201
+ onPress,
202
+ icon = null,
203
+ style,
204
+ labelStyle,
205
+ }) => {
206
+ const textStyle = useHMSRoomStyle((theme, typography) => ({
207
+ color: theme.palette.on_surface_high,
208
+ fontFamily: `${typography.font_family}-SemiBold`,
209
+ }));
210
+
211
+ return (
212
+ <TouchableOpacity style={[styles.container, style]} onPress={onPress}>
213
+ {icon}
214
+
215
+ <Text style={[styles.text, textStyle, labelStyle]}>{label}</Text>
216
+ </TouchableOpacity>
217
+ );
218
+ };
219
+
220
+ const styles = StyleSheet.create({
221
+ // Item styles
222
+ container: {
223
+ paddingHorizontal: 20,
224
+ paddingVertical: 16,
225
+ flexDirection: 'row',
226
+ alignItems: 'center',
227
+ },
228
+ text: {
229
+ fontSize: 14,
230
+ lineHeight: 20,
231
+ letterSpacing: 0.1,
232
+ marginLeft: 8,
233
+ },
234
+ // Container styles
235
+ headerDivider: {
236
+ marginVertical: 12,
237
+ },
238
+ icon: {
239
+ width: 20,
240
+ height: 20,
241
+ },
242
+ bottomSpacer: {
243
+ width: '100%',
244
+ height: 32,
245
+ },
246
+ });
247
+
248
+ export const MessageOptionsView = React.memo(_MessageOptionsView);
@@ -0,0 +1,49 @@
1
+ import * as React from 'react';
2
+ import { View, StyleSheet, Text } from 'react-native';
3
+ import type { StyleProp, ViewStyle } from 'react-native';
4
+
5
+ import { useHMSRoomStyleSheet } from '../../hooks-util';
6
+
7
+ interface PeerBlockedFromChatProps {
8
+ style?: StyleProp<ViewStyle>;
9
+ }
10
+
11
+ export const _PeerBlockedFromChat: React.FC<PeerBlockedFromChatProps> = ({
12
+ style,
13
+ }) => {
14
+ const hmsRoomStyles = useHMSRoomStyleSheet((theme, typography) => ({
15
+ container: {
16
+ backgroundColor: theme.palette.surface_default,
17
+ },
18
+ subtitle: {
19
+ color: theme.palette.on_surface_medium,
20
+ fontFamily: `${typography.font_family}-Regular`,
21
+ },
22
+ }));
23
+
24
+ return (
25
+ <View style={[styles.container, hmsRoomStyles.container, style]}>
26
+ <Text style={[styles.subtitle, hmsRoomStyles.subtitle]}>
27
+ You've been blocked from sending messages
28
+ </Text>
29
+ </View>
30
+ );
31
+ };
32
+
33
+ const styles = StyleSheet.create({
34
+ container: {
35
+ paddingVertical: 8,
36
+ paddingHorizontal: 16,
37
+ borderRadius: 8,
38
+ alignItems: 'center',
39
+ justifyContent: 'center',
40
+ },
41
+ subtitle: {
42
+ fontSize: 14,
43
+ lineHeight: 20,
44
+ letterSpacing: 0.25,
45
+ textAlign: 'center',
46
+ },
47
+ });
48
+
49
+ export const PeerBlockedFromChat = React.memo(_PeerBlockedFromChat);