@sendbird/uikit-react-native 2.1.0 → 2.3.0

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 (431) hide show
  1. package/README.md +42 -17
  2. package/lib/commonjs/components/ChatFlatList.js +2 -1
  3. package/lib/commonjs/components/ChatFlatList.js.map +1 -1
  4. package/lib/commonjs/components/FileViewer.js +2 -5
  5. package/lib/commonjs/components/FileViewer.js.map +1 -1
  6. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  7. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  8. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  9. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  10. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +26 -11
  11. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  12. package/lib/commonjs/components/MessageRenderer/FileMessage/index.js +1 -6
  13. package/lib/commonjs/components/MessageRenderer/FileMessage/index.js.map +1 -1
  14. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -10
  15. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  16. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +102 -15
  17. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  18. package/lib/commonjs/components/MessageRenderer/UserMessage/index.js.map +1 -1
  19. package/lib/commonjs/components/MessageRenderer/index.js +22 -3
  20. package/lib/commonjs/components/MessageRenderer/index.js.map +1 -1
  21. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +150 -0
  22. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  23. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js +135 -0
  24. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  25. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js +87 -0
  26. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  27. package/lib/commonjs/components/ReactionAddons/index.js +19 -0
  28. package/lib/commonjs/components/ReactionAddons/index.js.map +1 -0
  29. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js +150 -0
  30. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  31. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +276 -0
  32. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  33. package/lib/commonjs/components/ReactionBottomSheets/index.js +19 -0
  34. package/lib/commonjs/components/ReactionBottomSheets/index.js.map +1 -0
  35. package/lib/commonjs/constants.js +3 -1
  36. package/lib/commonjs/constants.js.map +1 -1
  37. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +4 -1
  38. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  39. package/lib/commonjs/containers/SendbirdUIKitContainer.js +130 -79
  40. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  41. package/lib/commonjs/contexts/PlatformServiceCtx.js.map +1 -1
  42. package/lib/commonjs/contexts/ReactionCtx.js +107 -0
  43. package/lib/commonjs/contexts/ReactionCtx.js.map +1 -0
  44. package/lib/commonjs/contexts/SendbirdChatCtx.js +26 -18
  45. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -1
  46. package/lib/commonjs/contexts/UserProfileCtx.js +9 -0
  47. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -1
  48. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +33 -37
  49. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  50. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +95 -23
  51. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  52. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +121 -31
  53. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  54. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +34 -13
  55. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  56. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +210 -0
  57. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  58. package/lib/commonjs/domain/groupChannel/index.js +8 -0
  59. package/lib/commonjs/domain/groupChannel/index.js.map +1 -1
  60. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +4 -0
  61. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  62. package/lib/commonjs/domain/groupChannel/module/moduleContext.js +4 -4
  63. package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
  64. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  65. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +3 -2
  66. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  67. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +2 -1
  68. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  69. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +2 -1
  70. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  71. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +39 -0
  72. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  73. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +140 -0
  74. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  75. package/lib/commonjs/domain/groupChannelNotifications/index.js +46 -0
  76. package/lib/commonjs/domain/groupChannelNotifications/index.js.map +1 -0
  77. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +33 -0
  78. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  79. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js +45 -0
  80. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  81. package/lib/commonjs/domain/groupChannelNotifications/types.js +6 -0
  82. package/lib/commonjs/domain/groupChannelNotifications/types.js.map +1 -0
  83. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +2 -1
  84. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  85. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +49 -6
  86. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  87. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +11 -16
  88. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  89. package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
  90. package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
  91. package/lib/commonjs/domain/userList/component/UserListList.js +4 -1
  92. package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -1
  93. package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -1
  94. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  95. package/lib/commonjs/fragments/createGroupChannelFragment.js +11 -4
  96. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  97. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
  98. package/lib/commonjs/fragments/createGroupChannelListFragment.js +4 -14
  99. package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
  100. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js +34 -0
  101. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  102. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +3 -1
  103. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  104. package/lib/commonjs/hooks/useConnection.js +3 -0
  105. package/lib/commonjs/hooks/useConnection.js.map +1 -1
  106. package/lib/commonjs/hooks/useContext.js +11 -1
  107. package/lib/commonjs/hooks/useContext.js.map +1 -1
  108. package/lib/commonjs/hooks/useKeyboardStatus.js +97 -0
  109. package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -0
  110. package/lib/commonjs/hooks/useMentionSuggestion.js +110 -0
  111. package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -0
  112. package/lib/commonjs/hooks/useMentionTextInput.js +139 -0
  113. package/lib/commonjs/hooks/useMentionTextInput.js.map +1 -0
  114. package/lib/commonjs/index.js +95 -40
  115. package/lib/commonjs/index.js.map +1 -1
  116. package/lib/commonjs/libs/EmojiManager.js +100 -0
  117. package/lib/commonjs/libs/EmojiManager.js.map +1 -0
  118. package/lib/commonjs/libs/ImageCompressionConfig.js +38 -0
  119. package/lib/commonjs/libs/ImageCompressionConfig.js.map +1 -0
  120. package/lib/commonjs/libs/MentionConfig.js +47 -0
  121. package/lib/commonjs/libs/MentionConfig.js.map +1 -0
  122. package/lib/commonjs/libs/MentionManager.js +235 -0
  123. package/lib/commonjs/libs/MentionManager.js.map +1 -0
  124. package/lib/commonjs/libs/SBUUtils.js +27 -0
  125. package/lib/commonjs/libs/SBUUtils.js.map +1 -1
  126. package/lib/commonjs/localization/StringSet.type.js +20 -5
  127. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  128. package/lib/commonjs/platform/createMediaService.expo.js +35 -1
  129. package/lib/commonjs/platform/createMediaService.expo.js.map +1 -1
  130. package/lib/commonjs/platform/createMediaService.native.js +41 -6
  131. package/lib/commonjs/platform/createMediaService.native.js.map +1 -1
  132. package/lib/commonjs/platform/dynamicModule.js +9 -57
  133. package/lib/commonjs/platform/dynamicModule.js.map +1 -1
  134. package/lib/commonjs/platform/types.js.map +1 -1
  135. package/lib/commonjs/types.js.map +1 -1
  136. package/lib/commonjs/version.js +1 -1
  137. package/lib/commonjs/version.js.map +1 -1
  138. package/lib/module/components/ChatFlatList.js +3 -2
  139. package/lib/module/components/ChatFlatList.js.map +1 -1
  140. package/lib/module/components/FileViewer.js +2 -5
  141. package/lib/module/components/FileViewer.js.map +1 -1
  142. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  143. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  144. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  145. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  146. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +26 -11
  147. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  148. package/lib/module/components/MessageRenderer/FileMessage/index.js +1 -5
  149. package/lib/module/components/MessageRenderer/FileMessage/index.js.map +1 -1
  150. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -12
  151. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  152. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +103 -19
  153. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  154. package/lib/module/components/MessageRenderer/UserMessage/index.js.map +1 -1
  155. package/lib/module/components/MessageRenderer/index.js +21 -4
  156. package/lib/module/components/MessageRenderer/index.js.map +1 -1
  157. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +132 -0
  158. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  159. package/lib/module/components/ReactionAddons/MessageReactionAddon.js +118 -0
  160. package/lib/module/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  161. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js +74 -0
  162. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  163. package/lib/module/components/ReactionAddons/index.js +7 -0
  164. package/lib/module/components/ReactionAddons/index.js.map +1 -0
  165. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js +135 -0
  166. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  167. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +259 -0
  168. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  169. package/lib/module/components/ReactionBottomSheets/index.js +7 -0
  170. package/lib/module/components/ReactionBottomSheets/index.js.map +1 -0
  171. package/lib/module/constants.js +1 -0
  172. package/lib/module/constants.js.map +1 -1
  173. package/lib/module/containers/GroupChannelPreviewContainer.js +4 -1
  174. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  175. package/lib/module/containers/SendbirdUIKitContainer.js +127 -81
  176. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  177. package/lib/module/contexts/PlatformServiceCtx.js.map +1 -1
  178. package/lib/module/contexts/ReactionCtx.js +85 -0
  179. package/lib/module/contexts/ReactionCtx.js.map +1 -0
  180. package/lib/module/contexts/SendbirdChatCtx.js +28 -18
  181. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -1
  182. package/lib/module/contexts/UserProfileCtx.js +7 -0
  183. package/lib/module/contexts/UserProfileCtx.js.map +1 -1
  184. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +34 -39
  185. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  186. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +92 -26
  187. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  188. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +118 -33
  189. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  190. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +35 -16
  191. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  192. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +188 -0
  193. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  194. package/lib/module/domain/groupChannel/index.js +1 -0
  195. package/lib/module/domain/groupChannel/index.js.map +1 -1
  196. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +3 -0
  197. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  198. package/lib/module/domain/groupChannel/module/moduleContext.js +4 -4
  199. package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
  200. package/lib/module/domain/groupChannel/types.js.map +1 -1
  201. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +4 -3
  202. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  203. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +3 -2
  204. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  205. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +3 -2
  206. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  207. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +25 -0
  208. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  209. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +122 -0
  210. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  211. package/lib/module/domain/groupChannelNotifications/index.js +5 -0
  212. package/lib/module/domain/groupChannelNotifications/index.js.map +1 -0
  213. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +21 -0
  214. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  215. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js +25 -0
  216. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  217. package/lib/module/domain/groupChannelNotifications/types.js +2 -0
  218. package/lib/module/domain/groupChannelNotifications/types.js.map +1 -0
  219. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +3 -2
  220. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  221. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +46 -6
  222. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  223. package/lib/module/domain/groupChannelSettings/module/moduleContext.js +12 -17
  224. package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  225. package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
  226. package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
  227. package/lib/module/domain/userList/component/UserListList.js +3 -1
  228. package/lib/module/domain/userList/component/UserListList.js.map +1 -1
  229. package/lib/module/domain/userList/module/createUserListModule.js.map +1 -1
  230. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  231. package/lib/module/fragments/createGroupChannelFragment.js +11 -4
  232. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  233. package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
  234. package/lib/module/fragments/createGroupChannelListFragment.js +5 -9
  235. package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
  236. package/lib/module/fragments/createGroupChannelNotificationsFragment.js +22 -0
  237. package/lib/module/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  238. package/lib/module/fragments/createGroupChannelSettingsFragment.js +3 -1
  239. package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  240. package/lib/module/hooks/useConnection.js +3 -0
  241. package/lib/module/hooks/useConnection.js.map +1 -1
  242. package/lib/module/hooks/useContext.js +6 -0
  243. package/lib/module/hooks/useContext.js.map +1 -1
  244. package/lib/module/hooks/useKeyboardStatus.js +78 -0
  245. package/lib/module/hooks/useKeyboardStatus.js.map +1 -0
  246. package/lib/module/hooks/useMentionSuggestion.js +100 -0
  247. package/lib/module/hooks/useMentionSuggestion.js.map +1 -0
  248. package/lib/module/hooks/useMentionTextInput.js +128 -0
  249. package/lib/module/hooks/useMentionTextInput.js.map +1 -0
  250. package/lib/module/index.js +8 -3
  251. package/lib/module/index.js.map +1 -1
  252. package/lib/module/libs/EmojiManager.js +90 -0
  253. package/lib/module/libs/EmojiManager.js.map +1 -0
  254. package/lib/module/libs/ImageCompressionConfig.js +30 -0
  255. package/lib/module/libs/ImageCompressionConfig.js.map +1 -0
  256. package/lib/module/libs/MentionConfig.js +39 -0
  257. package/lib/module/libs/MentionConfig.js.map +1 -0
  258. package/lib/module/libs/MentionManager.js +223 -0
  259. package/lib/module/libs/MentionManager.js.map +1 -0
  260. package/lib/module/libs/SBUUtils.js +26 -1
  261. package/lib/module/libs/SBUUtils.js.map +1 -1
  262. package/lib/module/localization/StringSet.type.js +21 -6
  263. package/lib/module/localization/StringSet.type.js.map +1 -1
  264. package/lib/module/platform/createMediaService.expo.js +33 -1
  265. package/lib/module/platform/createMediaService.expo.js.map +1 -1
  266. package/lib/module/platform/createMediaService.native.js +38 -5
  267. package/lib/module/platform/createMediaService.native.js.map +1 -1
  268. package/lib/module/platform/dynamicModule.js +10 -56
  269. package/lib/module/platform/dynamicModule.js.map +1 -1
  270. package/lib/module/platform/types.js.map +1 -1
  271. package/lib/module/types.js.map +1 -1
  272. package/lib/module/version.js +1 -1
  273. package/lib/module/version.js.map +1 -1
  274. package/lib/typescript/__template__/types.d.ts +3 -3
  275. package/lib/typescript/src/components/ChannelCover.d.ts +1 -1
  276. package/lib/typescript/src/components/ChatFlatList.d.ts +1 -1
  277. package/lib/typescript/src/components/FileViewer.d.ts +1 -1
  278. package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +1 -1
  279. package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +2 -2
  280. package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +1 -1
  281. package/lib/typescript/src/components/MessageRenderer/FileMessage/VideoFileMessage.d.ts +1 -1
  282. package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +11 -2
  283. package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +1 -1
  284. package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +1 -1
  285. package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +1 -1
  286. package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +1 -1
  287. package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +1 -1
  288. package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +1 -1
  289. package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +1 -1
  290. package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +2 -2
  291. package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +4 -1
  292. package/lib/typescript/src/components/MessageRenderer/index.d.ts +4 -3
  293. package/lib/typescript/src/components/NewMessagesButton.d.ts +1 -1
  294. package/lib/typescript/src/components/ReactionAddons/BottomSheetReactionAddon.d.ts +8 -0
  295. package/lib/typescript/src/components/ReactionAddons/MessageReactionAddon.d.ts +6 -0
  296. package/lib/typescript/src/components/ReactionAddons/ReactionRoundedButton.d.ts +14 -0
  297. package/lib/typescript/src/components/ReactionAddons/index.d.ts +11 -0
  298. package/lib/typescript/src/components/ReactionBottomSheets/ReactionListBottomSheet.d.ts +3 -0
  299. package/lib/typescript/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.d.ts +3 -0
  300. package/lib/typescript/src/components/ReactionBottomSheets/index.d.ts +20 -0
  301. package/lib/typescript/src/components/ScrollToBottomButton.d.ts +1 -1
  302. package/lib/typescript/src/components/StatusComposition.d.ts +1 -1
  303. package/lib/typescript/src/components/TypedPlaceholder.d.ts +1 -1
  304. package/lib/typescript/src/components/UserActionBar.d.ts +1 -1
  305. package/lib/typescript/src/components/UserSelectableBar.d.ts +1 -1
  306. package/lib/typescript/src/constants.d.ts +1 -0
  307. package/lib/typescript/src/containers/GroupChannelPreviewContainer.d.ts +1 -1
  308. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +20 -8
  309. package/lib/typescript/src/contexts/LocalizationCtx.d.ts +2 -2
  310. package/lib/typescript/src/contexts/PlatformServiceCtx.d.ts +9 -3
  311. package/lib/typescript/src/contexts/ReactionCtx.d.ts +18 -0
  312. package/lib/typescript/src/contexts/SendbirdChatCtx.d.ts +16 -3
  313. package/lib/typescript/src/contexts/UserProfileCtx.d.ts +4 -4
  314. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +35 -7
  315. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +32 -5
  316. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +19 -2
  317. package/lib/typescript/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.d.ts +3 -0
  318. package/lib/typescript/src/domain/groupChannel/index.d.ts +1 -0
  319. package/lib/typescript/src/domain/groupChannel/module/createGroupChannelModule.d.ts +1 -1
  320. package/lib/typescript/src/domain/groupChannel/types.d.ts +24 -7
  321. package/lib/typescript/src/domain/groupChannelBannedUsers/types.d.ts +3 -3
  322. package/lib/typescript/src/domain/groupChannelList/types.d.ts +2 -2
  323. package/lib/typescript/src/domain/groupChannelModeration/types.d.ts +3 -3
  324. package/lib/typescript/src/domain/groupChannelMutedMembers/types.d.ts +3 -3
  325. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.d.ts +3 -0
  326. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.d.ts +2 -0
  327. package/lib/typescript/src/domain/groupChannelNotifications/index.d.ts +4 -0
  328. package/lib/typescript/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.d.ts +3 -0
  329. package/lib/typescript/src/domain/groupChannelNotifications/module/moduleContext.d.ts +3 -0
  330. package/lib/typescript/src/domain/groupChannelNotifications/types.d.ts +33 -0
  331. package/lib/typescript/src/domain/groupChannelOperators/types.d.ts +3 -3
  332. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -1
  333. package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +3 -1
  334. package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +6 -6
  335. package/lib/typescript/src/domain/userList/component/UserListList.d.ts +2 -1
  336. package/lib/typescript/src/domain/userList/module/createUserListModule.d.ts +2 -1
  337. package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +1 -1
  338. package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +1 -1
  339. package/lib/typescript/src/fragments/createGroupChannelNotificationsFragment.d.ts +3 -0
  340. package/lib/typescript/src/hooks/useConnection.d.ts +1 -1
  341. package/lib/typescript/src/hooks/useContext.d.ts +3 -26
  342. package/lib/typescript/src/hooks/useKeyboardStatus.d.ts +6 -0
  343. package/lib/typescript/src/hooks/useMentionSuggestion.d.ts +17 -0
  344. package/lib/typescript/src/hooks/useMentionTextInput.d.ts +18 -0
  345. package/lib/typescript/src/index.d.ts +8 -3
  346. package/lib/typescript/src/libs/EmojiManager.d.ts +16 -0
  347. package/lib/typescript/src/libs/ImageCompressionConfig.d.ts +16 -0
  348. package/lib/typescript/src/libs/MentionConfig.d.ts +24 -0
  349. package/lib/typescript/src/libs/MentionManager.d.ts +61 -0
  350. package/lib/typescript/src/libs/SBUUtils.d.ts +6 -0
  351. package/lib/typescript/src/localization/StringSet.type.d.ts +19 -2
  352. package/lib/typescript/src/platform/createMediaService.expo.d.ts +6 -2
  353. package/lib/typescript/src/platform/createMediaService.native.d.ts +8 -6
  354. package/lib/typescript/src/platform/dynamicModule.d.ts +8 -13
  355. package/lib/typescript/src/platform/types.d.ts +33 -8
  356. package/lib/typescript/src/types.d.ts +13 -4
  357. package/lib/typescript/src/version.d.ts +1 -1
  358. package/package.json +16 -6
  359. package/src/components/ChatFlatList.tsx +2 -1
  360. package/src/components/FileViewer.tsx +2 -5
  361. package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +17 -12
  362. package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +30 -18
  363. package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +21 -11
  364. package/src/components/MessageRenderer/FileMessage/index.tsx +1 -4
  365. package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +82 -14
  366. package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +136 -62
  367. package/src/components/MessageRenderer/UserMessage/index.tsx +8 -1
  368. package/src/components/MessageRenderer/index.tsx +39 -7
  369. package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +106 -0
  370. package/src/components/ReactionAddons/MessageReactionAddon.tsx +123 -0
  371. package/src/components/ReactionAddons/ReactionRoundedButton.tsx +71 -0
  372. package/src/components/ReactionAddons/index.tsx +7 -0
  373. package/src/components/ReactionBottomSheets/ReactionListBottomSheet.tsx +113 -0
  374. package/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.tsx +249 -0
  375. package/src/components/ReactionBottomSheets/index.tsx +24 -0
  376. package/src/constants.ts +2 -0
  377. package/src/containers/GroupChannelPreviewContainer.tsx +3 -1
  378. package/src/containers/SendbirdUIKitContainer.tsx +165 -88
  379. package/src/contexts/PlatformServiceCtx.tsx +9 -2
  380. package/src/contexts/ReactionCtx.tsx +102 -0
  381. package/src/contexts/SendbirdChatCtx.tsx +46 -21
  382. package/src/contexts/UserProfileCtx.tsx +9 -0
  383. package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +56 -30
  384. package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +129 -32
  385. package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +138 -43
  386. package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +30 -12
  387. package/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.tsx +173 -0
  388. package/src/domain/groupChannel/index.ts +1 -0
  389. package/src/domain/groupChannel/module/createGroupChannelModule.tsx +12 -1
  390. package/src/domain/groupChannel/module/moduleContext.tsx +4 -4
  391. package/src/domain/groupChannel/types.ts +28 -5
  392. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +3 -2
  393. package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -1
  394. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +2 -1
  395. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.tsx +14 -0
  396. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.tsx +128 -0
  397. package/src/domain/groupChannelNotifications/index.ts +4 -0
  398. package/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.tsx +15 -0
  399. package/src/domain/groupChannelNotifications/module/moduleContext.tsx +31 -0
  400. package/src/domain/groupChannelNotifications/types.ts +38 -0
  401. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +2 -1
  402. package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +42 -3
  403. package/src/domain/groupChannelSettings/module/moduleContext.tsx +17 -14
  404. package/src/domain/groupChannelSettings/types.ts +2 -0
  405. package/src/domain/groupChannelUserList/types.ts +7 -2
  406. package/src/domain/userList/component/UserListList.tsx +5 -1
  407. package/src/domain/userList/module/createUserListModule.tsx +3 -1
  408. package/src/fragments/createGroupChannelCreateFragment.tsx +8 -2
  409. package/src/fragments/createGroupChannelFragment.tsx +19 -6
  410. package/src/fragments/createGroupChannelInviteFragment.tsx +2 -2
  411. package/src/fragments/createGroupChannelListFragment.tsx +5 -9
  412. package/src/fragments/createGroupChannelNotificationsFragment.tsx +27 -0
  413. package/src/fragments/createGroupChannelSettingsFragment.tsx +2 -0
  414. package/src/hooks/useConnection.ts +3 -1
  415. package/src/hooks/useContext.ts +7 -0
  416. package/src/hooks/useKeyboardStatus.ts +59 -0
  417. package/src/hooks/useMentionSuggestion.ts +106 -0
  418. package/src/hooks/useMentionTextInput.ts +139 -0
  419. package/src/index.ts +14 -2
  420. package/src/libs/EmojiManager.ts +80 -0
  421. package/src/libs/ImageCompressionConfig.ts +31 -0
  422. package/src/libs/MentionConfig.ts +40 -0
  423. package/src/libs/MentionManager.tsx +240 -0
  424. package/src/libs/SBUUtils.ts +28 -1
  425. package/src/localization/StringSet.type.ts +45 -8
  426. package/src/platform/createMediaService.expo.tsx +24 -1
  427. package/src/platform/createMediaService.native.tsx +31 -9
  428. package/src/platform/dynamicModule.ts +17 -59
  429. package/src/platform/types.ts +29 -7
  430. package/src/types.ts +12 -0
  431. package/src/version.ts +1 -1
@@ -1,8 +1,8 @@
1
1
  import type SBUError from '../libs/SBUError';
2
- export declare type Unsubscribe = () => void | undefined;
3
- export declare type DownloadedPath = string;
4
- export declare type FilePickerResponse = FileType | null;
5
- export declare type FileType = {
2
+ export type Unsubscribe = () => void | undefined;
3
+ export type DownloadedPath = string;
4
+ export type FilePickerResponse = FileType | null;
5
+ export type FileType = {
6
6
  uri: string;
7
7
  size: number;
8
8
  name: string;
@@ -32,7 +32,7 @@ export interface OpenCameraOptions extends OpenResultListener {
32
32
  cameraType?: 'front' | 'back';
33
33
  mediaType?: 'photo' | 'video' | 'all';
34
34
  }
35
- export declare type OpenDocumentOptions = OpenResultListener;
35
+ export type OpenDocumentOptions = OpenResultListener;
36
36
  export interface SaveOptions {
37
37
  fileUrl: string;
38
38
  fileName: string;
@@ -58,10 +58,35 @@ interface GetVideoThumbnailOptions {
58
58
  timeMills?: number;
59
59
  quality?: number;
60
60
  }
61
+ interface CompressImageOptions {
62
+ /**
63
+ * A uri of image file to compress
64
+ * */
65
+ uri: string;
66
+ /**
67
+ * A resize width, apply only to downscale
68
+ * */
69
+ maxWidth?: number;
70
+ /**
71
+ * A resize height, apply only to downscale
72
+ * */
73
+ maxHeight?: number;
74
+ /**
75
+ * A value in range 0.0 - 1.0 specifying compression level of the result image.
76
+ * 1 means highest quality and 0 the lowest quality.
77
+ * */
78
+ compressionRate?: number;
79
+ }
80
+ type GetVideoThumbnailResult = Promise<{
81
+ path: string;
82
+ } | null>;
83
+ type CompressImageResult = Promise<{
84
+ uri: string;
85
+ size: number;
86
+ } | null>;
61
87
  export interface MediaServiceInterface {
62
88
  VideoComponent<Props = {}>(props: VideoProps & Props): JSX.Element;
63
- getVideoThumbnail(options: GetVideoThumbnailOptions): Promise<{
64
- path: string;
65
- } | null>;
89
+ getVideoThumbnail(options: GetVideoThumbnailOptions): GetVideoThumbnailResult;
90
+ compressImage(options: CompressImageOptions): CompressImageResult;
66
91
  }
67
92
  export {};
@@ -1,6 +1,7 @@
1
1
  import type { ErrorInfo, ReactNode } from 'react';
2
- export declare type KeyValuePairGet = [string, string | null];
3
- export declare type KeyValuePairSet = [string, string];
2
+ import type { SendbirdUser } from '@sendbird/uikit-utils';
3
+ export type KeyValuePairGet = [string, string | null];
4
+ export type KeyValuePairSet = [string, string];
4
5
  export interface LocalCacheStorage {
5
6
  getAllKeys(): Promise<readonly string[] | string[]>;
6
7
  getItem(key: string): Promise<string | null>;
@@ -10,11 +11,19 @@ export interface LocalCacheStorage {
10
11
  multiGet?(keys: string[]): Promise<readonly KeyValuePairGet[] | KeyValuePairGet[]>;
11
12
  multiRemove?(keys: string[]): Promise<void>;
12
13
  }
13
- export declare type ErrorBoundaryProps = {
14
+ export type ErrorBoundaryProps = {
14
15
  error: Error;
15
16
  errorInfo: ErrorInfo;
16
17
  reset: () => void;
17
18
  };
18
- export declare type CommonComponent<P = {}> = (props: P & {
19
+ export type CommonComponent<P = {}> = (props: P & {
19
20
  children?: ReactNode;
20
21
  }) => null | JSX.Element;
22
+ export type MentionedUser = {
23
+ range: Range;
24
+ user: SendbirdUser;
25
+ };
26
+ export type Range = {
27
+ start: number;
28
+ end: number;
29
+ };
@@ -1,2 +1,2 @@
1
- declare const VERSION = "2.1.0";
1
+ declare const VERSION = "2.3.0";
2
2
  export default VERSION;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sendbird/uikit-react-native",
3
- "version": "2.1.0",
3
+ "version": "2.3.0",
4
4
  "description": "react-native-uikit",
5
5
  "main": "lib/commonjs/index",
6
6
  "module": "lib/module/index",
@@ -41,11 +41,12 @@
41
41
  "access": "public"
42
42
  },
43
43
  "dependencies": {
44
- "@sendbird/uikit-chat-hooks": "2.1.0",
45
- "@sendbird/uikit-react-native-foundation": "2.1.0",
46
- "@sendbird/uikit-utils": "2.1.0"
44
+ "@sendbird/uikit-chat-hooks": "2.3.0",
45
+ "@sendbird/uikit-react-native-foundation": "2.3.0",
46
+ "@sendbird/uikit-utils": "2.3.0"
47
47
  },
48
48
  "devDependencies": {
49
+ "@bam.tech/react-native-image-resizer": "^3.0.4",
49
50
  "@react-native-camera-roll/camera-roll": "^5.0.4",
50
51
  "@react-native-clipboard/clipboard": "^1.8.5",
51
52
  "@react-native-community/netinfo": "^9.3.0",
@@ -59,6 +60,7 @@
59
60
  "expo-clipboard": "^2.1.1",
60
61
  "expo-document-picker": "^10.1.3",
61
62
  "expo-file-system": "^13.1.4",
63
+ "expo-image-manipulator": "^11.0.0",
62
64
  "expo-image-picker": "^12.0.2",
63
65
  "expo-media-library": "^14.0.1",
64
66
  "expo-notifications": "^0.14.1",
@@ -76,9 +78,10 @@
76
78
  "react-native-permissions": "^3.6.0",
77
79
  "react-native-safe-area-context": "^3.3.2",
78
80
  "react-native-video": "^5.2.0",
79
- "typescript": "^4.1.3"
81
+ "typescript": "4.9.4"
80
82
  },
81
83
  "peerDependencies": {
84
+ "@bam.tech/react-native-image-resizer": ">=3.0.0",
82
85
  "@react-native-camera-roll/camera-roll": ">=5.0.0",
83
86
  "@react-native-clipboard/clipboard": ">=1.8.5",
84
87
  "@react-native-community/netinfo": ">=9.3.0",
@@ -89,6 +92,7 @@
89
92
  "expo-clipboard": ">=2.1.1",
90
93
  "expo-document-picker": ">=10.1.3",
91
94
  "expo-file-system": ">=13.1.4",
95
+ "expo-image-manipulator": ">=11.0.0",
92
96
  "expo-image-picker": ">=12.0.2",
93
97
  "expo-notifications": ">=0.14.1",
94
98
  "expo-video-thumbnails": ">=6.4.0",
@@ -103,6 +107,9 @@
103
107
  "react-native-video": ">=5.2.0"
104
108
  },
105
109
  "peerDependenciesMeta": {
110
+ "@bam.tech/react-native-image-resizer": {
111
+ "optional": true
112
+ },
106
113
  "@react-native-camera-roll/camera-roll": {
107
114
  "optional": true
108
115
  },
@@ -124,6 +131,9 @@
124
131
  "expo-file-system": {
125
132
  "optional": true
126
133
  },
134
+ "expo-image-manipulator": {
135
+ "optional": true
136
+ },
127
137
  "expo-image-picker": {
128
138
  "optional": true
129
139
  },
@@ -171,5 +181,5 @@
171
181
  "readmeFile": "./README.md",
172
182
  "displayName": "@sendbird/uikit-react-native"
173
183
  },
174
- "gitHead": "c778a84a632487047fe532db188b32dfa6e93a7f"
184
+ "gitHead": "a9bf41fd7919436db99f6cc3bacd0f8d791b7729"
175
185
  }
@@ -2,7 +2,7 @@ import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useRef
2
2
  import { FlatList, FlatListProps, Platform } from 'react-native';
3
3
 
4
4
  import { useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
5
- import { SendbirdMessage, isMyMessage } from '@sendbird/uikit-utils';
5
+ import { SendbirdMessage, getMessageUniqId, isMyMessage } from '@sendbird/uikit-utils';
6
6
 
7
7
  let ANDROID_BUG_ALERT_SHOWED = Platform.OS !== 'android';
8
8
  const BOTTOM_DETECT_THRESHOLD = 25;
@@ -90,6 +90,7 @@ const ChatFlatList = forwardRef<ChatFlatListRef, Props>(function CustomFlatList(
90
90
  onEndReached={onTopReached}
91
91
  scrollEventThrottle={16}
92
92
  onScroll={_onScroll}
93
+ keyExtractor={getMessageUniqId}
93
94
  />
94
95
  );
95
96
  });
@@ -63,10 +63,8 @@ const FileViewer = ({
63
63
  const fileType = getFileType(fileMessage.type || getFileExtension(fileMessage.url));
64
64
 
65
65
  useEffect(() => {
66
- if (!mediaService?.VideoComponent || fileType === 'file') {
67
- onClose();
68
- }
69
- }, [mediaService]);
66
+ if (fileType === 'file') onClose();
67
+ }, []);
70
68
 
71
69
  const fileViewer = useIIFE(() => {
72
70
  switch (fileType) {
@@ -83,7 +81,6 @@ const FileViewer = ({
83
81
 
84
82
  case 'video':
85
83
  case 'audio': {
86
- if (!mediaService?.VideoComponent) return null;
87
84
  return (
88
85
  <mediaService.VideoComponent
89
86
  source={{ uri: fileMessage.url }}
@@ -11,32 +11,37 @@ const iconMapper = { audio: 'file-audio', image: 'photo', video: 'play', file: '
11
11
  type Props = FileMessageProps & {
12
12
  type: 'image' | 'audio' | 'video' | 'file';
13
13
  };
14
- const BaseFileMessage = ({ message, variant, pressed, type }: Props) => {
14
+ const BaseFileMessage = ({ message, variant, pressed, type, children }: Props) => {
15
15
  const { STRINGS } = useLocalization();
16
16
  const { colors } = useUIKitTheme();
17
17
  const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
18
18
  return (
19
- <View style={[styles.container, { backgroundColor: color.background }]}>
20
- <Icon
21
- icon={iconMapper[type]}
22
- size={24}
23
- containerStyle={{ backgroundColor: colors.background, padding: 2, borderRadius: 8, marginRight: 8 }}
24
- />
25
- <Text body3 ellipsizeMode={'middle'} numberOfLines={1} color={color.textMsg} style={styles.name}>
26
- {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_FILE_TITLE(message)}
27
- </Text>
19
+ <View style={[styles.bubbleContainer, { backgroundColor: color.background }]}>
20
+ <View style={styles.container}>
21
+ <Icon
22
+ icon={iconMapper[type]}
23
+ size={24}
24
+ containerStyle={{ backgroundColor: colors.background, padding: 2, borderRadius: 8, marginRight: 8 }}
25
+ />
26
+ <Text body3 ellipsizeMode={'middle'} numberOfLines={1} color={color.textMsg} style={styles.name}>
27
+ {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_FILE_TITLE(message)}
28
+ </Text>
29
+ </View>
30
+ {children}
28
31
  </View>
29
32
  );
30
33
  };
31
34
 
32
35
  const styles = createStyleSheet({
36
+ bubbleContainer: {
37
+ borderRadius: 16,
38
+ overflow: 'hidden',
39
+ },
33
40
  container: {
34
41
  flexDirection: 'row',
35
42
  alignItems: 'center',
36
- justifyContent: 'center',
37
43
  paddingHorizontal: 12,
38
44
  paddingVertical: 6,
39
- borderRadius: 16,
40
45
  },
41
46
  name: {
42
47
  flexShrink: 1,
@@ -34,7 +34,7 @@ const useRetry = (hasError: boolean, retryCount = 5) => {
34
34
  return retryCountRef.current;
35
35
  };
36
36
 
37
- const ImageFileMessage = ({ message }: FileMessageProps) => {
37
+ const ImageFileMessage = ({ message, children, variant }: FileMessageProps) => {
38
38
  const { colors } = useUIKitTheme();
39
39
  const [imageNotFound, setImageNotFound] = useState(false);
40
40
 
@@ -44,29 +44,41 @@ const ImageFileMessage = ({ message }: FileMessageProps) => {
44
44
  const key = useRetry(imageNotFound);
45
45
 
46
46
  return (
47
- <View style={style}>
48
- <Image
49
- key={key}
50
- source={{ uri: fileUrl }}
51
- style={[StyleSheet.absoluteFill, imageNotFound && styles.hide]}
52
- resizeMode={'cover'}
53
- resizeMethod={'resize'}
54
- onError={() => setImageNotFound(true)}
55
- onLoad={() => setImageNotFound(false)}
56
- />
57
- {imageNotFound && (
58
- <Icon
59
- containerStyle={StyleSheet.absoluteFill}
60
- icon={'thumbnail-none'}
61
- size={48}
62
- color={colors.onBackground02}
47
+ <View
48
+ style={[
49
+ styles.bubbleContainer,
50
+ { backgroundColor: imageNotFound ? colors.onBackground04 : colors.ui.message[variant].enabled.background },
51
+ ]}
52
+ >
53
+ <View style={style}>
54
+ <Image
55
+ key={key}
56
+ source={{ uri: fileUrl }}
57
+ style={[StyleSheet.absoluteFill, imageNotFound && styles.hide]}
58
+ resizeMode={'cover'}
59
+ resizeMethod={'resize'}
60
+ onError={() => setImageNotFound(true)}
61
+ onLoad={() => setImageNotFound(false)}
63
62
  />
64
- )}
63
+ {imageNotFound && (
64
+ <Icon
65
+ containerStyle={StyleSheet.absoluteFill}
66
+ icon={'thumbnail-none'}
67
+ size={48}
68
+ color={colors.onBackground02}
69
+ />
70
+ )}
71
+ </View>
72
+ {children}
65
73
  </View>
66
74
  );
67
75
  };
68
76
 
69
77
  const styles = createStyleSheet({
78
+ bubbleContainer: {
79
+ borderRadius: 16,
80
+ overflow: 'hidden',
81
+ },
70
82
  image: {
71
83
  width: 240,
72
84
  maxWidth: 240,
@@ -15,7 +15,7 @@ const useRetry = (videoFileUrl: string, retryCount = 5) => {
15
15
  const { mediaService } = usePlatformService();
16
16
 
17
17
  const fetchThumbnail = () => {
18
- return mediaService?.getVideoThumbnail({ url: videoFileUrl, timeMills: 1000 }).then((result) => {
18
+ return mediaService.getVideoThumbnail({ url: videoFileUrl, timeMills: 1000 }).then((result) => {
19
19
  setState({ loading: false, thumbnail: result?.path ?? null });
20
20
  });
21
21
  };
@@ -41,26 +41,33 @@ const useRetry = (videoFileUrl: string, retryCount = 5) => {
41
41
  return state;
42
42
  };
43
43
 
44
- const VideoFileMessage = ({ message }: FileMessageProps) => {
44
+ const VideoFileMessage = ({ message, variant, children }: FileMessageProps) => {
45
45
  const { colors } = useUIKitTheme();
46
46
 
47
47
  const fileUrl = getAvailableUriFromFileMessage(message);
48
- const style = [styles.image, { backgroundColor: colors.onBackground04 }];
48
+ const style = [styles.video, { backgroundColor: colors.onBackground04 }];
49
49
 
50
50
  const { loading, thumbnail } = useRetry(fileUrl);
51
51
 
52
52
  if (loading) {
53
53
  return (
54
- <View style={[style, styles.container]}>
55
- <PlayIcon />
54
+ <View style={[styles.bubbleContainer, { backgroundColor: colors.ui.message[variant].enabled.background }]}>
55
+ <View style={[styles.bubbleContainer, styles.bubbleInnerContainer]}>
56
+ <View style={style} />
57
+ <PlayIcon />
58
+ </View>
59
+ {children}
56
60
  </View>
57
61
  );
58
62
  }
59
63
 
60
64
  return (
61
- <View style={styles.container}>
62
- <Image source={{ uri: thumbnail || fileUrl }} style={style} resizeMode={'cover'} resizeMethod={'resize'} />
63
- <PlayIcon />
65
+ <View style={[styles.bubbleContainer, { backgroundColor: colors.ui.message[variant].enabled.background }]}>
66
+ <View style={[styles.bubbleContainer, styles.bubbleInnerContainer]}>
67
+ <Image source={{ uri: thumbnail || fileUrl }} style={style} resizeMode={'cover'} resizeMethod={'resize'} />
68
+ <PlayIcon />
69
+ </View>
70
+ {children}
64
71
  </View>
65
72
  );
66
73
  };
@@ -79,15 +86,18 @@ const PlayIcon = () => {
79
86
  };
80
87
 
81
88
  const styles = createStyleSheet({
82
- container: {
89
+ bubbleContainer: {
90
+ borderRadius: 16,
91
+ overflow: 'hidden',
92
+ },
93
+ bubbleInnerContainer: {
83
94
  alignItems: 'center',
84
95
  justifyContent: 'center',
85
96
  },
86
- image: {
97
+ video: {
87
98
  width: 240,
88
99
  maxWidth: 240,
89
100
  height: 160,
90
- borderRadius: 16,
91
101
  },
92
102
  playIcon: {
93
103
  position: 'absolute',
@@ -2,7 +2,6 @@ import React from 'react';
2
2
 
3
3
  import { SendbirdFileMessage, getFileExtension, getFileType } from '@sendbird/uikit-utils';
4
4
 
5
- import { usePlatformService } from '../../../hooks/useContext';
6
5
  import type { MessageRendererInterface } from '../index';
7
6
  import BaseFileMessage from './BaseFileMessage';
8
7
  import ImageFileMessage from './ImageFileMessage';
@@ -10,12 +9,10 @@ import VideoFileMessage from './VideoFileMessage';
10
9
 
11
10
  export type FileMessageProps = MessageRendererInterface<SendbirdFileMessage>;
12
11
  const FileMessage = (props: FileMessageProps) => {
13
- const { mediaService } = usePlatformService();
14
-
15
12
  const fileType = getFileType(props.message.type || getFileExtension(props.message.name));
16
13
 
17
14
  if (fileType === 'image') return <ImageFileMessage {...props} />;
18
- if (fileType === 'video' && mediaService?.getVideoThumbnail) return <VideoFileMessage {...props} />;
15
+ if (fileType === 'video') return <VideoFileMessage {...props} />;
19
16
 
20
17
  return <BaseFileMessage {...props} type={fileType} />;
21
18
  };
@@ -1,33 +1,101 @@
1
1
  import React from 'react';
2
2
  import { View } from 'react-native';
3
3
 
4
- import { Text, URLParsedText, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
4
+ import { RegexText, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
5
+ import { urlRegexStrict } from '@sendbird/uikit-utils';
5
6
 
6
- import { useLocalization } from '../../../hooks/useContext';
7
+ import { useLocalization, useSendbirdChat, useUserProfile } from '../../../hooks/useContext';
8
+ import SBUUtils from '../../../libs/SBUUtils';
7
9
  import type { UserMessageProps } from './index';
8
10
 
9
- const BaseUserMessage = ({ message, variant, pressed }: UserMessageProps) => {
10
- const { colors } = useUIKitTheme();
11
- const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
11
+ const BaseUserMessage = ({
12
+ message,
13
+ variant,
14
+ pressed,
15
+ children,
16
+ onLongPressMentionedUser,
17
+ onLongPressURL,
18
+ }: UserMessageProps) => {
19
+ const { mentionManager, currentUser } = useSendbirdChat();
20
+ const { show } = useUserProfile();
12
21
  const { STRINGS } = useLocalization();
22
+ const { colors, palette } = useUIKitTheme();
23
+
24
+ const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
25
+
13
26
  return (
14
27
  <View style={[styles.container, { backgroundColor: color.background }]}>
15
- <URLParsedText body3 strict color={color.textMsg}>
16
- {message.message}
17
- {Boolean(message.updatedAt) && (
18
- <Text body3 color={color.textEdited}>
19
- {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_EDITED_POSTFIX}
20
- </Text>
21
- )}
22
- </URLParsedText>
28
+ <View style={styles.wrapper}>
29
+ <Text body3 color={color.textMsg}>
30
+ <RegexText
31
+ body3
32
+ color={color.textMsg}
33
+ patterns={[
34
+ {
35
+ regex: mentionManager.templateRegex,
36
+ replacer({ match, groups, parentProps, index, keyPrefix }) {
37
+ const user = message.mentionedUsers?.find((it) => it.userId === groups[2]);
38
+ if (user) {
39
+ return (
40
+ <Text
41
+ {...parentProps}
42
+ key={`${keyPrefix}-${index}`}
43
+ onPress={() => show(user)}
44
+ onLongPress={onLongPressMentionedUser}
45
+ style={[
46
+ parentProps?.style,
47
+ { fontWeight: 'bold' },
48
+ user.userId === currentUser?.userId && { backgroundColor: palette.highlight },
49
+ ]}
50
+ >
51
+ {`${mentionManager.asMentionedMessageText(user)}`}
52
+ </Text>
53
+ );
54
+ }
55
+ return match;
56
+ },
57
+ },
58
+ {
59
+ regex: urlRegexStrict,
60
+ replacer({ match, parentProps, index, keyPrefix }) {
61
+ return (
62
+ <Text
63
+ {...parentProps}
64
+ key={`${keyPrefix}-${index}`}
65
+ onPress={() => SBUUtils.openURL(match)}
66
+ onLongPress={onLongPressURL}
67
+ style={[parentProps?.style, { textDecorationLine: 'underline' }]}
68
+ >
69
+ {match}
70
+ </Text>
71
+ );
72
+ },
73
+ },
74
+ ]}
75
+ >
76
+ {mentionManager.shouldUseMentionedMessageTemplate(message)
77
+ ? message.mentionedMessageTemplate
78
+ : message.message}
79
+ </RegexText>
80
+ {Boolean(message.updatedAt) && (
81
+ <Text body3 color={color.textEdited}>
82
+ {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_EDITED_POSTFIX}
83
+ </Text>
84
+ )}
85
+ </Text>
86
+ </View>
87
+ {children}
23
88
  </View>
24
89
  );
25
90
  };
26
91
  const styles = createStyleSheet({
27
92
  container: {
93
+ borderRadius: 16,
94
+ overflow: 'hidden',
95
+ },
96
+ wrapper: {
28
97
  paddingHorizontal: 12,
29
98
  paddingVertical: 6,
30
- borderRadius: 16,
31
99
  },
32
100
  });
33
101