@sendbird/uikit-react-native 2.0.3 → 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 (677) hide show
  1. package/README.md +2 -2
  2. package/lib/commonjs/components/ChannelCover.js +22 -1
  3. package/lib/commonjs/components/ChannelCover.js.map +1 -1
  4. package/lib/commonjs/components/ChatFlatList.js +2 -1
  5. package/lib/commonjs/components/ChatFlatList.js.map +1 -1
  6. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  7. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  8. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  9. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  10. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
  11. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  12. package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js +9 -2
  13. package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
  14. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -10
  15. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  16. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +99 -14
  17. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  18. package/lib/commonjs/components/MessageRenderer/UserMessage/index.js.map +1 -1
  19. package/lib/commonjs/components/MessageRenderer/index.js +23 -4
  20. package/lib/commonjs/components/MessageRenderer/index.js.map +1 -1
  21. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +150 -0
  22. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  23. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js +135 -0
  24. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  25. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js +87 -0
  26. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  27. package/lib/commonjs/components/ReactionAddons/index.js +19 -0
  28. package/lib/commonjs/components/ReactionAddons/index.js.map +1 -0
  29. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js +150 -0
  30. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  31. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +276 -0
  32. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  33. package/lib/commonjs/components/ReactionBottomSheets/index.js +19 -0
  34. package/lib/commonjs/components/ReactionBottomSheets/index.js.map +1 -0
  35. package/lib/commonjs/components/TypedPlaceholder.js +2 -2
  36. package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
  37. package/lib/commonjs/components/UserActionBar.js +7 -4
  38. package/lib/commonjs/components/UserActionBar.js.map +1 -1
  39. package/lib/commonjs/constants.js +3 -1
  40. package/lib/commonjs/constants.js.map +1 -1
  41. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +9 -1
  42. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  43. package/lib/commonjs/containers/SendbirdUIKitContainer.js +130 -83
  44. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  45. package/lib/commonjs/contexts/{Localization.js → LocalizationCtx.js} +1 -1
  46. package/lib/commonjs/contexts/LocalizationCtx.js.map +1 -0
  47. package/lib/commonjs/contexts/{PlatformService.js → PlatformServiceCtx.js} +1 -1
  48. package/lib/commonjs/contexts/PlatformServiceCtx.js.map +1 -0
  49. package/lib/commonjs/contexts/ReactionCtx.js +107 -0
  50. package/lib/commonjs/contexts/ReactionCtx.js.map +1 -0
  51. package/lib/commonjs/contexts/{SendbirdChat.js → SendbirdChatCtx.js} +21 -7
  52. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -0
  53. package/lib/commonjs/contexts/UserProfileCtx.js +125 -0
  54. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -0
  55. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +34 -36
  56. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  57. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +31 -12
  58. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  59. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +129 -35
  60. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  61. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +31 -12
  62. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  63. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +210 -0
  64. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  65. package/lib/commonjs/domain/groupChannel/index.js +8 -0
  66. package/lib/commonjs/domain/groupChannel/index.js.map +1 -1
  67. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +4 -0
  68. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  69. package/lib/commonjs/domain/groupChannel/module/moduleContext.js +4 -4
  70. package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
  71. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  72. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +39 -0
  73. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
  74. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +54 -0
  75. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
  76. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +34 -0
  77. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
  78. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +38 -0
  79. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
  80. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +34 -0
  81. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
  82. package/lib/commonjs/domain/groupChannelBannedUsers/index.js +62 -0
  83. package/lib/commonjs/domain/groupChannelBannedUsers/index.js.map +1 -0
  84. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +45 -0
  85. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
  86. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js +45 -0
  87. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
  88. package/lib/commonjs/domain/groupChannelBannedUsers/types.js +6 -0
  89. package/lib/commonjs/domain/groupChannelBannedUsers/types.js.map +1 -0
  90. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +2 -1
  91. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  92. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js +32 -30
  93. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  94. package/lib/commonjs/domain/groupChannelList/types.js.map +1 -1
  95. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +39 -0
  96. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
  97. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +103 -0
  98. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
  99. package/lib/commonjs/domain/groupChannelModeration/index.js +46 -0
  100. package/lib/commonjs/domain/groupChannelModeration/index.js.map +1 -0
  101. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +33 -0
  102. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
  103. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js +46 -0
  104. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
  105. package/lib/commonjs/domain/groupChannelModeration/types.js +6 -0
  106. package/lib/commonjs/domain/groupChannelModeration/types.js.map +1 -0
  107. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +39 -0
  108. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
  109. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +52 -0
  110. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
  111. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +34 -0
  112. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
  113. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +38 -0
  114. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
  115. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +34 -0
  116. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
  117. package/lib/commonjs/domain/groupChannelMutedMembers/index.js +70 -0
  118. package/lib/commonjs/domain/groupChannelMutedMembers/index.js.map +1 -0
  119. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +45 -0
  120. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
  121. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js +45 -0
  122. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
  123. package/lib/commonjs/domain/groupChannelMutedMembers/types.js +6 -0
  124. package/lib/commonjs/domain/groupChannelMutedMembers/types.js.map +1 -0
  125. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +39 -0
  126. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  127. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +140 -0
  128. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  129. package/lib/commonjs/domain/groupChannelNotifications/index.js +46 -0
  130. package/lib/commonjs/domain/groupChannelNotifications/index.js.map +1 -0
  131. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +33 -0
  132. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  133. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js +45 -0
  134. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  135. package/lib/commonjs/domain/groupChannelNotifications/types.js +6 -0
  136. package/lib/commonjs/domain/groupChannelNotifications/types.js.map +1 -0
  137. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +44 -0
  138. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
  139. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +52 -0
  140. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
  141. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +34 -0
  142. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
  143. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +38 -0
  144. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
  145. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +34 -0
  146. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
  147. package/lib/commonjs/domain/groupChannelOperators/index.js +70 -0
  148. package/lib/commonjs/domain/groupChannelOperators/index.js.map +1 -0
  149. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +45 -0
  150. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
  151. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js +45 -0
  152. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
  153. package/lib/commonjs/domain/groupChannelOperators/types.js +6 -0
  154. package/lib/commonjs/domain/groupChannelOperators/types.js.map +1 -0
  155. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -8
  156. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  157. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +60 -6
  158. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  159. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +9 -14
  160. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  161. package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
  162. package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
  163. package/lib/commonjs/domain/userList/component/UserListList.js +4 -1
  164. package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -1
  165. package/lib/commonjs/domain/userList/component/UserListStatusError.js +2 -2
  166. package/lib/commonjs/domain/userList/component/UserListStatusError.js.map +1 -1
  167. package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -1
  168. package/lib/commonjs/domain/userList/types.js.map +1 -1
  169. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js +101 -0
  170. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
  171. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +9 -25
  172. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  173. package/lib/commonjs/fragments/createGroupChannelFragment.js +22 -8
  174. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  175. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js +21 -37
  176. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
  177. package/lib/commonjs/fragments/createGroupChannelListFragment.js +3 -11
  178. package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
  179. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +95 -51
  180. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
  181. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js +68 -0
  182. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js.map +1 -0
  183. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js +116 -0
  184. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
  185. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js +34 -0
  186. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  187. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js +129 -0
  188. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
  189. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js +114 -0
  190. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
  191. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +5 -1
  192. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  193. package/lib/commonjs/hooks/useConnection.js +7 -0
  194. package/lib/commonjs/hooks/useConnection.js.map +1 -1
  195. package/lib/commonjs/hooks/useContext.js +27 -7
  196. package/lib/commonjs/hooks/useContext.js.map +1 -1
  197. package/lib/commonjs/hooks/useKeyboardStatus.js +93 -0
  198. package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -0
  199. package/lib/commonjs/hooks/useMentionSuggestion.js +110 -0
  200. package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -0
  201. package/lib/commonjs/hooks/useMentionTextInput.js +139 -0
  202. package/lib/commonjs/hooks/useMentionTextInput.js.map +1 -0
  203. package/lib/commonjs/index.js +165 -42
  204. package/lib/commonjs/index.js.map +1 -1
  205. package/lib/commonjs/libs/EmojiManager.js +100 -0
  206. package/lib/commonjs/libs/EmojiManager.js.map +1 -0
  207. package/lib/commonjs/libs/MentionConfig.js +47 -0
  208. package/lib/commonjs/libs/MentionConfig.js.map +1 -0
  209. package/lib/commonjs/libs/MentionManager.js +235 -0
  210. package/lib/commonjs/libs/MentionManager.js.map +1 -0
  211. package/lib/commonjs/localization/StringSet.type.js +77 -16
  212. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  213. package/lib/commonjs/platform/createFileService.native.js.map +1 -1
  214. package/lib/commonjs/types.js.map +1 -1
  215. package/lib/commonjs/utils/common.js +19 -0
  216. package/lib/commonjs/utils/common.js.map +1 -0
  217. package/lib/commonjs/version.js +1 -1
  218. package/lib/commonjs/version.js.map +1 -1
  219. package/lib/module/components/ChannelCover.js +22 -2
  220. package/lib/module/components/ChannelCover.js.map +1 -1
  221. package/lib/module/components/ChatFlatList.js +3 -2
  222. package/lib/module/components/ChatFlatList.js.map +1 -1
  223. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
  224. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  225. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
  226. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  227. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
  228. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  229. package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js +9 -3
  230. package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
  231. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -12
  232. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  233. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +101 -17
  234. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  235. package/lib/module/components/MessageRenderer/UserMessage/index.js.map +1 -1
  236. package/lib/module/components/MessageRenderer/index.js +22 -5
  237. package/lib/module/components/MessageRenderer/index.js.map +1 -1
  238. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +132 -0
  239. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
  240. package/lib/module/components/ReactionAddons/MessageReactionAddon.js +118 -0
  241. package/lib/module/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
  242. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js +74 -0
  243. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
  244. package/lib/module/components/ReactionAddons/index.js +7 -0
  245. package/lib/module/components/ReactionAddons/index.js.map +1 -0
  246. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js +135 -0
  247. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
  248. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +259 -0
  249. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
  250. package/lib/module/components/ReactionBottomSheets/index.js +7 -0
  251. package/lib/module/components/ReactionBottomSheets/index.js.map +1 -0
  252. package/lib/module/components/TypedPlaceholder.js +2 -2
  253. package/lib/module/components/TypedPlaceholder.js.map +1 -1
  254. package/lib/module/components/UserActionBar.js +8 -5
  255. package/lib/module/components/UserActionBar.js.map +1 -1
  256. package/lib/module/constants.js +1 -0
  257. package/lib/module/constants.js.map +1 -1
  258. package/lib/module/containers/GroupChannelPreviewContainer.js +9 -1
  259. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  260. package/lib/module/containers/SendbirdUIKitContainer.js +123 -81
  261. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  262. package/lib/module/contexts/{Localization.js → LocalizationCtx.js} +1 -1
  263. package/lib/module/contexts/LocalizationCtx.js.map +1 -0
  264. package/lib/module/contexts/{PlatformService.js → PlatformServiceCtx.js} +1 -1
  265. package/lib/module/contexts/PlatformServiceCtx.js.map +1 -0
  266. package/lib/module/contexts/ReactionCtx.js +85 -0
  267. package/lib/module/contexts/ReactionCtx.js.map +1 -0
  268. package/lib/module/contexts/{SendbirdChat.js → SendbirdChatCtx.js} +21 -7
  269. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -0
  270. package/lib/module/contexts/UserProfileCtx.js +101 -0
  271. package/lib/module/contexts/UserProfileCtx.js.map +1 -0
  272. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +35 -38
  273. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  274. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +27 -14
  275. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  276. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +126 -37
  277. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  278. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +32 -14
  279. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  280. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +188 -0
  281. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
  282. package/lib/module/domain/groupChannel/index.js +1 -0
  283. package/lib/module/domain/groupChannel/index.js.map +1 -1
  284. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +3 -0
  285. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  286. package/lib/module/domain/groupChannel/module/moduleContext.js +4 -4
  287. package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
  288. package/lib/module/domain/groupChannel/types.js.map +1 -1
  289. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +25 -0
  290. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
  291. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +41 -0
  292. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
  293. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +21 -0
  294. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
  295. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +25 -0
  296. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
  297. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +21 -0
  298. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
  299. package/lib/module/domain/groupChannelBannedUsers/index.js +7 -0
  300. package/lib/module/domain/groupChannelBannedUsers/index.js.map +1 -0
  301. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +30 -0
  302. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
  303. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js +25 -0
  304. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
  305. package/lib/module/domain/groupChannelBannedUsers/types.js +2 -0
  306. package/lib/module/domain/groupChannelBannedUsers/types.js.map +1 -0
  307. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +3 -2
  308. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  309. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js +34 -33
  310. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  311. package/lib/module/domain/groupChannelList/types.js.map +1 -1
  312. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +25 -0
  313. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
  314. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +87 -0
  315. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
  316. package/lib/module/domain/groupChannelModeration/index.js +5 -0
  317. package/lib/module/domain/groupChannelModeration/index.js.map +1 -0
  318. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +21 -0
  319. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
  320. package/lib/module/domain/groupChannelModeration/module/moduleContext.js +26 -0
  321. package/lib/module/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
  322. package/lib/module/domain/groupChannelModeration/types.js +2 -0
  323. package/lib/module/domain/groupChannelModeration/types.js.map +1 -0
  324. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +25 -0
  325. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
  326. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +39 -0
  327. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
  328. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +21 -0
  329. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
  330. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +25 -0
  331. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
  332. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +21 -0
  333. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
  334. package/lib/module/domain/groupChannelMutedMembers/index.js +8 -0
  335. package/lib/module/domain/groupChannelMutedMembers/index.js.map +1 -0
  336. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +30 -0
  337. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
  338. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js +25 -0
  339. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
  340. package/lib/module/domain/groupChannelMutedMembers/types.js +2 -0
  341. package/lib/module/domain/groupChannelMutedMembers/types.js.map +1 -0
  342. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +25 -0
  343. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
  344. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +122 -0
  345. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
  346. package/lib/module/domain/groupChannelNotifications/index.js +5 -0
  347. package/lib/module/domain/groupChannelNotifications/index.js.map +1 -0
  348. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +21 -0
  349. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
  350. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js +25 -0
  351. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
  352. package/lib/module/domain/groupChannelNotifications/types.js +2 -0
  353. package/lib/module/domain/groupChannelNotifications/types.js.map +1 -0
  354. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +30 -0
  355. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
  356. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +39 -0
  357. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
  358. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +21 -0
  359. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
  360. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +25 -0
  361. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
  362. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +21 -0
  363. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
  364. package/lib/module/domain/groupChannelOperators/index.js +8 -0
  365. package/lib/module/domain/groupChannelOperators/index.js.map +1 -0
  366. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +30 -0
  367. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
  368. package/lib/module/domain/groupChannelOperators/module/moduleContext.js +25 -0
  369. package/lib/module/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
  370. package/lib/module/domain/groupChannelOperators/types.js +2 -0
  371. package/lib/module/domain/groupChannelOperators/types.js.map +1 -0
  372. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +2 -8
  373. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  374. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +57 -6
  375. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  376. package/lib/module/domain/groupChannelSettings/module/moduleContext.js +10 -15
  377. package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  378. package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
  379. package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
  380. package/lib/module/domain/userList/component/UserListList.js +3 -1
  381. package/lib/module/domain/userList/component/UserListList.js.map +1 -1
  382. package/lib/module/domain/userList/component/UserListStatusError.js +2 -2
  383. package/lib/module/domain/userList/component/UserListStatusError.js.map +1 -1
  384. package/lib/module/domain/userList/module/createUserListModule.js.map +1 -1
  385. package/lib/module/domain/userList/types.js.map +1 -1
  386. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js +84 -0
  387. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
  388. package/lib/module/fragments/createGroupChannelCreateFragment.js +10 -26
  389. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  390. package/lib/module/fragments/createGroupChannelFragment.js +22 -8
  391. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  392. package/lib/module/fragments/createGroupChannelInviteFragment.js +22 -37
  393. package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
  394. package/lib/module/fragments/createGroupChannelListFragment.js +4 -11
  395. package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
  396. package/lib/module/fragments/createGroupChannelMembersFragment.js +99 -56
  397. package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
  398. package/lib/module/fragments/createGroupChannelModerationFragment.js +53 -0
  399. package/lib/module/fragments/createGroupChannelModerationFragment.js.map +1 -0
  400. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js +98 -0
  401. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
  402. package/lib/module/fragments/createGroupChannelNotificationsFragment.js +22 -0
  403. package/lib/module/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
  404. package/lib/module/fragments/createGroupChannelOperatorsFragment.js +111 -0
  405. package/lib/module/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
  406. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js +94 -0
  407. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
  408. package/lib/module/fragments/createGroupChannelSettingsFragment.js +5 -1
  409. package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  410. package/lib/module/hooks/useConnection.js +7 -0
  411. package/lib/module/hooks/useConnection.js.map +1 -1
  412. package/lib/module/hooks/useContext.js +15 -3
  413. package/lib/module/hooks/useContext.js.map +1 -1
  414. package/lib/module/hooks/useKeyboardStatus.js +75 -0
  415. package/lib/module/hooks/useKeyboardStatus.js.map +1 -0
  416. package/lib/module/hooks/useMentionSuggestion.js +100 -0
  417. package/lib/module/hooks/useMentionSuggestion.js.map +1 -0
  418. package/lib/module/hooks/useMentionTextInput.js +128 -0
  419. package/lib/module/hooks/useMentionTextInput.js.map +1 -0
  420. package/lib/module/index.js +17 -6
  421. package/lib/module/index.js.map +1 -1
  422. package/lib/module/libs/EmojiManager.js +90 -0
  423. package/lib/module/libs/EmojiManager.js.map +1 -0
  424. package/lib/module/libs/MentionConfig.js +39 -0
  425. package/lib/module/libs/MentionConfig.js.map +1 -0
  426. package/lib/module/libs/MentionManager.js +223 -0
  427. package/lib/module/libs/MentionManager.js.map +1 -0
  428. package/lib/module/localization/StringSet.type.js +78 -17
  429. package/lib/module/localization/StringSet.type.js.map +1 -1
  430. package/lib/module/platform/createFileService.native.js.map +1 -1
  431. package/lib/module/types.js.map +1 -1
  432. package/lib/module/utils/common.js +7 -0
  433. package/lib/module/utils/common.js.map +1 -0
  434. package/lib/module/version.js +1 -1
  435. package/lib/module/version.js.map +1 -1
  436. package/lib/typescript/__template__/types.d.ts +3 -3
  437. package/lib/typescript/src/components/ChannelCover.d.ts +2 -2
  438. package/lib/typescript/src/components/ChatFlatList.d.ts +1 -1
  439. package/lib/typescript/src/components/FileViewer.d.ts +1 -1
  440. package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +1 -1
  441. package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +2 -2
  442. package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +1 -1
  443. package/lib/typescript/src/components/MessageRenderer/FileMessage/VideoFileMessage.d.ts +1 -1
  444. package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +11 -2
  445. package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +1 -1
  446. package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +1 -1
  447. package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +1 -1
  448. package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +1 -1
  449. package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +1 -1
  450. package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +1 -1
  451. package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +1 -1
  452. package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +2 -2
  453. package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +4 -1
  454. package/lib/typescript/src/components/MessageRenderer/index.d.ts +4 -3
  455. package/lib/typescript/src/components/NewMessagesButton.d.ts +1 -1
  456. package/lib/typescript/src/components/ReactionAddons/BottomSheetReactionAddon.d.ts +8 -0
  457. package/lib/typescript/src/components/ReactionAddons/MessageReactionAddon.d.ts +6 -0
  458. package/lib/typescript/src/components/ReactionAddons/ReactionRoundedButton.d.ts +14 -0
  459. package/lib/typescript/src/components/ReactionAddons/index.d.ts +11 -0
  460. package/lib/typescript/src/components/ReactionBottomSheets/ReactionListBottomSheet.d.ts +3 -0
  461. package/lib/typescript/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.d.ts +3 -0
  462. package/lib/typescript/src/components/ReactionBottomSheets/index.d.ts +20 -0
  463. package/lib/typescript/src/components/ScrollToBottomButton.d.ts +1 -1
  464. package/lib/typescript/src/components/StatusComposition.d.ts +1 -1
  465. package/lib/typescript/src/components/TypedPlaceholder.d.ts +2 -2
  466. package/lib/typescript/src/components/UserActionBar.d.ts +5 -3
  467. package/lib/typescript/src/components/UserSelectableBar.d.ts +1 -1
  468. package/lib/typescript/src/constants.d.ts +1 -0
  469. package/lib/typescript/src/containers/GroupChannelPreviewContainer.d.ts +1 -1
  470. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +19 -8
  471. package/lib/typescript/src/contexts/{Localization.d.ts → LocalizationCtx.d.ts} +2 -2
  472. package/lib/typescript/src/contexts/{PlatformService.d.ts → PlatformServiceCtx.d.ts} +1 -1
  473. package/lib/typescript/src/contexts/ReactionCtx.d.ts +18 -0
  474. package/lib/typescript/src/contexts/{SendbirdChat.d.ts → SendbirdChatCtx.d.ts} +17 -5
  475. package/lib/typescript/src/contexts/UserProfileCtx.d.ts +15 -0
  476. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +36 -7
  477. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +34 -5
  478. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +20 -3
  479. package/lib/typescript/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.d.ts +3 -0
  480. package/lib/typescript/src/domain/groupChannel/index.d.ts +1 -0
  481. package/lib/typescript/src/domain/groupChannel/module/createGroupChannelModule.d.ts +1 -1
  482. package/lib/typescript/src/domain/groupChannel/types.d.ts +25 -8
  483. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.d.ts +3 -0
  484. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.d.ts +3 -0
  485. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.d.ts +2 -0
  486. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.d.ts +3 -0
  487. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.d.ts +2 -0
  488. package/lib/typescript/src/domain/groupChannelBannedUsers/index.d.ts +6 -0
  489. package/lib/typescript/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.d.ts +3 -0
  490. package/lib/typescript/src/domain/groupChannelBannedUsers/module/moduleContext.d.ts +3 -0
  491. package/lib/typescript/src/domain/groupChannelBannedUsers/types.d.ts +47 -0
  492. package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListTypeSelector.d.ts +1 -1
  493. package/lib/typescript/src/domain/groupChannelList/types.d.ts +5 -11
  494. package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.d.ts +3 -0
  495. package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.d.ts +3 -0
  496. package/lib/typescript/src/domain/groupChannelModeration/index.d.ts +4 -0
  497. package/lib/typescript/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.d.ts +3 -0
  498. package/lib/typescript/src/domain/groupChannelModeration/module/moduleContext.d.ts +3 -0
  499. package/lib/typescript/src/domain/groupChannelModeration/types.d.ts +43 -0
  500. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.d.ts +3 -0
  501. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.d.ts +3 -0
  502. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.d.ts +2 -0
  503. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.d.ts +3 -0
  504. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.d.ts +2 -0
  505. package/lib/typescript/src/domain/groupChannelMutedMembers/index.d.ts +7 -0
  506. package/lib/typescript/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.d.ts +3 -0
  507. package/lib/typescript/src/domain/groupChannelMutedMembers/module/moduleContext.d.ts +3 -0
  508. package/lib/typescript/src/domain/groupChannelMutedMembers/types.d.ts +47 -0
  509. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.d.ts +3 -0
  510. package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.d.ts +2 -0
  511. package/lib/typescript/src/domain/groupChannelNotifications/index.d.ts +4 -0
  512. package/lib/typescript/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.d.ts +3 -0
  513. package/lib/typescript/src/domain/groupChannelNotifications/module/moduleContext.d.ts +3 -0
  514. package/lib/typescript/src/domain/groupChannelNotifications/types.d.ts +33 -0
  515. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.d.ts +3 -0
  516. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.d.ts +3 -0
  517. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.d.ts +2 -0
  518. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.d.ts +3 -0
  519. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.d.ts +2 -0
  520. package/lib/typescript/src/domain/groupChannelOperators/index.d.ts +7 -0
  521. package/lib/typescript/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.d.ts +3 -0
  522. package/lib/typescript/src/domain/groupChannelOperators/module/moduleContext.d.ts +3 -0
  523. package/lib/typescript/src/domain/groupChannelOperators/types.d.ts +49 -0
  524. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.d.ts +1 -1
  525. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -1
  526. package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +5 -1
  527. package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +17 -11
  528. package/lib/typescript/src/domain/userList/component/UserListList.d.ts +2 -1
  529. package/lib/typescript/src/domain/userList/component/UserListStatusError.d.ts +2 -2
  530. package/lib/typescript/src/domain/userList/module/createUserListModule.d.ts +2 -1
  531. package/lib/typescript/src/domain/userList/types.d.ts +4 -3
  532. package/lib/typescript/src/fragments/createGroupChannelBannedUsersFragment.d.ts +3 -0
  533. package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +2 -1
  534. package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +2 -1
  535. package/lib/typescript/src/fragments/createGroupChannelModerationFragment.d.ts +3 -0
  536. package/lib/typescript/src/fragments/createGroupChannelMutedMembersFragment.d.ts +3 -0
  537. package/lib/typescript/src/fragments/createGroupChannelNotificationsFragment.d.ts +3 -0
  538. package/lib/typescript/src/fragments/createGroupChannelOperatorsFragment.d.ts +3 -0
  539. package/lib/typescript/src/fragments/createGroupChannelRegisterOperatorFragment.d.ts +5 -0
  540. package/lib/typescript/src/hooks/useConnection.d.ts +1 -1
  541. package/lib/typescript/src/hooks/useContext.d.ts +7 -1
  542. package/lib/typescript/src/hooks/useKeyboardStatus.d.ts +6 -0
  543. package/lib/typescript/src/hooks/useMentionSuggestion.d.ts +17 -0
  544. package/lib/typescript/src/hooks/useMentionTextInput.d.ts +18 -0
  545. package/lib/typescript/src/index.d.ts +16 -5
  546. package/lib/typescript/src/libs/EmojiManager.d.ts +16 -0
  547. package/lib/typescript/src/libs/MentionConfig.d.ts +24 -0
  548. package/lib/typescript/src/libs/MentionManager.d.ts +61 -0
  549. package/lib/typescript/src/localization/StringSet.type.d.ts +63 -9
  550. package/lib/typescript/src/platform/createFileService.native.d.ts +1 -1
  551. package/lib/typescript/src/platform/createMediaService.expo.d.ts +1 -1
  552. package/lib/typescript/src/platform/createMediaService.native.d.ts +1 -1
  553. package/lib/typescript/src/platform/dynamicModule.d.ts +1 -1
  554. package/lib/typescript/src/platform/types.d.ts +5 -5
  555. package/lib/typescript/src/types.d.ts +13 -4
  556. package/lib/typescript/src/utils/common.d.ts +1 -0
  557. package/lib/typescript/src/version.d.ts +1 -1
  558. package/package.json +11 -11
  559. package/src/components/ChannelCover.tsx +23 -3
  560. package/src/components/ChatFlatList.tsx +2 -1
  561. package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +17 -12
  562. package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +25 -18
  563. package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +20 -10
  564. package/src/components/MessageRenderer/MessageIncomingAvatar.tsx +9 -2
  565. package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +82 -14
  566. package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +135 -61
  567. package/src/components/MessageRenderer/UserMessage/index.tsx +8 -1
  568. package/src/components/MessageRenderer/index.tsx +40 -8
  569. package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +106 -0
  570. package/src/components/ReactionAddons/MessageReactionAddon.tsx +123 -0
  571. package/src/components/ReactionAddons/ReactionRoundedButton.tsx +71 -0
  572. package/src/components/ReactionAddons/index.tsx +7 -0
  573. package/src/components/ReactionBottomSheets/ReactionListBottomSheet.tsx +113 -0
  574. package/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.tsx +249 -0
  575. package/src/components/ReactionBottomSheets/index.tsx +24 -0
  576. package/src/components/TypedPlaceholder.tsx +4 -4
  577. package/src/components/UserActionBar.tsx +10 -4
  578. package/src/constants.ts +2 -0
  579. package/src/containers/GroupChannelPreviewContainer.tsx +8 -1
  580. package/src/containers/SendbirdUIKitContainer.tsx +161 -84
  581. package/src/contexts/{Localization.tsx → LocalizationCtx.tsx} +0 -0
  582. package/src/contexts/{PlatformService.tsx → PlatformServiceCtx.tsx} +0 -0
  583. package/src/contexts/ReactionCtx.tsx +102 -0
  584. package/src/contexts/{SendbirdChat.tsx → SendbirdChatCtx.tsx} +34 -6
  585. package/src/contexts/UserProfileCtx.tsx +135 -0
  586. package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +57 -29
  587. package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +56 -13
  588. package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +138 -41
  589. package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +27 -10
  590. package/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.tsx +173 -0
  591. package/src/domain/groupChannel/index.ts +1 -0
  592. package/src/domain/groupChannel/module/createGroupChannelModule.tsx +12 -1
  593. package/src/domain/groupChannel/module/moduleContext.tsx +4 -4
  594. package/src/domain/groupChannel/types.ts +29 -6
  595. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.tsx +14 -0
  596. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +33 -0
  597. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.tsx +18 -0
  598. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.tsx +19 -0
  599. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.tsx +18 -0
  600. package/src/domain/groupChannelBannedUsers/index.ts +6 -0
  601. package/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.tsx +21 -0
  602. package/src/domain/groupChannelBannedUsers/module/moduleContext.tsx +30 -0
  603. package/src/domain/groupChannelBannedUsers/types.ts +50 -0
  604. package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -1
  605. package/src/domain/groupChannelList/component/GroupChannelListTypeSelector.tsx +37 -43
  606. package/src/domain/groupChannelList/types.ts +3 -9
  607. package/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.tsx +14 -0
  608. package/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.tsx +84 -0
  609. package/src/domain/groupChannelModeration/index.ts +4 -0
  610. package/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.tsx +15 -0
  611. package/src/domain/groupChannelModeration/module/moduleContext.tsx +33 -0
  612. package/src/domain/groupChannelModeration/types.ts +48 -0
  613. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.tsx +14 -0
  614. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +31 -0
  615. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.tsx +18 -0
  616. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.tsx +19 -0
  617. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.tsx +18 -0
  618. package/src/domain/groupChannelMutedMembers/index.ts +7 -0
  619. package/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.tsx +21 -0
  620. package/src/domain/groupChannelMutedMembers/module/moduleContext.tsx +30 -0
  621. package/src/domain/groupChannelMutedMembers/types.ts +50 -0
  622. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.tsx +14 -0
  623. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.tsx +128 -0
  624. package/src/domain/groupChannelNotifications/index.ts +4 -0
  625. package/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.tsx +15 -0
  626. package/src/domain/groupChannelNotifications/module/moduleContext.tsx +31 -0
  627. package/src/domain/groupChannelNotifications/types.ts +38 -0
  628. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.tsx +25 -0
  629. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +30 -0
  630. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.tsx +18 -0
  631. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.tsx +19 -0
  632. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.tsx +18 -0
  633. package/src/domain/groupChannelOperators/index.ts +7 -0
  634. package/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.tsx +21 -0
  635. package/src/domain/groupChannelOperators/module/moduleContext.tsx +30 -0
  636. package/src/domain/groupChannelOperators/types.ts +52 -0
  637. package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +2 -7
  638. package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +51 -3
  639. package/src/domain/groupChannelSettings/module/moduleContext.tsx +9 -12
  640. package/src/domain/groupChannelSettings/types.ts +4 -0
  641. package/src/domain/groupChannelUserList/types.ts +31 -11
  642. package/src/domain/userList/component/UserListList.tsx +5 -1
  643. package/src/domain/userList/component/UserListStatusError.tsx +2 -2
  644. package/src/domain/userList/module/createUserListModule.tsx +3 -1
  645. package/src/domain/userList/types.ts +4 -1
  646. package/src/fragments/createGroupChannelBannedUsersFragment.tsx +80 -0
  647. package/src/fragments/createGroupChannelCreateFragment.tsx +18 -32
  648. package/src/fragments/createGroupChannelFragment.tsx +31 -11
  649. package/src/fragments/createGroupChannelInviteFragment.tsx +28 -50
  650. package/src/fragments/createGroupChannelListFragment.tsx +4 -10
  651. package/src/fragments/createGroupChannelMembersFragment.tsx +110 -67
  652. package/src/fragments/createGroupChannelModerationFragment.tsx +57 -0
  653. package/src/fragments/createGroupChannelMutedMembersFragment.tsx +93 -0
  654. package/src/fragments/createGroupChannelNotificationsFragment.tsx +27 -0
  655. package/src/fragments/createGroupChannelOperatorsFragment.tsx +101 -0
  656. package/src/fragments/createGroupChannelRegisterOperatorFragment.tsx +94 -0
  657. package/src/fragments/createGroupChannelSettingsFragment.tsx +11 -1
  658. package/src/hooks/useConnection.ts +5 -1
  659. package/src/hooks/useContext.ts +17 -3
  660. package/src/hooks/useKeyboardStatus.ts +54 -0
  661. package/src/hooks/useMentionSuggestion.ts +106 -0
  662. package/src/hooks/useMentionTextInput.ts +139 -0
  663. package/src/index.ts +22 -5
  664. package/src/libs/EmojiManager.ts +80 -0
  665. package/src/libs/MentionConfig.ts +40 -0
  666. package/src/libs/MentionManager.tsx +240 -0
  667. package/src/localization/StringSet.type.ts +137 -22
  668. package/src/platform/createFileService.native.ts +1 -1
  669. package/src/types.ts +12 -0
  670. package/src/utils/common.ts +8 -0
  671. package/src/version.ts +1 -1
  672. package/lib/commonjs/contexts/Localization.js.map +0 -1
  673. package/lib/commonjs/contexts/PlatformService.js.map +0 -1
  674. package/lib/commonjs/contexts/SendbirdChat.js.map +0 -1
  675. package/lib/module/contexts/Localization.js.map +0 -1
  676. package/lib/module/contexts/PlatformService.js.map +0 -1
  677. package/lib/module/contexts/SendbirdChat.js.map +0 -1
@@ -0,0 +1,135 @@
1
+ import React, { useCallback, useContext, useState } from 'react';
2
+ import { useSafeAreaInsets } from 'react-native-safe-area-context';
3
+
4
+ import { Modal, OutlinedButton, ProfileCard, createStyleSheet } from '@sendbird/uikit-react-native-foundation';
5
+ import type {
6
+ SendbirdGroupChannel,
7
+ SendbirdGroupChannelCreateParams,
8
+ SendbirdMember,
9
+ SendbirdUser,
10
+ } from '@sendbird/uikit-utils';
11
+ import { Logger, PASS, useIIFE } from '@sendbird/uikit-utils';
12
+
13
+ import { LocalizationContext } from '../contexts/LocalizationCtx';
14
+ import { SendbirdChatContext } from '../contexts/SendbirdChatCtx';
15
+
16
+ type OnCreateChannel = (channel: SendbirdGroupChannel) => void;
17
+ type OnBeforeCreateChannel = (
18
+ channelParams: SendbirdGroupChannelCreateParams,
19
+ users: SendbirdUser[] | SendbirdMember[],
20
+ ) => SendbirdGroupChannelCreateParams | Promise<SendbirdGroupChannelCreateParams>;
21
+
22
+ export type UserProfileContextType = {
23
+ show(user: SendbirdUser | SendbirdMember): void;
24
+ hide(): void;
25
+ };
26
+
27
+ type Props = React.PropsWithChildren<{
28
+ onCreateChannel?: OnCreateChannel;
29
+ onBeforeCreateChannel?: OnBeforeCreateChannel;
30
+ }>;
31
+
32
+ let WARN_onCreateChannel = false;
33
+
34
+ export const UserProfileContext = React.createContext<UserProfileContextType | null>(null);
35
+ export const UserProfileProvider = ({ children, onCreateChannel, onBeforeCreateChannel = PASS }: Props) => {
36
+ const chatContext = useContext(SendbirdChatContext);
37
+ const localizationContext = useContext(LocalizationContext);
38
+
39
+ if (!chatContext) throw new Error('SendbirdChatContext is not provided');
40
+ if (!localizationContext) throw new Error('LocalizationContext is not provided');
41
+
42
+ if (__DEV__ && !WARN_onCreateChannel && !onCreateChannel) {
43
+ Logger.warn(
44
+ 'You should pass `userProfile.onCreateChannel` prop to SendbirdUIKitContainer if want to use message in a user profile',
45
+ );
46
+ WARN_onCreateChannel = true;
47
+ }
48
+
49
+ const { bottom, left, right } = useSafeAreaInsets();
50
+
51
+ const [user, setUser] = useState<SendbirdUser | SendbirdMember>();
52
+ const [visible, setVisible] = useState(false);
53
+
54
+ const show: UserProfileContextType['show'] = useCallback((user) => {
55
+ setUser(user);
56
+ setVisible(true);
57
+ }, []);
58
+
59
+ const hide: UserProfileContextType['hide'] = useCallback(() => {
60
+ setVisible(false);
61
+ }, []);
62
+
63
+ const userProfileButton = useIIFE(() => {
64
+ const isMe = chatContext.currentUser && user?.userId === chatContext.currentUser.userId;
65
+ if (isMe) return undefined;
66
+
67
+ const onPressMessageButton = async () => {
68
+ if (user) {
69
+ const params: SendbirdGroupChannelCreateParams = {
70
+ invitedUserIds: [user.userId],
71
+ name: '',
72
+ coverUrl: '',
73
+ isDistinct: false,
74
+ };
75
+
76
+ if (chatContext.currentUser) params.operatorUserIds = [chatContext.currentUser.userId];
77
+ const processedParams = await onBeforeCreateChannel(params, [user]);
78
+
79
+ hide();
80
+ const channel = await chatContext.sdk.groupChannel.createChannel(processedParams);
81
+
82
+ if (onCreateChannel) {
83
+ onCreateChannel(channel);
84
+ } else {
85
+ Logger.warn(
86
+ 'Please set `onCreateChannel` before message to user from profile card, see `userProfile` prop in the `SendbirdUIKitContainer` props',
87
+ );
88
+ }
89
+ }
90
+ };
91
+
92
+ return (
93
+ <OutlinedButton onPress={onPressMessageButton}>
94
+ {localizationContext.STRINGS.PROFILE_CARD.BUTTON_MESSAGE}
95
+ </OutlinedButton>
96
+ );
97
+ });
98
+
99
+ return (
100
+ <UserProfileContext.Provider value={{ show, hide }}>
101
+ {children}
102
+ <Modal
103
+ type={'slide'}
104
+ onClose={hide}
105
+ onDismiss={() => setUser(undefined)}
106
+ visible={visible && Boolean(user)}
107
+ backgroundStyle={styles.modal}
108
+ >
109
+ {user && (
110
+ <ProfileCard
111
+ containerStyle={[
112
+ styles.profileCardContainer,
113
+ { paddingLeft: left, paddingRight: right, paddingBottom: bottom },
114
+ ]}
115
+ uri={user.profileUrl}
116
+ username={user.nickname || localizationContext.STRINGS.LABELS.USER_NO_NAME}
117
+ bodyLabel={localizationContext.STRINGS.PROFILE_CARD.BODY_LABEL}
118
+ body={localizationContext.STRINGS.PROFILE_CARD.BODY(user)}
119
+ button={userProfileButton}
120
+ />
121
+ )}
122
+ </Modal>
123
+ </UserProfileContext.Provider>
124
+ );
125
+ };
126
+
127
+ const styles = createStyleSheet({
128
+ modal: {
129
+ justifyContent: 'flex-end',
130
+ },
131
+ profileCardContainer: {
132
+ borderTopLeftRadius: 8,
133
+ borderTopRightRadius: 8,
134
+ },
135
+ });
@@ -1,58 +1,86 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import { Platform, TextInput as RNTextInput, View } from 'react-native';
1
+ import React, { forwardRef } from 'react';
2
+ import {
3
+ NativeSyntheticEvent,
4
+ Platform,
5
+ TextInput as RNTextInput,
6
+ TextInputSelectionChangeEventData,
7
+ View,
8
+ } from 'react-native';
3
9
 
10
+ import { MentionType } from '@sendbird/chat/message';
4
11
  import { Button, TextInput, createStyleSheet, useToast } from '@sendbird/uikit-react-native-foundation';
5
12
  import type { SendbirdFileMessage, SendbirdUserMessage } from '@sendbird/uikit-utils';
6
13
 
7
- import { useLocalization } from '../../../../hooks/useContext';
14
+ import { useLocalization, useSendbirdChat } from '../../../../hooks/useContext';
15
+ import type { MentionedUser } from '../../../../types';
8
16
  import type { GroupChannelProps } from '../../types';
9
17
 
10
18
  type EditInputProps = GroupChannelProps['Input'] & {
11
19
  text: string;
12
- setText: (val: string) => void;
13
- editMessage: SendbirdUserMessage | SendbirdFileMessage;
14
- setEditMessage: (msg?: SendbirdUserMessage | SendbirdFileMessage) => void;
20
+ onChangeText: (val: string) => void;
21
+ messageToEdit: SendbirdUserMessage | SendbirdFileMessage;
22
+ setMessageToEdit: (msg?: SendbirdUserMessage | SendbirdFileMessage) => void;
23
+ onSelectionChange: (e: NativeSyntheticEvent<TextInputSelectionChangeEventData>) => void;
24
+ disabled: boolean;
25
+ autoFocus: boolean;
26
+ mentionedUsers: MentionedUser[];
15
27
  };
16
28
 
17
- const AUTO_FOCUS = Platform.select({ ios: false, android: true, default: false });
18
- const EditInput = ({ text, setText, editMessage, setEditMessage, onUpdateUserMessage }: EditInputProps) => {
29
+ const EditInput = forwardRef<RNTextInput, EditInputProps>(function EditInput(
30
+ {
31
+ text,
32
+ onChangeText,
33
+ messageToEdit,
34
+ setMessageToEdit,
35
+ onUpdateUserMessage,
36
+ onSelectionChange,
37
+ disabled,
38
+ autoFocus,
39
+ mentionedUsers,
40
+ },
41
+ ref,
42
+ ) {
43
+ const { mentionManager } = useSendbirdChat();
19
44
  const { STRINGS } = useLocalization();
20
- const inputRef = useRef<RNTextInput>(null);
21
45
  const toast = useToast();
22
46
 
23
- useEffect(() => {
24
- if (editMessage.isUserMessage()) {
25
- setText(editMessage.message ?? '');
26
-
27
- if (!AUTO_FOCUS) setTimeout(() => inputRef.current?.focus(), 500);
28
- }
29
- }, [editMessage]);
30
-
31
47
  const onPressCancel = () => {
32
- setEditMessage();
33
- setText('');
48
+ setMessageToEdit();
49
+ onChangeText('');
34
50
  };
35
51
 
36
52
  const onPressSave = () => {
37
- if (editMessage.isUserMessage()) {
38
- onUpdateUserMessage(text, editMessage).catch(() => toast.show(STRINGS.TOAST.UPDATE_MSG_ERROR, 'error'));
53
+ if (messageToEdit.isUserMessage()) {
54
+ const mention = {
55
+ userIds: mentionedUsers.map((it) => it.user.userId),
56
+ messageTemplate: mentionManager.textToMentionedMessageTemplate(text, mentionedUsers),
57
+ type: MentionType.USERS,
58
+ };
59
+
60
+ onUpdateUserMessage(text, messageToEdit, mention).catch(() =>
61
+ toast.show(STRINGS.TOAST.UPDATE_MSG_ERROR, 'error'),
62
+ );
39
63
  }
40
- setEditMessage();
41
- setText('');
64
+ setMessageToEdit();
65
+ onChangeText('');
42
66
  };
43
67
 
44
68
  return (
45
69
  <View style={styles.editInputContainer}>
46
70
  <View style={styles.inputWrapper}>
47
71
  <TextInput
48
- autoFocus={AUTO_FOCUS}
49
- ref={inputRef}
72
+ ref={ref}
50
73
  multiline
51
- value={text}
52
- onChangeText={setText}
74
+ disableFullscreenUI
75
+ editable={!disabled}
76
+ autoFocus={autoFocus}
77
+ onChangeText={onChangeText}
53
78
  style={styles.input}
54
79
  placeholder={STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_ACTIVE}
55
- />
80
+ onSelectionChange={onSelectionChange}
81
+ >
82
+ {mentionManager.textToMentionedComponents(text, mentionedUsers)}
83
+ </TextInput>
56
84
  </View>
57
85
  <View style={{ marginTop: 8, flexDirection: 'row' }}>
58
86
  <Button variant={'text'} onPress={onPressCancel}>
@@ -65,7 +93,7 @@ const EditInput = ({ text, setText, editMessage, setEditMessage, onUpdateUserMes
65
93
  </View>
66
94
  </View>
67
95
  );
68
- };
96
+ });
69
97
 
70
98
  const styles = createStyleSheet({
71
99
  editInputContainer: {
@@ -1,6 +1,14 @@
1
- import React from 'react';
2
- import { Platform, TouchableOpacity, View } from 'react-native';
1
+ import React, { forwardRef } from 'react';
2
+ import {
3
+ NativeSyntheticEvent,
4
+ Platform,
5
+ TextInput as RNTextInput,
6
+ TextInputSelectionChangeEventData,
7
+ TouchableOpacity,
8
+ View,
9
+ } from 'react-native';
3
10
 
11
+ import { MentionType } from '@sendbird/chat/message';
4
12
  import {
5
13
  Icon,
6
14
  TextInput,
@@ -12,17 +20,36 @@ import {
12
20
  } from '@sendbird/uikit-react-native-foundation';
13
21
  import { conditionChaining } from '@sendbird/uikit-utils';
14
22
 
15
- import { useLocalization, usePlatformService } from '../../../../hooks/useContext';
23
+ import { useLocalization, usePlatformService, useSendbirdChat } from '../../../../hooks/useContext';
16
24
  import SBUError from '../../../../libs/SBUError';
17
25
  import SBUUtils from '../../../../libs/SBUUtils';
26
+ import type { MentionedUser } from '../../../../types';
18
27
  import type { GroupChannelProps } from '../../types';
19
28
 
20
29
  type SendInputProps = GroupChannelProps['Input'] & {
21
30
  text: string;
22
- setText: (val: string) => void;
31
+ onChangeText: (val: string) => void;
32
+ frozen: boolean;
33
+ muted: boolean;
23
34
  disabled: boolean;
35
+ onSelectionChange: (e: NativeSyntheticEvent<TextInputSelectionChangeEventData>) => void;
36
+ mentionedUsers: MentionedUser[];
24
37
  };
25
- const SendInput = ({ onSendUserMessage, onSendFileMessage, text, setText, disabled }: SendInputProps) => {
38
+ const SendInput = forwardRef<RNTextInput, SendInputProps>(function SendInput(
39
+ {
40
+ onSendUserMessage,
41
+ onSendFileMessage,
42
+ text,
43
+ onChangeText,
44
+ disabled,
45
+ frozen,
46
+ muted,
47
+ onSelectionChange,
48
+ mentionedUsers,
49
+ },
50
+ ref,
51
+ ) {
52
+ const { mentionManager } = useSendbirdChat();
26
53
  const { STRINGS } = useLocalization();
27
54
  const { fileService } = usePlatformService();
28
55
  const { colors } = useUIKitTheme();
@@ -31,9 +58,16 @@ const SendInput = ({ onSendUserMessage, onSendFileMessage, text, setText, disabl
31
58
  const toast = useToast();
32
59
 
33
60
  const onPressSend = () => {
34
- onSendUserMessage(text).catch(() => toast.show(STRINGS.TOAST.SEND_MSG_ERROR, 'error'));
35
- setText('');
61
+ const mention = {
62
+ userIds: mentionedUsers.map((it) => it.user.userId),
63
+ messageTemplate: mentionManager.textToMentionedMessageTemplate(text, mentionedUsers),
64
+ type: MentionType.USERS,
65
+ };
66
+
67
+ onSendUserMessage(text, mention).catch(() => toast.show(STRINGS.TOAST.SEND_MSG_ERROR, 'error'));
68
+ onChangeText('');
36
69
  };
70
+
37
71
  const onPressAttachment = () => {
38
72
  openSheet({
39
73
  sheetItems: [
@@ -114,16 +148,25 @@ const SendInput = ({ onSendUserMessage, onSendFileMessage, text, setText, disabl
114
148
  />
115
149
  </TouchableOpacity>
116
150
  <TextInput
151
+ ref={ref}
117
152
  multiline
153
+ disableFullscreenUI
154
+ onSelectionChange={onSelectionChange}
118
155
  editable={!disabled}
119
- value={text}
120
- onChangeText={setText}
156
+ onChangeText={onChangeText}
121
157
  style={styles.input}
122
158
  placeholder={conditionChaining(
123
- [disabled],
124
- [STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_DISABLED, STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_ACTIVE],
159
+ [frozen, muted],
160
+ [
161
+ STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_DISABLED,
162
+ STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_MUTED,
163
+ STRINGS.GROUP_CHANNEL.INPUT_PLACEHOLDER_ACTIVE,
164
+ ],
125
165
  )}
126
- />
166
+ >
167
+ {mentionManager.textToMentionedComponents(text, mentionedUsers)}
168
+ </TextInput>
169
+
127
170
  {Boolean(text.trim()) && (
128
171
  <TouchableOpacity onPress={onPressSend} disabled={disabled}>
129
172
  <Icon
@@ -136,7 +179,7 @@ const SendInput = ({ onSendUserMessage, onSendFileMessage, text, setText, disabl
136
179
  )}
137
180
  </View>
138
181
  );
139
- };
182
+ });
140
183
 
141
184
  const styles = createStyleSheet({
142
185
  sendInputContainer: {
@@ -1,72 +1,169 @@
1
- import React, { useContext, useEffect, useRef, useState } from 'react';
2
- import { KeyboardAvoidingView, Platform, View } from 'react-native';
1
+ import React, { MutableRefObject, useContext, useEffect, useRef, useState } from 'react';
2
+ import { KeyboardAvoidingView, Platform, TextInput, View } from 'react-native';
3
3
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
4
 
5
- import { useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
6
- import { isGroupChannelChatUnavailable, useIIFE } from '@sendbird/uikit-utils';
5
+ import { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
6
+ import {
7
+ SendbirdFileMessage,
8
+ SendbirdGroupChannel,
9
+ SendbirdUserMessage,
10
+ getGroupChannelChatAvailableState,
11
+ replace,
12
+ useIIFE,
13
+ } from '@sendbird/uikit-utils';
7
14
 
15
+ import { useSendbirdChat } from '../../../../hooks/useContext';
16
+ import useMentionTextInput from '../../../../hooks/useMentionTextInput';
8
17
  import { GroupChannelContexts } from '../../module/moduleContext';
9
18
  import type { GroupChannelProps } from '../../types';
10
19
  import EditInput from './EditInput';
11
20
  import SendInput from './SendInput';
12
21
 
22
+ const AUTO_FOCUS = Platform.select({ ios: false, android: true, default: false });
13
23
  const KEYBOARD_AVOID_VIEW_BEHAVIOR = Platform.select({ ios: 'padding' as const, default: undefined });
14
- const GroupChannelInput = (props: GroupChannelProps['Input']) => {
15
- const { channel } = props;
16
24
 
17
- const { left, right, bottom } = useSafeAreaInsets();
25
+ // FIXME(iOS): Dynamic style does not work properly when typing the CJK. (https://github.com/facebook/react-native/issues/26107)
26
+ // To workaround temporarily, change the key for re-mount the component.
27
+ const GET_INPUT_KEY = (shouldReset: boolean) => (shouldReset ? 'uikit-input-clear' : 'uikit-input');
28
+
29
+ // TODO: Refactor 'Edit' mode to clearly
30
+ const GroupChannelInput = (props: GroupChannelProps['Input']) => {
31
+ const { top, left, right, bottom } = useSafeAreaInsets();
18
32
  const { colors } = useUIKitTheme();
19
- const { editMessage, setEditMessage, keyboardAvoidOffset = 0 } = useContext(GroupChannelContexts.Fragment);
33
+ const { features, mentionManager } = useSendbirdChat();
34
+ const {
35
+ channel,
36
+ messageToEdit,
37
+ setMessageToEdit,
38
+ keyboardAvoidOffset = 0,
39
+ } = useContext(GroupChannelContexts.Fragment);
20
40
 
21
- const [text, setText] = useState('');
22
- const textTmpRef = useRef('');
23
- const isChatUnavailable = isGroupChannelChatUnavailable(channel);
41
+ const chatAvailableState = getGroupChannelChatAvailableState(channel);
42
+ const mentionAvailable = features.userMentionEnabled && channel.isGroupChannel() && !channel.isBroadcast;
43
+ const inputMode = useIIFE(() => {
44
+ if (!messageToEdit) return 'send';
45
+ if (messageToEdit.isFileMessage()) return 'send';
46
+ return 'edit';
47
+ });
48
+
49
+ const [inputHeight, setInputHeight] = useState(styles.inputDefault.height);
50
+
51
+ const { selection, onSelectionChange, textInputRef, text, onChangeText, mentionedUsers } = useMentionTextInput({
52
+ messageToEdit: messageToEdit,
53
+ });
54
+
55
+ useTypingTrigger(text, channel);
56
+ useTextPersistenceOnDisabled(text, onChangeText, chatAvailableState.disabled);
57
+ useAutoFocusOnEditMode(textInputRef, messageToEdit);
58
+
59
+ const onPressToMention: GroupChannelProps['SuggestedMentionList']['onPressToMention'] = (user, searchStringRange) => {
60
+ const mentionedMessageText = mentionManager.asMentionedMessageText(user, true);
61
+ const range = { start: searchStringRange.start, end: searchStringRange.start + mentionedMessageText.length - 1 };
62
+
63
+ onChangeText(replace(text, searchStringRange.start, searchStringRange.end, mentionedMessageText), { user, range });
64
+ };
65
+
66
+ if (!props.shouldRenderInput) {
67
+ return <SafeAreaBottom height={bottom} />;
68
+ }
69
+
70
+ return (
71
+ <>
72
+ <KeyboardAvoidingView
73
+ keyboardVerticalOffset={-bottom + keyboardAvoidOffset}
74
+ behavior={KEYBOARD_AVOID_VIEW_BEHAVIOR}
75
+ >
76
+ <View style={{ paddingLeft: left, paddingRight: right, backgroundColor: colors.background }}>
77
+ <View onLayout={(e) => setInputHeight(e.nativeEvent.layout.height)} style={styles.inputContainer}>
78
+ {inputMode === 'send' && (
79
+ <SendInput
80
+ {...props}
81
+ {...chatAvailableState}
82
+ key={GET_INPUT_KEY(mentionedUsers.length === 0)}
83
+ ref={textInputRef as never}
84
+ text={text}
85
+ onChangeText={onChangeText}
86
+ onSelectionChange={onSelectionChange}
87
+ mentionedUsers={mentionedUsers}
88
+ />
89
+ )}
90
+ {inputMode === 'edit' && messageToEdit && (
91
+ <EditInput
92
+ {...props}
93
+ key={GET_INPUT_KEY(mentionedUsers.length === 0)}
94
+ ref={textInputRef as never}
95
+ autoFocus={AUTO_FOCUS}
96
+ text={text}
97
+ onChangeText={onChangeText}
98
+ messageToEdit={messageToEdit}
99
+ setMessageToEdit={setMessageToEdit}
100
+ disabled={chatAvailableState.disabled}
101
+ onSelectionChange={onSelectionChange}
102
+ mentionedUsers={mentionedUsers}
103
+ />
104
+ )}
105
+ </View>
106
+ <SafeAreaBottom height={bottom} />
107
+ </View>
108
+ </KeyboardAvoidingView>
109
+ {mentionAvailable && (
110
+ <props.SuggestedMentionList
111
+ text={text}
112
+ selection={selection}
113
+ inputHeight={inputHeight}
114
+ topInset={top}
115
+ bottomInset={bottom}
116
+ onPressToMention={onPressToMention}
117
+ mentionedUsers={mentionedUsers}
118
+ />
119
+ )}
120
+ </>
121
+ );
122
+ };
24
123
 
124
+ const useTypingTrigger = (text: string, channel: SendbirdGroupChannel) => {
25
125
  useEffect(() => {
26
126
  if (text.length === 0) channel.endTyping();
27
127
  else channel.startTyping();
28
128
  }, [text]);
129
+ };
130
+
131
+ const useTextPersistenceOnDisabled = (text: string, setText: (val: string) => void, chatDisabled: boolean) => {
132
+ const textTmpRef = useRef('');
29
133
 
30
134
  useEffect(() => {
31
- if (isChatUnavailable) {
135
+ if (chatDisabled) {
32
136
  textTmpRef.current = text;
33
137
  setText('');
34
138
  } else {
35
139
  setText(textTmpRef.current);
36
140
  }
37
- }, [isChatUnavailable]);
38
-
39
- const inputMode = useIIFE(() => {
40
- if (!editMessage) return 'send';
41
- if (editMessage.isFileMessage()) return 'send';
42
- return 'edit';
43
- });
141
+ }, [chatDisabled]);
142
+ };
44
143
 
45
- return (
46
- <KeyboardAvoidingView
47
- keyboardVerticalOffset={-bottom + keyboardAvoidOffset}
48
- behavior={KEYBOARD_AVOID_VIEW_BEHAVIOR}
49
- >
50
- <View style={{ paddingLeft: left, paddingRight: right, backgroundColor: colors.background }}>
51
- <View style={{ justifyContent: 'center', width: '100%' }}>
52
- {inputMode === 'send' && <SendInput {...props} text={text} setText={setText} disabled={isChatUnavailable} />}
53
- {inputMode === 'edit' && editMessage && (
54
- <EditInput
55
- {...props}
56
- text={text}
57
- setText={setText}
58
- editMessage={editMessage}
59
- setEditMessage={setEditMessage}
60
- />
61
- )}
62
- </View>
63
- <SafeAreaBottom height={bottom} />
64
- </View>
65
- </KeyboardAvoidingView>
66
- );
144
+ const useAutoFocusOnEditMode = (
145
+ textInputRef: MutableRefObject<TextInput | undefined>,
146
+ messageToEdit?: SendbirdUserMessage | SendbirdFileMessage,
147
+ ) => {
148
+ useEffect(() => {
149
+ if (messageToEdit?.isUserMessage()) {
150
+ if (!AUTO_FOCUS) setTimeout(() => textInputRef.current?.focus(), 500);
151
+ }
152
+ }, [messageToEdit]);
67
153
  };
154
+
68
155
  const SafeAreaBottom = ({ height }: { height: number }) => {
69
156
  return <View style={{ height }} />;
70
157
  };
71
158
 
159
+ const styles = createStyleSheet({
160
+ inputContainer: {
161
+ justifyContent: 'center',
162
+ width: '100%',
163
+ },
164
+ inputDefault: {
165
+ height: 56,
166
+ },
167
+ });
168
+
72
169
  export default React.memo(GroupChannelInput);
@@ -19,14 +19,16 @@ import {
19
19
  getFileType,
20
20
  isMyMessage,
21
21
  messageKeyExtractor,
22
+ shouldRenderReaction,
22
23
  toMegabyte,
23
24
  useFreshCallback,
24
25
  } from '@sendbird/uikit-utils';
25
26
 
26
27
  import type { ChatFlatListRef } from '../../../components/ChatFlatList';
27
28
  import ChatFlatList from '../../../components/ChatFlatList';
29
+ import { ReactionAddons } from '../../../components/ReactionAddons';
28
30
  import { DEPRECATION_WARNING } from '../../../constants';
29
- import { useLocalization, usePlatformService } from '../../../hooks/useContext';
31
+ import { useLocalization, usePlatformService, useSendbirdChat } from '../../../hooks/useContext';
30
32
  import { GroupChannelContexts } from '../module/moduleContext';
31
33
  import type { GroupChannelProps } from '../types';
32
34
 
@@ -57,11 +59,12 @@ const GroupChannelMessageList = ({
57
59
  const scrollRef = useRef<ChatFlatListRef>(null);
58
60
  const [newMessagesInternalBuffer, setNewMessagesInternalBuffer] = useState(() => newMessagesFromMembers);
59
61
  const getMessagePressActions = useGetMessagePressActions({
62
+ channel,
63
+ currentUserId,
60
64
  onDeleteMessage,
65
+ onResendFailedMessage,
61
66
  onPressImageMessage,
62
67
  onPressMediaMessage,
63
- currentUserId,
64
- onResendFailedMessage,
65
68
  });
66
69
 
67
70
  const safeAreaLayout = { paddingLeft: left, paddingRight: right };
@@ -140,14 +143,20 @@ const GroupChannelMessageList = ({
140
143
 
141
144
  type HandleableMessage = SendbirdUserMessage | SendbirdFileMessage;
142
145
  const useGetMessagePressActions = ({
146
+ channel,
147
+ currentUserId,
148
+ onResendFailedMessage,
149
+ onDeleteMessage,
143
150
  onPressImageMessage,
144
151
  onPressMediaMessage,
145
- onDeleteMessage,
146
- onResendFailedMessage,
147
- currentUserId,
148
152
  }: Pick<
149
153
  GroupChannelProps['MessageList'],
150
- 'onDeleteMessage' | 'onResendFailedMessage' | 'currentUserId' | 'onPressImageMessage' | 'onPressMediaMessage'
154
+ | 'channel'
155
+ | 'currentUserId'
156
+ | 'onResendFailedMessage'
157
+ | 'onDeleteMessage'
158
+ | 'onPressImageMessage'
159
+ | 'onPressMediaMessage'
151
160
  >) => {
152
161
  const { colors } = useUIKitTheme();
153
162
  const { STRINGS } = useLocalization();
@@ -155,7 +164,8 @@ const useGetMessagePressActions = ({
155
164
  const { openSheet } = useBottomSheet();
156
165
  const { alert } = useAlert();
157
166
  const { clipboardService, fileService } = usePlatformService();
158
- const { setEditMessage } = useContext(GroupChannelContexts.Fragment);
167
+ const { features } = useSendbirdChat();
168
+ const { setMessageToEdit } = useContext(GroupChannelContexts.Fragment);
159
169
 
160
170
  const handleFailedMessage = (message: HandleableMessage) => {
161
171
  openSheet({
@@ -215,7 +225,7 @@ const useGetMessagePressActions = ({
215
225
  {
216
226
  icon: 'edit',
217
227
  title: STRINGS.GROUP_CHANNEL.DIALOG_MESSAGE_EDIT,
218
- onPress: () => setEditMessage(msg),
228
+ onPress: () => setMessageToEdit(msg),
219
229
  },
220
230
  {
221
231
  icon: 'delete',
@@ -278,7 +288,14 @@ const useGetMessagePressActions = ({
278
288
  }
279
289
 
280
290
  if (sheetItems.length > 0) {
281
- response.onLongPress = () => openSheet({ sheetItems });
291
+ response.onLongPress = () => {
292
+ openSheet({
293
+ sheetItems,
294
+ HeaderComponent: shouldRenderReaction(channel, features.reactionEnabled)
295
+ ? ({ onClose }) => <ReactionAddons.BottomSheet message={msg} channel={channel} onClose={onClose} />
296
+ : undefined,
297
+ });
298
+ };
282
299
  }
283
300
 
284
301
  if (msg.sendingStatus === 'failed') {