@sendbird/uikit-react-native 2.1.0 → 2.2.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 (388) hide show
  1. package/lib/commonjs/components/ChatFlatList.js +2 -1
  2. package/lib/commonjs/components/ChatFlatList.js.map +1 -1
  3. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  4. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  5. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  6. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  7. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
  8. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  9. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -10
  10. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  11. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +99 -14
  12. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  13. package/lib/commonjs/components/MessageRenderer/UserMessage/index.js.map +1 -1
  14. package/lib/commonjs/components/MessageRenderer/index.js +22 -3
  15. package/lib/commonjs/components/MessageRenderer/index.js.map +1 -1
  16. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +150 -0
  17. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  18. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js +135 -0
  19. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  20. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js +87 -0
  21. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  22. package/lib/commonjs/components/ReactionAddons/index.js +19 -0
  23. package/lib/commonjs/components/ReactionAddons/index.js.map +1 -0
  24. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js +150 -0
  25. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  26. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +276 -0
  27. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  28. package/lib/commonjs/components/ReactionBottomSheets/index.js +19 -0
  29. package/lib/commonjs/components/ReactionBottomSheets/index.js.map +1 -0
  30. package/lib/commonjs/constants.js +3 -1
  31. package/lib/commonjs/constants.js.map +1 -1
  32. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +4 -1
  33. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  34. package/lib/commonjs/containers/SendbirdUIKitContainer.js +118 -78
  35. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  36. package/lib/commonjs/contexts/ReactionCtx.js +107 -0
  37. package/lib/commonjs/contexts/ReactionCtx.js.map +1 -0
  38. package/lib/commonjs/contexts/SendbirdChatCtx.js +18 -6
  39. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -1
  40. package/lib/commonjs/contexts/UserProfileCtx.js +9 -0
  41. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -1
  42. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +33 -37
  43. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  44. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +28 -11
  45. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  46. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +120 -31
  47. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  48. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +31 -12
  49. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  50. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +210 -0
  51. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  52. package/lib/commonjs/domain/groupChannel/index.js +8 -0
  53. package/lib/commonjs/domain/groupChannel/index.js.map +1 -1
  54. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +4 -0
  55. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  56. package/lib/commonjs/domain/groupChannel/module/moduleContext.js +4 -4
  57. package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
  58. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  59. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +3 -2
  60. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  61. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +2 -1
  62. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  63. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +2 -1
  64. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  65. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +39 -0
  66. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  67. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +140 -0
  68. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  69. package/lib/commonjs/domain/groupChannelNotifications/index.js +46 -0
  70. package/lib/commonjs/domain/groupChannelNotifications/index.js.map +1 -0
  71. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +33 -0
  72. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  73. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js +45 -0
  74. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  75. package/lib/commonjs/domain/groupChannelNotifications/types.js +6 -0
  76. package/lib/commonjs/domain/groupChannelNotifications/types.js.map +1 -0
  77. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +2 -1
  78. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  79. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +49 -6
  80. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  81. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +9 -14
  82. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  83. package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
  84. package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
  85. package/lib/commonjs/domain/userList/component/UserListList.js +4 -1
  86. package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -1
  87. package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -1
  88. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  89. package/lib/commonjs/fragments/createGroupChannelFragment.js +11 -4
  90. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  91. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
  92. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js +34 -0
  93. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  94. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +3 -1
  95. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  96. package/lib/commonjs/hooks/useConnection.js +3 -0
  97. package/lib/commonjs/hooks/useConnection.js.map +1 -1
  98. package/lib/commonjs/hooks/useContext.js +11 -1
  99. package/lib/commonjs/hooks/useContext.js.map +1 -1
  100. package/lib/commonjs/hooks/useKeyboardStatus.js +93 -0
  101. package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -0
  102. package/lib/commonjs/hooks/useMentionSuggestion.js +110 -0
  103. package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -0
  104. package/lib/commonjs/hooks/useMentionTextInput.js +139 -0
  105. package/lib/commonjs/hooks/useMentionTextInput.js.map +1 -0
  106. package/lib/commonjs/index.js +95 -40
  107. package/lib/commonjs/index.js.map +1 -1
  108. package/lib/commonjs/libs/EmojiManager.js +100 -0
  109. package/lib/commonjs/libs/EmojiManager.js.map +1 -0
  110. package/lib/commonjs/libs/MentionConfig.js +47 -0
  111. package/lib/commonjs/libs/MentionConfig.js.map +1 -0
  112. package/lib/commonjs/libs/MentionManager.js +235 -0
  113. package/lib/commonjs/libs/MentionManager.js.map +1 -0
  114. package/lib/commonjs/localization/StringSet.type.js +17 -5
  115. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  116. package/lib/commonjs/types.js.map +1 -1
  117. package/lib/commonjs/utils/common.js +19 -0
  118. package/lib/commonjs/utils/common.js.map +1 -0
  119. package/lib/commonjs/version.js +1 -1
  120. package/lib/commonjs/version.js.map +1 -1
  121. package/lib/module/components/ChatFlatList.js +3 -2
  122. package/lib/module/components/ChatFlatList.js.map +1 -1
  123. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  124. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  125. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  126. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  127. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
  128. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  129. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -12
  130. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  131. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +101 -17
  132. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  133. package/lib/module/components/MessageRenderer/UserMessage/index.js.map +1 -1
  134. package/lib/module/components/MessageRenderer/index.js +21 -4
  135. package/lib/module/components/MessageRenderer/index.js.map +1 -1
  136. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +132 -0
  137. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  138. package/lib/module/components/ReactionAddons/MessageReactionAddon.js +118 -0
  139. package/lib/module/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  140. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js +74 -0
  141. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  142. package/lib/module/components/ReactionAddons/index.js +7 -0
  143. package/lib/module/components/ReactionAddons/index.js.map +1 -0
  144. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js +135 -0
  145. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  146. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +259 -0
  147. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  148. package/lib/module/components/ReactionBottomSheets/index.js +7 -0
  149. package/lib/module/components/ReactionBottomSheets/index.js.map +1 -0
  150. package/lib/module/constants.js +1 -0
  151. package/lib/module/constants.js.map +1 -1
  152. package/lib/module/containers/GroupChannelPreviewContainer.js +4 -1
  153. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  154. package/lib/module/containers/SendbirdUIKitContainer.js +116 -80
  155. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  156. package/lib/module/contexts/ReactionCtx.js +85 -0
  157. package/lib/module/contexts/ReactionCtx.js.map +1 -0
  158. package/lib/module/contexts/SendbirdChatCtx.js +18 -6
  159. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -1
  160. package/lib/module/contexts/UserProfileCtx.js +7 -0
  161. package/lib/module/contexts/UserProfileCtx.js.map +1 -1
  162. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +34 -39
  163. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  164. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +24 -13
  165. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  166. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +117 -33
  167. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  168. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +32 -14
  169. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  170. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +188 -0
  171. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  172. package/lib/module/domain/groupChannel/index.js +1 -0
  173. package/lib/module/domain/groupChannel/index.js.map +1 -1
  174. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +3 -0
  175. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  176. package/lib/module/domain/groupChannel/module/moduleContext.js +4 -4
  177. package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
  178. package/lib/module/domain/groupChannel/types.js.map +1 -1
  179. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +4 -3
  180. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  181. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +3 -2
  182. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  183. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +3 -2
  184. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  185. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +25 -0
  186. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  187. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +122 -0
  188. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  189. package/lib/module/domain/groupChannelNotifications/index.js +5 -0
  190. package/lib/module/domain/groupChannelNotifications/index.js.map +1 -0
  191. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +21 -0
  192. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  193. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js +25 -0
  194. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  195. package/lib/module/domain/groupChannelNotifications/types.js +2 -0
  196. package/lib/module/domain/groupChannelNotifications/types.js.map +1 -0
  197. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +3 -2
  198. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  199. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +46 -6
  200. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  201. package/lib/module/domain/groupChannelSettings/module/moduleContext.js +10 -15
  202. package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  203. package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
  204. package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
  205. package/lib/module/domain/userList/component/UserListList.js +3 -1
  206. package/lib/module/domain/userList/component/UserListList.js.map +1 -1
  207. package/lib/module/domain/userList/module/createUserListModule.js.map +1 -1
  208. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  209. package/lib/module/fragments/createGroupChannelFragment.js +11 -4
  210. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  211. package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
  212. package/lib/module/fragments/createGroupChannelNotificationsFragment.js +22 -0
  213. package/lib/module/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  214. package/lib/module/fragments/createGroupChannelSettingsFragment.js +3 -1
  215. package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  216. package/lib/module/hooks/useConnection.js +3 -0
  217. package/lib/module/hooks/useConnection.js.map +1 -1
  218. package/lib/module/hooks/useContext.js +6 -0
  219. package/lib/module/hooks/useContext.js.map +1 -1
  220. package/lib/module/hooks/useKeyboardStatus.js +75 -0
  221. package/lib/module/hooks/useKeyboardStatus.js.map +1 -0
  222. package/lib/module/hooks/useMentionSuggestion.js +100 -0
  223. package/lib/module/hooks/useMentionSuggestion.js.map +1 -0
  224. package/lib/module/hooks/useMentionTextInput.js +128 -0
  225. package/lib/module/hooks/useMentionTextInput.js.map +1 -0
  226. package/lib/module/index.js +8 -3
  227. package/lib/module/index.js.map +1 -1
  228. package/lib/module/libs/EmojiManager.js +90 -0
  229. package/lib/module/libs/EmojiManager.js.map +1 -0
  230. package/lib/module/libs/MentionConfig.js +39 -0
  231. package/lib/module/libs/MentionConfig.js.map +1 -0
  232. package/lib/module/libs/MentionManager.js +223 -0
  233. package/lib/module/libs/MentionManager.js.map +1 -0
  234. package/lib/module/localization/StringSet.type.js +18 -6
  235. package/lib/module/localization/StringSet.type.js.map +1 -1
  236. package/lib/module/types.js.map +1 -1
  237. package/lib/module/utils/common.js +7 -0
  238. package/lib/module/utils/common.js.map +1 -0
  239. package/lib/module/version.js +1 -1
  240. package/lib/module/version.js.map +1 -1
  241. package/lib/typescript/__template__/types.d.ts +3 -3
  242. package/lib/typescript/src/components/ChannelCover.d.ts +1 -1
  243. package/lib/typescript/src/components/ChatFlatList.d.ts +1 -1
  244. package/lib/typescript/src/components/FileViewer.d.ts +1 -1
  245. package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +1 -1
  246. package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +2 -2
  247. package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +1 -1
  248. package/lib/typescript/src/components/MessageRenderer/FileMessage/VideoFileMessage.d.ts +1 -1
  249. package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +11 -2
  250. package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +1 -1
  251. package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +1 -1
  252. package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +1 -1
  253. package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +1 -1
  254. package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +1 -1
  255. package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +1 -1
  256. package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +1 -1
  257. package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +2 -2
  258. package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +4 -1
  259. package/lib/typescript/src/components/MessageRenderer/index.d.ts +4 -3
  260. package/lib/typescript/src/components/NewMessagesButton.d.ts +1 -1
  261. package/lib/typescript/src/components/ReactionAddons/BottomSheetReactionAddon.d.ts +8 -0
  262. package/lib/typescript/src/components/ReactionAddons/MessageReactionAddon.d.ts +6 -0
  263. package/lib/typescript/src/components/ReactionAddons/ReactionRoundedButton.d.ts +14 -0
  264. package/lib/typescript/src/components/ReactionAddons/index.d.ts +11 -0
  265. package/lib/typescript/src/components/ReactionBottomSheets/ReactionListBottomSheet.d.ts +3 -0
  266. package/lib/typescript/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.d.ts +3 -0
  267. package/lib/typescript/src/components/ReactionBottomSheets/index.d.ts +20 -0
  268. package/lib/typescript/src/components/ScrollToBottomButton.d.ts +1 -1
  269. package/lib/typescript/src/components/StatusComposition.d.ts +1 -1
  270. package/lib/typescript/src/components/TypedPlaceholder.d.ts +1 -1
  271. package/lib/typescript/src/components/UserActionBar.d.ts +1 -1
  272. package/lib/typescript/src/components/UserSelectableBar.d.ts +1 -1
  273. package/lib/typescript/src/constants.d.ts +1 -0
  274. package/lib/typescript/src/containers/GroupChannelPreviewContainer.d.ts +1 -1
  275. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +12 -3
  276. package/lib/typescript/src/contexts/LocalizationCtx.d.ts +2 -2
  277. package/lib/typescript/src/contexts/PlatformServiceCtx.d.ts +1 -1
  278. package/lib/typescript/src/contexts/ReactionCtx.d.ts +18 -0
  279. package/lib/typescript/src/contexts/SendbirdChatCtx.d.ts +10 -2
  280. package/lib/typescript/src/contexts/UserProfileCtx.d.ts +4 -4
  281. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +35 -7
  282. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +32 -5
  283. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +19 -2
  284. package/lib/typescript/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.d.ts +3 -0
  285. package/lib/typescript/src/domain/groupChannel/index.d.ts +1 -0
  286. package/lib/typescript/src/domain/groupChannel/module/createGroupChannelModule.d.ts +1 -1
  287. package/lib/typescript/src/domain/groupChannel/types.d.ts +24 -7
  288. package/lib/typescript/src/domain/groupChannelBannedUsers/types.d.ts +3 -3
  289. package/lib/typescript/src/domain/groupChannelList/types.d.ts +2 -2
  290. package/lib/typescript/src/domain/groupChannelModeration/types.d.ts +3 -3
  291. package/lib/typescript/src/domain/groupChannelMutedMembers/types.d.ts +3 -3
  292. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.d.ts +3 -0
  293. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.d.ts +2 -0
  294. package/lib/typescript/src/domain/groupChannelNotifications/index.d.ts +4 -0
  295. package/lib/typescript/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.d.ts +3 -0
  296. package/lib/typescript/src/domain/groupChannelNotifications/module/moduleContext.d.ts +3 -0
  297. package/lib/typescript/src/domain/groupChannelNotifications/types.d.ts +33 -0
  298. package/lib/typescript/src/domain/groupChannelOperators/types.d.ts +3 -3
  299. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -1
  300. package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +3 -1
  301. package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +6 -6
  302. package/lib/typescript/src/domain/userList/component/UserListList.d.ts +2 -1
  303. package/lib/typescript/src/domain/userList/module/createUserListModule.d.ts +2 -1
  304. package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +1 -1
  305. package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +1 -1
  306. package/lib/typescript/src/fragments/createGroupChannelNotificationsFragment.d.ts +3 -0
  307. package/lib/typescript/src/hooks/useConnection.d.ts +1 -1
  308. package/lib/typescript/src/hooks/useContext.d.ts +4 -0
  309. package/lib/typescript/src/hooks/useKeyboardStatus.d.ts +6 -0
  310. package/lib/typescript/src/hooks/useMentionSuggestion.d.ts +17 -0
  311. package/lib/typescript/src/hooks/useMentionTextInput.d.ts +18 -0
  312. package/lib/typescript/src/index.d.ts +7 -2
  313. package/lib/typescript/src/libs/EmojiManager.d.ts +16 -0
  314. package/lib/typescript/src/libs/MentionConfig.d.ts +24 -0
  315. package/lib/typescript/src/libs/MentionManager.d.ts +61 -0
  316. package/lib/typescript/src/localization/StringSet.type.d.ts +16 -2
  317. package/lib/typescript/src/platform/createMediaService.expo.d.ts +1 -1
  318. package/lib/typescript/src/platform/createMediaService.native.d.ts +1 -1
  319. package/lib/typescript/src/platform/dynamicModule.d.ts +1 -1
  320. package/lib/typescript/src/platform/types.d.ts +5 -5
  321. package/lib/typescript/src/types.d.ts +13 -4
  322. package/lib/typescript/src/utils/common.d.ts +1 -0
  323. package/lib/typescript/src/version.d.ts +1 -1
  324. package/package.json +6 -6
  325. package/src/components/ChatFlatList.tsx +2 -1
  326. package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +17 -12
  327. package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +25 -18
  328. package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +20 -10
  329. package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +82 -14
  330. package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +135 -61
  331. package/src/components/MessageRenderer/UserMessage/index.tsx +8 -1
  332. package/src/components/MessageRenderer/index.tsx +39 -7
  333. package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +106 -0
  334. package/src/components/ReactionAddons/MessageReactionAddon.tsx +123 -0
  335. package/src/components/ReactionAddons/ReactionRoundedButton.tsx +71 -0
  336. package/src/components/ReactionAddons/index.tsx +7 -0
  337. package/src/components/ReactionBottomSheets/ReactionListBottomSheet.tsx +113 -0
  338. package/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.tsx +249 -0
  339. package/src/components/ReactionBottomSheets/index.tsx +24 -0
  340. package/src/constants.ts +2 -0
  341. package/src/containers/GroupChannelPreviewContainer.tsx +3 -1
  342. package/src/containers/SendbirdUIKitContainer.tsx +141 -83
  343. package/src/contexts/ReactionCtx.tsx +102 -0
  344. package/src/contexts/SendbirdChatCtx.tsx +24 -2
  345. package/src/contexts/UserProfileCtx.tsx +9 -0
  346. package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +56 -30
  347. package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +48 -19
  348. package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +137 -43
  349. package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +27 -10
  350. package/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.tsx +173 -0
  351. package/src/domain/groupChannel/index.ts +1 -0
  352. package/src/domain/groupChannel/module/createGroupChannelModule.tsx +12 -1
  353. package/src/domain/groupChannel/module/moduleContext.tsx +4 -4
  354. package/src/domain/groupChannel/types.ts +28 -5
  355. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +3 -2
  356. package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -1
  357. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +2 -1
  358. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.tsx +14 -0
  359. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.tsx +128 -0
  360. package/src/domain/groupChannelNotifications/index.ts +4 -0
  361. package/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.tsx +15 -0
  362. package/src/domain/groupChannelNotifications/module/moduleContext.tsx +31 -0
  363. package/src/domain/groupChannelNotifications/types.ts +38 -0
  364. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +2 -1
  365. package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +42 -3
  366. package/src/domain/groupChannelSettings/module/moduleContext.tsx +9 -12
  367. package/src/domain/groupChannelSettings/types.ts +2 -0
  368. package/src/domain/groupChannelUserList/types.ts +7 -2
  369. package/src/domain/userList/component/UserListList.tsx +5 -1
  370. package/src/domain/userList/module/createUserListModule.tsx +3 -1
  371. package/src/fragments/createGroupChannelCreateFragment.tsx +8 -2
  372. package/src/fragments/createGroupChannelFragment.tsx +19 -6
  373. package/src/fragments/createGroupChannelInviteFragment.tsx +2 -2
  374. package/src/fragments/createGroupChannelNotificationsFragment.tsx +27 -0
  375. package/src/fragments/createGroupChannelSettingsFragment.tsx +2 -0
  376. package/src/hooks/useConnection.ts +3 -1
  377. package/src/hooks/useContext.ts +7 -0
  378. package/src/hooks/useKeyboardStatus.ts +54 -0
  379. package/src/hooks/useMentionSuggestion.ts +106 -0
  380. package/src/hooks/useMentionTextInput.ts +139 -0
  381. package/src/index.ts +13 -2
  382. package/src/libs/EmojiManager.ts +80 -0
  383. package/src/libs/MentionConfig.ts +40 -0
  384. package/src/libs/MentionManager.tsx +240 -0
  385. package/src/localization/StringSet.type.ts +38 -8
  386. package/src/types.ts +12 -0
  387. package/src/utils/common.ts +8 -0
  388. package/src/version.ts +1 -1
@@ -1,7 +1,7 @@
1
1
  import type * as CreateThumbnail from 'react-native-create-thumbnail';
2
2
  import type Video from 'react-native-video';
3
3
  import type { MediaServiceInterface } from './types';
4
- declare type Modules = {
4
+ type Modules = {
5
5
  VideoComponent: typeof Video;
6
6
  thumbnailModule: typeof CreateThumbnail;
7
7
  };
@@ -6,7 +6,7 @@ export interface DynamicModules {
6
6
  'react-native-fast-image': typeof RNFastImage;
7
7
  '@react-native-community/netinfo': typeof RNNetInfo;
8
8
  }
9
- export declare type SBUNativeModule = keyof DynamicModules;
9
+ export type SBUNativeModule = keyof DynamicModules;
10
10
  interface SBUDynamicModuleInfo {
11
11
  packageName: SBUNativeModule;
12
12
  minVersion: string;
@@ -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;
@@ -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
+ };
@@ -0,0 +1 @@
1
+ export declare const openUrl: (url: string) => void;
@@ -1,2 +1,2 @@
1
- declare const VERSION = "2.1.0";
1
+ declare const VERSION = "2.2.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.2.0",
4
4
  "description": "react-native-uikit",
5
5
  "main": "lib/commonjs/index",
6
6
  "module": "lib/module/index",
@@ -41,9 +41,9 @@
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.2.0",
45
+ "@sendbird/uikit-react-native-foundation": "2.2.0",
46
+ "@sendbird/uikit-utils": "2.2.0"
47
47
  },
48
48
  "devDependencies": {
49
49
  "@react-native-camera-roll/camera-roll": "^5.0.4",
@@ -76,7 +76,7 @@
76
76
  "react-native-permissions": "^3.6.0",
77
77
  "react-native-safe-area-context": "^3.3.2",
78
78
  "react-native-video": "^5.2.0",
79
- "typescript": "^4.1.3"
79
+ "typescript": "4.9.4"
80
80
  },
81
81
  "peerDependencies": {
82
82
  "@react-native-camera-roll/camera-roll": ">=5.0.0",
@@ -171,5 +171,5 @@
171
171
  "readmeFile": "./README.md",
172
172
  "displayName": "@sendbird/uikit-react-native"
173
173
  },
174
- "gitHead": "c778a84a632487047fe532db188b32dfa6e93a7f"
174
+ "gitHead": "bd7ab217a07e91ba644c0cb69694a92b123326bf"
175
175
  }
@@ -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
  });
@@ -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,36 @@ 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 style={[styles.bubbleContainer, { backgroundColor: colors.ui.message[variant].enabled.background }]}>
48
+ <View style={style}>
49
+ <Image
50
+ key={key}
51
+ source={{ uri: fileUrl }}
52
+ style={[StyleSheet.absoluteFill, imageNotFound && styles.hide]}
53
+ resizeMode={'cover'}
54
+ resizeMethod={'resize'}
55
+ onError={() => setImageNotFound(true)}
56
+ onLoad={() => setImageNotFound(false)}
63
57
  />
64
- )}
58
+ {imageNotFound && (
59
+ <Icon
60
+ containerStyle={StyleSheet.absoluteFill}
61
+ icon={'thumbnail-none'}
62
+ size={48}
63
+ color={colors.onBackground02}
64
+ />
65
+ )}
66
+ </View>
67
+ {children}
65
68
  </View>
66
69
  );
67
70
  };
68
71
 
69
72
  const styles = createStyleSheet({
73
+ bubbleContainer: {
74
+ borderRadius: 16,
75
+ overflow: 'hidden',
76
+ },
70
77
  image: {
71
78
  width: 240,
72
79
  maxWidth: 240,
@@ -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',
@@ -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 { openUrl } from '../../../utils/common';
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={() => 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
 
@@ -2,88 +2,156 @@ import React, { useState } from 'react';
2
2
  import { Linking, TouchableOpacity, View } from 'react-native';
3
3
 
4
4
  import type { OGMetaData } from '@sendbird/chat/message';
5
- import {
6
- Icon,
7
- Image,
8
- Text,
9
- URLParsedText,
10
- createStyleSheet,
11
- useUIKitTheme,
12
- } from '@sendbird/uikit-react-native-foundation';
13
- import { conditionChaining } from '@sendbird/uikit-utils';
5
+ import { Icon, Image, RegexText, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
6
+ import { conditionChaining, urlRegexRough } from '@sendbird/uikit-utils';
14
7
 
15
- import { useLocalization } from '../../../hooks/useContext';
8
+ import { useLocalization, useSendbirdChat, useUserProfile } from '../../../hooks/useContext';
9
+ import { openUrl } from '../../../utils/common';
16
10
  import type { UserMessageProps } from './index';
17
11
 
18
12
  type Props = UserMessageProps & {
19
13
  ogMetaData: OGMetaData;
20
14
  };
21
- const OpenGraphUserMessage = ({ message, variant, pressed, ogMetaData }: Props) => {
15
+
16
+ const OpenGraphUserMessage = ({
17
+ message,
18
+ variant,
19
+ pressed,
20
+ ogMetaData,
21
+ children,
22
+ onLongPressMentionedUser,
23
+ onLongPressURL,
24
+ }: Props) => {
25
+ const { mentionManager, currentUser } = useSendbirdChat();
22
26
  const { STRINGS } = useLocalization();
27
+ const { show } = useUserProfile();
23
28
  const { colors, select, palette } = useUIKitTheme();
24
- const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
29
+
25
30
  const [imageNotFound, setImageNotFound] = useState(false);
31
+ const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
32
+
33
+ const containerBackground = select({ dark: palette.background400, light: palette.background100 });
34
+
26
35
  return (
27
- <View style={[styles.container, { backgroundColor: color.background }]}>
28
- <View style={styles.messageContainer}>
29
- <URLParsedText body3 color={color.textMsg}>
30
- {message.message}
31
- {Boolean(message.updatedAt) && (
32
- <Text body3 color={color.textEdited}>
33
- {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_EDITED_POSTFIX}
34
- </Text>
35
- )}
36
- </URLParsedText>
37
- </View>
38
- <TouchableOpacity activeOpacity={0.7} onPress={() => Linking.openURL(ogMetaData.url).catch()}>
39
- <View
40
- style={[
41
- styles.ogImageContainer,
42
- { backgroundColor: select({ dark: palette.background500, light: palette.background200 }) },
43
- ]}
44
- >
45
- {conditionChaining(
46
- [imageNotFound],
47
- [
48
- <Icon containerStyle={styles.ogImage} icon={'thumbnail-none'} size={48} color={colors.onBackground02} />,
49
- <Image
50
- source={{ uri: ogMetaData.defaultImage?.url }}
51
- style={styles.ogImage}
52
- resizeMode={'cover'}
53
- onError={() => setImageNotFound(true)}
54
- />,
55
- ],
56
- )}
36
+ <View style={[styles.bubbleContainer, { backgroundColor: containerBackground }]}>
37
+ <View style={[styles.container, styles.bubbleContainer, { backgroundColor: color.background }]}>
38
+ <View style={styles.messageContainer}>
39
+ <Text body3 color={color.textMsg}>
40
+ <RegexText
41
+ body3
42
+ color={color.textMsg}
43
+ patterns={[
44
+ {
45
+ regex: mentionManager.templateRegex,
46
+ replacer({ match, groups, parentProps, keyPrefix, index }) {
47
+ const user = message.mentionedUsers?.find((it) => it.userId === groups[2]);
48
+ if (user) {
49
+ const isCurrentUser = user.userId === currentUser?.userId;
50
+ return (
51
+ <Text
52
+ {...parentProps}
53
+ key={`${keyPrefix}-${index}`}
54
+ onPress={() => show(user)}
55
+ onLongPress={onLongPressMentionedUser}
56
+ style={[
57
+ parentProps?.style,
58
+ styles.mentionedText,
59
+ isCurrentUser && { backgroundColor: palette.highlight },
60
+ ]}
61
+ >
62
+ {`${mentionManager.asMentionedMessageText(user)}`}
63
+ </Text>
64
+ );
65
+ }
66
+ return match;
67
+ },
68
+ },
69
+ {
70
+ regex: urlRegexRough,
71
+ replacer({ match, parentProps, keyPrefix, index }) {
72
+ return (
73
+ <Text
74
+ {...parentProps}
75
+ key={`${keyPrefix}-${index}`}
76
+ onPress={() => openUrl(match)}
77
+ onLongPress={onLongPressURL}
78
+ style={[parentProps?.style, styles.urlText]}
79
+ >
80
+ {match}
81
+ </Text>
82
+ );
83
+ },
84
+ },
85
+ ]}
86
+ >
87
+ {mentionManager.shouldUseMentionedMessageTemplate(message)
88
+ ? message.mentionedMessageTemplate
89
+ : message.message}
90
+ </RegexText>
91
+ {Boolean(message.updatedAt) && (
92
+ <Text body3 color={color.textEdited}>
93
+ {STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_EDITED_POSTFIX}
94
+ </Text>
95
+ )}
96
+ </Text>
57
97
  </View>
58
- <View
59
- style={[
60
- styles.ogContainer,
61
- { backgroundColor: select({ dark: palette.background400, light: palette.background100 }) },
62
- ]}
98
+ <TouchableOpacity
99
+ style={{ backgroundColor: select({ dark: palette.background500, light: palette.background200 }) }}
100
+ activeOpacity={0.85}
101
+ onPress={() => Linking.openURL(ogMetaData.url).catch()}
63
102
  >
64
- <Text numberOfLines={3} body2 color={colors.onBackground01} style={styles.ogTitle}>
65
- {ogMetaData.title}
66
- </Text>
67
- {Boolean(ogMetaData.description) && (
68
- <Text numberOfLines={1} caption2 color={colors.onBackground01} style={styles.ogDesc}>
69
- {ogMetaData.description}
103
+ <View
104
+ style={[
105
+ styles.ogImageContainer,
106
+ { backgroundColor: select({ dark: palette.background500, light: palette.background200 }) },
107
+ ]}
108
+ >
109
+ {conditionChaining(
110
+ [imageNotFound],
111
+ [
112
+ <Icon
113
+ containerStyle={styles.ogImage}
114
+ icon={'thumbnail-none'}
115
+ size={48}
116
+ color={colors.onBackground02}
117
+ />,
118
+ <Image
119
+ source={{ uri: ogMetaData.defaultImage?.url }}
120
+ style={styles.ogImage}
121
+ resizeMode={'cover'}
122
+ onError={() => setImageNotFound(true)}
123
+ />,
124
+ ],
125
+ )}
126
+ </View>
127
+ <View style={[styles.ogContainer, { backgroundColor: containerBackground }]}>
128
+ <Text numberOfLines={3} body2 color={colors.onBackground01} style={styles.ogTitle}>
129
+ {ogMetaData.title}
70
130
  </Text>
71
- )}
72
- <Text numberOfLines={1} caption2 color={colors.onBackground02}>
73
- {ogMetaData.url}
74
- </Text>
75
- </View>
76
- </TouchableOpacity>
131
+ {Boolean(ogMetaData.description) && (
132
+ <Text numberOfLines={1} caption2 color={colors.onBackground01} style={styles.ogDesc}>
133
+ {ogMetaData.description}
134
+ </Text>
135
+ )}
136
+ <Text numberOfLines={1} caption2 color={colors.onBackground02}>
137
+ {ogMetaData.url}
138
+ </Text>
139
+ </View>
140
+ </TouchableOpacity>
141
+ </View>
142
+ {children}
77
143
  </View>
78
144
  );
79
145
  };
80
146
 
81
147
  const styles = createStyleSheet({
148
+ bubbleContainer: {
149
+ borderRadius: 16,
150
+ overflow: 'hidden',
151
+ },
82
152
  container: {
83
153
  width: 240,
84
154
  maxWidth: 240,
85
- borderRadius: 16,
86
- overflow: 'hidden',
87
155
  },
88
156
  messageContainer: {
89
157
  paddingVertical: 6,
@@ -109,6 +177,12 @@ const styles = createStyleSheet({
109
177
  lineHeight: 14,
110
178
  marginBottom: 8,
111
179
  },
180
+ mentionedText: {
181
+ fontWeight: 'bold',
182
+ },
183
+ urlText: {
184
+ textDecorationLine: 'underline',
185
+ },
112
186
  });
113
187
 
114
188
  export default OpenGraphUserMessage;