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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (513) hide show
  1. package/lib/commonjs/HMSRoomSetup.js +4 -1
  2. package/lib/commonjs/HMSRoomSetup.js.map +1 -1
  3. package/lib/commonjs/Icons/Chat/assets/chat-on.png +0 -0
  4. package/lib/commonjs/Icons/Chat/assets/chat-on@2x.png +0 -0
  5. package/lib/commonjs/Icons/Chat/assets/chat-on@3x.png +0 -0
  6. package/lib/commonjs/Icons/Chat/index.js +4 -3
  7. package/lib/commonjs/Icons/Chat/index.js.map +1 -1
  8. package/lib/commonjs/Icons/NoEntry/assets/no-entry.png +0 -0
  9. package/lib/commonjs/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  10. package/lib/commonjs/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  11. package/lib/commonjs/Icons/NoEntry/index.js +33 -0
  12. package/lib/commonjs/Icons/NoEntry/index.js.map +1 -0
  13. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle.png +0 -0
  14. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  15. package/lib/commonjs/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  16. package/lib/commonjs/Icons/PauseCircle/index.js +29 -0
  17. package/lib/commonjs/Icons/PauseCircle/index.js.map +1 -0
  18. package/lib/commonjs/Icons/Pin/assets/unpin.png +0 -0
  19. package/lib/commonjs/Icons/Pin/assets/unpin@2x.png +0 -0
  20. package/lib/commonjs/Icons/Pin/assets/unpin@3x.png +0 -0
  21. package/lib/commonjs/Icons/Pin/index.js +2 -1
  22. package/lib/commonjs/Icons/Pin/index.js.map +1 -1
  23. package/lib/commonjs/Icons/Recording/assets/recording-pause.png +0 -0
  24. package/lib/commonjs/Icons/Recording/assets/recording-pause@2x.png +0 -0
  25. package/lib/commonjs/Icons/Recording/assets/recording-pause@3x.png +0 -0
  26. package/lib/commonjs/Icons/Recording/index.js.map +1 -1
  27. package/lib/commonjs/Icons/index.js +22 -0
  28. package/lib/commonjs/Icons/index.js.map +1 -1
  29. package/lib/commonjs/components/BottomSheet.js.map +1 -1
  30. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js +36 -0
  31. package/lib/commonjs/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  32. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js +90 -23
  33. package/lib/commonjs/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  34. package/lib/commonjs/components/Chat/ChatFilterItem.js +10 -7
  35. package/lib/commonjs/components/Chat/ChatFilterItem.js.map +1 -1
  36. package/lib/commonjs/components/Chat/ChatFilterView.js +54 -45
  37. package/lib/commonjs/components/Chat/ChatFilterView.js.map +1 -1
  38. package/lib/commonjs/components/Chat/ChatList.js +13 -6
  39. package/lib/commonjs/components/Chat/ChatList.js.map +1 -1
  40. package/lib/commonjs/components/Chat/ChatMessage.js +79 -7
  41. package/lib/commonjs/components/Chat/ChatMessage.js.map +1 -1
  42. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js +61 -0
  43. package/lib/commonjs/components/Chat/ChatMoreActionsModal.js.map +1 -0
  44. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js +63 -0
  45. package/lib/commonjs/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  46. package/lib/commonjs/components/Chat/ChatMoreActionsView.js +83 -0
  47. package/lib/commonjs/components/Chat/ChatMoreActionsView.js.map +1 -0
  48. package/lib/commonjs/components/Chat/ChatPaused.js +86 -0
  49. package/lib/commonjs/components/Chat/ChatPaused.js.map +1 -0
  50. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js +34 -0
  51. package/lib/commonjs/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  52. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js +66 -0
  53. package/lib/commonjs/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  54. package/lib/commonjs/components/Chat/MessageOptionsView.js +188 -0
  55. package/lib/commonjs/components/Chat/MessageOptionsView.js.map +1 -0
  56. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js +47 -0
  57. package/lib/commonjs/components/Chat/PeerBlockedFromChat.js.map +1 -0
  58. package/lib/commonjs/components/Chat/PinnedMessages.js +297 -0
  59. package/lib/commonjs/components/Chat/PinnedMessages.js.map +1 -0
  60. package/lib/commonjs/components/Chat/index.js +4 -4
  61. package/lib/commonjs/components/Chat/index.js.map +1 -1
  62. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  63. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js +21 -2
  64. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  65. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  66. package/lib/commonjs/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  67. package/lib/commonjs/components/ChatAndParticipants/ChatView.js +21 -2
  68. package/lib/commonjs/components/ChatAndParticipants/ChatView.js.map +1 -1
  69. package/lib/commonjs/components/EndRoomModalContent.js +6 -9
  70. package/lib/commonjs/components/EndRoomModalContent.js.map +1 -1
  71. package/lib/commonjs/components/Footer.js.map +1 -1
  72. package/lib/commonjs/components/GridView.js.map +1 -1
  73. package/lib/commonjs/components/HLSView.js +8 -6
  74. package/lib/commonjs/components/HLSView.js.map +1 -1
  75. package/lib/commonjs/components/HMSBaseButton.js +10 -2
  76. package/lib/commonjs/components/HMSBaseButton.js.map +1 -1
  77. package/lib/commonjs/components/HMSDangerButton.js +4 -2
  78. package/lib/commonjs/components/HMSDangerButton.js.map +1 -1
  79. package/lib/commonjs/components/HMSHLSMessage.js +86 -1
  80. package/lib/commonjs/components/HMSHLSMessage.js.map +1 -1
  81. package/lib/commonjs/components/HMSHLSMessageList.js +2 -2
  82. package/lib/commonjs/components/HMSHLSMessageList.js.map +1 -1
  83. package/lib/commonjs/components/HMSHandRaiseNotification.js +6 -3
  84. package/lib/commonjs/components/HMSHandRaiseNotification.js.map +1 -1
  85. package/lib/commonjs/components/HMSKeyboardAvoidingView.js +5 -1
  86. package/lib/commonjs/components/HMSKeyboardAvoidingView.js.map +1 -1
  87. package/lib/commonjs/components/HMSLiveIndicator.js +2 -6
  88. package/lib/commonjs/components/HMSLiveIndicator.js.map +1 -1
  89. package/lib/commonjs/components/HMSLiveViewerCount.js +8 -7
  90. package/lib/commonjs/components/HMSLiveViewerCount.js.map +1 -1
  91. package/lib/commonjs/components/HMSLocalScreenshareNotification.js +2 -1
  92. package/lib/commonjs/components/HMSLocalScreenshareNotification.js.map +1 -1
  93. package/lib/commonjs/components/HMSNotification.js +31 -4
  94. package/lib/commonjs/components/HMSNotification.js.map +1 -1
  95. package/lib/commonjs/components/HMSNotifications.js +9 -2
  96. package/lib/commonjs/components/HMSNotifications.js.map +1 -1
  97. package/lib/commonjs/components/HMSOverlayChatView.js +44 -2
  98. package/lib/commonjs/components/HMSOverlayChatView.js.map +1 -1
  99. package/lib/commonjs/components/HMSPreviewEditName.js.map +1 -1
  100. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js +2 -6
  101. package/lib/commonjs/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  102. package/lib/commonjs/components/HMSPrimaryButton.js +4 -2
  103. package/lib/commonjs/components/HMSPrimaryButton.js.map +1 -1
  104. package/lib/commonjs/components/HMSRecordingIndicator.js +11 -16
  105. package/lib/commonjs/components/HMSRecordingIndicator.js.map +1 -1
  106. package/lib/commonjs/components/HMSRoomOptions.js.map +1 -1
  107. package/lib/commonjs/components/HMSTerminalErrorNotification.js +6 -2
  108. package/lib/commonjs/components/HMSTerminalErrorNotification.js.map +1 -1
  109. package/lib/commonjs/components/Header.js.map +1 -1
  110. package/lib/commonjs/components/LeaveRoomBottomSheet.js +3 -6
  111. package/lib/commonjs/components/LeaveRoomBottomSheet.js.map +1 -1
  112. package/lib/commonjs/components/Meeting.js +3 -0
  113. package/lib/commonjs/components/Meeting.js.map +1 -1
  114. package/lib/commonjs/components/MeetingScreenContent.js.map +1 -1
  115. package/lib/commonjs/components/Modals.js +9 -12
  116. package/lib/commonjs/components/Modals.js.map +1 -1
  117. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js +5 -1
  118. package/lib/commonjs/components/Participants/ParticipantsItemOptions.js.map +1 -1
  119. package/lib/commonjs/components/PeerSettingsModalContent.js.map +1 -1
  120. package/lib/commonjs/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  121. package/lib/commonjs/components/Preview.js +14 -1
  122. package/lib/commonjs/components/Preview.js.map +1 -1
  123. package/lib/commonjs/components/PreviewForRoleChangeModal.js +5 -4
  124. package/lib/commonjs/components/PreviewForRoleChangeModal.js.map +1 -1
  125. package/lib/commonjs/components/RoomSettingsModalContent.js +15 -6
  126. package/lib/commonjs/components/RoomSettingsModalContent.js.map +1 -1
  127. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js +2 -4
  128. package/lib/commonjs/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  129. package/lib/commonjs/components/WebrtcView.js.map +1 -1
  130. package/lib/commonjs/hooks-sdk-selectors.js +16 -1
  131. package/lib/commonjs/hooks-sdk-selectors.js.map +1 -1
  132. package/lib/commonjs/hooks-sdk.js +27 -1
  133. package/lib/commonjs/hooks-sdk.js.map +1 -1
  134. package/lib/commonjs/hooks-util-selectors.js +3 -3
  135. package/lib/commonjs/hooks-util-selectors.js.map +1 -1
  136. package/lib/commonjs/hooks-util.js +408 -61
  137. package/lib/commonjs/hooks-util.js.map +1 -1
  138. package/lib/commonjs/redux/actionTypes.js +16 -3
  139. package/lib/commonjs/redux/actionTypes.js.map +1 -1
  140. package/lib/commonjs/redux/actions/index.js +44 -4
  141. package/lib/commonjs/redux/actions/index.js.map +1 -1
  142. package/lib/commonjs/redux/reducers/appState.js +41 -1
  143. package/lib/commonjs/redux/reducers/appState.js.map +1 -1
  144. package/lib/commonjs/redux/reducers/chatWindow.js +1 -2
  145. package/lib/commonjs/redux/reducers/chatWindow.js.map +1 -1
  146. package/lib/commonjs/redux/reducers/message.js +17 -4
  147. package/lib/commonjs/redux/reducers/message.js.map +1 -1
  148. package/lib/commonjs/types.js +1 -0
  149. package/lib/commonjs/types.js.map +1 -1
  150. package/lib/commonjs/utils/types.js +3 -0
  151. package/lib/commonjs/utils/types.js.map +1 -1
  152. package/lib/commonjs/utils.js +2 -2
  153. package/lib/commonjs/utils.js.map +1 -1
  154. package/lib/module/HMSRoomSetup.js +5 -2
  155. package/lib/module/HMSRoomSetup.js.map +1 -1
  156. package/lib/module/Icons/Chat/assets/chat-on.png +0 -0
  157. package/lib/module/Icons/Chat/assets/chat-on@2x.png +0 -0
  158. package/lib/module/Icons/Chat/assets/chat-on@3x.png +0 -0
  159. package/lib/module/Icons/Chat/index.js +4 -3
  160. package/lib/module/Icons/Chat/index.js.map +1 -1
  161. package/lib/module/Icons/NoEntry/assets/no-entry.png +0 -0
  162. package/lib/module/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  163. package/lib/module/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  164. package/lib/module/Icons/NoEntry/index.js +25 -0
  165. package/lib/module/Icons/NoEntry/index.js.map +1 -0
  166. package/lib/module/Icons/PauseCircle/assets/pause-circle.png +0 -0
  167. package/lib/module/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  168. package/lib/module/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  169. package/lib/module/Icons/PauseCircle/index.js +21 -0
  170. package/lib/module/Icons/PauseCircle/index.js.map +1 -0
  171. package/lib/module/Icons/Pin/assets/unpin.png +0 -0
  172. package/lib/module/Icons/Pin/assets/unpin@2x.png +0 -0
  173. package/lib/module/Icons/Pin/assets/unpin@3x.png +0 -0
  174. package/lib/module/Icons/Pin/index.js +2 -1
  175. package/lib/module/Icons/Pin/index.js.map +1 -1
  176. package/lib/module/Icons/Recording/assets/recording-pause.png +0 -0
  177. package/lib/module/Icons/Recording/assets/recording-pause@2x.png +0 -0
  178. package/lib/module/Icons/Recording/assets/recording-pause@3x.png +0 -0
  179. package/lib/module/Icons/Recording/index.js.map +1 -1
  180. package/lib/module/Icons/index.js +2 -0
  181. package/lib/module/Icons/index.js.map +1 -1
  182. package/lib/module/components/BottomSheet.js.map +1 -1
  183. package/lib/module/components/Chat/ChatFilterBottomSheet.js +28 -0
  184. package/lib/module/components/Chat/ChatFilterBottomSheet.js.map +1 -0
  185. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js +93 -26
  186. package/lib/module/components/Chat/ChatFilterBottomSheetOpener.js.map +1 -1
  187. package/lib/module/components/Chat/ChatFilterItem.js +11 -8
  188. package/lib/module/components/Chat/ChatFilterItem.js.map +1 -1
  189. package/lib/module/components/Chat/ChatFilterView.js +55 -46
  190. package/lib/module/components/Chat/ChatFilterView.js.map +1 -1
  191. package/lib/module/components/Chat/ChatList.js +14 -7
  192. package/lib/module/components/Chat/ChatList.js.map +1 -1
  193. package/lib/module/components/Chat/ChatMessage.js +81 -9
  194. package/lib/module/components/Chat/ChatMessage.js.map +1 -1
  195. package/lib/module/components/Chat/ChatMoreActionsModal.js +53 -0
  196. package/lib/module/components/Chat/ChatMoreActionsModal.js.map +1 -0
  197. package/lib/module/components/Chat/ChatMoreActionsSheetView.js +55 -0
  198. package/lib/module/components/Chat/ChatMoreActionsSheetView.js.map +1 -0
  199. package/lib/module/components/Chat/ChatMoreActionsView.js +75 -0
  200. package/lib/module/components/Chat/ChatMoreActionsView.js.map +1 -0
  201. package/lib/module/components/Chat/ChatPaused.js +77 -0
  202. package/lib/module/components/Chat/ChatPaused.js.map +1 -0
  203. package/lib/module/components/Chat/MessageOptionsBottomSheet.js +26 -0
  204. package/lib/module/components/Chat/MessageOptionsBottomSheet.js.map +1 -0
  205. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js +58 -0
  206. package/lib/module/components/Chat/MessageOptionsBottomSheetView.js.map +1 -0
  207. package/lib/module/components/Chat/MessageOptionsView.js +180 -0
  208. package/lib/module/components/Chat/MessageOptionsView.js.map +1 -0
  209. package/lib/module/components/Chat/PeerBlockedFromChat.js +38 -0
  210. package/lib/module/components/Chat/PeerBlockedFromChat.js.map +1 -0
  211. package/lib/module/components/Chat/PinnedMessages.js +288 -0
  212. package/lib/module/components/Chat/PinnedMessages.js.map +1 -0
  213. package/lib/module/components/Chat/index.js +1 -1
  214. package/lib/module/components/Chat/index.js.map +1 -1
  215. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.js.map +1 -1
  216. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js +24 -5
  217. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsHeader.js.map +1 -1
  218. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js +3 -1
  219. package/lib/module/components/ChatAndParticipants/ChatAndParticipantsView.js.map +1 -1
  220. package/lib/module/components/ChatAndParticipants/ChatView.js +22 -3
  221. package/lib/module/components/ChatAndParticipants/ChatView.js.map +1 -1
  222. package/lib/module/components/EndRoomModalContent.js +6 -9
  223. package/lib/module/components/EndRoomModalContent.js.map +1 -1
  224. package/lib/module/components/Footer.js.map +1 -1
  225. package/lib/module/components/GridView.js.map +1 -1
  226. package/lib/module/components/HLSView.js +9 -7
  227. package/lib/module/components/HLSView.js.map +1 -1
  228. package/lib/module/components/HMSBaseButton.js +10 -2
  229. package/lib/module/components/HMSBaseButton.js.map +1 -1
  230. package/lib/module/components/HMSDangerButton.js +4 -2
  231. package/lib/module/components/HMSDangerButton.js.map +1 -1
  232. package/lib/module/components/HMSHLSMessage.js +88 -3
  233. package/lib/module/components/HMSHLSMessage.js.map +1 -1
  234. package/lib/module/components/HMSHLSMessageList.js +2 -2
  235. package/lib/module/components/HMSHLSMessageList.js.map +1 -1
  236. package/lib/module/components/HMSHandRaiseNotification.js +6 -3
  237. package/lib/module/components/HMSHandRaiseNotification.js.map +1 -1
  238. package/lib/module/components/HMSKeyboardAvoidingView.js +6 -2
  239. package/lib/module/components/HMSKeyboardAvoidingView.js.map +1 -1
  240. package/lib/module/components/HMSLiveIndicator.js +2 -6
  241. package/lib/module/components/HMSLiveIndicator.js.map +1 -1
  242. package/lib/module/components/HMSLiveViewerCount.js +8 -7
  243. package/lib/module/components/HMSLiveViewerCount.js.map +1 -1
  244. package/lib/module/components/HMSLocalScreenshareNotification.js +2 -1
  245. package/lib/module/components/HMSLocalScreenshareNotification.js.map +1 -1
  246. package/lib/module/components/HMSNotification.js +32 -5
  247. package/lib/module/components/HMSNotification.js.map +1 -1
  248. package/lib/module/components/HMSNotifications.js +9 -2
  249. package/lib/module/components/HMSNotifications.js.map +1 -1
  250. package/lib/module/components/HMSOverlayChatView.js +45 -3
  251. package/lib/module/components/HMSOverlayChatView.js.map +1 -1
  252. package/lib/module/components/HMSPreviewEditName.js.map +1 -1
  253. package/lib/module/components/HMSPreviewHLSLiveIndicator.js +2 -6
  254. package/lib/module/components/HMSPreviewHLSLiveIndicator.js.map +1 -1
  255. package/lib/module/components/HMSPrimaryButton.js +4 -2
  256. package/lib/module/components/HMSPrimaryButton.js.map +1 -1
  257. package/lib/module/components/HMSRecordingIndicator.js +11 -16
  258. package/lib/module/components/HMSRecordingIndicator.js.map +1 -1
  259. package/lib/module/components/HMSRoomOptions.js.map +1 -1
  260. package/lib/module/components/HMSTerminalErrorNotification.js +6 -2
  261. package/lib/module/components/HMSTerminalErrorNotification.js.map +1 -1
  262. package/lib/module/components/Header.js.map +1 -1
  263. package/lib/module/components/LeaveRoomBottomSheet.js +3 -6
  264. package/lib/module/components/LeaveRoomBottomSheet.js.map +1 -1
  265. package/lib/module/components/Meeting.js +4 -1
  266. package/lib/module/components/Meeting.js.map +1 -1
  267. package/lib/module/components/MeetingScreenContent.js.map +1 -1
  268. package/lib/module/components/Modals.js +10 -13
  269. package/lib/module/components/Modals.js.map +1 -1
  270. package/lib/module/components/Participants/ParticipantsItemOptions.js +5 -1
  271. package/lib/module/components/Participants/ParticipantsItemOptions.js.map +1 -1
  272. package/lib/module/components/PeerSettingsModalContent.js.map +1 -1
  273. package/lib/module/components/PeerVideoTile/PeerVideoTileView.js.map +1 -1
  274. package/lib/module/components/Preview.js +13 -2
  275. package/lib/module/components/Preview.js.map +1 -1
  276. package/lib/module/components/PreviewForRoleChangeModal.js +5 -4
  277. package/lib/module/components/PreviewForRoleChangeModal.js.map +1 -1
  278. package/lib/module/components/RoomSettingsModalContent.js +16 -7
  279. package/lib/module/components/RoomSettingsModalContent.js.map +1 -1
  280. package/lib/module/components/RoomSettingsModalDebugModeContent.js +3 -5
  281. package/lib/module/components/RoomSettingsModalDebugModeContent.js.map +1 -1
  282. package/lib/module/components/WebrtcView.js.map +1 -1
  283. package/lib/module/hooks-sdk-selectors.js +12 -0
  284. package/lib/module/hooks-sdk-selectors.js.map +1 -1
  285. package/lib/module/hooks-sdk.js +23 -1
  286. package/lib/module/hooks-sdk.js.map +1 -1
  287. package/lib/module/hooks-util-selectors.js +3 -3
  288. package/lib/module/hooks-util-selectors.js.map +1 -1
  289. package/lib/module/hooks-util.js +398 -62
  290. package/lib/module/hooks-util.js.map +1 -1
  291. package/lib/module/redux/actionTypes.js +16 -3
  292. package/lib/module/redux/actionTypes.js.map +1 -1
  293. package/lib/module/redux/actions/index.js +36 -2
  294. package/lib/module/redux/actions/index.js.map +1 -1
  295. package/lib/module/redux/reducers/appState.js +41 -1
  296. package/lib/module/redux/reducers/appState.js.map +1 -1
  297. package/lib/module/redux/reducers/chatWindow.js +1 -2
  298. package/lib/module/redux/reducers/chatWindow.js.map +1 -1
  299. package/lib/module/redux/reducers/message.js +17 -4
  300. package/lib/module/redux/reducers/message.js.map +1 -1
  301. package/lib/module/types.js +1 -0
  302. package/lib/module/types.js.map +1 -1
  303. package/lib/module/utils/types.js +3 -0
  304. package/lib/module/utils/types.js.map +1 -1
  305. package/lib/module/utils.js +2 -2
  306. package/lib/module/utils.js.map +1 -1
  307. package/lib/typescript/HMSRoomSetup.d.ts.map +1 -1
  308. package/lib/typescript/Icons/Chat/index.d.ts +1 -0
  309. package/lib/typescript/Icons/Chat/index.d.ts.map +1 -1
  310. package/lib/typescript/Icons/NoEntry/index.d.ts +7 -0
  311. package/lib/typescript/Icons/NoEntry/index.d.ts.map +1 -0
  312. package/lib/typescript/Icons/PauseCircle/index.d.ts +7 -0
  313. package/lib/typescript/Icons/PauseCircle/index.d.ts.map +1 -0
  314. package/lib/typescript/Icons/Pin/index.d.ts +1 -0
  315. package/lib/typescript/Icons/Pin/index.d.ts.map +1 -1
  316. package/lib/typescript/Icons/index.d.ts +2 -0
  317. package/lib/typescript/Icons/index.d.ts.map +1 -1
  318. package/lib/typescript/components/BottomSheet.d.ts.map +1 -1
  319. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts +3 -0
  320. package/lib/typescript/components/Chat/ChatFilterBottomSheet.d.ts.map +1 -0
  321. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts +1 -0
  322. package/lib/typescript/components/Chat/ChatFilterBottomSheetOpener.d.ts.map +1 -1
  323. package/lib/typescript/components/Chat/ChatFilterItem.d.ts +1 -0
  324. package/lib/typescript/components/Chat/ChatFilterItem.d.ts.map +1 -1
  325. package/lib/typescript/components/Chat/ChatFilterView.d.ts +1 -0
  326. package/lib/typescript/components/Chat/ChatFilterView.d.ts.map +1 -1
  327. package/lib/typescript/components/Chat/ChatList.d.ts.map +1 -1
  328. package/lib/typescript/components/Chat/ChatMessage.d.ts.map +1 -1
  329. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts +7 -0
  330. package/lib/typescript/components/Chat/ChatMoreActionsModal.d.ts.map +1 -0
  331. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts +6 -0
  332. package/lib/typescript/components/Chat/ChatMoreActionsSheetView.d.ts.map +1 -0
  333. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts +7 -0
  334. package/lib/typescript/components/Chat/ChatMoreActionsView.d.ts.map +1 -0
  335. package/lib/typescript/components/Chat/ChatPaused.d.ts +10 -0
  336. package/lib/typescript/components/Chat/ChatPaused.d.ts.map +1 -0
  337. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts +3 -0
  338. package/lib/typescript/components/Chat/MessageOptionsBottomSheet.d.ts.map +1 -0
  339. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts +6 -0
  340. package/lib/typescript/components/Chat/MessageOptionsBottomSheetView.d.ts.map +1 -0
  341. package/lib/typescript/components/Chat/MessageOptionsView.d.ts +7 -0
  342. package/lib/typescript/components/Chat/MessageOptionsView.d.ts.map +1 -0
  343. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts +9 -0
  344. package/lib/typescript/components/Chat/PeerBlockedFromChat.d.ts.map +1 -0
  345. package/lib/typescript/components/Chat/PinnedMessages.d.ts +8 -0
  346. package/lib/typescript/components/Chat/PinnedMessages.d.ts.map +1 -0
  347. package/lib/typescript/components/Chat/index.d.ts +1 -1
  348. package/lib/typescript/components/Chat/index.d.ts.map +1 -1
  349. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.d.ts.map +1 -1
  350. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsHeader.d.ts.map +1 -1
  351. package/lib/typescript/components/ChatAndParticipants/ChatAndParticipantsView.d.ts.map +1 -1
  352. package/lib/typescript/components/ChatAndParticipants/ChatView.d.ts.map +1 -1
  353. package/lib/typescript/components/EndRoomModalContent.d.ts.map +1 -1
  354. package/lib/typescript/components/Footer.d.ts.map +1 -1
  355. package/lib/typescript/components/GridView.d.ts.map +1 -1
  356. package/lib/typescript/components/HMSBaseButton.d.ts +1 -0
  357. package/lib/typescript/components/HMSBaseButton.d.ts.map +1 -1
  358. package/lib/typescript/components/HMSDangerButton.d.ts +1 -0
  359. package/lib/typescript/components/HMSDangerButton.d.ts.map +1 -1
  360. package/lib/typescript/components/HMSHLSMessage.d.ts +1 -1
  361. package/lib/typescript/components/HMSHLSMessage.d.ts.map +1 -1
  362. package/lib/typescript/components/HMSHandRaiseNotification.d.ts.map +1 -1
  363. package/lib/typescript/components/HMSKeyboardAvoidingView.d.ts.map +1 -1
  364. package/lib/typescript/components/HMSLiveIndicator.d.ts.map +1 -1
  365. package/lib/typescript/components/HMSLiveViewerCount.d.ts.map +1 -1
  366. package/lib/typescript/components/HMSLocalScreenshareNotification.d.ts.map +1 -1
  367. package/lib/typescript/components/HMSNotification.d.ts +2 -1
  368. package/lib/typescript/components/HMSNotification.d.ts.map +1 -1
  369. package/lib/typescript/components/HMSNotifications.d.ts.map +1 -1
  370. package/lib/typescript/components/HMSOverlayChatView.d.ts.map +1 -1
  371. package/lib/typescript/components/HMSPreviewEditName.d.ts.map +1 -1
  372. package/lib/typescript/components/HMSPreviewHLSLiveIndicator.d.ts.map +1 -1
  373. package/lib/typescript/components/HMSPrimaryButton.d.ts +1 -0
  374. package/lib/typescript/components/HMSPrimaryButton.d.ts.map +1 -1
  375. package/lib/typescript/components/HMSRecordingIndicator.d.ts.map +1 -1
  376. package/lib/typescript/components/HMSRoomOptions.d.ts.map +1 -1
  377. package/lib/typescript/components/HMSTerminalErrorNotification.d.ts.map +1 -1
  378. package/lib/typescript/components/Header.d.ts.map +1 -1
  379. package/lib/typescript/components/LeaveRoomBottomSheet.d.ts.map +1 -1
  380. package/lib/typescript/components/Meeting.d.ts.map +1 -1
  381. package/lib/typescript/components/MeetingScreenContent.d.ts.map +1 -1
  382. package/lib/typescript/components/Modals.d.ts.map +1 -1
  383. package/lib/typescript/components/Participants/ParticipantsItemOptions.d.ts.map +1 -1
  384. package/lib/typescript/components/PeerSettingsModalContent.d.ts.map +1 -1
  385. package/lib/typescript/components/PeerVideoTile/PeerVideoTileView.d.ts.map +1 -1
  386. package/lib/typescript/components/Preview.d.ts.map +1 -1
  387. package/lib/typescript/components/PreviewForRoleChangeModal.d.ts.map +1 -1
  388. package/lib/typescript/components/RoomSettingsModalContent.d.ts.map +1 -1
  389. package/lib/typescript/components/RoomSettingsModalDebugModeContent.d.ts.map +1 -1
  390. package/lib/typescript/components/WebrtcView.d.ts.map +1 -1
  391. package/lib/typescript/hooks-sdk-selectors.d.ts +3 -0
  392. package/lib/typescript/hooks-sdk-selectors.d.ts.map +1 -1
  393. package/lib/typescript/hooks-sdk.d.ts +4 -0
  394. package/lib/typescript/hooks-sdk.d.ts.map +1 -1
  395. package/lib/typescript/hooks-util-selectors.d.ts.map +1 -1
  396. package/lib/typescript/hooks-util.d.ts +35 -3
  397. package/lib/typescript/hooks-util.d.ts.map +1 -1
  398. package/lib/typescript/redux/actionTypes.d.ts +9 -2
  399. package/lib/typescript/redux/actionTypes.d.ts.map +1 -1
  400. package/lib/typescript/redux/actions/index.d.ts +37 -3
  401. package/lib/typescript/redux/actions/index.d.ts.map +1 -1
  402. package/lib/typescript/redux/index.d.ts +7 -2
  403. package/lib/typescript/redux/index.d.ts.map +1 -1
  404. package/lib/typescript/redux/reducers/appState.d.ts +7 -2
  405. package/lib/typescript/redux/reducers/appState.d.ts.map +1 -1
  406. package/lib/typescript/redux/reducers/chatWindow.d.ts +1 -1
  407. package/lib/typescript/redux/reducers/chatWindow.d.ts.map +1 -1
  408. package/lib/typescript/redux/reducers/index.d.ts +7 -2
  409. package/lib/typescript/redux/reducers/index.d.ts.map +1 -1
  410. package/lib/typescript/redux/reducers/message.d.ts +3 -2
  411. package/lib/typescript/redux/reducers/message.d.ts.map +1 -1
  412. package/lib/typescript/types.d.ts +23 -3
  413. package/lib/typescript/types.d.ts.map +1 -1
  414. package/lib/typescript/utils/types.d.ts +3 -0
  415. package/lib/typescript/utils/types.d.ts.map +1 -1
  416. package/package.json +179 -179
  417. package/src/HMSRoomSetup.tsx +7 -2
  418. package/src/Icons/Chat/assets/chat-on.png +0 -0
  419. package/src/Icons/Chat/assets/chat-on@2x.png +0 -0
  420. package/src/Icons/Chat/assets/chat-on@3x.png +0 -0
  421. package/src/Icons/Chat/index.tsx +19 -6
  422. package/src/Icons/NoEntry/assets/no-entry.png +0 -0
  423. package/src/Icons/NoEntry/assets/no-entry@2x.png +0 -0
  424. package/src/Icons/NoEntry/assets/no-entry@3x.png +0 -0
  425. package/src/Icons/NoEntry/index.tsx +33 -0
  426. package/src/Icons/PauseCircle/assets/pause-circle.png +0 -0
  427. package/src/Icons/PauseCircle/assets/pause-circle@2x.png +0 -0
  428. package/src/Icons/PauseCircle/assets/pause-circle@3x.png +0 -0
  429. package/src/Icons/PauseCircle/index.tsx +27 -0
  430. package/src/Icons/Pin/assets/unpin.png +0 -0
  431. package/src/Icons/Pin/assets/unpin@2x.png +0 -0
  432. package/src/Icons/Pin/assets/unpin@3x.png +0 -0
  433. package/src/Icons/Pin/index.tsx +13 -3
  434. package/src/Icons/Recording/assets/recording-pause.png +0 -0
  435. package/src/Icons/Recording/assets/recording-pause@2x.png +0 -0
  436. package/src/Icons/Recording/assets/recording-pause@3x.png +0 -0
  437. package/src/Icons/Recording/index.tsx +2 -2
  438. package/src/Icons/index.ts +2 -0
  439. package/src/components/BottomSheet.tsx +13 -3
  440. package/src/components/Chat/ChatFilterBottomSheet.tsx +35 -0
  441. package/src/components/Chat/ChatFilterBottomSheetOpener.tsx +170 -42
  442. package/src/components/Chat/ChatFilterItem.tsx +8 -4
  443. package/src/components/Chat/ChatFilterView.tsx +102 -75
  444. package/src/components/Chat/ChatList.tsx +18 -6
  445. package/src/components/Chat/ChatMessage.tsx +111 -7
  446. package/src/components/Chat/ChatMoreActionsModal.tsx +75 -0
  447. package/src/components/Chat/ChatMoreActionsSheetView.tsx +77 -0
  448. package/src/components/Chat/ChatMoreActionsView.tsx +84 -0
  449. package/src/components/Chat/ChatPaused.tsx +103 -0
  450. package/src/components/Chat/MessageOptionsBottomSheet.tsx +33 -0
  451. package/src/components/Chat/MessageOptionsBottomSheetView.tsx +82 -0
  452. package/src/components/Chat/MessageOptionsView.tsx +248 -0
  453. package/src/components/Chat/PeerBlockedFromChat.tsx +49 -0
  454. package/src/components/Chat/PinnedMessages.tsx +422 -0
  455. package/src/components/Chat/index.ts +1 -1
  456. package/src/components/ChatAndParticipants/ChatAndParticipantsBottomSheet.tsx +4 -1
  457. package/src/components/ChatAndParticipants/ChatAndParticipantsHeader.tsx +48 -12
  458. package/src/components/ChatAndParticipants/ChatAndParticipantsView.tsx +9 -1
  459. package/src/components/ChatAndParticipants/ChatView.tsx +37 -5
  460. package/src/components/EndRoomModalContent.tsx +11 -14
  461. package/src/components/Footer.tsx +3 -1
  462. package/src/components/GridView.tsx +17 -8
  463. package/src/components/HLSView.tsx +45 -45
  464. package/src/components/HMSBaseButton.tsx +17 -2
  465. package/src/components/HMSDangerButton.tsx +3 -0
  466. package/src/components/HMSHLSMessage.tsx +130 -13
  467. package/src/components/HMSHLSMessageList.tsx +2 -2
  468. package/src/components/HMSHandRaiseNotification.tsx +17 -10
  469. package/src/components/HMSKeyboardAvoidingView.tsx +6 -1
  470. package/src/components/HMSLiveIndicator.tsx +9 -13
  471. package/src/components/HMSLiveViewerCount.tsx +21 -20
  472. package/src/components/HMSLocalScreenshareNotification.tsx +1 -0
  473. package/src/components/HMSNotification.tsx +56 -13
  474. package/src/components/HMSNotifications.tsx +12 -2
  475. package/src/components/HMSOverlayChatView.tsx +74 -17
  476. package/src/components/HMSPreviewEditName.tsx +3 -1
  477. package/src/components/HMSPreviewHLSLiveIndicator.tsx +2 -6
  478. package/src/components/HMSPrimaryButton.tsx +3 -0
  479. package/src/components/HMSRecordingIndicator.tsx +8 -22
  480. package/src/components/HMSRoomOptions.tsx +4 -1
  481. package/src/components/HMSTerminalErrorNotification.tsx +15 -10
  482. package/src/components/Header.tsx +4 -1
  483. package/src/components/LeaveRoomBottomSheet.tsx +13 -11
  484. package/src/components/Meeting.tsx +4 -0
  485. package/src/components/MeetingScreenContent.tsx +24 -21
  486. package/src/components/Modals.tsx +23 -25
  487. package/src/components/Participants/ParticipantsItemOptions.tsx +12 -7
  488. package/src/components/PeerSettingsModalContent.tsx +3 -1
  489. package/src/components/PeerVideoTile/PeerVideoTileView.tsx +3 -1
  490. package/src/components/Preview.tsx +15 -2
  491. package/src/components/PreviewForRoleChangeModal.tsx +4 -3
  492. package/src/components/RoomSettingsModalContent.tsx +62 -18
  493. package/src/components/RoomSettingsModalDebugModeContent.tsx +2 -5
  494. package/src/components/WebrtcView.tsx +6 -2
  495. package/src/hooks-sdk-selectors.tsx +19 -0
  496. package/src/hooks-sdk.ts +37 -0
  497. package/src/hooks-util-selectors.tsx +2 -3
  498. package/src/hooks-util.ts +578 -87
  499. package/src/redux/actionTypes.ts +22 -2
  500. package/src/redux/actions/index.ts +41 -4
  501. package/src/redux/reducers/appState.ts +54 -5
  502. package/src/redux/reducers/chatWindow.ts +2 -2
  503. package/src/redux/reducers/message.ts +20 -6
  504. package/src/types.ts +35 -6
  505. package/src/utils/types.ts +3 -0
  506. package/src/utils.ts +2 -2
  507. package/lib/commonjs/components/Chat/PinnedMessage.js +0 -81
  508. package/lib/commonjs/components/Chat/PinnedMessage.js.map +0 -1
  509. package/lib/module/components/Chat/PinnedMessage.js +0 -72
  510. package/lib/module/components/Chat/PinnedMessage.js.map +0 -1
  511. package/lib/typescript/components/Chat/PinnedMessage.d.ts +0 -3
  512. package/lib/typescript/components/Chat/PinnedMessage.d.ts.map +0 -1
  513. package/src/components/Chat/PinnedMessage.tsx +0 -89
@@ -1,7 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { useSelector } from 'react-redux';
3
3
  import { View, Text, StyleSheet, TouchableOpacity } from 'react-native';
4
- import { HMSStreamingState } from '@100mslive/react-native-hms';
5
4
 
6
5
  import { useHMSRoomStyleSheet, useLeaveMethods } from '../hooks-util';
7
6
  import { AlertTriangleIcon, CloseIcon } from '../Icons';
@@ -9,6 +8,7 @@ import { HMSDangerButton } from './HMSDangerButton';
9
8
  import type { RootState } from '../redux';
10
9
  import { OnLeaveReason } from '../utils/types';
11
10
  import { TestIds } from '../utils/constants';
11
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
12
12
 
13
13
  export interface EndRoomModalContentProps {
14
14
  dismissModal(): void;
@@ -39,10 +39,7 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
39
39
  state.hmsStates.localPeer?.role?.permissions?.hlsStreaming
40
40
  );
41
41
 
42
- const isStreaming = useSelector(
43
- (state: RootState) =>
44
- state.hmsStates.room?.hlsStreamingState?.state === HMSStreamingState.STARTED ?? false
45
- );
42
+ const isHLSStreaming = useIsHLSStreamingOn();
46
43
 
47
44
  return (
48
45
  <View style={styles.container}>
@@ -54,11 +51,11 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
54
51
  testID={TestIds.end_confirmation_heading}
55
52
  style={[styles.headerText, hmsRoomStyles.headerText]}
56
53
  >
57
- {canStream && isStreaming
54
+ {canStream && isHLSStreaming
58
55
  ? 'End Stream'
59
56
  : canEndRoom
60
- ? 'End Session'
61
- : 'Leave'}
57
+ ? 'End Session'
58
+ : 'Leave'}
62
59
  </Text>
63
60
  </View>
64
61
 
@@ -75,23 +72,23 @@ export const EndRoomModalContent: React.FC<EndRoomModalContentProps> = ({
75
72
  testID={TestIds.end_confirmation_description}
76
73
  style={[styles.text, hmsRoomStyles.text]}
77
74
  >
78
- {canStream && isStreaming
75
+ {canStream && isHLSStreaming
79
76
  ? 'The stream will end for everyone after they’ve watched it.'
80
77
  : canEndRoom
81
- ? 'The session will end for everyone in the room immediately. '
82
- : 'Others will continue after you leave. You can join the session again.'}
78
+ ? 'The session will end for everyone in the room immediately. '
79
+ : 'Others will continue after you leave. You can join the session again.'}
83
80
  </Text>
84
81
  <HMSDangerButton
85
82
  testID={TestIds.end_confirmation_cta}
86
83
  loading={false}
87
84
  onPress={() => {
88
- if (canStream && isStreaming) {
89
- leave(OnLeaveReason.LEAVE, true)
85
+ if (canStream && isHLSStreaming) {
86
+ leave(OnLeaveReason.LEAVE, true);
90
87
  } else {
91
88
  endRoom(OnLeaveReason.ROOM_END);
92
89
  }
93
90
  }}
94
- title={canStream && isStreaming ? 'End Stream' : 'End Session'}
91
+ title={canStream && isHLSStreaming ? 'End Stream' : 'End Session'}
95
92
  />
96
93
  </View>
97
94
  );
@@ -32,7 +32,9 @@ export const _Footer: React.FC<FooterProps> = () => {
32
32
  const canPublishAudio = useCanPublishAudio();
33
33
  const canPublishVideo = useCanPublishVideo();
34
34
  const canPublishScreen = useCanPublishScreen();
35
- const editUsernameDisabled = useSelector((state: RootState) => state.app.editUsernameDisabled);
35
+ const editUsernameDisabled = useSelector(
36
+ (state: RootState) => state.app.editUsernameDisabled
37
+ );
36
38
 
37
39
  const isViewer = !(canPublishAudio || canPublishVideo || canPublishScreen);
38
40
 
@@ -1,11 +1,14 @@
1
1
  import React, { useRef, useState, useImperativeHandle } from 'react';
2
2
  import type { ElementRef } from 'react';
3
- import { View, FlatList, StyleSheet, useWindowDimensions, Platform } from 'react-native';
4
- import { useDispatch, useSelector } from 'react-redux';
5
- import type {
6
- LayoutChangeEvent,
7
- ViewToken,
3
+ import {
4
+ View,
5
+ FlatList,
6
+ StyleSheet,
7
+ useWindowDimensions,
8
+ Platform,
8
9
  } from 'react-native';
10
+ import { useDispatch, useSelector } from 'react-redux';
11
+ import type { LayoutChangeEvent, ViewToken } from 'react-native';
9
12
  import type { HMSView, HMSPeer } from '@100mslive/react-native-hms';
10
13
 
11
14
  import { DefaultModal } from './DefaultModal';
@@ -62,14 +65,20 @@ export const GridView = React.forwardRef<GridViewRefAttrs, GridViewProps>(
62
65
  // On Orientation change, scroll to first page of list
63
66
  React.useEffect(() => {
64
67
  if (screenshareTilesAvailable) {
65
- screenshareTilesFlatlistRef.current?.scrollToOffset({ offset: 0, animated: false });
68
+ screenshareTilesFlatlistRef.current?.scrollToOffset({
69
+ offset: 0,
70
+ animated: false,
71
+ });
66
72
  }
67
73
  }, [screenshareTilesAvailable, isLandscapeOrientation]);
68
74
 
69
75
  // On Orientation change, scroll to first page of list
70
76
  React.useEffect(() => {
71
77
  if (regularTilesAvailable) {
72
- regularTilesFlatlistRef.current?.scrollToOffset({ offset: 0, animated: false });
78
+ regularTilesFlatlistRef.current?.scrollToOffset({
79
+ offset: 0,
80
+ animated: false,
81
+ });
73
82
  }
74
83
  }, [regularTilesAvailable, isLandscapeOrientation]);
75
84
 
@@ -249,7 +258,7 @@ const RegularTiles = React.forwardRef<
249
258
  <FlatList
250
259
  ref={flatlistRef}
251
260
  horizontal={true}
252
- style={Platform.OS === 'ios' ? {maxHeight: (safeHeight - 16)} : null}
261
+ style={Platform.OS === 'ios' ? { maxHeight: safeHeight - 16 } : null}
253
262
  data={pairedPeers}
254
263
  initialNumToRender={1}
255
264
  maxToRenderPerBatch={1}
@@ -6,7 +6,6 @@ import {
6
6
  HMSHLSPlayer,
7
7
  HMSHLSPlayerPlaybackState,
8
8
  useHMSHLSPlayerPlaybackState,
9
- HMSStreamingState,
10
9
  } from '@100mslive/react-native-hms';
11
10
 
12
11
  import type { RootState } from '../redux';
@@ -18,10 +17,15 @@ import { COLORS, hexToRgbA } from '../utils/theme';
18
17
  import { HMSHLSNotStarted } from './HMSHLSNotStarted';
19
18
  import { CrossCircleIcon } from '../Icons';
20
19
  import { useHMSRoomStyleSheet } from '../hooks-util';
20
+ import { useIsHLSStreamingOn } from '../hooks-sdk';
21
21
 
22
22
  export const _HLSView: React.FC = () => {
23
23
  const dispatch = useDispatch();
24
- const room = useSelector((state: RootState) => state.hmsStates.room);
24
+ const isHLSStreaming = useIsHLSStreamingOn();
25
+ const isStreamUrlPresent = useSelector(
26
+ (state: RootState) =>
27
+ !!state.hmsStates.room?.hlsStreamingState.variants?.[0]?.hlsStreamUrl
28
+ );
25
29
  const hmsHlsPlayerRef = useRef<ComponentRef<typeof HMSHLSPlayer>>(null);
26
30
  const showHLSStats = useSelector(
27
31
  (state: RootState) => state.app.joinConfig.showHLSStats
@@ -129,49 +133,45 @@ export const _HLSView: React.FC = () => {
129
133
 
130
134
  return (
131
135
  <View style={styles.hlsView}>
132
- {room?.hlsStreamingState?.state === HMSStreamingState.STARTED ? (
133
- room?.hlsStreamingState?.variants?.slice(0, 1)?.map((variant, index) =>
134
- variant?.hlsStreamUrl ? (
135
- <View key={index} style={styles.hlsPlayerContainer}>
136
- <HMSHLSPlayer
137
- key={playerKey}
138
- ref={hmsHlsPlayerRef}
139
- enableStats={showHLSStats}
140
- enableControls={enableHLSPlayerControls}
141
- />
142
-
143
- <HLSPlayerEmoticons />
144
-
145
- {showHLSStats ? (
146
- <HLSPlayerStatsView onClosePress={handleClosePress} />
147
- ) : null}
148
-
149
- {showCustomHLSPlayerControls ? (
150
- <CustomControls handleControlPress={hlsPlayerActions} />
151
- ) : null}
152
-
153
- {isPlaybackFailed ? (
154
- <View
155
- style={[
156
- styles.playbackFailedContainer,
157
- hmsRoomStyles.failedContainer,
158
- ]}
159
- >
160
- <CrossCircleIcon />
161
-
162
- <Text
163
- style={[styles.playbackFailed, hmsRoomStyles.failedText]}
164
- >
165
- Playback Failed
166
- </Text>
167
- </View>
168
- ) : null}
169
- </View>
170
- ) : (
171
- <View key={index} style={styles.textContainer}>
172
- <Text style={styles.warningSubtitle}>Stream URL not found!</Text>
173
- </View>
174
- )
136
+ {isHLSStreaming ? (
137
+ isStreamUrlPresent ? (
138
+ <View style={styles.hlsPlayerContainer}>
139
+ <HMSHLSPlayer
140
+ key={playerKey}
141
+ ref={hmsHlsPlayerRef}
142
+ enableStats={showHLSStats}
143
+ enableControls={enableHLSPlayerControls}
144
+ />
145
+
146
+ <HLSPlayerEmoticons />
147
+
148
+ {showHLSStats ? (
149
+ <HLSPlayerStatsView onClosePress={handleClosePress} />
150
+ ) : null}
151
+
152
+ {showCustomHLSPlayerControls ? (
153
+ <CustomControls handleControlPress={hlsPlayerActions} />
154
+ ) : null}
155
+
156
+ {isPlaybackFailed ? (
157
+ <View
158
+ style={[
159
+ styles.playbackFailedContainer,
160
+ hmsRoomStyles.failedContainer,
161
+ ]}
162
+ >
163
+ <CrossCircleIcon />
164
+
165
+ <Text style={[styles.playbackFailed, hmsRoomStyles.failedText]}>
166
+ Playback Failed
167
+ </Text>
168
+ </View>
169
+ ) : null}
170
+ </View>
171
+ ) : (
172
+ <View style={styles.textContainer}>
173
+ <Text style={styles.warningSubtitle}>Stream URL not found!</Text>
174
+ </View>
175
175
  )
176
176
  ) : (
177
177
  <HMSHLSNotStarted />
@@ -6,12 +6,20 @@ import {
6
6
  TouchableHighlight,
7
7
  View,
8
8
  } from 'react-native';
9
- import type { StyleProp, ViewStyle, TextStyle, ColorValue, TouchableHighlightProps } from 'react-native';
9
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
10
+ import type {
11
+ StyleProp,
12
+ ViewStyle,
13
+ TextStyle,
14
+ ColorValue,
15
+ TouchableHighlightProps,
16
+ } from 'react-native';
10
17
 
11
18
  export interface HMSBaseButtonProps {
12
19
  title: string;
13
20
  loading: boolean;
14
21
  onPress(): void;
22
+ wrapWithGestureDetector?: boolean;
15
23
  testID?: TouchableHighlightProps['testID'];
16
24
  underlayColor?: ColorValue | undefined;
17
25
  loaderColor?: ColorValue | undefined;
@@ -32,8 +40,9 @@ export const HMSBaseButton: React.FC<HMSBaseButtonProps> = ({
32
40
  textStyle,
33
41
  disabled,
34
42
  leftComponent,
43
+ wrapWithGestureDetector,
35
44
  }) => {
36
- return (
45
+ const button = (
37
46
  <TouchableHighlight
38
47
  testID={testID}
39
48
  underlayColor={underlayColor}
@@ -63,6 +72,12 @@ export const HMSBaseButton: React.FC<HMSBaseButtonProps> = ({
63
72
  </>
64
73
  </TouchableHighlight>
65
74
  );
75
+
76
+ if (wrapWithGestureDetector) {
77
+ return <GestureDetector gesture={Gesture.Tap()}>{button}</GestureDetector>;
78
+ }
79
+
80
+ return button;
66
81
  };
67
82
 
68
83
  const styles = StyleSheet.create({
@@ -14,6 +14,7 @@ export interface HMSDangerButtonProps {
14
14
  style?: StyleProp<ViewStyle>;
15
15
  disabled?: boolean;
16
16
  leftComponent?: React.ReactElement | null;
17
+ wrapWithGestureDetector?: boolean;
17
18
  }
18
19
 
19
20
  export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
@@ -24,6 +25,7 @@ export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
24
25
  style,
25
26
  disabled,
26
27
  leftComponent,
28
+ wrapWithGestureDetector,
27
29
  }) => {
28
30
  const {
29
31
  alert_error_dim: alertErrorDimColor,
@@ -65,6 +67,7 @@ export const HMSDangerButton: React.FC<HMSDangerButtonProps> = ({
65
67
  hmsRoomStyles.buttonText,
66
68
  disabled ? hmsRoomStyles.disabledText : null,
67
69
  ]}
70
+ wrapWithGestureDetector={wrapWithGestureDetector}
68
71
  />
69
72
  );
70
73
  };
@@ -1,14 +1,51 @@
1
1
  import * as React from 'react';
2
- import { View, Text, StyleSheet, Platform } from 'react-native';
3
- import { HMSMessage } from '@100mslive/react-native-hms';
2
+ import { useDispatch, useSelector } from 'react-redux';
3
+ import {
4
+ View,
5
+ Text,
6
+ StyleSheet,
7
+ Platform,
8
+ TouchableOpacity,
9
+ } from 'react-native';
10
+ import type { HMSMessage } from '@100mslive/react-native-hms';
11
+ import { Gesture, GestureDetector } from 'react-native-gesture-handler';
4
12
 
5
- import { useHMSRoomStyleSheet } from '../hooks-util';
13
+ import {
14
+ useAllowBlockingPeerFromChat,
15
+ useAllowPinningMessage,
16
+ useHMSRoomStyleSheet,
17
+ useModalType,
18
+ } from '../hooks-util';
19
+ import { PinIcon, ThreeDotsIcon } from '../Icons';
20
+ import { setSelectedMessageForAction } from '../redux/actions';
21
+ import { ModalTypes } from '../utils/types';
22
+ import type { RootState } from '../redux';
6
23
 
7
24
  interface HMSHLSMessageProps {
8
25
  message: HMSMessage;
9
26
  }
10
27
 
11
28
  const _HMSHLSMessage: React.FC<HMSHLSMessageProps> = ({ message }) => {
29
+ const dispatch = useDispatch();
30
+ const { handleModalVisibleType } = useModalType();
31
+ const localPeerId = useSelector(
32
+ (state: RootState) => state.hmsStates.localPeer?.peerID
33
+ );
34
+
35
+ const allowPinningMessage = useAllowPinningMessage();
36
+ const allowPeerBlocking = useAllowBlockingPeerFromChat();
37
+ const canRemoveOthers = useSelector(
38
+ (state: RootState) =>
39
+ !!state.hmsStates.localPeer?.role?.permissions?.removeOthers
40
+ );
41
+
42
+ const isPinned = useSelector(
43
+ (state: RootState) =>
44
+ state.messages.pinnedMessages.findIndex(
45
+ (pinnedMessage) => pinnedMessage.id === message.messageId
46
+ ) >= 0
47
+ );
48
+
12
49
  const messageSender = message.sender;
13
50
 
14
51
  const hmsRoomStyles = useHMSRoomStyleSheet(
@@ -23,22 +60,70 @@ const _HMSHLSMessage: React.FC<HMSHLSMessageProps> = ({ message }) => {
23
60
  fontFamily: `${typography.font_family}-Regular`,
24
61
  textShadowColor: 'rgba(0, 0, 0, 0.5)',
25
62
  },
63
+ threeDots: {
64
+ tintColor: '#ffffff',
65
+ },
66
+ pinnedLabel: {
67
+ color: '#ffffff',
68
+ },
26
69
  }),
27
70
  []
28
71
  );
29
72
 
73
+ const onThreeDotsPress = () => {
74
+ dispatch(setSelectedMessageForAction(message));
75
+ handleModalVisibleType(ModalTypes.MESSAGE_OPTIONS);
76
+ };
77
+
78
+ const canTakeAction =
79
+ allowPinningMessage || // can pin message, OR
80
+ (allowPeerBlocking &&
81
+ message.sender &&
82
+ message.sender.peerID !== localPeerId) || // can block peers, OR
83
+ (canRemoveOthers &&
84
+ message.sender &&
85
+ message.sender.peerID !== localPeerId); // can remove participants
86
+
30
87
  return (
31
88
  <View style={styles.container}>
32
- <Text
33
- style={[styles.senderName, hmsRoomStyles.senderName]}
34
- numberOfLines={1}
35
- >
36
- {messageSender
37
- ? messageSender.isLocal
38
- ? 'You'
39
- : messageSender.name
40
- : 'Anonymous'}
41
- </Text>
89
+ {isPinned ? (
90
+ <View style={styles.pinLabelContainer}>
91
+ <PinIcon
92
+ type="pin"
93
+ style={[styles.pinIcon, hmsRoomStyles.threeDots]}
94
+ />
95
+ <Text style={[styles.pinnedLabel, hmsRoomStyles.pinnedLabel]}>
96
+ PINNED
97
+ </Text>
98
+ </View>
99
+ ) : null}
100
+
101
+ <View style={styles.nameWrapper}>
102
+ <Text
103
+ style={[styles.senderName, hmsRoomStyles.senderName]}
104
+ numberOfLines={1}
105
+ >
106
+ {messageSender
107
+ ? messageSender.isLocal
108
+ ? 'You'
109
+ : messageSender.name
110
+ : 'Anonymous'}
111
+ </Text>
112
+
113
+ {canTakeAction ? (
114
+ <GestureDetector gesture={Gesture.Tap()}>
115
+ <TouchableOpacity
116
+ hitSlop={styles.threeDotsHitSlop}
117
+ onPress={onThreeDotsPress}
118
+ >
119
+ <ThreeDotsIcon
120
+ stack="vertical"
121
+ style={[styles.threeDots, hmsRoomStyles.threeDots]}
122
+ />
123
+ </TouchableOpacity>
124
+ </GestureDetector>
125
+ ) : null}
126
+ </View>
42
127
 
43
128
  <Text style={[styles.message, hmsRoomStyles.message]}>
44
129
  {message.message}
@@ -54,7 +139,12 @@ const styles = StyleSheet.create({
54
139
  marginTop: 8,
55
140
  width: '100%',
56
141
  },
142
+ nameWrapper: {
143
+ flexDirection: 'row',
144
+ alignItems: 'center',
145
+ },
57
146
  senderName: {
147
+ flexGrow: 1,
58
148
  fontSize: 14,
59
149
  lineHeight: Platform.OS === 'android' ? 20 : undefined,
60
150
  letterSpacing: 0.1,
@@ -69,4 +159,31 @@ const styles = StyleSheet.create({
69
159
  textShadowOffset: { height: 0.5, width: 0.5 },
70
160
  textShadowRadius: 2,
71
161
  },
162
+ threeDots: {
163
+ width: 20,
164
+ height: 20,
165
+ marginLeft: 4,
166
+ },
167
+ threeDotsHitSlop: {
168
+ left: 12,
169
+ right: 12,
170
+ top: 12,
171
+ bottom: 12,
172
+ },
173
+ pinLabelContainer: {
174
+ flexDirection: 'row',
175
+ alignItems: 'center',
176
+ marginBottom: 4,
177
+ },
178
+ pinIcon: {
179
+ width: 12,
180
+ height: 12,
181
+ marginRight: 4,
182
+ },
183
+ pinnedLabel: {
184
+ fontSize: 10,
185
+ textTransform: 'uppercase',
186
+ lineHeight: 16,
187
+ letterSpacing: 1.5,
188
+ },
72
189
  });
@@ -26,7 +26,7 @@ export const HMSHLSMessageList: React.FC = () => {
26
26
  return null;
27
27
  }
28
28
 
29
- const HEIGHT_MULTIPLIER = isLandscapeOrientation ? 0.45 : 0.2;
29
+ const HEIGHT_MULTIPLIER = isLandscapeOrientation ? 0.42 : 0.25;
30
30
 
31
31
  return (
32
32
  <View
@@ -37,7 +37,7 @@ export const HMSHLSMessageList: React.FC = () => {
37
37
  height:
38
38
  messages.length > 3
39
39
  ? windowHeight * HEIGHT_MULTIPLIER
40
- : messages.length * 54,
40
+ : messages.length * 66,
41
41
  },
42
42
  ]}
43
43
  >
@@ -1,6 +1,7 @@
1
1
  import * as React from 'react';
2
2
  import { StyleSheet, Text, TouchableHighlight } from 'react-native';
3
3
  import type { HMSPeer } from '@100mslive/react-native-hms';
4
+ import { GestureDetector, Gesture } from 'react-native-gesture-handler';
4
5
 
5
6
  import { HandIcon } from '../Icons';
6
7
  import {
@@ -61,7 +62,11 @@ export const HMSHandRaiseNotification: React.FC<
61
62
  );
62
63
  }
63
64
  dispatch(removeNotification(id));
64
- await hmsInstance.changeRoleOfPeer(peer, onStageRole, false);
65
+ await hmsInstance.changeRoleOfPeer(
66
+ peer,
67
+ onStageRole,
68
+ onStageExpData?.skip_preview_for_role_change || false
69
+ );
65
70
  };
66
71
 
67
72
  return (
@@ -72,15 +77,17 @@ export const HMSHandRaiseNotification: React.FC<
72
77
  dismissDelay={dismissDelay}
73
78
  autoDismiss={autoDismiss}
74
79
  cta={
75
- <TouchableHighlight
76
- underlayColor={secondaryDimColor}
77
- style={[styles.button, hmsRoomStyles.button]}
78
- onPress={bringPeerToStage}
79
- >
80
- <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
81
- {onStageExpData?.bring_to_stage_label || 'Bring to Stage'}
82
- </Text>
83
- </TouchableHighlight>
80
+ <GestureDetector gesture={Gesture.Tap()}>
81
+ <TouchableHighlight
82
+ underlayColor={secondaryDimColor}
83
+ style={[styles.button, hmsRoomStyles.button]}
84
+ onPress={bringPeerToStage}
85
+ >
86
+ <Text style={[styles.buttonText, hmsRoomStyles.buttonText]}>
87
+ {onStageExpData?.bring_to_stage_label || 'Bring to Stage'}
88
+ </Text>
89
+ </TouchableHighlight>
90
+ </GestureDetector>
84
91
  }
85
92
  />
86
93
  );
@@ -1,12 +1,15 @@
1
1
  import * as React from 'react';
2
2
  import type { StyleProp, ViewStyle } from 'react-native';
3
3
  import Animated, {
4
+ KeyboardState,
4
5
  useAnimatedKeyboard,
5
6
  useAnimatedStyle,
6
7
  useDerivedValue,
7
8
  } from 'react-native-reanimated';
8
9
  import type { SharedValue } from 'react-native-reanimated';
9
10
 
11
+ import { useKeyboardState } from '../hooks-util';
12
+
10
13
  export interface HMSKeyboardAvoidingViewProps {
11
14
  style?: StyleProp<Animated.AnimateStyle<StyleProp<ViewStyle>>>;
12
15
  bottomOffset?: number | SharedValue<number>;
@@ -16,6 +19,7 @@ export const HMSKeyboardAvoidingView: React.FC<
16
19
  HMSKeyboardAvoidingViewProps
17
20
  > = ({ children, style, bottomOffset = 0 }) => {
18
21
  const animatedKeyboard = useAnimatedKeyboard();
22
+ const { keyboardState } = useKeyboardState();
19
23
 
20
24
  const initialPageY = useDerivedValue(() => {
21
25
  return typeof bottomOffset === 'number' ? bottomOffset : bottomOffset.value;
@@ -27,7 +31,8 @@ export const HMSKeyboardAvoidingView: React.FC<
27
31
  transform: [
28
32
  {
29
33
  translateY:
30
- keyboardHeight <= initialPageY.value
34
+ keyboardHeight <= initialPageY.value ||
35
+ keyboardState.value === KeyboardState.CLOSED
31
36
  ? 0 // Keep element at original `pageY` till and when keyboard height is less than `pageY`
32
37
  : -(keyboardHeight - initialPageY.value),
33
38
  },
@@ -1,22 +1,13 @@
1
1
  import * as React from 'react';
2
- import {
3
- StyleSheet,
4
- View,
5
- Text,
6
- Platform,
7
- } from 'react-native';
8
- import { useSelector } from 'react-redux';
9
- import { HMSStreamingState } from '@100mslive/react-native-hms';
2
+ import { StyleSheet, View, Text, Platform } from 'react-native';
10
3
 
11
4
  import { useHMSRoomStyleSheet } from '../hooks-util';
12
5
  import { COLORS } from '../utils/theme';
13
- import type { RootState } from '../redux';
14
6
  import { TestIds } from '../utils/constants';
7
+ import { useIsAnyStreamingOn } from '../hooks-sdk';
15
8
 
16
9
  const _HMSLiveIndicator = () => {
17
- const live = useSelector(
18
- (state: RootState) => state.hmsStates.room?.hlsStreamingState?.state === HMSStreamingState.STARTED
19
- );
10
+ const live = useIsAnyStreamingOn();
20
11
 
21
12
  const hmsRoomStyles = useHMSRoomStyleSheet((theme, typograhy) => ({
22
13
  live: {
@@ -34,7 +25,12 @@ const _HMSLiveIndicator = () => {
34
25
 
35
26
  return (
36
27
  <View style={[styles.live, hmsRoomStyles.live]}>
37
- <Text testID={TestIds.live_text} style={[styles.liveText, hmsRoomStyles.liveText]}>LIVE</Text>
28
+ <Text
29
+ testID={TestIds.live_text}
30
+ style={[styles.liveText, hmsRoomStyles.liveText]}
31
+ >
32
+ LIVE
33
+ </Text>
38
34
  </View>
39
35
  );
40
36
  };