@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
@@ -0,0 +1,38 @@
1
+ import type React from 'react';
2
+
3
+ import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
4
+
5
+ import type { CommonComponent } from '../../types';
6
+
7
+ export type GroupChannelNotificationsProps = {
8
+ Fragment: {
9
+ channel: SendbirdGroupChannel;
10
+ onPressHeaderLeft: GroupChannelNotificationsProps['Header']['onPressHeaderLeft'];
11
+ };
12
+ Header: {
13
+ onPressHeaderLeft: () => void;
14
+ };
15
+ View: {};
16
+ Provider: {
17
+ channel: SendbirdGroupChannel;
18
+ };
19
+ };
20
+
21
+ /**
22
+ * Internal context for GroupChannelNotifications
23
+ * For example, the developer can create a custom header
24
+ * with getting data from the domain context
25
+ * */
26
+ export type GroupChannelNotificationsContextsType = {
27
+ Fragment: React.Context<{
28
+ channel: SendbirdGroupChannel;
29
+ headerTitle: string;
30
+ }>;
31
+ };
32
+ export interface GroupChannelNotificationsModule {
33
+ Provider: CommonComponent<GroupChannelNotificationsProps['Provider']>;
34
+ Header: CommonComponent<GroupChannelNotificationsProps['Header']>;
35
+ View: CommonComponent<GroupChannelNotificationsProps['View']>;
36
+ }
37
+
38
+ export type GroupChannelNotificationsFragment = CommonComponent<GroupChannelNotificationsProps['Fragment']>;
@@ -3,7 +3,7 @@ import { FlatList, ListRenderItem } from 'react-native';
3
3
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
4
 
5
5
  import type { SendbirdUser } from '@sendbird/uikit-utils';
6
- import { useFreshCallback } from '@sendbird/uikit-utils';
6
+ import { getUserUniqId, useFreshCallback } from '@sendbird/uikit-utils';
7
7
 
8
8
  import type { GroupChannelOperatorsProps } from '../types';
9
9
 
@@ -22,6 +22,7 @@ const GroupChannelOperatorsList = ({
22
22
  contentContainerStyle={{ paddingLeft: left, paddingRight: right, flexGrow: 1 }}
23
23
  ListEmptyComponent={ListEmptyComponent}
24
24
  bounces={false}
25
+ keyExtractor={getUserUniqId}
25
26
  />
26
27
  );
27
28
  };
@@ -4,22 +4,31 @@ import { View } from 'react-native';
4
4
  import { PushTriggerOption } from '@sendbird/chat';
5
5
  import type { MenuBarProps } from '@sendbird/uikit-react-native-foundation';
6
6
  import { Icon, MenuBar, Switch, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
7
+ import { Logger, conditionChaining, useIIFE } from '@sendbird/uikit-utils';
7
8
 
8
9
  import { useLocalization, useSendbirdChat } from '../../../hooks/useContext';
9
10
  import { GroupChannelSettingsContexts } from '../module/moduleContext';
10
11
  import type { GroupChannelSettingsProps } from '../types';
11
12
 
13
+ let WARN_onPressMenuNotification = false;
14
+
12
15
  const GroupChannelSettingsMenu = ({
13
16
  onPressMenuModeration,
14
17
  onPressMenuMembers,
15
18
  onPressMenuLeaveChannel,
19
+ onPressMenuNotification,
16
20
  menuItemsCreator = (menu) => menu,
17
21
  }: GroupChannelSettingsProps['Menu']) => {
18
- const { sdk } = useSendbirdChat();
22
+ const { sdk, features } = useSendbirdChat();
19
23
  const { channel } = useContext(GroupChannelSettingsContexts.Fragment);
20
24
  const { STRINGS } = useLocalization();
21
25
  const { colors } = useUIKitTheme();
22
26
 
27
+ if (__DEV__ && !WARN_onPressMenuNotification && !onPressMenuNotification) {
28
+ Logger.warn('You should pass `onPressMenuNotification` prop if using mention');
29
+ WARN_onPressMenuNotification = true;
30
+ }
31
+
23
32
  const toggleNotification = async () => {
24
33
  if (channel.myPushTriggerOption === 'off') {
25
34
  await channel.setMyPushTriggerOption(PushTriggerOption.DEFAULT);
@@ -28,6 +37,35 @@ const GroupChannelSettingsMenu = ({
28
37
  }
29
38
  };
30
39
 
40
+ const { onPressNotificationMenu, actionLabelNotificationMenu, actionItemNotificationMenu } = useIIFE(() => {
41
+ const getNotificationsLabel = () => {
42
+ switch (channel.myPushTriggerOption) {
43
+ case PushTriggerOption.ALL:
44
+ case PushTriggerOption.DEFAULT:
45
+ return STRINGS.GROUP_CHANNEL_SETTINGS.MENU_NOTIFICATION_LABEL_ON;
46
+ case PushTriggerOption.OFF:
47
+ return STRINGS.GROUP_CHANNEL_SETTINGS.MENU_NOTIFICATION_LABEL_OFF;
48
+ case PushTriggerOption.MENTION_ONLY:
49
+ return STRINGS.GROUP_CHANNEL_SETTINGS.MENU_NOTIFICATION_LABEL_MENTION_ONLY;
50
+ }
51
+ };
52
+
53
+ return {
54
+ actionLabelNotificationMenu: getNotificationsLabel(),
55
+ actionItemNotificationMenu: conditionChaining(
56
+ [features.userMentionEnabled],
57
+ [
58
+ <Icon icon={'chevron-right'} color={colors.onBackground01} />,
59
+ <Switch value={channel.myPushTriggerOption !== 'off'} onChangeValue={toggleNotification} />,
60
+ ],
61
+ ),
62
+ onPressNotificationMenu: () => {
63
+ if (features.userMentionEnabled) onPressMenuNotification?.();
64
+ else toggleNotification();
65
+ },
66
+ };
67
+ });
68
+
31
69
  const menuItems: MenuBarProps[] = menuItemsCreator([
32
70
  {
33
71
  icon: 'moderation',
@@ -39,8 +77,9 @@ const GroupChannelSettingsMenu = ({
39
77
  {
40
78
  icon: 'notifications',
41
79
  name: STRINGS.GROUP_CHANNEL_SETTINGS.MENU_NOTIFICATION,
42
- onPress: toggleNotification,
43
- actionItem: <Switch value={channel.myPushTriggerOption !== 'off'} onChangeValue={toggleNotification} />,
80
+ onPress: onPressNotificationMenu,
81
+ actionLabel: actionLabelNotificationMenu,
82
+ actionItem: actionItemNotificationMenu,
44
83
  },
45
84
  {
46
85
  icon: 'members',
@@ -1,6 +1,6 @@
1
1
  import React, { createContext, useCallback } from 'react';
2
2
 
3
- import { useActiveGroupChannel, useChannelHandler } from '@sendbird/uikit-chat-hooks';
3
+ import { useChannelHandler } from '@sendbird/uikit-chat-hooks';
4
4
  import { useActionMenu, useAlert, useBottomSheet, usePrompt, useToast } from '@sendbird/uikit-react-native-foundation';
5
5
  import {
6
6
  NOOP,
@@ -36,11 +36,8 @@ export const GroupChannelSettingsContextsProvider: GroupChannelSettingsModule['P
36
36
  const { fileService } = usePlatformService();
37
37
  const { alert } = useAlert();
38
38
 
39
- const { activeChannel, setActiveChannel } = useActiveGroupChannel(sdk, channel);
40
-
41
- const onChannelChanged = (channel: SendbirdBaseChannel) => {
42
- if (isDifferentChannel(channel, activeChannel) || !channel.isGroupChannel()) return;
43
- setActiveChannel(channel);
39
+ const onChannelChanged = (eventChannel: SendbirdBaseChannel) => {
40
+ if (isDifferentChannel(eventChannel, channel)) return;
44
41
  forceUpdate();
45
42
  };
46
43
 
@@ -48,6 +45,7 @@ export const GroupChannelSettingsContextsProvider: GroupChannelSettingsModule['P
48
45
  onChannelChanged: onChannelChanged,
49
46
  onChannelFrozen: onChannelChanged,
50
47
  onChannelUnfrozen: onChannelChanged,
48
+ onUserBanned: onChannelChanged,
51
49
  });
52
50
 
53
51
  const toast = useToast();
@@ -57,11 +55,10 @@ export const GroupChannelSettingsContextsProvider: GroupChannelSettingsModule['P
57
55
 
58
56
  const updateChannel = useCallback(
59
57
  async (params: SendbirdGroupChannelUpdateParams) => {
60
- const updatedChannel = await activeChannel.updateChannel(params);
61
- setActiveChannel(updatedChannel);
58
+ await channel.updateChannel(params);
62
59
  forceUpdate();
63
60
  },
64
- [activeChannel],
61
+ [channel],
65
62
  );
66
63
 
67
64
  const changeChannelName = useCallback(() => {
@@ -69,10 +66,10 @@ export const GroupChannelSettingsContextsProvider: GroupChannelSettingsModule['P
69
66
  title: STRINGS.GROUP_CHANNEL_SETTINGS.DIALOG_CHANGE_NAME_PROMPT_TITLE,
70
67
  submitLabel: STRINGS.GROUP_CHANNEL_SETTINGS.DIALOG_CHANGE_NAME_PROMPT_OK,
71
68
  placeholder: STRINGS.GROUP_CHANNEL_SETTINGS.DIALOG_CHANGE_NAME_PROMPT_PLACEHOLDER,
72
- defaultValue: activeChannel.name,
69
+ defaultValue: channel.name,
73
70
  onSubmit: (channelName) => updateChannel({ name: channelName }),
74
71
  });
75
- }, [STRINGS, updateChannel, activeChannel.name]);
72
+ }, [STRINGS, updateChannel, channel.name]);
76
73
 
77
74
  const changeChannelImage = useCallback(() => {
78
75
  openMenu({
@@ -140,7 +137,7 @@ export const GroupChannelSettingsContextsProvider: GroupChannelSettingsModule['P
140
137
  <ProviderLayout>
141
138
  <GroupChannelSettingsContexts.Fragment.Provider
142
139
  value={{
143
- channel: activeChannel,
140
+ channel,
144
141
  headerTitle: STRINGS.GROUP_CHANNEL_SETTINGS.HEADER_TITLE,
145
142
  headerRight: STRINGS.GROUP_CHANNEL_SETTINGS.HEADER_RIGHT,
146
143
  onPressHeaderRight,
@@ -12,6 +12,7 @@ export interface GroupChannelSettingsProps {
12
12
  onPressMenuModeration: GroupChannelSettingsProps['Menu']['onPressMenuModeration'];
13
13
  onPressMenuMembers: GroupChannelSettingsProps['Menu']['onPressMenuMembers'];
14
14
  onPressMenuLeaveChannel: GroupChannelSettingsProps['Menu']['onPressMenuLeaveChannel'];
15
+ onPressMenuNotification?: GroupChannelSettingsProps['Menu']['onPressMenuNotification'];
15
16
  menuItemsCreator?: GroupChannelSettingsProps['Menu']['menuItemsCreator'];
16
17
  };
17
18
  Header: {
@@ -22,6 +23,7 @@ export interface GroupChannelSettingsProps {
22
23
  onPressMenuModeration: () => void;
23
24
  onPressMenuMembers: () => void;
24
25
  onPressMenuLeaveChannel: () => void;
26
+ onPressMenuNotification?: () => void;
25
27
  menuItemsCreator?: (defaultMenuItems: MenuBarProps[]) => MenuBarProps[];
26
28
  };
27
29
  Provider: {
@@ -1,5 +1,10 @@
1
- import type { UseUserListOptions, UserStruct } from '@sendbird/uikit-chat-hooks';
2
- import type { SendbirdGroupChannel, SendbirdGroupChannelCreateParams, SendbirdMember } from '@sendbird/uikit-utils';
1
+ import type { UseUserListOptions } from '@sendbird/uikit-chat-hooks';
2
+ import type {
3
+ SendbirdGroupChannel,
4
+ SendbirdGroupChannelCreateParams,
5
+ SendbirdMember,
6
+ UserStruct,
7
+ } from '@sendbird/uikit-utils';
3
8
 
4
9
  import type { CommonComponent } from '../../types';
5
10
  import type { GroupChannelType } from '../groupChannelList/types';
@@ -2,10 +2,13 @@ import React, { useCallback, useContext } from 'react';
2
2
  import { FlatList, ListRenderItem } from 'react-native';
3
3
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
4
 
5
+ import type { UserStruct } from '@sendbird/uikit-utils';
6
+ import { getUserUniqId } from '@sendbird/uikit-utils';
7
+
5
8
  import { UserListContexts } from '../module/moduleContext';
6
9
  import type { UserListContextsType, UserListProps } from '../types';
7
10
 
8
- const UserListList = <T,>({
11
+ const UserListList = <T extends UserStruct>({
9
12
  users,
10
13
  onRefresh,
11
14
  refreshing,
@@ -29,6 +32,7 @@ const UserListList = <T,>({
29
32
  onEndReached={onLoadNext}
30
33
  contentContainerStyle={{ paddingLeft: left, paddingRight: right, flexGrow: 1 }}
31
34
  ListEmptyComponent={ListEmptyComponent}
35
+ keyExtractor={getUserUniqId}
32
36
  />
33
37
  );
34
38
  };
@@ -1,3 +1,5 @@
1
+ import type { UserStruct } from '@sendbird/uikit-utils';
2
+
1
3
  import UserListHeader from '../component/UserListHeader';
2
4
  import UserListList from '../component/UserListList';
3
5
  import UserListStatusEmpty from '../component/UserListStatusEmpty';
@@ -6,7 +8,7 @@ import UserListStatusLoading from '../component/UserListStatusLoading';
6
8
  import type { UserListModule } from '../types';
7
9
  import { UserListContextsProvider } from './moduleContext';
8
10
 
9
- const createUserListModule = <T,>({
11
+ const createUserListModule = <T extends UserStruct>({
10
12
  Header = UserListHeader,
11
13
  List = UserListList,
12
14
  StatusLoading = UserListStatusLoading,
@@ -1,8 +1,14 @@
1
1
  import React from 'react';
2
2
  import { TouchableOpacity } from 'react-native';
3
3
 
4
- import { UserStruct, useUserList } from '@sendbird/uikit-chat-hooks';
5
- import { PASS, SendbirdGroupChannelCreateParams, SendbirdUser, useFreshCallback } from '@sendbird/uikit-utils';
4
+ import { useUserList } from '@sendbird/uikit-chat-hooks';
5
+ import {
6
+ PASS,
7
+ SendbirdGroupChannelCreateParams,
8
+ SendbirdUser,
9
+ UserStruct,
10
+ useFreshCallback,
11
+ } from '@sendbird/uikit-utils';
6
12
 
7
13
  import StatusComposition from '../components/StatusComposition';
8
14
  import UserSelectableBar from '../components/UserSelectableBar';
@@ -75,10 +75,17 @@ const createGroupChannelFragment = (initModule?: Partial<GroupChannelModule>): G
75
75
  const processedParams = await onBeforeSendFileMessage({ file });
76
76
  await sendFileMessage(processedParams);
77
77
  });
78
- const onSendUserMessage: GroupChannelProps['Input']['onSendUserMessage'] = useFreshCallback(async (text) => {
79
- const processedParams = await onBeforeSendUserMessage({ message: text });
80
- await sendUserMessage(processedParams);
81
- });
78
+ const onSendUserMessage: GroupChannelProps['Input']['onSendUserMessage'] = useFreshCallback(
79
+ async (text, mention) => {
80
+ const processedParams = await onBeforeSendUserMessage({
81
+ message: text,
82
+ mentionedUserIds: mention?.userIds,
83
+ mentionedMessageTemplate: mention?.messageTemplate,
84
+ mentionType: mention?.type,
85
+ });
86
+ await sendUserMessage(processedParams);
87
+ },
88
+ );
82
89
  const onUpdateFileMessage: GroupChannelProps['Input']['onUpdateFileMessage'] = useFreshCallback(
83
90
  async (editedFile, message) => {
84
91
  const processedParams = await onBeforeSendFileMessage({ file: editedFile });
@@ -86,8 +93,13 @@ const createGroupChannelFragment = (initModule?: Partial<GroupChannelModule>): G
86
93
  },
87
94
  );
88
95
  const onUpdateUserMessage: GroupChannelProps['Input']['onUpdateUserMessage'] = useFreshCallback(
89
- async (editedText, message) => {
90
- const processedParams = await onBeforeSendUserMessage({ message: editedText });
96
+ async (editedText, message, mention) => {
97
+ const processedParams = await onBeforeSendUserMessage({
98
+ message: editedText,
99
+ mentionedUserIds: mention?.userIds,
100
+ mentionedMessageTemplate: mention?.messageTemplate,
101
+ mentionType: mention?.type,
102
+ });
91
103
  await updateUserMessage(message.messageId, processedParams);
92
104
  },
93
105
  );
@@ -119,6 +131,7 @@ const createGroupChannelFragment = (initModule?: Partial<GroupChannelModule>): G
119
131
  flatListProps={memoizedFlatListProps}
120
132
  />
121
133
  <GroupChannelModule.Input
134
+ SuggestedMentionList={GroupChannelModule.SuggestedMentionList}
122
135
  shouldRenderInput={shouldRenderInput(channel)}
123
136
  onSendFileMessage={onSendFileMessage}
124
137
  onSendUserMessage={onSendUserMessage}
@@ -1,8 +1,8 @@
1
1
  import React, { useCallback } from 'react';
2
2
  import { TouchableOpacity } from 'react-native';
3
3
 
4
- import { UserStruct, useUserList } from '@sendbird/uikit-chat-hooks';
5
- import type { SendbirdGroupChannel, SendbirdUser } from '@sendbird/uikit-utils';
4
+ import { useUserList } from '@sendbird/uikit-chat-hooks';
5
+ import type { SendbirdGroupChannel, SendbirdUser, UserStruct } from '@sendbird/uikit-utils';
6
6
 
7
7
  import StatusComposition from '../components/StatusComposition';
8
8
  import UserSelectableBar from '../components/UserSelectableBar';
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+
3
+ import { NOOP } from '@sendbird/uikit-utils';
4
+
5
+ import { createGroupChannelNotificationsModule } from '../domain/groupChannelNotifications';
6
+ import type {
7
+ GroupChannelNotificationsFragment,
8
+ GroupChannelNotificationsModule,
9
+ } from '../domain/groupChannelNotifications/types';
10
+
11
+ const createGroupChannelNotificationsFragment = (
12
+ initModule?: Partial<GroupChannelNotificationsModule>,
13
+ ): GroupChannelNotificationsFragment => {
14
+ const GroupChannelNotificationsModule = createGroupChannelNotificationsModule(initModule);
15
+
16
+ return ({ onPressHeaderLeft = NOOP, children, channel }) => {
17
+ return (
18
+ <GroupChannelNotificationsModule.Provider channel={channel}>
19
+ <GroupChannelNotificationsModule.Header onPressHeaderLeft={onPressHeaderLeft} />
20
+ <GroupChannelNotificationsModule.View />
21
+ {children}
22
+ </GroupChannelNotificationsModule.Provider>
23
+ );
24
+ };
25
+ };
26
+
27
+ export default createGroupChannelNotificationsFragment;
@@ -19,6 +19,7 @@ const createGroupChannelSettingsFragment = (
19
19
  onPressMenuModeration,
20
20
  onPressMenuMembers,
21
21
  onPressMenuLeaveChannel,
22
+ onPressMenuNotification,
22
23
  menuItemsCreator,
23
24
  }) => {
24
25
  const { colors } = useUIKitTheme();
@@ -40,6 +41,7 @@ const createGroupChannelSettingsFragment = (
40
41
  onPressMenuModeration={onPressMenuModeration}
41
42
  onPressMenuMembers={onPressMenuMembers}
42
43
  onPressMenuLeaveChannel={onPressMenuLeaveChannel}
44
+ onPressMenuNotification={onPressMenuNotification}
43
45
  />
44
46
  </ScrollView>
45
47
  </GroupChannelSettingsModule.Provider>
@@ -9,7 +9,7 @@ type ConnectOptions = { nickname?: string; accessToken?: string };
9
9
  const cacheRestrictCodes = [400300, 400301, 400302, 400310];
10
10
 
11
11
  const useConnection = () => {
12
- const { sdk, setCurrentUser, features } = useSendbirdChat();
12
+ const { sdk, emojiManager, setCurrentUser, features } = useSendbirdChat();
13
13
  const { registerPushTokenForCurrentUser, unregisterPushTokenForCurrentUser } = usePushTokenRegistration();
14
14
 
15
15
  const connect = useCallback(
@@ -37,6 +37,7 @@ const useConnection = () => {
37
37
 
38
38
  Logger.debug('[useConnection]', 'connected! (online)');
39
39
  setCurrentUser(user);
40
+ sdk.getAllEmoji().then(emojiManager.init);
40
41
 
41
42
  return user;
42
43
  } catch (e) {
@@ -50,6 +51,7 @@ const useConnection = () => {
50
51
  } else if (sdk.currentUser) {
51
52
  Logger.debug('[useConnection]', 'connected! (offline)');
52
53
  setCurrentUser(sdk.currentUser);
54
+ sdk.getAllEmoji().finally(emojiManager.init);
53
55
  return sdk.currentUser;
54
56
  }
55
57
  }
@@ -2,6 +2,7 @@ import { useContext } from 'react';
2
2
 
3
3
  import { LocalizationContext } from '../contexts/LocalizationCtx';
4
4
  import { PlatformServiceContext } from '../contexts/PlatformServiceCtx';
5
+ import { ReactionContext } from '../contexts/ReactionCtx';
5
6
  import { SendbirdChatContext } from '../contexts/SendbirdChatCtx';
6
7
  import { UserProfileContext } from '../contexts/UserProfileCtx';
7
8
 
@@ -28,3 +29,9 @@ export const useUserProfile = () => {
28
29
  if (!value) throw new Error('UserProfileContext is not provided');
29
30
  return value;
30
31
  };
32
+
33
+ export const useReaction = () => {
34
+ const value = useContext(ReactionContext);
35
+ if (!value) throw new Error('ReactionContext is not provided');
36
+ return value;
37
+ };
@@ -0,0 +1,54 @@
1
+ import { useEffect, useState } from 'react';
2
+ import { Keyboard, KeyboardEvent, KeyboardEventName, LayoutAnimation, Platform } from 'react-native';
3
+ import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
+
5
+ import { NOOP } from '@sendbird/uikit-utils';
6
+
7
+ type KeyboardEvents = {
8
+ showEvent: KeyboardEventName;
9
+ hideEvent: KeyboardEventName;
10
+ };
11
+
12
+ const configureNextLayoutAnimation = (event: KeyboardEvent) => {
13
+ const config = LayoutAnimation.create(event.duration, event.easing);
14
+ LayoutAnimation.configureNext(config);
15
+ };
16
+
17
+ const { showEvent, hideEvent } = Platform.select<KeyboardEvents>({
18
+ android: { showEvent: 'keyboardDidShow', hideEvent: 'keyboardDidHide' },
19
+ default: { showEvent: 'keyboardWillShow', hideEvent: 'keyboardWillHide' },
20
+ });
21
+
22
+ const useKeyboardStatus = () => {
23
+ const [keyboardStatus, setKeyboardStatus] = useState({ visible: false, height: 0, bottomSpace: 0 });
24
+ const { bottom: bottomInset } = useSafeAreaInsets();
25
+
26
+ useEffect(() => {
27
+ const subscriptions = [
28
+ Keyboard.addListener(showEvent, (event) => {
29
+ const height = event.endCoordinates.height;
30
+ const bottomSpace = Platform.select({ ios: height - bottomInset, default: 0 });
31
+ const nextLayoutAnimation = Platform.select({ ios: configureNextLayoutAnimation, default: NOOP });
32
+
33
+ nextLayoutAnimation(event);
34
+ setKeyboardStatus({ visible: true, height, bottomSpace });
35
+ }),
36
+
37
+ Keyboard.addListener(hideEvent, (event) => {
38
+ const height = 0;
39
+ const bottomSpace = Platform.select({ default: height });
40
+ const nextLayoutAnimation = Platform.select({ ios: configureNextLayoutAnimation, default: NOOP });
41
+
42
+ nextLayoutAnimation(event);
43
+ setKeyboardStatus({ visible: false, height, bottomSpace });
44
+ }),
45
+ ];
46
+ return () => {
47
+ subscriptions.forEach((it) => it.remove());
48
+ };
49
+ }, []);
50
+
51
+ return keyboardStatus;
52
+ };
53
+
54
+ export default useKeyboardStatus;
@@ -0,0 +1,106 @@
1
+ import { useCallback, useEffect, useRef, useState } from 'react';
2
+
3
+ import type { SendbirdGroupChannel, SendbirdMember, SendbirdUser } from '@sendbird/uikit-utils';
4
+ import { useAsyncEffect } from '@sendbird/uikit-utils';
5
+
6
+ import { useSendbirdChat } from '../hooks/useContext';
7
+ import type { Range } from '../types';
8
+
9
+ const useMentionSuggestion = (params: {
10
+ text: string;
11
+ selection: Range;
12
+ channel: SendbirdGroupChannel;
13
+ mentionedUsers: { user: SendbirdUser; range: Range }[];
14
+ }) => {
15
+ const { text, selection, channel, mentionedUsers } = params;
16
+
17
+ const [freshChannel, setFreshChannel] = useState(channel);
18
+
19
+ useAsyncEffect(async () => {
20
+ setFreshChannel(await channel.refresh());
21
+ }, [channel.url]);
22
+
23
+ const { mentionManager, currentUser } = useSendbirdChat();
24
+ const [members, setMembers] = useState<SendbirdMember[]>([]);
25
+ const timeoutRef = useRef<NodeJS.Timeout>();
26
+
27
+ const searchStringRangeRef = useRef<Range>({ start: 0, end: 0 });
28
+ const searchLimitedRef = useRef(false);
29
+
30
+ const updateSearchStringRange = (selectionIndex: number, searchString: string) => {
31
+ searchStringRangeRef.current = mentionManager.getSearchStringRangeInText(selectionIndex, searchString);
32
+ return searchStringRangeRef.current;
33
+ };
34
+ const updateSearchLimited = (mentionCount: number, mentionLimit: number) => {
35
+ searchLimitedRef.current = mentionCount >= mentionLimit;
36
+ return searchLimitedRef.current;
37
+ };
38
+ const resetRefs = () => {
39
+ searchLimitedRef.current = false;
40
+ searchStringRangeRef.current = { start: 0, end: 0 };
41
+ };
42
+
43
+ const fetchMembers = async (): Promise<SendbirdMember[]> => {
44
+ resetRefs();
45
+
46
+ const selectionRanged = selection.start !== selection.end;
47
+ if (selectionRanged) return [];
48
+
49
+ const selectionContainsMentionedUser = mentionedUsers.some((it) =>
50
+ mentionManager.rangeHelpers.overlaps(it.range, selection, 'underMore'),
51
+ );
52
+ if (selectionContainsMentionedUser) return [];
53
+
54
+ const { isTriggered, isValidSearchString, searchString } = mentionManager.getSearchString(text, selection.start);
55
+ if (!isTriggered() || !isValidSearchString()) return [];
56
+
57
+ const limited = updateSearchLimited(mentionedUsers.length, mentionManager.config.mentionLimit);
58
+ if (limited) return [];
59
+
60
+ updateSearchStringRange(selection.start, searchString);
61
+
62
+ if (freshChannel.isSuper) {
63
+ return freshChannel
64
+ .createMemberListQuery({
65
+ nicknameStartsWithFilter: searchString,
66
+ limit: mentionManager.config.suggestionLimit + 1,
67
+ })
68
+ .next()
69
+ .then((members) => members.filter((member) => member.userId !== currentUser?.userId));
70
+ } else {
71
+ return freshChannel.members
72
+ .sort((a, b) => a.nickname?.localeCompare(b.nickname))
73
+ .filter(
74
+ (member) =>
75
+ member.nickname?.toLowerCase().startsWith(searchString.toLowerCase()) &&
76
+ member.userId !== currentUser?.userId,
77
+ )
78
+ .slice(0, mentionManager.config.suggestionLimit);
79
+ }
80
+ };
81
+
82
+ useEffect(() => {
83
+ timeoutRef.current = setTimeout(async () => {
84
+ fetchMembers()
85
+ .then(setMembers)
86
+ .catch(() => setMembers([]))
87
+ .finally(() => (timeoutRef.current = undefined));
88
+ }, mentionManager.config.debounceMills);
89
+
90
+ return () => {
91
+ if (timeoutRef.current) {
92
+ clearTimeout(timeoutRef.current);
93
+ timeoutRef.current = undefined;
94
+ }
95
+ };
96
+ }, [text, selection]);
97
+
98
+ return {
99
+ members,
100
+ reset: useCallback(() => setMembers([]), []),
101
+ searchStringRange: searchStringRangeRef.current,
102
+ searchLimited: searchLimitedRef.current,
103
+ };
104
+ };
105
+
106
+ export default useMentionSuggestion;