@sendbird/uikit-react-native 3.7.6 → 3.8.1

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 (1104) hide show
  1. package/lib/commonjs/components/ChannelCover.js +9 -11
  2. package/lib/commonjs/components/ChannelCover.js.map +1 -1
  3. package/lib/commonjs/components/ChannelInput/AttachmentsButton.js +7 -9
  4. package/lib/commonjs/components/ChannelInput/AttachmentsButton.js.map +1 -1
  5. package/lib/commonjs/components/ChannelInput/EditInput.js +18 -18
  6. package/lib/commonjs/components/ChannelInput/EditInput.js.map +1 -1
  7. package/lib/commonjs/components/ChannelInput/MessageToReplyPreview.js +37 -50
  8. package/lib/commonjs/components/ChannelInput/MessageToReplyPreview.js.map +1 -1
  9. package/lib/commonjs/components/ChannelInput/SendInput.js +44 -49
  10. package/lib/commonjs/components/ChannelInput/SendInput.js.map +1 -1
  11. package/lib/commonjs/components/ChannelInput/VoiceMessageInput.js +12 -14
  12. package/lib/commonjs/components/ChannelInput/VoiceMessageInput.js.map +1 -1
  13. package/lib/commonjs/components/ChannelInput/index.js +22 -27
  14. package/lib/commonjs/components/ChannelInput/index.js.map +1 -1
  15. package/lib/commonjs/components/ChannelMessageList/index.js +59 -75
  16. package/lib/commonjs/components/ChannelMessageList/index.js.map +1 -1
  17. package/lib/commonjs/components/ChannelThreadMessageList/index.js +54 -70
  18. package/lib/commonjs/components/ChannelThreadMessageList/index.js.map +1 -1
  19. package/lib/commonjs/components/ChatFlatList/FlatListInternal.js +1 -2
  20. package/lib/commonjs/components/ChatFlatList/FlatListInternal.js.map +1 -1
  21. package/lib/commonjs/components/ChatFlatList/index.js +13 -15
  22. package/lib/commonjs/components/ChatFlatList/index.js.map +1 -1
  23. package/lib/commonjs/components/FileViewer/FileViewerContent.js +18 -21
  24. package/lib/commonjs/components/FileViewer/FileViewerContent.js.map +1 -1
  25. package/lib/commonjs/components/FileViewer/FileViewerFooter.js +14 -19
  26. package/lib/commonjs/components/FileViewer/FileViewerFooter.js.map +1 -1
  27. package/lib/commonjs/components/FileViewer/FileViewerHeader.js +14 -20
  28. package/lib/commonjs/components/FileViewer/FileViewerHeader.js.map +1 -1
  29. package/lib/commonjs/components/FileViewer/index.js +15 -17
  30. package/lib/commonjs/components/FileViewer/index.js.map +1 -1
  31. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageDateSeparator.js +6 -8
  32. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageDateSeparator.js.map +1 -1
  33. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageFocusAnimation.js +3 -4
  34. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageFocusAnimation.js.map +1 -1
  35. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageOutgoingStatus.js +7 -9
  36. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageOutgoingStatus.js.map +1 -1
  37. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageParentMessage.js +18 -21
  38. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageParentMessage.js.map +1 -1
  39. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageReplyInfo.js +13 -15
  40. package/lib/commonjs/components/GroupChannelMessageRenderer/GroupChannelMessageReplyInfo.js.map +1 -1
  41. package/lib/commonjs/components/GroupChannelMessageRenderer/index.js +36 -39
  42. package/lib/commonjs/components/GroupChannelMessageRenderer/index.js.map +1 -1
  43. package/lib/commonjs/components/MessageSearchResultItem.js +20 -18
  44. package/lib/commonjs/components/MessageSearchResultItem.js.map +1 -1
  45. package/lib/commonjs/components/NewMessagesButton.js +7 -9
  46. package/lib/commonjs/components/NewMessagesButton.js.map +1 -1
  47. package/lib/commonjs/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js +6 -8
  48. package/lib/commonjs/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js.map +1 -1
  49. package/lib/commonjs/components/OpenChannelMessageRenderer/index.js +13 -15
  50. package/lib/commonjs/components/OpenChannelMessageRenderer/index.js.map +1 -1
  51. package/lib/commonjs/components/ProviderLayout.js +5 -7
  52. package/lib/commonjs/components/ProviderLayout.js.map +1 -1
  53. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +28 -42
  54. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -1
  55. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js +31 -41
  56. package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js.map +1 -1
  57. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js +14 -16
  58. package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js.map +1 -1
  59. package/lib/commonjs/components/ReactionAddons/index.js +2 -3
  60. package/lib/commonjs/components/ReactionAddons/index.js.map +1 -1
  61. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js +28 -39
  62. package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -1
  63. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +45 -51
  64. package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -1
  65. package/lib/commonjs/components/ReactionBottomSheets/index.js +2 -3
  66. package/lib/commonjs/components/ReactionBottomSheets/index.js.map +1 -1
  67. package/lib/commonjs/components/ScrollToBottomButton.js +6 -8
  68. package/lib/commonjs/components/ScrollToBottomButton.js.map +1 -1
  69. package/lib/commonjs/components/StatusComposition.js +9 -11
  70. package/lib/commonjs/components/StatusComposition.js.map +1 -1
  71. package/lib/commonjs/components/ThreadChatFlatList/index.js +13 -15
  72. package/lib/commonjs/components/ThreadChatFlatList/index.js.map +1 -1
  73. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.image.js +2 -3
  74. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.image.js.map +1 -1
  75. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.js +3 -4
  76. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.js.map +1 -1
  77. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.video.js +2 -3
  78. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.video.js.map +1 -1
  79. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.js +8 -8
  80. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.js.map +1 -1
  81. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.user.js +20 -14
  82. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.user.js.map +1 -1
  83. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.user.og.js +24 -18
  84. package/lib/commonjs/components/ThreadParentMessageRenderer/ThreadParentMessage.user.og.js.map +1 -1
  85. package/lib/commonjs/components/ThreadParentMessageRenderer/index.js +23 -22
  86. package/lib/commonjs/components/ThreadParentMessageRenderer/index.js.map +1 -1
  87. package/lib/commonjs/components/TypedPlaceholder.js +6 -8
  88. package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
  89. package/lib/commonjs/components/UserActionBar.js +20 -20
  90. package/lib/commonjs/components/UserActionBar.js.map +1 -1
  91. package/lib/commonjs/components/UserSelectableBar.js +14 -14
  92. package/lib/commonjs/components/UserSelectableBar.js.map +1 -1
  93. package/lib/commonjs/constants.js +6 -12
  94. package/lib/commonjs/constants.js.map +1 -1
  95. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +12 -14
  96. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  97. package/lib/commonjs/containers/InternalErrorBoundaryContainer.js +8 -9
  98. package/lib/commonjs/containers/InternalErrorBoundaryContainer.js.map +1 -1
  99. package/lib/commonjs/containers/SendbirdUIKitContainer.js +17 -20
  100. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  101. package/lib/commonjs/contexts/LocalizationCtx.js +6 -8
  102. package/lib/commonjs/contexts/LocalizationCtx.js.map +1 -1
  103. package/lib/commonjs/contexts/PlatformServiceCtx.js +8 -10
  104. package/lib/commonjs/contexts/PlatformServiceCtx.js.map +1 -1
  105. package/lib/commonjs/contexts/ReactionCtx.js +14 -19
  106. package/lib/commonjs/contexts/ReactionCtx.js.map +1 -1
  107. package/lib/commonjs/contexts/SBUHandlersCtx.js +7 -9
  108. package/lib/commonjs/contexts/SBUHandlersCtx.js.map +1 -1
  109. package/lib/commonjs/contexts/SendbirdChatCtx.js +16 -18
  110. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -1
  111. package/lib/commonjs/contexts/UserProfileCtx.js +13 -24
  112. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -1
  113. package/lib/commonjs/domain/groupChannel/component/GroupChannelHeader.js +14 -18
  114. package/lib/commonjs/domain/groupChannel/component/GroupChannelHeader.js.map +1 -1
  115. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput.js +9 -11
  116. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput.js.map +1 -1
  117. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +12 -16
  118. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  119. package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusEmpty.js +2 -3
  120. package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusEmpty.js.map +1 -1
  121. package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusLoading.js +2 -3
  122. package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusLoading.js.map +1 -1
  123. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +26 -34
  124. package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -1
  125. package/lib/commonjs/domain/groupChannel/index.js +1 -1
  126. package/lib/commonjs/domain/groupChannel/index.js.map +1 -1
  127. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +12 -14
  128. package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  129. package/lib/commonjs/domain/groupChannel/module/moduleContext.js +19 -22
  130. package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
  131. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  132. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +6 -8
  133. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -1
  134. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +15 -25
  135. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  136. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +2 -3
  137. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -1
  138. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +5 -7
  139. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -1
  140. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +2 -3
  141. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -1
  142. package/lib/commonjs/domain/groupChannelBannedUsers/index.js +1 -1
  143. package/lib/commonjs/domain/groupChannelBannedUsers/index.js.map +1 -1
  144. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +11 -13
  145. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -1
  146. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js +8 -10
  147. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -1
  148. package/lib/commonjs/domain/groupChannelBannedUsers/types.js.map +1 -1
  149. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListHeader.js +3 -4
  150. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -1
  151. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +20 -32
  152. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  153. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusEmpty.js +2 -3
  154. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusEmpty.js.map +1 -1
  155. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusLoading.js +2 -3
  156. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusLoading.js.map +1 -1
  157. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js +13 -17
  158. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  159. package/lib/commonjs/domain/groupChannelList/index.js +1 -1
  160. package/lib/commonjs/domain/groupChannelList/index.js.map +1 -1
  161. package/lib/commonjs/domain/groupChannelList/module/createGroupChannelListModule.js +11 -13
  162. package/lib/commonjs/domain/groupChannelList/module/createGroupChannelListModule.js.map +1 -1
  163. package/lib/commonjs/domain/groupChannelList/module/moduleContext.js +7 -9
  164. package/lib/commonjs/domain/groupChannelList/module/moduleContext.js.map +1 -1
  165. package/lib/commonjs/domain/groupChannelList/types.js.map +1 -1
  166. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +6 -8
  167. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -1
  168. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +9 -11
  169. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -1
  170. package/lib/commonjs/domain/groupChannelModeration/index.js +1 -1
  171. package/lib/commonjs/domain/groupChannelModeration/index.js.map +1 -1
  172. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +8 -10
  173. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -1
  174. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js +8 -10
  175. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js.map +1 -1
  176. package/lib/commonjs/domain/groupChannelModeration/types.js.map +1 -1
  177. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +6 -8
  178. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -1
  179. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +15 -25
  180. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  181. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +2 -3
  182. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -1
  183. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +5 -7
  184. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -1
  185. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +2 -3
  186. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -1
  187. package/lib/commonjs/domain/groupChannelMutedMembers/index.js +1 -1
  188. package/lib/commonjs/domain/groupChannelMutedMembers/index.js.map +1 -1
  189. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +11 -13
  190. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -1
  191. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js +8 -10
  192. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -1
  193. package/lib/commonjs/domain/groupChannelMutedMembers/types.js.map +1 -1
  194. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +6 -8
  195. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -1
  196. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +19 -18
  197. package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -1
  198. package/lib/commonjs/domain/groupChannelNotifications/index.js +1 -1
  199. package/lib/commonjs/domain/groupChannelNotifications/index.js.map +1 -1
  200. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +8 -10
  201. package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -1
  202. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js +8 -10
  203. package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js.map +1 -1
  204. package/lib/commonjs/domain/groupChannelNotifications/types.js.map +1 -1
  205. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +7 -9
  206. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -1
  207. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +15 -25
  208. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  209. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +2 -3
  210. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -1
  211. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +5 -7
  212. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -1
  213. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +2 -3
  214. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -1
  215. package/lib/commonjs/domain/groupChannelOperators/index.js +1 -1
  216. package/lib/commonjs/domain/groupChannelOperators/index.js.map +1 -1
  217. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +11 -13
  218. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -1
  219. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js +8 -10
  220. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js.map +1 -1
  221. package/lib/commonjs/domain/groupChannelOperators/types.js.map +1 -1
  222. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js +6 -8
  223. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -1
  224. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +4 -5
  225. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  226. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +12 -14
  227. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  228. package/lib/commonjs/domain/groupChannelSettings/index.js +1 -1
  229. package/lib/commonjs/domain/groupChannelSettings/index.js.map +1 -1
  230. package/lib/commonjs/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js +9 -11
  231. package/lib/commonjs/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js.map +1 -1
  232. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +10 -13
  233. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  234. package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
  235. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadHeader.js +11 -15
  236. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadHeader.js.map +1 -1
  237. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadInput.js +9 -11
  238. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadInput.js.map +1 -1
  239. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadMessageList.js +12 -16
  240. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadMessageList.js.map +1 -1
  241. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadParentMessageInfo.js +34 -37
  242. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadParentMessageInfo.js.map +1 -1
  243. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadStatusEmpty.js +2 -3
  244. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadStatusEmpty.js.map +1 -1
  245. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadStatusLoading.js +2 -3
  246. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadStatusLoading.js.map +1 -1
  247. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.js +25 -33
  248. package/lib/commonjs/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.js.map +1 -1
  249. package/lib/commonjs/domain/groupChannelThread/index.js +1 -1
  250. package/lib/commonjs/domain/groupChannelThread/index.js.map +1 -1
  251. package/lib/commonjs/domain/groupChannelThread/module/createGroupChannelThreadModule.js +13 -15
  252. package/lib/commonjs/domain/groupChannelThread/module/createGroupChannelThreadModule.js.map +1 -1
  253. package/lib/commonjs/domain/groupChannelThread/module/moduleContext.js +12 -14
  254. package/lib/commonjs/domain/groupChannelThread/module/moduleContext.js.map +1 -1
  255. package/lib/commonjs/domain/groupChannelThread/types.js.map +1 -1
  256. package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
  257. package/lib/commonjs/domain/messageSearch/component/MessageSearchHeader.js +18 -18
  258. package/lib/commonjs/domain/messageSearch/component/MessageSearchHeader.js.map +1 -1
  259. package/lib/commonjs/domain/messageSearch/component/MessageSearchList.js +13 -16
  260. package/lib/commonjs/domain/messageSearch/component/MessageSearchList.js.map +1 -1
  261. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusEmpty.js +2 -3
  262. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusEmpty.js.map +1 -1
  263. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusError.js +5 -7
  264. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusError.js.map +1 -1
  265. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusLoading.js +2 -3
  266. package/lib/commonjs/domain/messageSearch/component/MessageSearchStatusLoading.js.map +1 -1
  267. package/lib/commonjs/domain/messageSearch/index.js +1 -1
  268. package/lib/commonjs/domain/messageSearch/index.js.map +1 -1
  269. package/lib/commonjs/domain/messageSearch/module/createMessageSearchModule.js +11 -13
  270. package/lib/commonjs/domain/messageSearch/module/createMessageSearchModule.js.map +1 -1
  271. package/lib/commonjs/domain/messageSearch/module/moduleContext.js +7 -9
  272. package/lib/commonjs/domain/messageSearch/module/moduleContext.js.map +1 -1
  273. package/lib/commonjs/domain/messageSearch/types.js.map +1 -1
  274. package/lib/commonjs/domain/openChannel/component/OpenChannelHeader.js +10 -12
  275. package/lib/commonjs/domain/openChannel/component/OpenChannelHeader.js.map +1 -1
  276. package/lib/commonjs/domain/openChannel/component/OpenChannelInput.js +9 -11
  277. package/lib/commonjs/domain/openChannel/component/OpenChannelInput.js.map +1 -1
  278. package/lib/commonjs/domain/openChannel/component/OpenChannelMessageList.js +10 -13
  279. package/lib/commonjs/domain/openChannel/component/OpenChannelMessageList.js.map +1 -1
  280. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusEmpty.js +2 -3
  281. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusEmpty.js.map +1 -1
  282. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusLoading.js +2 -3
  283. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusLoading.js.map +1 -1
  284. package/lib/commonjs/domain/openChannel/index.js +1 -1
  285. package/lib/commonjs/domain/openChannel/index.js.map +1 -1
  286. package/lib/commonjs/domain/openChannel/module/createOpenChannelModule.js +11 -13
  287. package/lib/commonjs/domain/openChannel/module/createOpenChannelModule.js.map +1 -1
  288. package/lib/commonjs/domain/openChannel/module/moduleContext.js +10 -12
  289. package/lib/commonjs/domain/openChannel/module/moduleContext.js.map +1 -1
  290. package/lib/commonjs/domain/openChannel/types.js.map +1 -1
  291. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js +6 -8
  292. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js.map +1 -1
  293. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js +15 -25
  294. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js.map +1 -1
  295. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js +2 -3
  296. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js.map +1 -1
  297. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js +5 -7
  298. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js.map +1 -1
  299. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js +2 -3
  300. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js.map +1 -1
  301. package/lib/commonjs/domain/openChannelBannedUsers/index.js +1 -1
  302. package/lib/commonjs/domain/openChannelBannedUsers/index.js.map +1 -1
  303. package/lib/commonjs/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js +11 -13
  304. package/lib/commonjs/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js.map +1 -1
  305. package/lib/commonjs/domain/openChannelBannedUsers/module/moduleContext.js +8 -10
  306. package/lib/commonjs/domain/openChannelBannedUsers/module/moduleContext.js.map +1 -1
  307. package/lib/commonjs/domain/openChannelBannedUsers/types.js.map +1 -1
  308. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateHeader.js +8 -10
  309. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateHeader.js.map +1 -1
  310. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js +14 -16
  311. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js.map +1 -1
  312. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js +2 -3
  313. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js.map +1 -1
  314. package/lib/commonjs/domain/openChannelCreate/index.js +1 -1
  315. package/lib/commonjs/domain/openChannelCreate/index.js.map +1 -1
  316. package/lib/commonjs/domain/openChannelCreate/module/createOpenChannelCreateModule.js +9 -11
  317. package/lib/commonjs/domain/openChannelCreate/module/createOpenChannelCreateModule.js.map +1 -1
  318. package/lib/commonjs/domain/openChannelCreate/module/moduleContext.js +7 -9
  319. package/lib/commonjs/domain/openChannelCreate/module/moduleContext.js.map +1 -1
  320. package/lib/commonjs/domain/openChannelCreate/types.js.map +1 -1
  321. package/lib/commonjs/domain/openChannelList/component/OpenChannelListHeader.js +6 -8
  322. package/lib/commonjs/domain/openChannelList/component/OpenChannelListHeader.js.map +1 -1
  323. package/lib/commonjs/domain/openChannelList/component/OpenChannelListList.js +20 -32
  324. package/lib/commonjs/domain/openChannelList/component/OpenChannelListList.js.map +1 -1
  325. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusEmpty.js +2 -3
  326. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusEmpty.js.map +1 -1
  327. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusError.js +5 -7
  328. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusError.js.map +1 -1
  329. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusLoading.js +2 -3
  330. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusLoading.js.map +1 -1
  331. package/lib/commonjs/domain/openChannelList/index.js +1 -1
  332. package/lib/commonjs/domain/openChannelList/index.js.map +1 -1
  333. package/lib/commonjs/domain/openChannelList/module/createOpenChannelListModule.js +11 -13
  334. package/lib/commonjs/domain/openChannelList/module/createOpenChannelListModule.js.map +1 -1
  335. package/lib/commonjs/domain/openChannelList/module/moduleContext.js +7 -9
  336. package/lib/commonjs/domain/openChannelList/module/moduleContext.js.map +1 -1
  337. package/lib/commonjs/domain/openChannelList/types.js.map +1 -1
  338. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationHeader.js +6 -8
  339. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationHeader.js.map +1 -1
  340. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationMenu.js +8 -10
  341. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationMenu.js.map +1 -1
  342. package/lib/commonjs/domain/openChannelModeration/index.js +1 -1
  343. package/lib/commonjs/domain/openChannelModeration/index.js.map +1 -1
  344. package/lib/commonjs/domain/openChannelModeration/module/createOpenChannelModerationModule.js +8 -10
  345. package/lib/commonjs/domain/openChannelModeration/module/createOpenChannelModerationModule.js.map +1 -1
  346. package/lib/commonjs/domain/openChannelModeration/module/moduleContext.js +8 -10
  347. package/lib/commonjs/domain/openChannelModeration/module/moduleContext.js.map +1 -1
  348. package/lib/commonjs/domain/openChannelModeration/types.js.map +1 -1
  349. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js +6 -8
  350. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js.map +1 -1
  351. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js +15 -25
  352. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js.map +1 -1
  353. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js +2 -3
  354. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js.map +1 -1
  355. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js +5 -7
  356. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js.map +1 -1
  357. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js +2 -3
  358. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js.map +1 -1
  359. package/lib/commonjs/domain/openChannelMutedParticipants/index.js +1 -1
  360. package/lib/commonjs/domain/openChannelMutedParticipants/index.js.map +1 -1
  361. package/lib/commonjs/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js +11 -13
  362. package/lib/commonjs/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js.map +1 -1
  363. package/lib/commonjs/domain/openChannelMutedParticipants/module/moduleContext.js +8 -10
  364. package/lib/commonjs/domain/openChannelMutedParticipants/module/moduleContext.js.map +1 -1
  365. package/lib/commonjs/domain/openChannelMutedParticipants/types.js.map +1 -1
  366. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js +7 -9
  367. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js.map +1 -1
  368. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsList.js +15 -25
  369. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsList.js.map +1 -1
  370. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js +2 -3
  371. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js.map +1 -1
  372. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js +5 -7
  373. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js.map +1 -1
  374. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js +2 -3
  375. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js.map +1 -1
  376. package/lib/commonjs/domain/openChannelOperators/index.js +1 -1
  377. package/lib/commonjs/domain/openChannelOperators/index.js.map +1 -1
  378. package/lib/commonjs/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js +11 -13
  379. package/lib/commonjs/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js.map +1 -1
  380. package/lib/commonjs/domain/openChannelOperators/module/moduleContext.js +8 -10
  381. package/lib/commonjs/domain/openChannelOperators/module/moduleContext.js.map +1 -1
  382. package/lib/commonjs/domain/openChannelOperators/types.js.map +1 -1
  383. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsHeader.js +6 -8
  384. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsHeader.js.map +1 -1
  385. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsInfo.js +4 -5
  386. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsInfo.js.map +1 -1
  387. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsMenu.js +9 -11
  388. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsMenu.js.map +1 -1
  389. package/lib/commonjs/domain/openChannelSettings/index.js +1 -1
  390. package/lib/commonjs/domain/openChannelSettings/index.js.map +1 -1
  391. package/lib/commonjs/domain/openChannelSettings/module/createOpenChannelSettingsModule.js +9 -11
  392. package/lib/commonjs/domain/openChannelSettings/module/createOpenChannelSettingsModule.js.map +1 -1
  393. package/lib/commonjs/domain/openChannelSettings/module/moduleContext.js +9 -11
  394. package/lib/commonjs/domain/openChannelSettings/module/moduleContext.js.map +1 -1
  395. package/lib/commonjs/domain/openChannelSettings/types.js.map +1 -1
  396. package/lib/commonjs/domain/openChannelUserList/types.js.map +1 -1
  397. package/lib/commonjs/domain/userList/component/UserListHeader.js +10 -12
  398. package/lib/commonjs/domain/userList/component/UserListHeader.js.map +1 -1
  399. package/lib/commonjs/domain/userList/component/UserListList.js +16 -26
  400. package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -1
  401. package/lib/commonjs/domain/userList/component/UserListStatusEmpty.js +2 -3
  402. package/lib/commonjs/domain/userList/component/UserListStatusEmpty.js.map +1 -1
  403. package/lib/commonjs/domain/userList/component/UserListStatusError.js +5 -7
  404. package/lib/commonjs/domain/userList/component/UserListStatusError.js.map +1 -1
  405. package/lib/commonjs/domain/userList/component/UserListStatusLoading.js +2 -3
  406. package/lib/commonjs/domain/userList/component/UserListStatusLoading.js.map +1 -1
  407. package/lib/commonjs/domain/userList/index.js +1 -1
  408. package/lib/commonjs/domain/userList/index.js.map +1 -1
  409. package/lib/commonjs/domain/userList/module/createUserListModule.js +11 -13
  410. package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -1
  411. package/lib/commonjs/domain/userList/module/moduleContext.js +9 -11
  412. package/lib/commonjs/domain/userList/module/moduleContext.js.map +1 -1
  413. package/lib/commonjs/domain/userList/types.js.map +1 -1
  414. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js +10 -12
  415. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js.map +1 -1
  416. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +12 -15
  417. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  418. package/lib/commonjs/fragments/createGroupChannelFragment.js +28 -30
  419. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  420. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js +13 -16
  421. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
  422. package/lib/commonjs/fragments/createGroupChannelListFragment.js +12 -14
  423. package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
  424. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +16 -18
  425. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
  426. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js +13 -19
  427. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js.map +1 -1
  428. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js +12 -14
  429. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js.map +1 -1
  430. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js +6 -8
  431. package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js.map +1 -1
  432. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js +13 -15
  433. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js.map +1 -1
  434. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js +15 -18
  435. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -1
  436. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +15 -21
  437. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  438. package/lib/commonjs/fragments/createGroupChannelThreadFragment.js +25 -27
  439. package/lib/commonjs/fragments/createGroupChannelThreadFragment.js.map +1 -1
  440. package/lib/commonjs/fragments/createMessageSearchFragment.js +15 -18
  441. package/lib/commonjs/fragments/createMessageSearchFragment.js.map +1 -1
  442. package/lib/commonjs/fragments/createOpenChannelBannedUsersFragment.js +10 -12
  443. package/lib/commonjs/fragments/createOpenChannelBannedUsersFragment.js.map +1 -1
  444. package/lib/commonjs/fragments/createOpenChannelCreateFragment.js +8 -10
  445. package/lib/commonjs/fragments/createOpenChannelCreateFragment.js.map +1 -1
  446. package/lib/commonjs/fragments/createOpenChannelFragment.js +24 -26
  447. package/lib/commonjs/fragments/createOpenChannelFragment.js.map +1 -1
  448. package/lib/commonjs/fragments/createOpenChannelListFragment.js +9 -11
  449. package/lib/commonjs/fragments/createOpenChannelListFragment.js.map +1 -1
  450. package/lib/commonjs/fragments/createOpenChannelModerationFragment.js +13 -19
  451. package/lib/commonjs/fragments/createOpenChannelModerationFragment.js.map +1 -1
  452. package/lib/commonjs/fragments/createOpenChannelMutedParticipantsFragment.js +10 -12
  453. package/lib/commonjs/fragments/createOpenChannelMutedParticipantsFragment.js.map +1 -1
  454. package/lib/commonjs/fragments/createOpenChannelOperatorsFragment.js +11 -13
  455. package/lib/commonjs/fragments/createOpenChannelOperatorsFragment.js.map +1 -1
  456. package/lib/commonjs/fragments/createOpenChannelParticipantsFragment.js +13 -15
  457. package/lib/commonjs/fragments/createOpenChannelParticipantsFragment.js.map +1 -1
  458. package/lib/commonjs/fragments/createOpenChannelRegisterOperatorFragment.js +15 -18
  459. package/lib/commonjs/fragments/createOpenChannelRegisterOperatorFragment.js.map +1 -1
  460. package/lib/commonjs/fragments/createOpenChannelSettingsFragment.js +14 -20
  461. package/lib/commonjs/fragments/createOpenChannelSettingsFragment.js.map +1 -1
  462. package/lib/commonjs/hooks/useChannelInputItems.js +1 -1
  463. package/lib/commonjs/hooks/useChannelInputItems.js.map +1 -1
  464. package/lib/commonjs/hooks/useConnection.js +2 -3
  465. package/lib/commonjs/hooks/useConnection.js.map +1 -1
  466. package/lib/commonjs/hooks/useContext.js.map +1 -1
  467. package/lib/commonjs/hooks/useKeyboardStatus.js +1 -2
  468. package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -1
  469. package/lib/commonjs/hooks/useMentionSuggestion.js +3 -5
  470. package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -1
  471. package/lib/commonjs/hooks/useMentionTextInput.js +4 -4
  472. package/lib/commonjs/hooks/useMentionTextInput.js.map +1 -1
  473. package/lib/commonjs/hooks/usePushTokenRegistration.js +2 -3
  474. package/lib/commonjs/hooks/usePushTokenRegistration.js.map +1 -1
  475. package/lib/commonjs/hooks/useVoiceMessageInput.js +13 -17
  476. package/lib/commonjs/hooks/useVoiceMessageInput.js.map +1 -1
  477. package/lib/commonjs/index.js +3 -3
  478. package/lib/commonjs/index.js.map +1 -1
  479. package/lib/commonjs/libs/EmojiManager.js +12 -8
  480. package/lib/commonjs/libs/EmojiManager.js.map +1 -1
  481. package/lib/commonjs/libs/ImageCompressionConfig.js +4 -5
  482. package/lib/commonjs/libs/ImageCompressionConfig.js.map +1 -1
  483. package/lib/commonjs/libs/InternalLocalCacheStorage.js +5 -11
  484. package/lib/commonjs/libs/InternalLocalCacheStorage.js.map +1 -1
  485. package/lib/commonjs/libs/MentionConfig.js +4 -5
  486. package/lib/commonjs/libs/MentionConfig.js.map +1 -1
  487. package/lib/commonjs/libs/MentionManager.js +45 -31
  488. package/lib/commonjs/libs/MentionManager.js.map +1 -1
  489. package/lib/commonjs/libs/SBUError.js +3 -3
  490. package/lib/commonjs/libs/SBUError.js.map +1 -1
  491. package/lib/commonjs/libs/SBUUtils.js.map +1 -1
  492. package/lib/commonjs/libs/VoiceMessageConfig.js +4 -5
  493. package/lib/commonjs/libs/VoiceMessageConfig.js.map +1 -1
  494. package/lib/commonjs/libs/VoiceMessageStatusManager.js +9 -10
  495. package/lib/commonjs/libs/VoiceMessageStatusManager.js.map +1 -1
  496. package/lib/commonjs/localization/StringSet.en.js +1 -2
  497. package/lib/commonjs/localization/StringSet.en.js.map +1 -1
  498. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  499. package/lib/commonjs/localization/createBaseStringSet.js +25 -30
  500. package/lib/commonjs/localization/createBaseStringSet.js.map +1 -1
  501. package/lib/commonjs/platform/createClipboardService.expo.js +1 -2
  502. package/lib/commonjs/platform/createClipboardService.expo.js.map +1 -1
  503. package/lib/commonjs/platform/createClipboardService.native.js +1 -2
  504. package/lib/commonjs/platform/createClipboardService.native.js.map +1 -1
  505. package/lib/commonjs/platform/createFileService.expo.js +12 -15
  506. package/lib/commonjs/platform/createFileService.expo.js.map +1 -1
  507. package/lib/commonjs/platform/createFileService.native.js +29 -35
  508. package/lib/commonjs/platform/createFileService.native.js.map +1 -1
  509. package/lib/commonjs/platform/createMediaService.expo.js +26 -31
  510. package/lib/commonjs/platform/createMediaService.expo.js.map +1 -1
  511. package/lib/commonjs/platform/createMediaService.native.js +24 -29
  512. package/lib/commonjs/platform/createMediaService.native.js.map +1 -1
  513. package/lib/commonjs/platform/createNotificationService.expo.js +4 -8
  514. package/lib/commonjs/platform/createNotificationService.expo.js.map +1 -1
  515. package/lib/commonjs/platform/createNotificationService.native.js +5 -7
  516. package/lib/commonjs/platform/createNotificationService.native.js.map +1 -1
  517. package/lib/commonjs/platform/createPlayerService.expo.js +8 -10
  518. package/lib/commonjs/platform/createPlayerService.expo.js.map +1 -1
  519. package/lib/commonjs/platform/createPlayerService.native.js +8 -10
  520. package/lib/commonjs/platform/createPlayerService.native.js.map +1 -1
  521. package/lib/commonjs/platform/createRecorderService.expo.js +8 -10
  522. package/lib/commonjs/platform/createRecorderService.expo.js.map +1 -1
  523. package/lib/commonjs/platform/createRecorderService.native.js +10 -12
  524. package/lib/commonjs/platform/createRecorderService.native.js.map +1 -1
  525. package/lib/commonjs/platform/dynamicModule.js +2 -4
  526. package/lib/commonjs/platform/dynamicModule.js.map +1 -1
  527. package/lib/commonjs/platform/types.js.map +1 -1
  528. package/lib/commonjs/types.js +1 -2
  529. package/lib/commonjs/types.js.map +1 -1
  530. package/lib/commonjs/utils/expoBackwardUtils.js +24 -31
  531. package/lib/commonjs/utils/expoBackwardUtils.js.map +1 -1
  532. package/lib/commonjs/utils/expoPermissionGranted.js +2 -3
  533. package/lib/commonjs/utils/expoPermissionGranted.js.map +1 -1
  534. package/lib/commonjs/utils/nativePermissionGranted.js +2 -3
  535. package/lib/commonjs/utils/nativePermissionGranted.js.map +1 -1
  536. package/lib/commonjs/utils/normalizeFile.js +7 -9
  537. package/lib/commonjs/utils/normalizeFile.js.map +1 -1
  538. package/lib/commonjs/utils/promise.js +1 -2
  539. package/lib/commonjs/utils/promise.js.map +1 -1
  540. package/lib/commonjs/utils/pubsub.js +1 -2
  541. package/lib/commonjs/utils/pubsub.js.map +1 -1
  542. package/lib/commonjs/version.js +2 -3
  543. package/lib/commonjs/version.js.map +1 -1
  544. package/lib/module/components/ChannelCover.js +7 -8
  545. package/lib/module/components/ChannelCover.js.map +1 -1
  546. package/lib/module/components/ChannelInput/AttachmentsButton.js +5 -6
  547. package/lib/module/components/ChannelInput/AttachmentsButton.js.map +1 -1
  548. package/lib/module/components/ChannelInput/EditInput.js +15 -14
  549. package/lib/module/components/ChannelInput/EditInput.js.map +1 -1
  550. package/lib/module/components/ChannelInput/MessageToReplyPreview.js +36 -49
  551. package/lib/module/components/ChannelInput/MessageToReplyPreview.js.map +1 -1
  552. package/lib/module/components/ChannelInput/SendInput.js +40 -44
  553. package/lib/module/components/ChannelInput/SendInput.js.map +1 -1
  554. package/lib/module/components/ChannelInput/VoiceMessageInput.js +8 -9
  555. package/lib/module/components/ChannelInput/VoiceMessageInput.js.map +1 -1
  556. package/lib/module/components/ChannelInput/index.js +19 -23
  557. package/lib/module/components/ChannelInput/index.js.map +1 -1
  558. package/lib/module/components/ChannelMessageList/index.js +58 -73
  559. package/lib/module/components/ChannelMessageList/index.js.map +1 -1
  560. package/lib/module/components/ChannelThreadMessageList/index.js +53 -68
  561. package/lib/module/components/ChannelThreadMessageList/index.js.map +1 -1
  562. package/lib/module/components/ChatFlatList/FlatListInternal.js.map +1 -1
  563. package/lib/module/components/ChatFlatList/index.js +9 -10
  564. package/lib/module/components/ChatFlatList/index.js.map +1 -1
  565. package/lib/module/components/FileViewer/FileViewerContent.js +14 -16
  566. package/lib/module/components/FileViewer/FileViewerContent.js.map +1 -1
  567. package/lib/module/components/FileViewer/FileViewerFooter.js +12 -16
  568. package/lib/module/components/FileViewer/FileViewerFooter.js.map +1 -1
  569. package/lib/module/components/FileViewer/FileViewerHeader.js +13 -18
  570. package/lib/module/components/FileViewer/FileViewerHeader.js.map +1 -1
  571. package/lib/module/components/FileViewer/index.js +11 -12
  572. package/lib/module/components/FileViewer/index.js.map +1 -1
  573. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageDateSeparator.js +4 -5
  574. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageDateSeparator.js.map +1 -1
  575. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageFocusAnimation.js.map +1 -1
  576. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageOutgoingStatus.js +5 -6
  577. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageOutgoingStatus.js.map +1 -1
  578. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageParentMessage.js +15 -17
  579. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageParentMessage.js.map +1 -1
  580. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageReplyInfo.js +11 -12
  581. package/lib/module/components/GroupChannelMessageRenderer/GroupChannelMessageReplyInfo.js.map +1 -1
  582. package/lib/module/components/GroupChannelMessageRenderer/index.js +32 -34
  583. package/lib/module/components/GroupChannelMessageRenderer/index.js.map +1 -1
  584. package/lib/module/components/MessageSearchResultItem.js +18 -15
  585. package/lib/module/components/MessageSearchResultItem.js.map +1 -1
  586. package/lib/module/components/NewMessagesButton.js +5 -6
  587. package/lib/module/components/NewMessagesButton.js.map +1 -1
  588. package/lib/module/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js +4 -5
  589. package/lib/module/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js.map +1 -1
  590. package/lib/module/components/OpenChannelMessageRenderer/index.js +11 -12
  591. package/lib/module/components/OpenChannelMessageRenderer/index.js.map +1 -1
  592. package/lib/module/components/ProviderLayout.js +3 -4
  593. package/lib/module/components/ProviderLayout.js.map +1 -1
  594. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +27 -40
  595. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -1
  596. package/lib/module/components/ReactionAddons/MessageReactionAddon.js +30 -39
  597. package/lib/module/components/ReactionAddons/MessageReactionAddon.js.map +1 -1
  598. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js +12 -13
  599. package/lib/module/components/ReactionAddons/ReactionRoundedButton.js.map +1 -1
  600. package/lib/module/components/ReactionAddons/index.js.map +1 -1
  601. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js +27 -37
  602. package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -1
  603. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +44 -49
  604. package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -1
  605. package/lib/module/components/ReactionBottomSheets/index.js.map +1 -1
  606. package/lib/module/components/ScrollToBottomButton.js +4 -5
  607. package/lib/module/components/ScrollToBottomButton.js.map +1 -1
  608. package/lib/module/components/StatusComposition.js +7 -8
  609. package/lib/module/components/StatusComposition.js.map +1 -1
  610. package/lib/module/components/ThreadChatFlatList/index.js +9 -10
  611. package/lib/module/components/ThreadChatFlatList/index.js.map +1 -1
  612. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.image.js.map +1 -1
  613. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.js +1 -1
  614. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.js.map +1 -1
  615. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.video.js.map +1 -1
  616. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.js +5 -4
  617. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.js.map +1 -1
  618. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.user.js +19 -12
  619. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.user.js.map +1 -1
  620. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.user.og.js +22 -15
  621. package/lib/module/components/ThreadParentMessageRenderer/ThreadParentMessage.user.og.js.map +1 -1
  622. package/lib/module/components/ThreadParentMessageRenderer/index.js +19 -17
  623. package/lib/module/components/ThreadParentMessageRenderer/index.js.map +1 -1
  624. package/lib/module/components/TypedPlaceholder.js +4 -5
  625. package/lib/module/components/TypedPlaceholder.js.map +1 -1
  626. package/lib/module/components/UserActionBar.js +19 -18
  627. package/lib/module/components/UserActionBar.js.map +1 -1
  628. package/lib/module/components/UserSelectableBar.js +13 -12
  629. package/lib/module/components/UserSelectableBar.js.map +1 -1
  630. package/lib/module/constants.js.map +1 -1
  631. package/lib/module/containers/GroupChannelPreviewContainer.js +10 -11
  632. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  633. package/lib/module/containers/InternalErrorBoundaryContainer.js +6 -6
  634. package/lib/module/containers/InternalErrorBoundaryContainer.js.map +1 -1
  635. package/lib/module/containers/SendbirdUIKitContainer.js +12 -13
  636. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  637. package/lib/module/contexts/LocalizationCtx.js +4 -5
  638. package/lib/module/contexts/LocalizationCtx.js.map +1 -1
  639. package/lib/module/contexts/PlatformServiceCtx.js +5 -6
  640. package/lib/module/contexts/PlatformServiceCtx.js.map +1 -1
  641. package/lib/module/contexts/ReactionCtx.js +11 -15
  642. package/lib/module/contexts/ReactionCtx.js.map +1 -1
  643. package/lib/module/contexts/SBUHandlersCtx.js +5 -6
  644. package/lib/module/contexts/SBUHandlersCtx.js.map +1 -1
  645. package/lib/module/contexts/SendbirdChatCtx.js +12 -13
  646. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -1
  647. package/lib/module/contexts/UserProfileCtx.js +11 -21
  648. package/lib/module/contexts/UserProfileCtx.js.map +1 -1
  649. package/lib/module/domain/groupChannel/component/GroupChannelHeader.js +11 -14
  650. package/lib/module/domain/groupChannel/component/GroupChannelHeader.js.map +1 -1
  651. package/lib/module/domain/groupChannel/component/GroupChannelInput.js +5 -6
  652. package/lib/module/domain/groupChannel/component/GroupChannelInput.js.map +1 -1
  653. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +9 -13
  654. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  655. package/lib/module/domain/groupChannel/component/GroupChannelStatusEmpty.js.map +1 -1
  656. package/lib/module/domain/groupChannel/component/GroupChannelStatusLoading.js.map +1 -1
  657. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +24 -31
  658. package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -1
  659. package/lib/module/domain/groupChannel/index.js.map +1 -1
  660. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +10 -11
  661. package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
  662. package/lib/module/domain/groupChannel/module/moduleContext.js +16 -18
  663. package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
  664. package/lib/module/domain/groupChannel/types.js.map +1 -1
  665. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +3 -4
  666. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -1
  667. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +14 -23
  668. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -1
  669. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -1
  670. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +3 -4
  671. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -1
  672. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -1
  673. package/lib/module/domain/groupChannelBannedUsers/index.js.map +1 -1
  674. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +9 -10
  675. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -1
  676. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js +4 -5
  677. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -1
  678. package/lib/module/domain/groupChannelBannedUsers/types.js.map +1 -1
  679. package/lib/module/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -1
  680. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +19 -30
  681. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  682. package/lib/module/domain/groupChannelList/component/GroupChannelListStatusEmpty.js.map +1 -1
  683. package/lib/module/domain/groupChannelList/component/GroupChannelListStatusLoading.js.map +1 -1
  684. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js +10 -13
  685. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  686. package/lib/module/domain/groupChannelList/index.js.map +1 -1
  687. package/lib/module/domain/groupChannelList/module/createGroupChannelListModule.js +9 -10
  688. package/lib/module/domain/groupChannelList/module/createGroupChannelListModule.js.map +1 -1
  689. package/lib/module/domain/groupChannelList/module/moduleContext.js +3 -4
  690. package/lib/module/domain/groupChannelList/module/moduleContext.js.map +1 -1
  691. package/lib/module/domain/groupChannelList/types.js.map +1 -1
  692. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +3 -4
  693. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -1
  694. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +6 -7
  695. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -1
  696. package/lib/module/domain/groupChannelModeration/index.js.map +1 -1
  697. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +6 -7
  698. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -1
  699. package/lib/module/domain/groupChannelModeration/module/moduleContext.js +4 -5
  700. package/lib/module/domain/groupChannelModeration/module/moduleContext.js.map +1 -1
  701. package/lib/module/domain/groupChannelModeration/types.js.map +1 -1
  702. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +3 -4
  703. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -1
  704. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +14 -23
  705. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  706. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -1
  707. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +3 -4
  708. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -1
  709. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -1
  710. package/lib/module/domain/groupChannelMutedMembers/index.js.map +1 -1
  711. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +9 -10
  712. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -1
  713. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js +4 -5
  714. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -1
  715. package/lib/module/domain/groupChannelMutedMembers/types.js.map +1 -1
  716. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +3 -4
  717. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -1
  718. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +18 -16
  719. package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -1
  720. package/lib/module/domain/groupChannelNotifications/index.js.map +1 -1
  721. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +6 -7
  722. package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -1
  723. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js +4 -5
  724. package/lib/module/domain/groupChannelNotifications/module/moduleContext.js.map +1 -1
  725. package/lib/module/domain/groupChannelNotifications/types.js.map +1 -1
  726. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +4 -5
  727. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -1
  728. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +14 -23
  729. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  730. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -1
  731. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +3 -4
  732. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -1
  733. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -1
  734. package/lib/module/domain/groupChannelOperators/index.js.map +1 -1
  735. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +9 -10
  736. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -1
  737. package/lib/module/domain/groupChannelOperators/module/moduleContext.js +4 -5
  738. package/lib/module/domain/groupChannelOperators/module/moduleContext.js.map +1 -1
  739. package/lib/module/domain/groupChannelOperators/types.js.map +1 -1
  740. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js +3 -4
  741. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -1
  742. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  743. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +9 -10
  744. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  745. package/lib/module/domain/groupChannelSettings/index.js.map +1 -1
  746. package/lib/module/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js +7 -8
  747. package/lib/module/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js.map +1 -1
  748. package/lib/module/domain/groupChannelSettings/module/moduleContext.js +7 -9
  749. package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  750. package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
  751. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadHeader.js +9 -12
  752. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadHeader.js.map +1 -1
  753. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadInput.js +5 -6
  754. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadInput.js.map +1 -1
  755. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadMessageList.js +9 -12
  756. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadMessageList.js.map +1 -1
  757. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadParentMessageInfo.js +31 -33
  758. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadParentMessageInfo.js.map +1 -1
  759. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadStatusEmpty.js.map +1 -1
  760. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadStatusLoading.js.map +1 -1
  761. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.js +22 -29
  762. package/lib/module/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.js.map +1 -1
  763. package/lib/module/domain/groupChannelThread/index.js.map +1 -1
  764. package/lib/module/domain/groupChannelThread/module/createGroupChannelThreadModule.js +11 -12
  765. package/lib/module/domain/groupChannelThread/module/createGroupChannelThreadModule.js.map +1 -1
  766. package/lib/module/domain/groupChannelThread/module/moduleContext.js +8 -9
  767. package/lib/module/domain/groupChannelThread/module/moduleContext.js.map +1 -1
  768. package/lib/module/domain/groupChannelThread/types.js.map +1 -1
  769. package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
  770. package/lib/module/domain/messageSearch/component/MessageSearchHeader.js +16 -15
  771. package/lib/module/domain/messageSearch/component/MessageSearchHeader.js.map +1 -1
  772. package/lib/module/domain/messageSearch/component/MessageSearchList.js +11 -13
  773. package/lib/module/domain/messageSearch/component/MessageSearchList.js.map +1 -1
  774. package/lib/module/domain/messageSearch/component/MessageSearchStatusEmpty.js.map +1 -1
  775. package/lib/module/domain/messageSearch/component/MessageSearchStatusError.js +3 -4
  776. package/lib/module/domain/messageSearch/component/MessageSearchStatusError.js.map +1 -1
  777. package/lib/module/domain/messageSearch/component/MessageSearchStatusLoading.js.map +1 -1
  778. package/lib/module/domain/messageSearch/index.js.map +1 -1
  779. package/lib/module/domain/messageSearch/module/createMessageSearchModule.js +9 -10
  780. package/lib/module/domain/messageSearch/module/createMessageSearchModule.js.map +1 -1
  781. package/lib/module/domain/messageSearch/module/moduleContext.js +3 -4
  782. package/lib/module/domain/messageSearch/module/moduleContext.js.map +1 -1
  783. package/lib/module/domain/messageSearch/types.js.map +1 -1
  784. package/lib/module/domain/openChannel/component/OpenChannelHeader.js +6 -7
  785. package/lib/module/domain/openChannel/component/OpenChannelHeader.js.map +1 -1
  786. package/lib/module/domain/openChannel/component/OpenChannelInput.js +5 -6
  787. package/lib/module/domain/openChannel/component/OpenChannelInput.js.map +1 -1
  788. package/lib/module/domain/openChannel/component/OpenChannelMessageList.js +6 -8
  789. package/lib/module/domain/openChannel/component/OpenChannelMessageList.js.map +1 -1
  790. package/lib/module/domain/openChannel/component/OpenChannelStatusEmpty.js.map +1 -1
  791. package/lib/module/domain/openChannel/component/OpenChannelStatusLoading.js.map +1 -1
  792. package/lib/module/domain/openChannel/index.js.map +1 -1
  793. package/lib/module/domain/openChannel/module/createOpenChannelModule.js +9 -10
  794. package/lib/module/domain/openChannel/module/createOpenChannelModule.js.map +1 -1
  795. package/lib/module/domain/openChannel/module/moduleContext.js +6 -7
  796. package/lib/module/domain/openChannel/module/moduleContext.js.map +1 -1
  797. package/lib/module/domain/openChannel/types.js.map +1 -1
  798. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js +3 -4
  799. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js.map +1 -1
  800. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js +14 -23
  801. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js.map +1 -1
  802. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js.map +1 -1
  803. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js +3 -4
  804. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js.map +1 -1
  805. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js.map +1 -1
  806. package/lib/module/domain/openChannelBannedUsers/index.js.map +1 -1
  807. package/lib/module/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js +9 -10
  808. package/lib/module/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js.map +1 -1
  809. package/lib/module/domain/openChannelBannedUsers/module/moduleContext.js +4 -5
  810. package/lib/module/domain/openChannelBannedUsers/module/moduleContext.js.map +1 -1
  811. package/lib/module/domain/openChannelBannedUsers/types.js.map +1 -1
  812. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateHeader.js +5 -6
  813. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateHeader.js.map +1 -1
  814. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js +12 -13
  815. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js.map +1 -1
  816. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js.map +1 -1
  817. package/lib/module/domain/openChannelCreate/index.js.map +1 -1
  818. package/lib/module/domain/openChannelCreate/module/createOpenChannelCreateModule.js +7 -8
  819. package/lib/module/domain/openChannelCreate/module/createOpenChannelCreateModule.js.map +1 -1
  820. package/lib/module/domain/openChannelCreate/module/moduleContext.js +3 -4
  821. package/lib/module/domain/openChannelCreate/module/moduleContext.js.map +1 -1
  822. package/lib/module/domain/openChannelCreate/types.js.map +1 -1
  823. package/lib/module/domain/openChannelList/component/OpenChannelListHeader.js +3 -4
  824. package/lib/module/domain/openChannelList/component/OpenChannelListHeader.js.map +1 -1
  825. package/lib/module/domain/openChannelList/component/OpenChannelListList.js +19 -30
  826. package/lib/module/domain/openChannelList/component/OpenChannelListList.js.map +1 -1
  827. package/lib/module/domain/openChannelList/component/OpenChannelListStatusEmpty.js.map +1 -1
  828. package/lib/module/domain/openChannelList/component/OpenChannelListStatusError.js +3 -4
  829. package/lib/module/domain/openChannelList/component/OpenChannelListStatusError.js.map +1 -1
  830. package/lib/module/domain/openChannelList/component/OpenChannelListStatusLoading.js.map +1 -1
  831. package/lib/module/domain/openChannelList/index.js.map +1 -1
  832. package/lib/module/domain/openChannelList/module/createOpenChannelListModule.js +9 -10
  833. package/lib/module/domain/openChannelList/module/createOpenChannelListModule.js.map +1 -1
  834. package/lib/module/domain/openChannelList/module/moduleContext.js +3 -4
  835. package/lib/module/domain/openChannelList/module/moduleContext.js.map +1 -1
  836. package/lib/module/domain/openChannelList/types.js.map +1 -1
  837. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationHeader.js +3 -4
  838. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationHeader.js.map +1 -1
  839. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationMenu.js +6 -7
  840. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationMenu.js.map +1 -1
  841. package/lib/module/domain/openChannelModeration/index.js.map +1 -1
  842. package/lib/module/domain/openChannelModeration/module/createOpenChannelModerationModule.js +6 -7
  843. package/lib/module/domain/openChannelModeration/module/createOpenChannelModerationModule.js.map +1 -1
  844. package/lib/module/domain/openChannelModeration/module/moduleContext.js +4 -5
  845. package/lib/module/domain/openChannelModeration/module/moduleContext.js.map +1 -1
  846. package/lib/module/domain/openChannelModeration/types.js.map +1 -1
  847. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js +3 -4
  848. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js.map +1 -1
  849. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js +14 -23
  850. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js.map +1 -1
  851. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js.map +1 -1
  852. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js +3 -4
  853. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js.map +1 -1
  854. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js.map +1 -1
  855. package/lib/module/domain/openChannelMutedParticipants/index.js.map +1 -1
  856. package/lib/module/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js +9 -10
  857. package/lib/module/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js.map +1 -1
  858. package/lib/module/domain/openChannelMutedParticipants/module/moduleContext.js +4 -5
  859. package/lib/module/domain/openChannelMutedParticipants/module/moduleContext.js.map +1 -1
  860. package/lib/module/domain/openChannelMutedParticipants/types.js.map +1 -1
  861. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js +4 -5
  862. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js.map +1 -1
  863. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsList.js +14 -23
  864. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsList.js.map +1 -1
  865. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js.map +1 -1
  866. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js +3 -4
  867. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js.map +1 -1
  868. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js.map +1 -1
  869. package/lib/module/domain/openChannelOperators/index.js.map +1 -1
  870. package/lib/module/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js +9 -10
  871. package/lib/module/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js.map +1 -1
  872. package/lib/module/domain/openChannelOperators/module/moduleContext.js +4 -5
  873. package/lib/module/domain/openChannelOperators/module/moduleContext.js.map +1 -1
  874. package/lib/module/domain/openChannelOperators/types.js.map +1 -1
  875. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsHeader.js +3 -4
  876. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsHeader.js.map +1 -1
  877. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsInfo.js.map +1 -1
  878. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsMenu.js +6 -7
  879. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsMenu.js.map +1 -1
  880. package/lib/module/domain/openChannelSettings/index.js.map +1 -1
  881. package/lib/module/domain/openChannelSettings/module/createOpenChannelSettingsModule.js +7 -8
  882. package/lib/module/domain/openChannelSettings/module/createOpenChannelSettingsModule.js.map +1 -1
  883. package/lib/module/domain/openChannelSettings/module/moduleContext.js +5 -6
  884. package/lib/module/domain/openChannelSettings/module/moduleContext.js.map +1 -1
  885. package/lib/module/domain/openChannelSettings/types.js.map +1 -1
  886. package/lib/module/domain/openChannelUserList/types.js.map +1 -1
  887. package/lib/module/domain/userList/component/UserListHeader.js +7 -8
  888. package/lib/module/domain/userList/component/UserListHeader.js.map +1 -1
  889. package/lib/module/domain/userList/component/UserListList.js +14 -23
  890. package/lib/module/domain/userList/component/UserListList.js.map +1 -1
  891. package/lib/module/domain/userList/component/UserListStatusEmpty.js.map +1 -1
  892. package/lib/module/domain/userList/component/UserListStatusError.js +3 -4
  893. package/lib/module/domain/userList/component/UserListStatusError.js.map +1 -1
  894. package/lib/module/domain/userList/component/UserListStatusLoading.js.map +1 -1
  895. package/lib/module/domain/userList/index.js.map +1 -1
  896. package/lib/module/domain/userList/module/createUserListModule.js +9 -10
  897. package/lib/module/domain/userList/module/createUserListModule.js.map +1 -1
  898. package/lib/module/domain/userList/module/moduleContext.js +5 -6
  899. package/lib/module/domain/userList/module/moduleContext.js.map +1 -1
  900. package/lib/module/domain/userList/types.js.map +1 -1
  901. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js +8 -9
  902. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js.map +1 -1
  903. package/lib/module/fragments/createGroupChannelCreateFragment.js +10 -12
  904. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  905. package/lib/module/fragments/createGroupChannelFragment.js +24 -25
  906. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  907. package/lib/module/fragments/createGroupChannelInviteFragment.js +9 -11
  908. package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
  909. package/lib/module/fragments/createGroupChannelListFragment.js +10 -11
  910. package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
  911. package/lib/module/fragments/createGroupChannelMembersFragment.js +14 -15
  912. package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
  913. package/lib/module/fragments/createGroupChannelModerationFragment.js +12 -17
  914. package/lib/module/fragments/createGroupChannelModerationFragment.js.map +1 -1
  915. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js +12 -13
  916. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js.map +1 -1
  917. package/lib/module/fragments/createGroupChannelNotificationsFragment.js +4 -5
  918. package/lib/module/fragments/createGroupChannelNotificationsFragment.js.map +1 -1
  919. package/lib/module/fragments/createGroupChannelOperatorsFragment.js +13 -14
  920. package/lib/module/fragments/createGroupChannelOperatorsFragment.js.map +1 -1
  921. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js +11 -13
  922. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -1
  923. package/lib/module/fragments/createGroupChannelSettingsFragment.js +14 -19
  924. package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  925. package/lib/module/fragments/createGroupChannelThreadFragment.js +21 -22
  926. package/lib/module/fragments/createGroupChannelThreadFragment.js.map +1 -1
  927. package/lib/module/fragments/createMessageSearchFragment.js +11 -13
  928. package/lib/module/fragments/createMessageSearchFragment.js.map +1 -1
  929. package/lib/module/fragments/createOpenChannelBannedUsersFragment.js +8 -9
  930. package/lib/module/fragments/createOpenChannelBannedUsersFragment.js.map +1 -1
  931. package/lib/module/fragments/createOpenChannelCreateFragment.js +5 -6
  932. package/lib/module/fragments/createOpenChannelCreateFragment.js.map +1 -1
  933. package/lib/module/fragments/createOpenChannelFragment.js +20 -21
  934. package/lib/module/fragments/createOpenChannelFragment.js.map +1 -1
  935. package/lib/module/fragments/createOpenChannelListFragment.js +7 -8
  936. package/lib/module/fragments/createOpenChannelListFragment.js.map +1 -1
  937. package/lib/module/fragments/createOpenChannelModerationFragment.js +12 -17
  938. package/lib/module/fragments/createOpenChannelModerationFragment.js.map +1 -1
  939. package/lib/module/fragments/createOpenChannelMutedParticipantsFragment.js +8 -9
  940. package/lib/module/fragments/createOpenChannelMutedParticipantsFragment.js.map +1 -1
  941. package/lib/module/fragments/createOpenChannelOperatorsFragment.js +9 -10
  942. package/lib/module/fragments/createOpenChannelOperatorsFragment.js.map +1 -1
  943. package/lib/module/fragments/createOpenChannelParticipantsFragment.js +9 -10
  944. package/lib/module/fragments/createOpenChannelParticipantsFragment.js.map +1 -1
  945. package/lib/module/fragments/createOpenChannelRegisterOperatorFragment.js +11 -13
  946. package/lib/module/fragments/createOpenChannelRegisterOperatorFragment.js.map +1 -1
  947. package/lib/module/fragments/createOpenChannelSettingsFragment.js +13 -18
  948. package/lib/module/fragments/createOpenChannelSettingsFragment.js.map +1 -1
  949. package/lib/module/hooks/useChannelInputItems.js.map +1 -1
  950. package/lib/module/hooks/useConnection.js.map +1 -1
  951. package/lib/module/hooks/useContext.js.map +1 -1
  952. package/lib/module/hooks/useKeyboardStatus.js.map +1 -1
  953. package/lib/module/hooks/useMentionSuggestion.js +3 -4
  954. package/lib/module/hooks/useMentionSuggestion.js.map +1 -1
  955. package/lib/module/hooks/useMentionTextInput.js +4 -2
  956. package/lib/module/hooks/useMentionTextInput.js.map +1 -1
  957. package/lib/module/hooks/usePushTokenRegistration.js +1 -1
  958. package/lib/module/hooks/usePushTokenRegistration.js.map +1 -1
  959. package/lib/module/hooks/useVoiceMessageInput.js +11 -14
  960. package/lib/module/hooks/useVoiceMessageInput.js.map +1 -1
  961. package/lib/module/index.js.map +1 -1
  962. package/lib/module/libs/EmojiManager.js +10 -5
  963. package/lib/module/libs/EmojiManager.js.map +1 -1
  964. package/lib/module/libs/ImageCompressionConfig.js +3 -3
  965. package/lib/module/libs/ImageCompressionConfig.js.map +1 -1
  966. package/lib/module/libs/InternalLocalCacheStorage.js +5 -11
  967. package/lib/module/libs/InternalLocalCacheStorage.js.map +1 -1
  968. package/lib/module/libs/MentionConfig.js +3 -3
  969. package/lib/module/libs/MentionConfig.js.map +1 -1
  970. package/lib/module/libs/MentionManager.js +44 -29
  971. package/lib/module/libs/MentionManager.js.map +1 -1
  972. package/lib/module/libs/SBUError.js +3 -3
  973. package/lib/module/libs/SBUError.js.map +1 -1
  974. package/lib/module/libs/SBUUtils.js.map +1 -1
  975. package/lib/module/libs/VoiceMessageConfig.js +3 -3
  976. package/lib/module/libs/VoiceMessageConfig.js.map +1 -1
  977. package/lib/module/libs/VoiceMessageStatusManager.js +8 -8
  978. package/lib/module/libs/VoiceMessageStatusManager.js.map +1 -1
  979. package/lib/module/localization/StringSet.en.js.map +1 -1
  980. package/lib/module/localization/StringSet.type.js.map +1 -1
  981. package/lib/module/localization/createBaseStringSet.js +25 -30
  982. package/lib/module/localization/createBaseStringSet.js.map +1 -1
  983. package/lib/module/platform/createClipboardService.expo.js.map +1 -1
  984. package/lib/module/platform/createClipboardService.native.js.map +1 -1
  985. package/lib/module/platform/createFileService.expo.js +10 -12
  986. package/lib/module/platform/createFileService.expo.js.map +1 -1
  987. package/lib/module/platform/createFileService.native.js +27 -32
  988. package/lib/module/platform/createFileService.native.js.map +1 -1
  989. package/lib/module/platform/createMediaService.expo.js +24 -28
  990. package/lib/module/platform/createMediaService.expo.js.map +1 -1
  991. package/lib/module/platform/createMediaService.native.js +22 -26
  992. package/lib/module/platform/createMediaService.native.js.map +1 -1
  993. package/lib/module/platform/createNotificationService.expo.js +3 -6
  994. package/lib/module/platform/createNotificationService.expo.js.map +1 -1
  995. package/lib/module/platform/createNotificationService.native.js +4 -5
  996. package/lib/module/platform/createNotificationService.native.js.map +1 -1
  997. package/lib/module/platform/createPlayerService.expo.js +6 -7
  998. package/lib/module/platform/createPlayerService.expo.js.map +1 -1
  999. package/lib/module/platform/createPlayerService.native.js +7 -8
  1000. package/lib/module/platform/createPlayerService.native.js.map +1 -1
  1001. package/lib/module/platform/createRecorderService.expo.js +6 -7
  1002. package/lib/module/platform/createRecorderService.expo.js.map +1 -1
  1003. package/lib/module/platform/createRecorderService.native.js +8 -9
  1004. package/lib/module/platform/createRecorderService.native.js.map +1 -1
  1005. package/lib/module/platform/dynamicModule.js +1 -2
  1006. package/lib/module/platform/dynamicModule.js.map +1 -1
  1007. package/lib/module/platform/types.js.map +1 -1
  1008. package/lib/module/types.js.map +1 -1
  1009. package/lib/module/utils/expoBackwardUtils.js +22 -28
  1010. package/lib/module/utils/expoBackwardUtils.js.map +1 -1
  1011. package/lib/module/utils/expoPermissionGranted.js +1 -1
  1012. package/lib/module/utils/expoPermissionGranted.js.map +1 -1
  1013. package/lib/module/utils/nativePermissionGranted.js +1 -1
  1014. package/lib/module/utils/nativePermissionGranted.js.map +1 -1
  1015. package/lib/module/utils/normalizeFile.js +6 -7
  1016. package/lib/module/utils/normalizeFile.js.map +1 -1
  1017. package/lib/module/utils/promise.js.map +1 -1
  1018. package/lib/module/utils/pubsub.js.map +1 -1
  1019. package/lib/module/version.js +1 -1
  1020. package/lib/module/version.js.map +1 -1
  1021. package/lib/typescript/src/components/ChannelInput/index.d.ts +4 -0
  1022. package/lib/typescript/src/components/GroupChannelMessageRenderer/index.d.ts +1 -1
  1023. package/lib/typescript/src/components/OpenChannelMessageRenderer/index.d.ts +1 -1
  1024. package/lib/typescript/src/components/ReactionAddons/ReactionRoundedButton.d.ts +7 -3
  1025. package/lib/typescript/src/components/ReactionBottomSheets/index.d.ts +2 -2
  1026. package/lib/typescript/src/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.d.ts +1 -0
  1027. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +4 -4
  1028. package/lib/typescript/src/contexts/UserProfileCtx.d.ts +3 -3
  1029. package/lib/typescript/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.d.ts +1 -1
  1030. package/lib/typescript/src/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.d.ts +1 -1
  1031. package/lib/typescript/src/domain/userList/component/UserListList.d.ts +1 -1
  1032. package/lib/typescript/src/libs/EmojiManager.d.ts +3 -1
  1033. package/lib/typescript/src/libs/MentionManager.d.ts +1 -0
  1034. package/lib/typescript/src/localization/StringSet.type.d.ts +5 -2
  1035. package/lib/typescript/src/version.d.ts +1 -1
  1036. package/package.json +6 -6
  1037. package/src/components/ChannelInput/AttachmentsButton.tsx +1 -1
  1038. package/src/components/ChannelInput/EditInput.tsx +2 -0
  1039. package/src/components/ChannelInput/MessageToReplyPreview.tsx +29 -33
  1040. package/src/components/ChannelInput/SendInput.tsx +3 -1
  1041. package/src/components/ChannelInput/VoiceMessageInput.tsx +4 -4
  1042. package/src/components/ChannelInput/index.tsx +23 -11
  1043. package/src/components/ChannelMessageList/index.tsx +5 -7
  1044. package/src/components/ChannelThreadMessageList/index.tsx +5 -7
  1045. package/src/components/FileViewer/FileViewerFooter.tsx +6 -6
  1046. package/src/components/FileViewer/FileViewerHeader.tsx +6 -7
  1047. package/src/components/GroupChannelMessageRenderer/GroupChannelMessageParentMessage.tsx +4 -4
  1048. package/src/components/GroupChannelMessageRenderer/GroupChannelMessageReplyInfo.tsx +5 -5
  1049. package/src/components/GroupChannelMessageRenderer/index.tsx +3 -2
  1050. package/src/components/MessageSearchResultItem.tsx +17 -15
  1051. package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +5 -7
  1052. package/src/components/ReactionAddons/MessageReactionAddon.tsx +15 -19
  1053. package/src/components/ReactionAddons/ReactionRoundedButton.tsx +9 -5
  1054. package/src/components/ReactionBottomSheets/ReactionListBottomSheet.tsx +7 -8
  1055. package/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.tsx +41 -28
  1056. package/src/components/ReactionBottomSheets/index.tsx +2 -2
  1057. package/src/components/ThreadParentMessageRenderer/ThreadParentMessage.file.tsx +1 -1
  1058. package/src/components/ThreadParentMessageRenderer/ThreadParentMessage.file.voice.tsx +4 -2
  1059. package/src/components/ThreadParentMessageRenderer/ThreadParentMessage.user.og.tsx +15 -6
  1060. package/src/components/ThreadParentMessageRenderer/ThreadParentMessage.user.tsx +37 -31
  1061. package/src/components/ThreadParentMessageRenderer/index.tsx +12 -2
  1062. package/src/components/UserActionBar.tsx +11 -10
  1063. package/src/components/UserSelectableBar.tsx +8 -7
  1064. package/src/containers/GroupChannelPreviewContainer.tsx +4 -5
  1065. package/src/containers/SendbirdUIKitContainer.tsx +3 -2
  1066. package/src/contexts/ReactionCtx.tsx +0 -3
  1067. package/src/contexts/UserProfileCtx.tsx +14 -13
  1068. package/src/domain/groupChannel/component/GroupChannelHeader.tsx +6 -7
  1069. package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +9 -5
  1070. package/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.tsx +21 -18
  1071. package/src/domain/groupChannel/module/moduleContext.tsx +2 -4
  1072. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +3 -4
  1073. package/src/domain/groupChannelList/component/GroupChannelListList.tsx +10 -4
  1074. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +3 -4
  1075. package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.tsx +26 -11
  1076. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +3 -5
  1077. package/src/domain/groupChannelSettings/module/moduleContext.tsx +2 -4
  1078. package/src/domain/groupChannelThread/component/GroupChannelThreadHeader.tsx +12 -6
  1079. package/src/domain/groupChannelThread/component/GroupChannelThreadMessageList.tsx +3 -4
  1080. package/src/domain/groupChannelThread/component/GroupChannelThreadParentMessageInfo.tsx +11 -10
  1081. package/src/domain/groupChannelThread/component/GroupChannelThreadSuggestedMentionList.tsx +18 -16
  1082. package/src/domain/messageSearch/component/MessageSearchHeader.tsx +9 -6
  1083. package/src/domain/openChannel/component/OpenChannelHeader.tsx +1 -1
  1084. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.tsx +3 -4
  1085. package/src/domain/openChannelCreate/component/OpenChannelCreateProfileInput.tsx +6 -6
  1086. package/src/domain/openChannelList/component/OpenChannelListList.tsx +3 -4
  1087. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.tsx +3 -4
  1088. package/src/domain/openChannelOperators/component/OpenChannelOperatorsList.tsx +3 -4
  1089. package/src/domain/userList/component/UserListList.tsx +3 -5
  1090. package/src/fragments/createGroupChannelFragment.tsx +1 -1
  1091. package/src/fragments/createGroupChannelMembersFragment.tsx +4 -5
  1092. package/src/fragments/createGroupChannelModerationFragment.tsx +4 -5
  1093. package/src/fragments/createGroupChannelMutedMembersFragment.tsx +4 -5
  1094. package/src/fragments/createGroupChannelOperatorsFragment.tsx +4 -5
  1095. package/src/fragments/createGroupChannelSettingsFragment.tsx +4 -5
  1096. package/src/fragments/createOpenChannelModerationFragment.tsx +4 -5
  1097. package/src/fragments/createOpenChannelSettingsFragment.tsx +4 -5
  1098. package/src/hooks/useMentionSuggestion.ts +3 -5
  1099. package/src/hooks/useMentionTextInput.ts +1 -0
  1100. package/src/libs/EmojiManager.ts +11 -3
  1101. package/src/libs/MentionManager.tsx +29 -3
  1102. package/src/localization/StringSet.type.ts +5 -1
  1103. package/src/localization/createBaseStringSet.ts +3 -0
  1104. package/src/version.ts +1 -1
@@ -1 +1 @@
1
- {"version":3,"names":["React","Pressable","createStyleSheet","useUIKitTheme","useForceUpdate","useGroupChannelHandler","getReactionCount","DEFAULT_LONG_PRESS_DELAY","UNKNOWN_USER_ID","useReaction","useSendbirdChat","ReactionRoundedButton","NUM_COL","REACTION_MORE_KEY","getUserReacted","reaction","userId","arguments","length","undefined","userIds","indexOf","createOnPressReaction","channel","message","reacted","deleteReaction","key","addReaction","createReactionButtons","getEmoji","emojiLimit","onOpenReactionList","onOpenReactionUserList","currentUserId","reactionAddonType","reactions","buttons","map","index","isNotLastOfRow","isNotLastOfCol","createElement","onPress","onLongPress","delayLongPress","_ref","pressed","url","count","style","styles","marginRight","marginBottom","push","_ref2","More","MessageReactionAddon","_ref3","_message$reactions","colors","sdk","emojiManager","currentUser","openReactionList","openReactionUserList","forceUpdate","onReactionUpdated","_","event","messageId","applyReactionEvent","reactionButtons","allEmojiMap","allEmoji","focusIndex","containerStyle","reactionContainer","reactionThreadParentMessageContainer","backgroundColor","background","borderColor","ui","rounded","enabled","alignItems","flexDirection","flexWrap","padding","borderRadius","borderWidth"],"sources":["MessageReactionAddon.tsx"],"sourcesContent":["import React from 'react';\nimport { Pressable } from 'react-native';\n\nimport type { Emoji } from '@sendbird/chat';\nimport { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { useForceUpdate, useGroupChannelHandler } from '@sendbird/uikit-tools';\nimport type { SendbirdBaseChannel, SendbirdBaseMessage, SendbirdReaction } from '@sendbird/uikit-utils';\nimport { getReactionCount } from '@sendbird/uikit-utils';\n\nimport { DEFAULT_LONG_PRESS_DELAY, UNKNOWN_USER_ID } from '../../constants';\nimport { useReaction, useSendbirdChat } from '../../hooks/useContext';\nimport ReactionRoundedButton from './ReactionRoundedButton';\n\nconst NUM_COL = 4;\nconst REACTION_MORE_KEY = 'reaction-more-button';\nexport type ReactionAddonType = 'default' | 'thread_parent_message';\n\nconst getUserReacted = (reaction: SendbirdReaction, userId = UNKNOWN_USER_ID) => {\n return reaction.userIds.indexOf(userId) > -1;\n};\n\nconst createOnPressReaction = (\n reaction: SendbirdReaction,\n channel: SendbirdBaseChannel,\n message: SendbirdBaseMessage,\n reacted: boolean,\n) => {\n return () => {\n if (reacted) {\n return channel.deleteReaction(message, reaction.key);\n } else {\n return channel.addReaction(message, reaction.key);\n }\n };\n};\n\nconst createReactionButtons = (\n channel: SendbirdBaseChannel,\n message: SendbirdBaseMessage,\n getEmoji: (key: string) => Emoji,\n emojiLimit: number,\n onOpenReactionList: () => void,\n onOpenReactionUserList: (focusIndex: number) => void,\n currentUserId?: string,\n reactionAddonType?: ReactionAddonType,\n) => {\n const reactions = message.reactions ?? [];\n const buttons = reactions.map((reaction, index) => {\n const isNotLastOfRow = index % NUM_COL !== NUM_COL - 1;\n const isNotLastOfCol = index < NUM_COL && reactions.length >= NUM_COL;\n return (\n <Pressable\n key={reaction.key}\n onPress={createOnPressReaction(reaction, channel, message, getUserReacted(reaction, currentUserId))}\n onLongPress={() => onOpenReactionUserList(index)}\n delayLongPress={DEFAULT_LONG_PRESS_DELAY}\n >\n {({ pressed }) => (\n <ReactionRoundedButton\n url={getEmoji(reaction.key).url}\n count={getReactionCount(reaction)}\n reacted={pressed || getUserReacted(reaction, currentUserId)}\n style={\n reactionAddonType === 'default'\n ? [isNotLastOfRow && styles.marginRight, isNotLastOfCol && styles.marginBottom]\n : [styles.marginRight, styles.marginBottom]\n }\n />\n )}\n </Pressable>\n );\n });\n if (buttons.length < emojiLimit) {\n buttons.push(\n <Pressable key={REACTION_MORE_KEY} onPress={onOpenReactionList}>\n {({ pressed }) => <ReactionRoundedButton.More pressed={pressed} />}\n </Pressable>,\n );\n }\n\n return buttons;\n};\n\nconst MessageReactionAddon = ({\n channel,\n message,\n reactionAddonType = 'default',\n}: {\n channel: SendbirdBaseChannel;\n message: SendbirdBaseMessage;\n reactionAddonType?: ReactionAddonType;\n}) => {\n const { colors } = useUIKitTheme();\n const { sdk, emojiManager, currentUser } = useSendbirdChat();\n const { openReactionList, openReactionUserList } = useReaction();\n const forceUpdate = useForceUpdate();\n\n useGroupChannelHandler(sdk, {\n async onReactionUpdated(_, event) {\n if (event.messageId === message.messageId) {\n message.applyReactionEvent(event);\n forceUpdate();\n }\n },\n });\n\n if (reactionAddonType === 'default' && !message.reactions?.length) return null;\n\n const reactionButtons = createReactionButtons(\n channel,\n message,\n (key) => emojiManager.allEmojiMap[key],\n emojiManager.allEmoji.length,\n () => openReactionList({ channel, message }),\n (focusIndex) => openReactionUserList({ channel, message, focusIndex }),\n currentUser?.userId,\n reactionAddonType,\n );\n\n const containerStyle =\n reactionAddonType === 'default' ? styles.reactionContainer : styles.reactionThreadParentMessageContainer;\n\n return (\n <Pressable\n style={[\n containerStyle,\n { backgroundColor: colors.background, borderColor: colors.ui.reaction.rounded.enabled.background },\n ]}\n >\n {reactionButtons}\n </Pressable>\n );\n};\n\nconst styles = createStyleSheet({\n reactionContainer: {\n alignItems: 'stretch',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 8,\n borderRadius: 16,\n borderWidth: 1,\n },\n reactionThreadParentMessageContainer: {\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n marginRight: {\n marginRight: 4.5,\n },\n marginBottom: {\n marginBottom: 4,\n },\n});\n\nexport default MessageReactionAddon;\n"],"mappings":"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"}
1
+ {"version":3,"names":["React","Pressable","createStyleSheet","useUIKitTheme","useForceUpdate","useGroupChannelHandler","getReactionCount","DEFAULT_LONG_PRESS_DELAY","useReaction","useSendbirdChat","ReactionRoundedButton","NUM_COL","REACTION_MORE_KEY","createOnPressReaction","reaction","channel","message","reacted","deleteReaction","key","addReaction","createReactionButtons","getIconSource","emojiLimit","onOpenReactionList","onOpenReactionUserList","reactionAddonType","reactions","buttons","map","index","isNotLastOfRow","isNotLastOfCol","length","createElement","onPress","hasCurrentUserReacted","onLongPress","delayLongPress","pressed","source","count","style","styles","marginEnd","marginBottom","push","More","MessageReactionAddon","_message$reactions","colors","sdk","emojiManager","openReactionList","openReactionUserList","forceUpdate","onReactionUpdated","_","event","messageId","applyReactionEvent","reactionButtons","reactionKey","emoji","allEmojiMap","getEmojiIconSource","allEmoji","focusIndex","containerStyle","reactionContainer","reactionThreadParentMessageContainer","backgroundColor","background","borderColor","ui","rounded","enabled","alignItems","flexDirection","flexWrap","padding","borderRadius","borderWidth"],"sources":["MessageReactionAddon.tsx"],"sourcesContent":["import React from 'react';\nimport { ImageProps, Pressable } from 'react-native';\n\nimport { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { useForceUpdate, useGroupChannelHandler } from '@sendbird/uikit-tools';\nimport type { SendbirdBaseChannel, SendbirdBaseMessage, SendbirdReaction } from '@sendbird/uikit-utils';\nimport { getReactionCount } from '@sendbird/uikit-utils';\n\nimport { DEFAULT_LONG_PRESS_DELAY } from '../../constants';\nimport { useReaction, useSendbirdChat } from '../../hooks/useContext';\nimport ReactionRoundedButton from './ReactionRoundedButton';\n\nconst NUM_COL = 4;\nconst REACTION_MORE_KEY = 'reaction-more-button';\nexport type ReactionAddonType = 'default' | 'thread_parent_message';\n\nconst createOnPressReaction = (\n reaction: SendbirdReaction,\n channel: SendbirdBaseChannel,\n message: SendbirdBaseMessage,\n reacted: boolean,\n) => {\n return () => {\n if (reacted) {\n return channel.deleteReaction(message, reaction.key);\n } else {\n return channel.addReaction(message, reaction.key);\n }\n };\n};\n\nconst createReactionButtons = (\n channel: SendbirdBaseChannel,\n message: SendbirdBaseMessage,\n getIconSource: (reactionKey: string) => ImageProps['source'],\n emojiLimit: number,\n onOpenReactionList: () => void,\n onOpenReactionUserList: (focusIndex: number) => void,\n reactionAddonType?: ReactionAddonType,\n) => {\n const reactions = message.reactions ?? [];\n const buttons = reactions.map((reaction, index) => {\n const isNotLastOfRow = index % NUM_COL !== NUM_COL - 1;\n const isNotLastOfCol = index < NUM_COL && reactions.length >= NUM_COL;\n return (\n <Pressable\n key={reaction.key}\n onPress={createOnPressReaction(reaction, channel, message, reaction.hasCurrentUserReacted)}\n onLongPress={() => onOpenReactionUserList(index)}\n delayLongPress={DEFAULT_LONG_PRESS_DELAY}\n >\n {({ pressed }) => (\n <ReactionRoundedButton\n source={getIconSource(reaction.key)}\n count={getReactionCount(reaction)}\n reacted={pressed || reaction.hasCurrentUserReacted}\n style={\n reactionAddonType === 'default'\n ? [isNotLastOfRow && styles.marginEnd, isNotLastOfCol && styles.marginBottom]\n : [styles.marginEnd, styles.marginBottom]\n }\n />\n )}\n </Pressable>\n );\n });\n if (buttons.length < emojiLimit) {\n buttons.push(\n <Pressable key={REACTION_MORE_KEY} onPress={onOpenReactionList}>\n {({ pressed }) => <ReactionRoundedButton.More pressed={pressed} />}\n </Pressable>,\n );\n }\n\n return buttons;\n};\n\nconst MessageReactionAddon = ({\n channel,\n message,\n reactionAddonType = 'default',\n}: {\n channel: SendbirdBaseChannel;\n message: SendbirdBaseMessage;\n reactionAddonType?: ReactionAddonType;\n}) => {\n const { colors } = useUIKitTheme();\n const { sdk, emojiManager } = useSendbirdChat();\n const { openReactionList, openReactionUserList } = useReaction();\n const forceUpdate = useForceUpdate();\n\n useGroupChannelHandler(sdk, {\n async onReactionUpdated(_, event) {\n if (event.messageId === message.messageId) {\n message.applyReactionEvent(event);\n forceUpdate();\n }\n },\n });\n\n if (reactionAddonType === 'default' && !message.reactions?.length) return null;\n\n const reactionButtons = createReactionButtons(\n channel,\n message,\n (reactionKey) => {\n const emoji = emojiManager.allEmojiMap[reactionKey];\n return emojiManager.getEmojiIconSource(emoji);\n },\n emojiManager.allEmoji.length,\n () => openReactionList({ channel, message }),\n (focusIndex) => openReactionUserList({ channel, message, focusIndex }),\n reactionAddonType,\n );\n\n const containerStyle =\n reactionAddonType === 'default' ? styles.reactionContainer : styles.reactionThreadParentMessageContainer;\n\n return (\n <Pressable\n style={[\n containerStyle,\n { backgroundColor: colors.background, borderColor: colors.ui.reaction.rounded.enabled.background },\n ]}\n >\n {reactionButtons}\n </Pressable>\n );\n};\n\nconst styles = createStyleSheet({\n reactionContainer: {\n alignItems: 'stretch',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 8,\n borderRadius: 16,\n borderWidth: 1,\n },\n reactionThreadParentMessageContainer: {\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n marginEnd: {\n marginEnd: 4.5,\n },\n marginBottom: {\n marginBottom: 4,\n },\n});\n\nexport default MessageReactionAddon;\n"],"mappings":"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","ignoreList":[]}
@@ -2,13 +2,13 @@ import React from 'react';
2
2
  import { View } from 'react-native';
3
3
  import { Icon, Image, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
4
4
  import { truncatedCount } from '@sendbird/uikit-utils';
5
- const ReactionRoundedButton = _ref => {
6
- let {
7
- url,
8
- count,
9
- reacted,
10
- style
11
- } = _ref;
5
+ const ReactionRoundedButton = ({
6
+ source,
7
+ count,
8
+ reacted,
9
+ style,
10
+ url
11
+ }) => {
12
12
  const {
13
13
  colors
14
14
  } = useUIKitTheme();
@@ -18,7 +18,7 @@ const ReactionRoundedButton = _ref => {
18
18
  backgroundColor: reacted ? color.selected.background : color.enabled.background
19
19
  }, style]
20
20
  }, /*#__PURE__*/React.createElement(Image, {
21
- source: {
21
+ source: source ? source : {
22
22
  uri: url
23
23
  },
24
24
  style: styles.emoji
@@ -29,10 +29,9 @@ const ReactionRoundedButton = _ref => {
29
29
  style: styles.count
30
30
  }, truncatedCount(count, 99, '')));
31
31
  };
32
- ReactionRoundedButton.More = _ref2 => {
33
- let {
34
- pressed
35
- } = _ref2;
32
+ ReactionRoundedButton.More = ({
33
+ pressed
34
+ }) => {
36
35
  const {
37
36
  colors
38
37
  } = useUIKitTheme();
@@ -60,7 +59,7 @@ const styles = createStyleSheet({
60
59
  emoji: {
61
60
  width: 20,
62
61
  height: 20,
63
- marginRight: 4
62
+ marginEnd: 4
64
63
  },
65
64
  count: {
66
65
  width: 13,
@@ -1 +1 @@
1
- {"version":3,"names":["React","View","Icon","Image","Text","createStyleSheet","useUIKitTheme","truncatedCount","ReactionRoundedButton","_ref","url","count","reacted","style","colors","color","ui","reaction","rounded","createElement","styles","reactionContainer","backgroundColor","selected","background","enabled","source","uri","emoji","caption4","onBackground01","numberOfLines","More","_ref2","pressed","icon","onBackground03","size","flexDirection","justifyContent","alignItems","width","borderRadius","paddingVertical","paddingHorizontal","height","marginRight","textAlign"],"sources":["ReactionRoundedButton.tsx"],"sourcesContent":["import React from 'react';\nimport { StyleProp, View, ViewStyle } from 'react-native';\n\nimport { Icon, Image, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { truncatedCount } from '@sendbird/uikit-utils';\n\ntype Props = {\n url: string;\n count: number;\n reacted: boolean;\n style: StyleProp<ViewStyle>;\n};\n\nconst ReactionRoundedButton = ({ url, count, reacted, style }: Props) => {\n const { colors } = useUIKitTheme();\n const color = colors.ui.reaction.rounded;\n\n return (\n <View\n style={[\n styles.reactionContainer,\n { backgroundColor: reacted ? color.selected.background : color.enabled.background },\n style,\n ]}\n >\n <Image source={{ uri: url }} style={styles.emoji} />\n <Text caption4 color={colors.onBackground01} numberOfLines={1} style={styles.count}>\n {truncatedCount(count, 99, '')}\n </Text>\n </View>\n );\n};\n\nReactionRoundedButton.More = ({ pressed }: { pressed: boolean }) => {\n const { colors } = useUIKitTheme();\n const color = colors.ui.reaction.rounded;\n\n return (\n <View\n style={[\n styles.reactionContainer,\n { backgroundColor: pressed ? color.selected.background : color.enabled.background },\n ]}\n >\n <Icon icon={'emoji-more'} color={colors.onBackground03} size={20} />\n </View>\n );\n};\n\nconst styles = createStyleSheet({\n reactionContainer: {\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n width: 52,\n borderRadius: 24,\n paddingVertical: 5,\n paddingHorizontal: 8,\n },\n emoji: {\n width: 20,\n height: 20,\n marginRight: 4,\n },\n count: {\n width: 13,\n textAlign: 'left',\n },\n});\n\nexport default ReactionRoundedButton;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAAoBC,IAAI,QAAmB,cAAc;AAEzD,SAASC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,gBAAgB,EAAEC,aAAa,QAAQ,yCAAyC;AAC5G,SAASC,cAAc,QAAQ,uBAAuB;AAStD,MAAMC,qBAAqB,GAAGC,IAAA,IAA2C;EAAA,IAA1C;IAAEC,GAAG;IAAEC,KAAK;IAAEC,OAAO;IAAEC;EAAa,CAAC,GAAAJ,IAAA;EAClE,MAAM;IAAEK;EAAO,CAAC,GAAGR,aAAa,EAAE;EAClC,MAAMS,KAAK,GAAGD,MAAM,CAACE,EAAE,CAACC,QAAQ,CAACC,OAAO;EAExC,oBACElB,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IACHY,KAAK,EAAE,CACLO,MAAM,CAACC,iBAAiB,EACxB;MAAEC,eAAe,EAAEV,OAAO,GAAGG,KAAK,CAACQ,QAAQ,CAACC,UAAU,GAAGT,KAAK,CAACU,OAAO,CAACD;IAAW,CAAC,EACnFX,KAAK;EACL,gBAEFb,KAAA,CAAAmB,aAAA,CAAChB,KAAK;IAACuB,MAAM,EAAE;MAAEC,GAAG,EAAEjB;IAAI,CAAE;IAACG,KAAK,EAAEO,MAAM,CAACQ;EAAM,EAAG,eACpD5B,KAAA,CAAAmB,aAAA,CAACf,IAAI;IAACyB,QAAQ;IAACd,KAAK,EAAED,MAAM,CAACgB,cAAe;IAACC,aAAa,EAAE,CAAE;IAAClB,KAAK,EAAEO,MAAM,CAACT;EAAM,GAChFJ,cAAc,CAACI,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CACzB,CACF;AAEX,CAAC;AAEDH,qBAAqB,CAACwB,IAAI,GAAGC,KAAA,IAAuC;EAAA,IAAtC;IAAEC;EAA8B,CAAC,GAAAD,KAAA;EAC7D,MAAM;IAAEnB;EAAO,CAAC,GAAGR,aAAa,EAAE;EAClC,MAAMS,KAAK,GAAGD,MAAM,CAACE,EAAE,CAACC,QAAQ,CAACC,OAAO;EAExC,oBACElB,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IACHY,KAAK,EAAE,CACLO,MAAM,CAACC,iBAAiB,EACxB;MAAEC,eAAe,EAAEY,OAAO,GAAGnB,KAAK,CAACQ,QAAQ,CAACC,UAAU,GAAGT,KAAK,CAACU,OAAO,CAACD;IAAW,CAAC;EACnF,gBAEFxB,KAAA,CAAAmB,aAAA,CAACjB,IAAI;IAACiC,IAAI,EAAE,YAAa;IAACpB,KAAK,EAAED,MAAM,CAACsB,cAAe;IAACC,IAAI,EAAE;EAAG,EAAG,CAC/D;AAEX,CAAC;AAED,MAAMjB,MAAM,GAAGf,gBAAgB,CAAC;EAC9BgB,iBAAiB,EAAE;IACjBiB,aAAa,EAAE,KAAK;IACpBC,cAAc,EAAE,QAAQ;IACxBC,UAAU,EAAE,QAAQ;IACpBC,KAAK,EAAE,EAAE;IACTC,YAAY,EAAE,EAAE;IAChBC,eAAe,EAAE,CAAC;IAClBC,iBAAiB,EAAE;EACrB,CAAC;EACDhB,KAAK,EAAE;IACLa,KAAK,EAAE,EAAE;IACTI,MAAM,EAAE,EAAE;IACVC,WAAW,EAAE;EACf,CAAC;EACDnC,KAAK,EAAE;IACL8B,KAAK,EAAE,EAAE;IACTM,SAAS,EAAE;EACb;AACF,CAAC,CAAC;AAEF,eAAevC,qBAAqB"}
1
+ {"version":3,"names":["React","View","Icon","Image","Text","createStyleSheet","useUIKitTheme","truncatedCount","ReactionRoundedButton","source","count","reacted","style","url","colors","color","ui","reaction","rounded","createElement","styles","reactionContainer","backgroundColor","selected","background","enabled","uri","emoji","caption4","onBackground01","numberOfLines","More","pressed","icon","onBackground03","size","flexDirection","justifyContent","alignItems","width","borderRadius","paddingVertical","paddingHorizontal","height","marginEnd","textAlign"],"sources":["ReactionRoundedButton.tsx"],"sourcesContent":["import React from 'react';\nimport { ImageProps, StyleProp, View, ViewStyle } from 'react-native';\n\nimport { Icon, Image, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { truncatedCount } from '@sendbird/uikit-utils';\n\ntype Props = {\n source: ImageProps['source'];\n count: number;\n reacted: boolean;\n style: StyleProp<ViewStyle>;\n /**\n * @deprecated Please use `source` instead\n * */\n url?: string;\n};\n\nconst ReactionRoundedButton = ({ source, count, reacted, style, url }: Props) => {\n const { colors } = useUIKitTheme();\n const color = colors.ui.reaction.rounded;\n\n return (\n <View\n style={[\n styles.reactionContainer,\n { backgroundColor: reacted ? color.selected.background : color.enabled.background },\n style,\n ]}\n >\n <Image source={source ? source : { uri: url }} style={styles.emoji} />\n <Text caption4 color={colors.onBackground01} numberOfLines={1} style={styles.count}>\n {truncatedCount(count, 99, '')}\n </Text>\n </View>\n );\n};\n\nReactionRoundedButton.More = ({ pressed }: { pressed: boolean }) => {\n const { colors } = useUIKitTheme();\n const color = colors.ui.reaction.rounded;\n\n return (\n <View\n style={[\n styles.reactionContainer,\n { backgroundColor: pressed ? color.selected.background : color.enabled.background },\n ]}\n >\n <Icon icon={'emoji-more'} color={colors.onBackground03} size={20} />\n </View>\n );\n};\n\nconst styles = createStyleSheet({\n reactionContainer: {\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n width: 52,\n borderRadius: 24,\n paddingVertical: 5,\n paddingHorizontal: 8,\n },\n emoji: {\n width: 20,\n height: 20,\n marginEnd: 4,\n },\n count: {\n width: 13,\n textAlign: 'left',\n },\n});\n\nexport default ReactionRoundedButton;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAAgCC,IAAI,QAAmB,cAAc;AAErE,SAASC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,gBAAgB,EAAEC,aAAa,QAAQ,yCAAyC;AAC5G,SAASC,cAAc,QAAQ,uBAAuB;AAatD,MAAMC,qBAAqB,GAAGA,CAAC;EAAEC,MAAM;EAAEC,KAAK;EAAEC,OAAO;EAAEC,KAAK;EAAEC;AAAW,CAAC,KAAK;EAC/E,MAAM;IAAEC;EAAO,CAAC,GAAGR,aAAa,CAAC,CAAC;EAClC,MAAMS,KAAK,GAAGD,MAAM,CAACE,EAAE,CAACC,QAAQ,CAACC,OAAO;EAExC,oBACElB,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IACHW,KAAK,EAAE,CACLQ,MAAM,CAACC,iBAAiB,EACxB;MAAEC,eAAe,EAAEX,OAAO,GAAGI,KAAK,CAACQ,QAAQ,CAACC,UAAU,GAAGT,KAAK,CAACU,OAAO,CAACD;IAAW,CAAC,EACnFZ,KAAK;EACL,gBAEFZ,KAAA,CAAAmB,aAAA,CAAChB,KAAK;IAACM,MAAM,EAAEA,MAAM,GAAGA,MAAM,GAAG;MAAEiB,GAAG,EAAEb;IAAI,CAAE;IAACD,KAAK,EAAEQ,MAAM,CAACO;EAAM,CAAE,CAAC,eACtE3B,KAAA,CAAAmB,aAAA,CAACf,IAAI;IAACwB,QAAQ;IAACb,KAAK,EAAED,MAAM,CAACe,cAAe;IAACC,aAAa,EAAE,CAAE;IAAClB,KAAK,EAAEQ,MAAM,CAACV;EAAM,GAChFH,cAAc,CAACG,KAAK,EAAE,EAAE,EAAE,EAAE,CACzB,CACF,CAAC;AAEX,CAAC;AAEDF,qBAAqB,CAACuB,IAAI,GAAG,CAAC;EAAEC;AAA8B,CAAC,KAAK;EAClE,MAAM;IAAElB;EAAO,CAAC,GAAGR,aAAa,CAAC,CAAC;EAClC,MAAMS,KAAK,GAAGD,MAAM,CAACE,EAAE,CAACC,QAAQ,CAACC,OAAO;EAExC,oBACElB,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IACHW,KAAK,EAAE,CACLQ,MAAM,CAACC,iBAAiB,EACxB;MAAEC,eAAe,EAAEU,OAAO,GAAGjB,KAAK,CAACQ,QAAQ,CAACC,UAAU,GAAGT,KAAK,CAACU,OAAO,CAACD;IAAW,CAAC;EACnF,gBAEFxB,KAAA,CAAAmB,aAAA,CAACjB,IAAI;IAAC+B,IAAI,EAAE,YAAa;IAAClB,KAAK,EAAED,MAAM,CAACoB,cAAe;IAACC,IAAI,EAAE;EAAG,CAAE,CAC/D,CAAC;AAEX,CAAC;AAED,MAAMf,MAAM,GAAGf,gBAAgB,CAAC;EAC9BgB,iBAAiB,EAAE;IACjBe,aAAa,EAAE,KAAK;IACpBC,cAAc,EAAE,QAAQ;IACxBC,UAAU,EAAE,QAAQ;IACpBC,KAAK,EAAE,EAAE;IACTC,YAAY,EAAE,EAAE;IAChBC,eAAe,EAAE,CAAC;IAClBC,iBAAiB,EAAE;EACrB,CAAC;EACDf,KAAK,EAAE;IACLY,KAAK,EAAE,EAAE;IACTI,MAAM,EAAE,EAAE;IACVC,SAAS,EAAE;EACb,CAAC;EACDlC,KAAK,EAAE;IACL6B,KAAK,EAAE,EAAE;IACTM,SAAS,EAAE;EACb;AACF,CAAC,CAAC;AAEF,eAAerC,qBAAqB","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"names":["BottomSheet","Message","ReactionAddons"],"sources":["index.tsx"],"sourcesContent":["import BottomSheet from './BottomSheetReactionAddon';\nimport Message from './MessageReactionAddon';\n\nexport const ReactionAddons = {\n BottomSheet,\n Message,\n};\n"],"mappings":"AAAA,OAAOA,WAAW,MAAM,4BAA4B;AACpD,OAAOC,OAAO,MAAM,wBAAwB;AAE5C,OAAO,MAAMC,cAAc,GAAG;EAC5BF,WAAW;EACXC;AACF,CAAC"}
1
+ {"version":3,"names":["BottomSheet","Message","ReactionAddons"],"sources":["index.tsx"],"sourcesContent":["import BottomSheet from './BottomSheetReactionAddon';\nimport Message from './MessageReactionAddon';\n\nexport const ReactionAddons = {\n BottomSheet,\n Message,\n};\n"],"mappings":"AAAA,OAAOA,WAAW,MAAM,4BAA4B;AACpD,OAAOC,OAAO,MAAM,wBAAwB;AAE5C,OAAO,MAAMC,cAAc,GAAG;EAC5BF,WAAW;EACXC;AACF,CAAC","ignoreList":[]}
@@ -1,26 +1,20 @@
1
1
  import React from 'react';
2
2
  import { FlatList, Pressable, View, useWindowDimensions } from 'react-native';
3
- import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
3
  import { Image, Modal, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
5
- import { Logger } from '@sendbird/uikit-utils';
4
+ import { Logger, useSafeAreaPadding } from '@sendbird/uikit-utils';
6
5
  import { UNKNOWN_USER_ID } from '../../constants';
7
6
  const NUM_COLUMN = 6;
8
- const ReactionListBottomSheet = _ref => {
9
- let {
10
- visible,
11
- onClose,
12
- onDismiss,
13
- reactionCtx,
14
- chatCtx
15
- } = _ref;
7
+ const ReactionListBottomSheet = ({
8
+ visible,
9
+ onClose,
10
+ onDismiss,
11
+ reactionCtx,
12
+ chatCtx
13
+ }) => {
16
14
  const {
17
15
  width
18
16
  } = useWindowDimensions();
19
- const {
20
- bottom,
21
- left,
22
- right
23
- } = useSafeAreaInsets();
17
+ const safeArea = useSafeAreaPadding(['bottom', 'left', 'right']);
24
18
  const {
25
19
  colors
26
20
  } = useUIKitTheme();
@@ -42,10 +36,10 @@ const ReactionListBottomSheet = _ref => {
42
36
  }, /*#__PURE__*/React.createElement(View, {
43
37
  style: [styles.container, {
44
38
  width,
45
- paddingBottom: bottom,
39
+ paddingBottom: safeArea.paddingBottom,
46
40
  backgroundColor: colors.ui.dialog.default.none.background,
47
- paddingLeft: left + styles.container.paddingHorizontal,
48
- paddingRight: right + styles.container.paddingHorizontal
41
+ paddingStart: safeArea.paddingStart + styles.container.paddingHorizontal,
42
+ paddingEnd: safeArea.paddingEnd + styles.container.paddingHorizontal
49
43
  }]
50
44
  }, /*#__PURE__*/React.createElement(FlatList, {
51
45
  data: emojiManager.allEmoji,
@@ -57,15 +51,14 @@ const ReactionListBottomSheet = _ref => {
57
51
  height: 16
58
52
  }
59
53
  }),
60
- renderItem: _ref2 => {
61
- var _message$reactions, _message$reactions$fi;
62
- let {
63
- item: {
64
- key,
65
- url
66
- }
67
- } = _ref2;
68
- const reactedUserIds = (message === null || message === void 0 ? void 0 : (_message$reactions = message.reactions) === null || _message$reactions === void 0 ? void 0 : (_message$reactions$fi = _message$reactions.find(it => it.key === key)) === null || _message$reactions$fi === void 0 ? void 0 : _message$reactions$fi.userIds) ?? [];
54
+ renderItem: ({
55
+ item: {
56
+ key,
57
+ url
58
+ }
59
+ }) => {
60
+ var _message$reactions;
61
+ const reactedUserIds = (message === null || message === void 0 || (_message$reactions = message.reactions) === null || _message$reactions === void 0 || (_message$reactions = _message$reactions.find(it => it.key === key)) === null || _message$reactions === void 0 ? void 0 : _message$reactions.userIds) ?? [];
69
62
  const idx = reactedUserIds.indexOf((currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ?? UNKNOWN_USER_ID);
70
63
  const reacted = idx > -1;
71
64
  return /*#__PURE__*/React.createElement(View, {
@@ -83,14 +76,11 @@ const ReactionListBottomSheet = _ref => {
83
76
  }
84
77
  await onClose();
85
78
  },
86
- style: _ref3 => {
87
- let {
88
- pressed
89
- } = _ref3;
90
- return [styles.button, {
91
- backgroundColor: reacted || pressed ? color.selected.background : color.enabled.background
92
- }];
93
- }
79
+ style: ({
80
+ pressed
81
+ }) => [styles.button, {
82
+ backgroundColor: reacted || pressed ? color.selected.background : color.enabled.background
83
+ }]
94
84
  }, /*#__PURE__*/React.createElement(Image, {
95
85
  source: {
96
86
  uri: url
@@ -103,8 +93,8 @@ const ReactionListBottomSheet = _ref => {
103
93
  const styles = createStyleSheet({
104
94
  container: {
105
95
  overflow: 'hidden',
106
- borderTopLeftRadius: 8,
107
- borderTopRightRadius: 8,
96
+ borderTopStartRadius: 8,
97
+ borderTopEndRadius: 8,
108
98
  paddingTop: 16,
109
99
  paddingHorizontal: 18,
110
100
  flexDirection: 'row'
@@ -1 +1 @@
1
- {"version":3,"names":["React","FlatList","Pressable","View","useWindowDimensions","useSafeAreaInsets","Image","Modal","createStyleSheet","useUIKitTheme","Logger","UNKNOWN_USER_ID","NUM_COLUMN","ReactionListBottomSheet","_ref","visible","onClose","onDismiss","reactionCtx","chatCtx","width","bottom","left","right","colors","currentUser","emojiManager","channel","message","color","ui","reaction","default","createElement","type","Boolean","backgroundStyle","styles","modal","style","container","paddingBottom","backgroundColor","dialog","none","background","paddingLeft","paddingHorizontal","paddingRight","data","allEmoji","numColumns","keyExtractor","item","key","contentContainerStyle","flatlist","ItemSeparatorComponent","height","renderItem","_ref2","_message$reactions","_message$reactions$fi","url","reactedUserIds","reactions","find","it","userIds","idx","indexOf","userId","reacted","emojiItem","onPress","action","deleteReaction","addReaction","catch","error","warn","_ref3","pressed","button","selected","enabled","source","uri","emoji","overflow","borderTopLeftRadius","borderTopRightRadius","paddingTop","flexDirection","alignItems","justifyContent","padding","borderRadius"],"sources":["ReactionListBottomSheet.tsx"],"sourcesContent":["import React from 'react';\nimport { FlatList, Pressable, View, useWindowDimensions } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\n\nimport type { BaseMessage } from '@sendbird/chat/message';\nimport { Image, Modal, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { Logger } from '@sendbird/uikit-utils';\n\nimport { UNKNOWN_USER_ID } from '../../constants';\nimport type { ReactionBottomSheetProps } from './index';\n\nconst NUM_COLUMN = 6;\nconst ReactionListBottomSheet = ({ visible, onClose, onDismiss, reactionCtx, chatCtx }: ReactionBottomSheetProps) => {\n const { width } = useWindowDimensions();\n const { bottom, left, right } = useSafeAreaInsets();\n const { colors } = useUIKitTheme();\n\n const { currentUser, emojiManager } = chatCtx;\n const { channel, message } = reactionCtx;\n const color = colors.ui.reaction.default;\n\n return (\n <Modal\n type={'slide'}\n visible={Boolean(visible && channel && message)}\n onClose={onClose}\n onDismiss={onDismiss}\n backgroundStyle={styles.modal}\n >\n <View\n style={[\n styles.container,\n {\n width,\n paddingBottom: bottom,\n backgroundColor: colors.ui.dialog.default.none.background,\n paddingLeft: left + styles.container.paddingHorizontal,\n paddingRight: right + styles.container.paddingHorizontal,\n },\n ]}\n >\n <FlatList\n data={emojiManager.allEmoji}\n numColumns={NUM_COLUMN}\n keyExtractor={(item) => item.key}\n contentContainerStyle={styles.flatlist}\n ItemSeparatorComponent={() => <View style={{ height: 16 }} />}\n renderItem={({ item: { key, url } }) => {\n const reactedUserIds = message?.reactions?.find((it) => it.key === key)?.userIds ?? [];\n\n const idx = reactedUserIds.indexOf(currentUser?.userId ?? UNKNOWN_USER_ID);\n const reacted = idx > -1;\n\n return (\n <View style={styles.emojiItem}>\n <Pressable\n key={key}\n onPress={async () => {\n if (message && channel) {\n const action = (message: BaseMessage, key: string) => {\n return reacted ? channel.deleteReaction(message, key) : channel.addReaction(message, key);\n };\n\n action(message, key).catch((error) => {\n Logger.warn('Failed to reaction', error);\n });\n }\n await onClose();\n }}\n style={({ pressed }) => [\n styles.button,\n { backgroundColor: reacted || pressed ? color.selected.background : color.enabled.background },\n ]}\n >\n <Image source={{ uri: url }} style={styles.emoji} />\n </Pressable>\n </View>\n );\n }}\n />\n </View>\n </Modal>\n );\n};\n\nconst styles = createStyleSheet({\n container: {\n overflow: 'hidden',\n borderTopLeftRadius: 8,\n borderTopRightRadius: 8,\n paddingTop: 16,\n paddingHorizontal: 18,\n flexDirection: 'row',\n },\n modal: {\n alignItems: 'center',\n justifyContent: 'flex-end',\n },\n flatlist: {\n width: '100%',\n flexDirection: 'column',\n justifyContent: 'space-between',\n },\n emojiItem: {\n width: `${100 / NUM_COLUMN}%`,\n alignItems: 'center',\n },\n button: {\n width: 44,\n height: 44,\n padding: 4,\n borderRadius: 8,\n },\n emoji: {\n width: '100%',\n height: '100%',\n },\n});\n\nexport default ReactionListBottomSheet;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,QAAQ,EAAEC,SAAS,EAAEC,IAAI,EAAEC,mBAAmB,QAAQ,cAAc;AAC7E,SAASC,iBAAiB,QAAQ,gCAAgC;AAGlE,SAASC,KAAK,EAAEC,KAAK,EAAEC,gBAAgB,EAAEC,aAAa,QAAQ,yCAAyC;AACvG,SAASC,MAAM,QAAQ,uBAAuB;AAE9C,SAASC,eAAe,QAAQ,iBAAiB;AAGjD,MAAMC,UAAU,GAAG,CAAC;AACpB,MAAMC,uBAAuB,GAAGC,IAAA,IAAqF;EAAA,IAApF;IAAEC,OAAO;IAAEC,OAAO;IAAEC,SAAS;IAAEC,WAAW;IAAEC;EAAkC,CAAC,GAAAL,IAAA;EAC9G,MAAM;IAAEM;EAAM,CAAC,GAAGhB,mBAAmB,EAAE;EACvC,MAAM;IAAEiB,MAAM;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGlB,iBAAiB,EAAE;EACnD,MAAM;IAAEmB;EAAO,CAAC,GAAGf,aAAa,EAAE;EAElC,MAAM;IAAEgB,WAAW;IAAEC;EAAa,CAAC,GAAGP,OAAO;EAC7C,MAAM;IAAEQ,OAAO;IAAEC;EAAQ,CAAC,GAAGV,WAAW;EACxC,MAAMW,KAAK,GAAGL,MAAM,CAACM,EAAE,CAACC,QAAQ,CAACC,OAAO;EAExC,oBACEhC,KAAA,CAAAiC,aAAA,CAAC1B,KAAK;IACJ2B,IAAI,EAAE,OAAQ;IACdnB,OAAO,EAAEoB,OAAO,CAACpB,OAAO,IAAIY,OAAO,IAAIC,OAAO,CAAE;IAChDZ,OAAO,EAAEA,OAAQ;IACjBC,SAAS,EAAEA,SAAU;IACrBmB,eAAe,EAAEC,MAAM,CAACC;EAAM,gBAE9BtC,KAAA,CAAAiC,aAAA,CAAC9B,IAAI;IACHoC,KAAK,EAAE,CACLF,MAAM,CAACG,SAAS,EAChB;MACEpB,KAAK;MACLqB,aAAa,EAAEpB,MAAM;MACrBqB,eAAe,EAAElB,MAAM,CAACM,EAAE,CAACa,MAAM,CAACX,OAAO,CAACY,IAAI,CAACC,UAAU;MACzDC,WAAW,EAAExB,IAAI,GAAGe,MAAM,CAACG,SAAS,CAACO,iBAAiB;MACtDC,YAAY,EAAEzB,KAAK,GAAGc,MAAM,CAACG,SAAS,CAACO;IACzC,CAAC;EACD,gBAEF/C,KAAA,CAAAiC,aAAA,CAAChC,QAAQ;IACPgD,IAAI,EAAEvB,YAAY,CAACwB,QAAS;IAC5BC,UAAU,EAAEvC,UAAW;IACvBwC,YAAY,EAAGC,IAAI,IAAKA,IAAI,CAACC,GAAI;IACjCC,qBAAqB,EAAElB,MAAM,CAACmB,QAAS;IACvCC,sBAAsB,EAAEA,CAAA,kBAAMzD,KAAA,CAAAiC,aAAA,CAAC9B,IAAI;MAACoC,KAAK,EAAE;QAAEmB,MAAM,EAAE;MAAG;IAAE,EAAI;IAC9DC,UAAU,EAAEC,KAAA,IAA4B;MAAA,IAAAC,kBAAA,EAAAC,qBAAA;MAAA,IAA3B;QAAET,IAAI,EAAE;UAAEC,GAAG;UAAES;QAAI;MAAE,CAAC,GAAAH,KAAA;MACjC,MAAMI,cAAc,GAAG,CAAApC,OAAO,aAAPA,OAAO,wBAAAiC,kBAAA,GAAPjC,OAAO,CAAEqC,SAAS,cAAAJ,kBAAA,wBAAAC,qBAAA,GAAlBD,kBAAA,CAAoBK,IAAI,CAAEC,EAAE,IAAKA,EAAE,CAACb,GAAG,KAAKA,GAAG,CAAC,cAAAQ,qBAAA,uBAAhDA,qBAAA,CAAkDM,OAAO,KAAI,EAAE;MAEtF,MAAMC,GAAG,GAAGL,cAAc,CAACM,OAAO,CAAC,CAAA7C,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAE8C,MAAM,KAAI5D,eAAe,CAAC;MAC1E,MAAM6D,OAAO,GAAGH,GAAG,GAAG,CAAC,CAAC;MAExB,oBACErE,KAAA,CAAAiC,aAAA,CAAC9B,IAAI;QAACoC,KAAK,EAAEF,MAAM,CAACoC;MAAU,gBAC5BzE,KAAA,CAAAiC,aAAA,CAAC/B,SAAS;QACRoD,GAAG,EAAEA,GAAI;QACToB,OAAO,EAAE,MAAAA,CAAA,KAAY;UACnB,IAAI9C,OAAO,IAAID,OAAO,EAAE;YACtB,MAAMgD,MAAM,GAAGA,CAAC/C,OAAoB,EAAE0B,GAAW,KAAK;cACpD,OAAOkB,OAAO,GAAG7C,OAAO,CAACiD,cAAc,CAAChD,OAAO,EAAE0B,GAAG,CAAC,GAAG3B,OAAO,CAACkD,WAAW,CAACjD,OAAO,EAAE0B,GAAG,CAAC;YAC3F,CAAC;YAEDqB,MAAM,CAAC/C,OAAO,EAAE0B,GAAG,CAAC,CAACwB,KAAK,CAAEC,KAAK,IAAK;cACpCrE,MAAM,CAACsE,IAAI,CAAC,oBAAoB,EAAED,KAAK,CAAC;YAC1C,CAAC,CAAC;UACJ;UACA,MAAM/D,OAAO,EAAE;QACjB,CAAE;QACFuB,KAAK,EAAE0C,KAAA;UAAA,IAAC;YAAEC;UAAQ,CAAC,GAAAD,KAAA;UAAA,OAAK,CACtB5C,MAAM,CAAC8C,MAAM,EACb;YAAEzC,eAAe,EAAE8B,OAAO,IAAIU,OAAO,GAAGrD,KAAK,CAACuD,QAAQ,CAACvC,UAAU,GAAGhB,KAAK,CAACwD,OAAO,CAACxC;UAAW,CAAC,CAC/F;QAAA;MAAC,gBAEF7C,KAAA,CAAAiC,aAAA,CAAC3B,KAAK;QAACgF,MAAM,EAAE;UAAEC,GAAG,EAAExB;QAAI,CAAE;QAACxB,KAAK,EAAEF,MAAM,CAACmD;MAAM,EAAG,CAC1C,CACP;IAEX;EAAE,EACF,CACG,CACD;AAEZ,CAAC;AAED,MAAMnD,MAAM,GAAG7B,gBAAgB,CAAC;EAC9BgC,SAAS,EAAE;IACTiD,QAAQ,EAAE,QAAQ;IAClBC,mBAAmB,EAAE,CAAC;IACtBC,oBAAoB,EAAE,CAAC;IACvBC,UAAU,EAAE,EAAE;IACd7C,iBAAiB,EAAE,EAAE;IACrB8C,aAAa,EAAE;EACjB,CAAC;EACDvD,KAAK,EAAE;IACLwD,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB,CAAC;EACDvC,QAAQ,EAAE;IACRpC,KAAK,EAAE,MAAM;IACbyE,aAAa,EAAE,QAAQ;IACvBE,cAAc,EAAE;EAClB,CAAC;EACDtB,SAAS,EAAE;IACTrD,KAAK,EAAG,GAAE,GAAG,GAAGR,UAAW,GAAE;IAC7BkF,UAAU,EAAE;EACd,CAAC;EACDX,MAAM,EAAE;IACN/D,KAAK,EAAE,EAAE;IACTsC,MAAM,EAAE,EAAE;IACVsC,OAAO,EAAE,CAAC;IACVC,YAAY,EAAE;EAChB,CAAC;EACDT,KAAK,EAAE;IACLpE,KAAK,EAAE,MAAM;IACbsC,MAAM,EAAE;EACV;AACF,CAAC,CAAC;AAEF,eAAe7C,uBAAuB"}
1
+ {"version":3,"names":["React","FlatList","Pressable","View","useWindowDimensions","Image","Modal","createStyleSheet","useUIKitTheme","Logger","useSafeAreaPadding","UNKNOWN_USER_ID","NUM_COLUMN","ReactionListBottomSheet","visible","onClose","onDismiss","reactionCtx","chatCtx","width","safeArea","colors","currentUser","emojiManager","channel","message","color","ui","reaction","default","createElement","type","Boolean","backgroundStyle","styles","modal","style","container","paddingBottom","backgroundColor","dialog","none","background","paddingStart","paddingHorizontal","paddingEnd","data","allEmoji","numColumns","keyExtractor","item","key","contentContainerStyle","flatlist","ItemSeparatorComponent","height","renderItem","url","_message$reactions","reactedUserIds","reactions","find","it","userIds","idx","indexOf","userId","reacted","emojiItem","onPress","action","deleteReaction","addReaction","catch","error","warn","pressed","button","selected","enabled","source","uri","emoji","overflow","borderTopStartRadius","borderTopEndRadius","paddingTop","flexDirection","alignItems","justifyContent","padding","borderRadius"],"sources":["ReactionListBottomSheet.tsx"],"sourcesContent":["import React from 'react';\nimport { FlatList, Pressable, View, useWindowDimensions } from 'react-native';\n\nimport type { BaseMessage } from '@sendbird/chat/message';\nimport { Image, Modal, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { Logger, useSafeAreaPadding } from '@sendbird/uikit-utils';\n\nimport { UNKNOWN_USER_ID } from '../../constants';\nimport type { ReactionBottomSheetProps } from './index';\n\nconst NUM_COLUMN = 6;\nconst ReactionListBottomSheet = ({ visible, onClose, onDismiss, reactionCtx, chatCtx }: ReactionBottomSheetProps) => {\n const { width } = useWindowDimensions();\n const safeArea = useSafeAreaPadding(['bottom', 'left', 'right']);\n const { colors } = useUIKitTheme();\n\n const { currentUser, emojiManager } = chatCtx;\n const { channel, message } = reactionCtx;\n const color = colors.ui.reaction.default;\n\n return (\n <Modal\n type={'slide'}\n visible={Boolean(visible && channel && message)}\n onClose={onClose}\n onDismiss={onDismiss}\n backgroundStyle={styles.modal}\n >\n <View\n style={[\n styles.container,\n {\n width,\n paddingBottom: safeArea.paddingBottom,\n backgroundColor: colors.ui.dialog.default.none.background,\n paddingStart: safeArea.paddingStart + styles.container.paddingHorizontal,\n paddingEnd: safeArea.paddingEnd + styles.container.paddingHorizontal,\n },\n ]}\n >\n <FlatList\n data={emojiManager.allEmoji}\n numColumns={NUM_COLUMN}\n keyExtractor={(item) => item.key}\n contentContainerStyle={styles.flatlist}\n ItemSeparatorComponent={() => <View style={{ height: 16 }} />}\n renderItem={({ item: { key, url } }) => {\n const reactedUserIds = message?.reactions?.find((it) => it.key === key)?.userIds ?? [];\n\n const idx = reactedUserIds.indexOf(currentUser?.userId ?? UNKNOWN_USER_ID);\n const reacted = idx > -1;\n\n return (\n <View style={styles.emojiItem}>\n <Pressable\n key={key}\n onPress={async () => {\n if (message && channel) {\n const action = (message: BaseMessage, key: string) => {\n return reacted ? channel.deleteReaction(message, key) : channel.addReaction(message, key);\n };\n\n action(message, key).catch((error) => {\n Logger.warn('Failed to reaction', error);\n });\n }\n await onClose();\n }}\n style={({ pressed }) => [\n styles.button,\n { backgroundColor: reacted || pressed ? color.selected.background : color.enabled.background },\n ]}\n >\n <Image source={{ uri: url }} style={styles.emoji} />\n </Pressable>\n </View>\n );\n }}\n />\n </View>\n </Modal>\n );\n};\n\nconst styles = createStyleSheet({\n container: {\n overflow: 'hidden',\n borderTopStartRadius: 8,\n borderTopEndRadius: 8,\n paddingTop: 16,\n paddingHorizontal: 18,\n flexDirection: 'row',\n },\n modal: {\n alignItems: 'center',\n justifyContent: 'flex-end',\n },\n flatlist: {\n width: '100%',\n flexDirection: 'column',\n justifyContent: 'space-between',\n },\n emojiItem: {\n width: `${100 / NUM_COLUMN}%`,\n alignItems: 'center',\n },\n button: {\n width: 44,\n height: 44,\n padding: 4,\n borderRadius: 8,\n },\n emoji: {\n width: '100%',\n height: '100%',\n },\n});\n\nexport default ReactionListBottomSheet;\n"],"mappings":"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","ignoreList":[]}
@@ -1,26 +1,20 @@
1
1
  import React, { useEffect, useRef, useState } from 'react';
2
- import { Animated, Easing, Pressable, ScrollView, View, useWindowDimensions } from 'react-native';
3
- import { useSafeAreaInsets } from 'react-native-safe-area-context';
2
+ import { Animated, Easing, I18nManager, Pressable, ScrollView, View, useWindowDimensions } from 'react-native';
4
3
  import { Avatar, Divider, Image, Modal, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
5
- import { getReactionCount, truncatedCount } from '@sendbird/uikit-utils';
6
- const ReactionUserListBottomSheet = _ref => {
7
- let {
8
- visible,
9
- onClose,
10
- onDismiss,
11
- reactionCtx,
12
- chatCtx,
13
- localizationCtx,
14
- onPressUserProfile
15
- } = _ref;
4
+ import { getReactionCount, truncatedCount, useSafeAreaPadding } from '@sendbird/uikit-utils';
5
+ const ReactionUserListBottomSheet = ({
6
+ visible,
7
+ onClose,
8
+ onDismiss,
9
+ reactionCtx,
10
+ chatCtx,
11
+ localizationCtx,
12
+ onPressUserProfile
13
+ }) => {
16
14
  const {
17
15
  width
18
16
  } = useWindowDimensions();
19
- const {
20
- bottom,
21
- left,
22
- right
23
- } = useSafeAreaInsets();
17
+ const safeArea = useSafeAreaPadding(['left', 'right', 'bottom']);
24
18
  const {
25
19
  colors
26
20
  } = useUIKitTheme();
@@ -47,24 +41,22 @@ const ReactionUserListBottomSheet = _ref => {
47
41
  const reactions = (message === null || message === void 0 ? void 0 : message.reactions) ?? [];
48
42
  const focusedReaction = reactions[tabIndex];
49
43
  const containerSafeArea = {
50
- paddingLeft: left + styles.layout.paddingHorizontal,
51
- paddingRight: right + styles.layout.paddingHorizontal
44
+ paddingStart: safeArea.paddingStart + styles.layout.paddingHorizontal,
45
+ paddingEnd: safeArea.paddingEnd + styles.layout.paddingHorizontal
52
46
  };
53
- const focusTab = function (index) {
54
- let animated = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
47
+ const focusTab = (index, animated = true) => {
55
48
  const indicatorValue = tabIndicatorValue.current[index];
56
49
  if (indicatorValue) {
57
50
  var _scrollRef$current;
58
51
  setTabIndex(index);
59
52
  animateTabIndicator(indicatorValue.x, indicatorValue.width, animated);
60
- (_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollTo({
53
+ (_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 || _scrollRef$current.scrollTo({
61
54
  x: indicatorValue.x,
62
55
  animated
63
56
  });
64
57
  }
65
58
  };
66
- const animateTabIndicator = function (x, width) {
67
- let animated = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
59
+ const animateTabIndicator = (x, width, animated = true) => {
68
60
  const baseConfig = {
69
61
  duration: animated ? 300 : 0,
70
62
  easing: Easing.inOut(Easing.ease),
@@ -79,7 +71,7 @@ const ReactionUserListBottomSheet = _ref => {
79
71
  })]).start();
80
72
  };
81
73
  const layoutCalculated = () => {
82
- return tabIndicatorValue.current.length === reactions.length && tabIndicatorValue.current.every(Boolean);
74
+ return tabIndicatorValue.current.filter(Boolean).length === reactions.length;
83
75
  };
84
76
  useEffect(() => {
85
77
  if (!visible) {
@@ -99,13 +91,15 @@ const ReactionUserListBottomSheet = _ref => {
99
91
  return /*#__PURE__*/React.createElement(Pressable, {
100
92
  key: reaction.key,
101
93
  style: [styles.tabItem, isLastItem && {
102
- marginRight: styles.layout.marginRight
94
+ marginEnd: styles.layout.marginEnd
103
95
  }],
104
96
  onPress: () => focusTab(index),
105
97
  onLayout: e => {
106
- tabIndicatorValue.current[index] = e.nativeEvent.layout;
98
+ const indexForLayout = I18nManager.isRTL ? reactions.length - 1 - index : index;
99
+ tabIndicatorValue.current[indexForLayout] = e.nativeEvent.layout;
107
100
  if (layoutCalculated()) {
108
101
  if (focusedWithLayoutCalculated.current) {
102
+ // re-calculating layout when screen rotation
109
103
  focusTab(tabIndex, false);
110
104
  } else {
111
105
  focusedWithLayoutCalculated.current = true;
@@ -114,9 +108,7 @@ const ReactionUserListBottomSheet = _ref => {
114
108
  }
115
109
  }
116
110
  }, /*#__PURE__*/React.createElement(Image, {
117
- source: {
118
- uri: emoji.url
119
- },
111
+ source: emojiManager.getEmojiIconSource(emoji),
120
112
  style: styles.tabEmoji
121
113
  }), /*#__PURE__*/React.createElement(Text, {
122
114
  button: true,
@@ -124,38 +116,41 @@ const ReactionUserListBottomSheet = _ref => {
124
116
  }, truncatedCount(getReactionCount(reaction))));
125
117
  }), /*#__PURE__*/React.createElement(Animated.View, {
126
118
  style: [styles.tabIndicator, {
127
- left: tabIndicatorAnimated.x,
119
+ start: tabIndicatorAnimated.x,
128
120
  width: tabIndicatorAnimated.width,
129
121
  backgroundColor: color.selected.highlight
130
122
  }]
131
123
  }));
132
124
  };
133
125
  const renderPage = () => {
134
- return /*#__PURE__*/React.createElement(React.Fragment, null, focusedReaction === null || focusedReaction === void 0 ? void 0 : focusedReaction.userIds.map(userId => {
126
+ const userCountDifference = ((focusedReaction === null || focusedReaction === void 0 ? void 0 : focusedReaction.count) || 0) - ((focusedReaction === null || focusedReaction === void 0 ? void 0 : focusedReaction.sampledUserInfoList.length) || 0);
127
+ return /*#__PURE__*/React.createElement(React.Fragment, null, focusedReaction === null || focusedReaction === void 0 ? void 0 : focusedReaction.sampledUserInfoList.map(reactedUserInfo => {
135
128
  if (channel !== null && channel !== void 0 && channel.isGroupChannel()) {
136
- const user = channel.members.find(x => x.userId === userId);
137
129
  return /*#__PURE__*/React.createElement(Pressable, {
138
- key: userId,
130
+ key: reactedUserInfo.userId,
139
131
  onPress: async () => {
140
- if (user) {
141
- await onClose();
142
- onPressUserProfile(user);
143
- }
132
+ await onClose();
133
+ onPressUserProfile(reactedUserInfo);
144
134
  },
145
135
  style: styles.pageItem
146
136
  }, /*#__PURE__*/React.createElement(Avatar, {
147
137
  size: 36,
148
- uri: user === null || user === void 0 ? void 0 : user.profileUrl,
138
+ uri: reactedUserInfo === null || reactedUserInfo === void 0 ? void 0 : reactedUserInfo.profileUrl,
149
139
  containerStyle: styles.avatar
150
140
  }), /*#__PURE__*/React.createElement(Text, {
151
141
  subtitle2: true,
152
142
  style: {
153
143
  flex: 1
154
144
  }
155
- }, (user === null || user === void 0 ? void 0 : user.nickname) || STRINGS.LABELS.USER_NO_NAME));
145
+ }, (reactedUserInfo === null || reactedUserInfo === void 0 ? void 0 : reactedUserInfo.nickname) || STRINGS.LABELS.USER_NO_NAME));
156
146
  }
157
147
  return null;
158
- }));
148
+ }), userCountDifference > 0 && /*#__PURE__*/React.createElement(View, {
149
+ style: styles.pageItem
150
+ }, /*#__PURE__*/React.createElement(Text, {
151
+ body3: true,
152
+ color: colors.onBackground02
153
+ }, STRINGS.REACTION.MORE_USERS(userCountDifference))));
159
154
  };
160
155
  return /*#__PURE__*/React.createElement(Modal, {
161
156
  type: 'slide-no-gesture',
@@ -166,7 +161,7 @@ const ReactionUserListBottomSheet = _ref => {
166
161
  }, /*#__PURE__*/React.createElement(View, {
167
162
  style: [styles.container, {
168
163
  width,
169
- paddingBottom: bottom,
164
+ paddingBottom: safeArea.paddingBottom,
170
165
  backgroundColor: colors.ui.dialog.default.none.background
171
166
  }]
172
167
  }, /*#__PURE__*/React.createElement(ScrollView, {
@@ -189,12 +184,12 @@ const ReactionUserListBottomSheet = _ref => {
189
184
  const styles = createStyleSheet({
190
185
  layout: {
191
186
  paddingHorizontal: 16,
192
- marginRight: 0
187
+ marginEnd: 0
193
188
  },
194
189
  container: {
195
190
  overflow: 'hidden',
196
- borderTopLeftRadius: 8,
197
- borderTopRightRadius: 8,
191
+ borderTopStartRadius: 8,
192
+ borderTopEndRadius: 8,
198
193
  paddingTop: 16,
199
194
  alignItems: 'center'
200
195
  },
@@ -213,7 +208,7 @@ const styles = createStyleSheet({
213
208
  height: 44
214
209
  },
215
210
  tabItem: {
216
- marginRight: 16,
211
+ marginEnd: 16,
217
212
  flexDirection: 'row',
218
213
  alignItems: 'center',
219
214
  justifyContent: 'center'
@@ -221,7 +216,7 @@ const styles = createStyleSheet({
221
216
  tabEmoji: {
222
217
  width: 28,
223
218
  height: 28,
224
- marginRight: 4
219
+ marginEnd: 4
225
220
  },
226
221
  tabIndicator: {
227
222
  position: 'absolute',
@@ -239,7 +234,7 @@ const styles = createStyleSheet({
239
234
  alignItems: 'center'
240
235
  },
241
236
  avatar: {
242
- marginRight: 16
237
+ marginEnd: 16
243
238
  }
244
239
  });
245
240
  export default ReactionUserListBottomSheet;
@@ -1 +1 @@
1
- {"version":3,"names":["React","useEffect","useRef","useState","Animated","Easing","Pressable","ScrollView","View","useWindowDimensions","useSafeAreaInsets","Avatar","Divider","Image","Modal","Text","createStyleSheet","useUIKitTheme","getReactionCount","truncatedCount","ReactionUserListBottomSheet","_ref","visible","onClose","onDismiss","reactionCtx","chatCtx","localizationCtx","onPressUserProfile","width","bottom","left","right","colors","tabIndex","setTabIndex","scrollRef","tabIndicatorValue","tabIndicatorAnimated","x","Value","current","focusedWithLayoutCalculated","emojiManager","channel","message","focusIndex","STRINGS","color","ui","reaction","default","reactions","focusedReaction","containerSafeArea","paddingLeft","styles","layout","paddingHorizontal","paddingRight","focusTab","index","animated","arguments","length","undefined","indicatorValue","_scrollRef$current","animateTabIndicator","scrollTo","baseConfig","duration","easing","inOut","ease","useNativeDriver","parallel","timing","toValue","start","layoutCalculated","every","Boolean","renderTabs","createElement","style","tabsWrapper","map","isFocused","key","isLastItem","emoji","allEmojiMap","tabItem","marginRight","onPress","onLayout","e","nativeEvent","source","uri","url","tabEmoji","button","selected","highlight","enabled","tabIndicator","backgroundColor","renderPage","Fragment","userIds","userId","isGroupChannel","user","members","find","pageItem","size","profileUrl","containerStyle","avatar","subtitle2","flex","nickname","LABELS","USER_NO_NAME","type","backgroundStyle","modal","container","paddingBottom","dialog","none","background","ref","horizontal","bounces","showsHorizontalScrollIndicator","contentContainerStyle","tabsContainer","top","showsVerticalScrollIndicator","pageContainer","overflow","borderTopLeftRadius","borderTopRightRadius","paddingTop","alignItems","justifyContent","flexGrow","flexDirection","height","position"],"sources":["ReactionUserListBottomSheet.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { Animated, Easing, Pressable, ScrollView, View, useWindowDimensions } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\n\nimport {\n Avatar,\n Divider,\n Image,\n Modal,\n Text,\n createStyleSheet,\n useUIKitTheme,\n} from '@sendbird/uikit-react-native-foundation';\nimport { SendbirdReaction, getReactionCount, truncatedCount } from '@sendbird/uikit-utils';\n\nimport type { ReactionBottomSheetProps } from './index';\n\nconst ReactionUserListBottomSheet = ({\n visible,\n onClose,\n onDismiss,\n reactionCtx,\n chatCtx,\n localizationCtx,\n onPressUserProfile,\n}: ReactionBottomSheetProps) => {\n const { width } = useWindowDimensions();\n const { bottom, left, right } = useSafeAreaInsets();\n const { colors } = useUIKitTheme();\n\n const [tabIndex, setTabIndex] = useState(0);\n const scrollRef = useRef<ScrollView>();\n const tabIndicatorValue = useRef<Array<{ x: number; width: number }>>([]);\n const tabIndicatorAnimated = useRef({ x: new Animated.Value(0), width: new Animated.Value(0) }).current;\n const focusedWithLayoutCalculated = useRef(false);\n\n const { emojiManager } = chatCtx;\n const { channel, message, focusIndex } = reactionCtx;\n const { STRINGS } = localizationCtx;\n\n const color = colors.ui.reaction.default;\n const reactions = message?.reactions ?? [];\n const focusedReaction = reactions[tabIndex] as SendbirdReaction | undefined;\n const containerSafeArea = {\n paddingLeft: left + styles.layout.paddingHorizontal,\n paddingRight: right + styles.layout.paddingHorizontal,\n };\n\n const focusTab = (index: number, animated = true) => {\n const indicatorValue = tabIndicatorValue.current[index];\n if (indicatorValue) {\n setTabIndex(index);\n animateTabIndicator(indicatorValue.x, indicatorValue.width, animated);\n scrollRef.current?.scrollTo({ x: indicatorValue.x, animated });\n }\n };\n\n const animateTabIndicator = (x: number, width: number, animated = true) => {\n const baseConfig = { duration: animated ? 300 : 0, easing: Easing.inOut(Easing.ease), useNativeDriver: false };\n Animated.parallel([\n Animated.timing(tabIndicatorAnimated.x, { toValue: x, ...baseConfig }),\n Animated.timing(tabIndicatorAnimated.width, { toValue: width, ...baseConfig }),\n ]).start();\n };\n\n const layoutCalculated = () => {\n return tabIndicatorValue.current.length === reactions.length && tabIndicatorValue.current.every(Boolean);\n };\n\n useEffect(() => {\n if (!visible) {\n tabIndicatorValue.current = [];\n tabIndicatorAnimated.x = new Animated.Value(0);\n tabIndicatorAnimated.width = new Animated.Value(0);\n focusedWithLayoutCalculated.current = false;\n }\n }, [visible]);\n\n const renderTabs = () => {\n return (\n <Pressable style={styles.tabsWrapper}>\n {reactions.map((reaction, index) => {\n const isFocused = focusedReaction?.key === reaction.key;\n const isLastItem = reactions.length - 1 === index;\n const emoji = emojiManager.allEmojiMap[reaction.key];\n\n return (\n <Pressable\n key={reaction.key}\n style={[styles.tabItem, isLastItem && { marginRight: styles.layout.marginRight }]}\n onPress={() => focusTab(index)}\n onLayout={(e) => {\n tabIndicatorValue.current[index] = e.nativeEvent.layout;\n if (layoutCalculated()) {\n if (focusedWithLayoutCalculated.current) {\n focusTab(tabIndex, false);\n } else {\n focusedWithLayoutCalculated.current = true;\n focusTab(focusIndex);\n }\n }\n }}\n >\n <Image source={{ uri: emoji.url }} style={styles.tabEmoji} />\n <Text button color={isFocused ? color.selected.highlight : color.enabled.highlight}>\n {truncatedCount(getReactionCount(reaction))}\n </Text>\n </Pressable>\n );\n })}\n <Animated.View\n style={[\n styles.tabIndicator,\n {\n left: tabIndicatorAnimated.x,\n width: tabIndicatorAnimated.width,\n backgroundColor: color.selected.highlight,\n },\n ]}\n />\n </Pressable>\n );\n };\n\n const renderPage = () => {\n return (\n <>\n {focusedReaction?.userIds.map((userId) => {\n if (channel?.isGroupChannel()) {\n const user = channel.members.find((x) => x.userId === userId);\n return (\n <Pressable\n key={userId}\n onPress={async () => {\n if (user) {\n await onClose();\n onPressUserProfile(user);\n }\n }}\n style={styles.pageItem}\n >\n <Avatar size={36} uri={user?.profileUrl} containerStyle={styles.avatar} />\n <Text subtitle2 style={{ flex: 1 }}>\n {user?.nickname || STRINGS.LABELS.USER_NO_NAME}\n </Text>\n </Pressable>\n );\n }\n return null;\n })}\n </>\n );\n };\n\n return (\n <Modal\n type={'slide-no-gesture'}\n visible={Boolean(visible && channel && message)}\n onClose={onClose}\n onDismiss={onDismiss}\n backgroundStyle={styles.modal}\n >\n <View\n style={[\n styles.container,\n { width, paddingBottom: bottom, backgroundColor: colors.ui.dialog.default.none.background },\n ]}\n >\n <ScrollView\n ref={scrollRef as never}\n horizontal\n bounces={false}\n showsHorizontalScrollIndicator={false}\n contentContainerStyle={[containerSafeArea, styles.tabsContainer]}\n >\n {renderTabs()}\n </ScrollView>\n <Divider style={{ top: -1 }} />\n <ScrollView\n bounces={false}\n showsVerticalScrollIndicator={false}\n style={styles.pageContainer}\n contentContainerStyle={containerSafeArea}\n >\n {renderPage()}\n </ScrollView>\n </View>\n </Modal>\n );\n};\n\nconst styles = createStyleSheet({\n layout: {\n paddingHorizontal: 16,\n marginRight: 0,\n },\n container: {\n overflow: 'hidden',\n borderTopLeftRadius: 8,\n borderTopRightRadius: 8,\n paddingTop: 16,\n alignItems: 'center',\n },\n modal: {\n alignItems: 'center',\n justifyContent: 'flex-end',\n },\n tabsContainer: {\n flexGrow: 1,\n },\n tabsWrapper: {\n flexGrow: 1,\n flexDirection: 'row',\n alignItems: 'flex-start',\n justifyContent: 'center',\n height: 44,\n },\n tabItem: {\n marginRight: 16,\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n tabEmoji: {\n width: 28,\n height: 28,\n marginRight: 4,\n },\n tabIndicator: {\n position: 'absolute',\n bottom: 0,\n height: 3,\n },\n pageContainer: {\n height: 216,\n width: '100%',\n },\n pageItem: {\n flexDirection: 'row',\n width: '100%',\n height: 48,\n alignItems: 'center',\n },\n avatar: {\n marginRight: 16,\n },\n});\n\nexport default ReactionUserListBottomSheet;\n"],"mappings":"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"}
1
+ {"version":3,"names":["React","useEffect","useRef","useState","Animated","Easing","I18nManager","Pressable","ScrollView","View","useWindowDimensions","Avatar","Divider","Image","Modal","Text","createStyleSheet","useUIKitTheme","getReactionCount","truncatedCount","useSafeAreaPadding","ReactionUserListBottomSheet","visible","onClose","onDismiss","reactionCtx","chatCtx","localizationCtx","onPressUserProfile","width","safeArea","colors","tabIndex","setTabIndex","scrollRef","tabIndicatorValue","tabIndicatorAnimated","x","Value","current","focusedWithLayoutCalculated","emojiManager","channel","message","focusIndex","STRINGS","color","ui","reaction","default","reactions","focusedReaction","containerSafeArea","paddingStart","styles","layout","paddingHorizontal","paddingEnd","focusTab","index","animated","indicatorValue","_scrollRef$current","animateTabIndicator","scrollTo","baseConfig","duration","easing","inOut","ease","useNativeDriver","parallel","timing","toValue","start","layoutCalculated","filter","Boolean","length","renderTabs","createElement","style","tabsWrapper","map","isFocused","key","isLastItem","emoji","allEmojiMap","tabItem","marginEnd","onPress","onLayout","e","indexForLayout","isRTL","nativeEvent","source","getEmojiIconSource","tabEmoji","button","selected","highlight","enabled","tabIndicator","backgroundColor","renderPage","userCountDifference","count","sampledUserInfoList","Fragment","reactedUserInfo","isGroupChannel","userId","pageItem","size","uri","profileUrl","containerStyle","avatar","subtitle2","flex","nickname","LABELS","USER_NO_NAME","body3","onBackground02","REACTION","MORE_USERS","type","backgroundStyle","modal","container","paddingBottom","dialog","none","background","ref","horizontal","bounces","showsHorizontalScrollIndicator","contentContainerStyle","tabsContainer","top","showsVerticalScrollIndicator","pageContainer","overflow","borderTopStartRadius","borderTopEndRadius","paddingTop","alignItems","justifyContent","flexGrow","flexDirection","height","position","bottom"],"sources":["ReactionUserListBottomSheet.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport { Animated, Easing, I18nManager, Pressable, ScrollView, View, useWindowDimensions } from 'react-native';\n\nimport {\n Avatar,\n Divider,\n Image,\n Modal,\n Text,\n createStyleSheet,\n useUIKitTheme,\n} from '@sendbird/uikit-react-native-foundation';\nimport {\n SendbirdEmoji,\n SendbirdReaction,\n getReactionCount,\n truncatedCount,\n useSafeAreaPadding,\n} from '@sendbird/uikit-utils';\n\nimport type { ReactionBottomSheetProps } from './index';\n\nconst ReactionUserListBottomSheet = ({\n visible,\n onClose,\n onDismiss,\n reactionCtx,\n chatCtx,\n localizationCtx,\n onPressUserProfile,\n}: ReactionBottomSheetProps) => {\n const { width } = useWindowDimensions();\n const safeArea = useSafeAreaPadding(['left', 'right', 'bottom']);\n const { colors } = useUIKitTheme();\n\n const [tabIndex, setTabIndex] = useState(0);\n const scrollRef = useRef<ScrollView>();\n const tabIndicatorValue = useRef<Array<{ x: number; width: number }>>([]);\n const tabIndicatorAnimated = useRef({ x: new Animated.Value(0), width: new Animated.Value(0) }).current;\n const focusedWithLayoutCalculated = useRef(false);\n\n const { emojiManager } = chatCtx;\n const { channel, message, focusIndex } = reactionCtx;\n const { STRINGS } = localizationCtx;\n\n const color = colors.ui.reaction.default;\n const reactions = message?.reactions ?? [];\n const focusedReaction = reactions[tabIndex] as SendbirdReaction | undefined;\n const containerSafeArea = {\n paddingStart: safeArea.paddingStart + styles.layout.paddingHorizontal,\n paddingEnd: safeArea.paddingEnd + styles.layout.paddingHorizontal,\n };\n\n const focusTab = (index: number, animated = true) => {\n const indicatorValue = tabIndicatorValue.current[index];\n if (indicatorValue) {\n setTabIndex(index);\n animateTabIndicator(indicatorValue.x, indicatorValue.width, animated);\n scrollRef.current?.scrollTo({ x: indicatorValue.x, animated });\n }\n };\n\n const animateTabIndicator = (x: number, width: number, animated = true) => {\n const baseConfig = { duration: animated ? 300 : 0, easing: Easing.inOut(Easing.ease), useNativeDriver: false };\n Animated.parallel([\n Animated.timing(tabIndicatorAnimated.x, { toValue: x, ...baseConfig }),\n Animated.timing(tabIndicatorAnimated.width, { toValue: width, ...baseConfig }),\n ]).start();\n };\n\n const layoutCalculated = () => {\n return tabIndicatorValue.current.filter(Boolean).length === reactions.length;\n };\n\n useEffect(() => {\n if (!visible) {\n tabIndicatorValue.current = [];\n tabIndicatorAnimated.x = new Animated.Value(0);\n tabIndicatorAnimated.width = new Animated.Value(0);\n focusedWithLayoutCalculated.current = false;\n }\n }, [visible]);\n\n const renderTabs = () => {\n return (\n <Pressable style={styles.tabsWrapper}>\n {reactions.map((reaction, index) => {\n const isFocused = focusedReaction?.key === reaction.key;\n const isLastItem = reactions.length - 1 === index;\n const emoji = emojiManager.allEmojiMap[reaction.key] as SendbirdEmoji | undefined;\n\n return (\n <Pressable\n key={reaction.key}\n style={[styles.tabItem, isLastItem && { marginEnd: styles.layout.marginEnd }]}\n onPress={() => focusTab(index)}\n onLayout={(e) => {\n const indexForLayout = I18nManager.isRTL ? reactions.length - 1 - index : index;\n tabIndicatorValue.current[indexForLayout] = e.nativeEvent.layout;\n if (layoutCalculated()) {\n if (focusedWithLayoutCalculated.current) {\n // re-calculating layout when screen rotation\n focusTab(tabIndex, false);\n } else {\n focusedWithLayoutCalculated.current = true;\n focusTab(focusIndex);\n }\n }\n }}\n >\n <Image source={emojiManager.getEmojiIconSource(emoji)} style={styles.tabEmoji} />\n <Text button color={isFocused ? color.selected.highlight : color.enabled.highlight}>\n {truncatedCount(getReactionCount(reaction))}\n </Text>\n </Pressable>\n );\n })}\n <Animated.View\n style={[\n styles.tabIndicator,\n {\n start: tabIndicatorAnimated.x,\n width: tabIndicatorAnimated.width,\n backgroundColor: color.selected.highlight,\n },\n ]}\n />\n </Pressable>\n );\n };\n\n const renderPage = () => {\n const userCountDifference = (focusedReaction?.count || 0) - (focusedReaction?.sampledUserInfoList.length || 0);\n\n return (\n <>\n {focusedReaction?.sampledUserInfoList.map((reactedUserInfo) => {\n if (channel?.isGroupChannel()) {\n return (\n <Pressable\n key={reactedUserInfo.userId}\n onPress={async () => {\n await onClose();\n onPressUserProfile(reactedUserInfo);\n }}\n style={styles.pageItem}\n >\n <Avatar size={36} uri={reactedUserInfo?.profileUrl} containerStyle={styles.avatar} />\n <Text subtitle2 style={{ flex: 1 }}>\n {reactedUserInfo?.nickname || STRINGS.LABELS.USER_NO_NAME}\n </Text>\n </Pressable>\n );\n }\n return null;\n })}\n {userCountDifference > 0 && (\n <View style={styles.pageItem}>\n <Text body3 color={colors.onBackground02}>\n {STRINGS.REACTION.MORE_USERS(userCountDifference)}\n </Text>\n </View>\n )}\n </>\n );\n };\n\n return (\n <Modal\n type={'slide-no-gesture'}\n visible={Boolean(visible && channel && message)}\n onClose={onClose}\n onDismiss={onDismiss}\n backgroundStyle={styles.modal}\n >\n <View\n style={[\n styles.container,\n { width, paddingBottom: safeArea.paddingBottom, backgroundColor: colors.ui.dialog.default.none.background },\n ]}\n >\n <ScrollView\n ref={scrollRef as never}\n horizontal\n bounces={false}\n showsHorizontalScrollIndicator={false}\n contentContainerStyle={[containerSafeArea, styles.tabsContainer]}\n >\n {renderTabs()}\n </ScrollView>\n <Divider style={{ top: -1 }} />\n <ScrollView\n bounces={false}\n showsVerticalScrollIndicator={false}\n style={styles.pageContainer}\n contentContainerStyle={containerSafeArea}\n >\n {renderPage()}\n </ScrollView>\n </View>\n </Modal>\n );\n};\n\nconst styles = createStyleSheet({\n layout: {\n paddingHorizontal: 16,\n marginEnd: 0,\n },\n container: {\n overflow: 'hidden',\n borderTopStartRadius: 8,\n borderTopEndRadius: 8,\n paddingTop: 16,\n alignItems: 'center',\n },\n modal: {\n alignItems: 'center',\n justifyContent: 'flex-end',\n },\n tabsContainer: {\n flexGrow: 1,\n },\n tabsWrapper: {\n flexGrow: 1,\n flexDirection: 'row',\n alignItems: 'flex-start',\n justifyContent: 'center',\n height: 44,\n },\n tabItem: {\n marginEnd: 16,\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n tabEmoji: {\n width: 28,\n height: 28,\n marginEnd: 4,\n },\n tabIndicator: {\n position: 'absolute',\n bottom: 0,\n height: 3,\n },\n pageContainer: {\n height: 216,\n width: '100%',\n },\n pageItem: {\n flexDirection: 'row',\n width: '100%',\n height: 48,\n alignItems: 'center',\n },\n avatar: {\n marginEnd: 16,\n },\n});\n\nexport default ReactionUserListBottomSheet;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAC1D,SAASC,QAAQ,EAAEC,MAAM,EAAEC,WAAW,EAAEC,SAAS,EAAEC,UAAU,EAAEC,IAAI,EAAEC,mBAAmB,QAAQ,cAAc;AAE9G,SACEC,MAAM,EACNC,OAAO,EACPC,KAAK,EACLC,KAAK,EACLC,IAAI,EACJC,gBAAgB,EAChBC,aAAa,QACR,yCAAyC;AAChD,SAGEC,gBAAgB,EAChBC,cAAc,EACdC,kBAAkB,QACb,uBAAuB;AAI9B,MAAMC,2BAA2B,GAAGA,CAAC;EACnCC,OAAO;EACPC,OAAO;EACPC,SAAS;EACTC,WAAW;EACXC,OAAO;EACPC,eAAe;EACfC;AACwB,CAAC,KAAK;EAC9B,MAAM;IAAEC;EAAM,CAAC,GAAGnB,mBAAmB,CAAC,CAAC;EACvC,MAAMoB,QAAQ,GAAGV,kBAAkB,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;EAChE,MAAM;IAAEW;EAAO,CAAC,GAAGd,aAAa,CAAC,CAAC;EAElC,MAAM,CAACe,QAAQ,EAAEC,WAAW,CAAC,GAAG9B,QAAQ,CAAC,CAAC,CAAC;EAC3C,MAAM+B,SAAS,GAAGhC,MAAM,CAAa,CAAC;EACtC,MAAMiC,iBAAiB,GAAGjC,MAAM,CAAsC,EAAE,CAAC;EACzE,MAAMkC,oBAAoB,GAAGlC,MAAM,CAAC;IAAEmC,CAAC,EAAE,IAAIjC,QAAQ,CAACkC,KAAK,CAAC,CAAC,CAAC;IAAET,KAAK,EAAE,IAAIzB,QAAQ,CAACkC,KAAK,CAAC,CAAC;EAAE,CAAC,CAAC,CAACC,OAAO;EACvG,MAAMC,2BAA2B,GAAGtC,MAAM,CAAC,KAAK,CAAC;EAEjD,MAAM;IAAEuC;EAAa,CAAC,GAAGf,OAAO;EAChC,MAAM;IAAEgB,OAAO;IAAEC,OAAO;IAAEC;EAAW,CAAC,GAAGnB,WAAW;EACpD,MAAM;IAAEoB;EAAQ,CAAC,GAAGlB,eAAe;EAEnC,MAAMmB,KAAK,GAAGf,MAAM,CAACgB,EAAE,CAACC,QAAQ,CAACC,OAAO;EACxC,MAAMC,SAAS,GAAG,CAAAP,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEO,SAAS,KAAI,EAAE;EAC1C,MAAMC,eAAe,GAAGD,SAAS,CAAClB,QAAQ,CAAiC;EAC3E,MAAMoB,iBAAiB,GAAG;IACxBC,YAAY,EAAEvB,QAAQ,CAACuB,YAAY,GAAGC,MAAM,CAACC,MAAM,CAACC,iBAAiB;IACrEC,UAAU,EAAE3B,QAAQ,CAAC2B,UAAU,GAAGH,MAAM,CAACC,MAAM,CAACC;EAClD,CAAC;EAED,MAAME,QAAQ,GAAGA,CAACC,KAAa,EAAEC,QAAQ,GAAG,IAAI,KAAK;IACnD,MAAMC,cAAc,GAAG1B,iBAAiB,CAACI,OAAO,CAACoB,KAAK,CAAC;IACvD,IAAIE,cAAc,EAAE;MAAA,IAAAC,kBAAA;MAClB7B,WAAW,CAAC0B,KAAK,CAAC;MAClBI,mBAAmB,CAACF,cAAc,CAACxB,CAAC,EAAEwB,cAAc,CAAChC,KAAK,EAAE+B,QAAQ,CAAC;MACrE,CAAAE,kBAAA,GAAA5B,SAAS,CAACK,OAAO,cAAAuB,kBAAA,eAAjBA,kBAAA,CAAmBE,QAAQ,CAAC;QAAE3B,CAAC,EAAEwB,cAAc,CAACxB,CAAC;QAAEuB;MAAS,CAAC,CAAC;IAChE;EACF,CAAC;EAED,MAAMG,mBAAmB,GAAGA,CAAC1B,CAAS,EAAER,KAAa,EAAE+B,QAAQ,GAAG,IAAI,KAAK;IACzE,MAAMK,UAAU,GAAG;MAAEC,QAAQ,EAAEN,QAAQ,GAAG,GAAG,GAAG,CAAC;MAAEO,MAAM,EAAE9D,MAAM,CAAC+D,KAAK,CAAC/D,MAAM,CAACgE,IAAI,CAAC;MAAEC,eAAe,EAAE;IAAM,CAAC;IAC9GlE,QAAQ,CAACmE,QAAQ,CAAC,CAChBnE,QAAQ,CAACoE,MAAM,CAACpC,oBAAoB,CAACC,CAAC,EAAE;MAAEoC,OAAO,EAAEpC,CAAC;MAAE,GAAG4B;IAAW,CAAC,CAAC,EACtE7D,QAAQ,CAACoE,MAAM,CAACpC,oBAAoB,CAACP,KAAK,EAAE;MAAE4C,OAAO,EAAE5C,KAAK;MAAE,GAAGoC;IAAW,CAAC,CAAC,CAC/E,CAAC,CAACS,KAAK,CAAC,CAAC;EACZ,CAAC;EAED,MAAMC,gBAAgB,GAAGA,CAAA,KAAM;IAC7B,OAAOxC,iBAAiB,CAACI,OAAO,CAACqC,MAAM,CAACC,OAAO,CAAC,CAACC,MAAM,KAAK5B,SAAS,CAAC4B,MAAM;EAC9E,CAAC;EAED7E,SAAS,CAAC,MAAM;IACd,IAAI,CAACqB,OAAO,EAAE;MACZa,iBAAiB,CAACI,OAAO,GAAG,EAAE;MAC9BH,oBAAoB,CAACC,CAAC,GAAG,IAAIjC,QAAQ,CAACkC,KAAK,CAAC,CAAC,CAAC;MAC9CF,oBAAoB,CAACP,KAAK,GAAG,IAAIzB,QAAQ,CAACkC,KAAK,CAAC,CAAC,CAAC;MAClDE,2BAA2B,CAACD,OAAO,GAAG,KAAK;IAC7C;EACF,CAAC,EAAE,CAACjB,OAAO,CAAC,CAAC;EAEb,MAAMyD,UAAU,GAAGA,CAAA,KAAM;IACvB,oBACE/E,KAAA,CAAAgF,aAAA,CAACzE,SAAS;MAAC0E,KAAK,EAAE3B,MAAM,CAAC4B;IAAY,GAClChC,SAAS,CAACiC,GAAG,CAAC,CAACnC,QAAQ,EAAEW,KAAK,KAAK;MAClC,MAAMyB,SAAS,GAAG,CAAAjC,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEkC,GAAG,MAAKrC,QAAQ,CAACqC,GAAG;MACvD,MAAMC,UAAU,GAAGpC,SAAS,CAAC4B,MAAM,GAAG,CAAC,KAAKnB,KAAK;MACjD,MAAM4B,KAAK,GAAG9C,YAAY,CAAC+C,WAAW,CAACxC,QAAQ,CAACqC,GAAG,CAA8B;MAEjF,oBACErF,KAAA,CAAAgF,aAAA,CAACzE,SAAS;QACR8E,GAAG,EAAErC,QAAQ,CAACqC,GAAI;QAClBJ,KAAK,EAAE,CAAC3B,MAAM,CAACmC,OAAO,EAAEH,UAAU,IAAI;UAAEI,SAAS,EAAEpC,MAAM,CAACC,MAAM,CAACmC;QAAU,CAAC,CAAE;QAC9EC,OAAO,EAAEA,CAAA,KAAMjC,QAAQ,CAACC,KAAK,CAAE;QAC/BiC,QAAQ,EAAGC,CAAC,IAAK;UACf,MAAMC,cAAc,GAAGxF,WAAW,CAACyF,KAAK,GAAG7C,SAAS,CAAC4B,MAAM,GAAG,CAAC,GAAGnB,KAAK,GAAGA,KAAK;UAC/ExB,iBAAiB,CAACI,OAAO,CAACuD,cAAc,CAAC,GAAGD,CAAC,CAACG,WAAW,CAACzC,MAAM;UAChE,IAAIoB,gBAAgB,CAAC,CAAC,EAAE;YACtB,IAAInC,2BAA2B,CAACD,OAAO,EAAE;cACvC;cACAmB,QAAQ,CAAC1B,QAAQ,EAAE,KAAK,CAAC;YAC3B,CAAC,MAAM;cACLQ,2BAA2B,CAACD,OAAO,GAAG,IAAI;cAC1CmB,QAAQ,CAACd,UAAU,CAAC;YACtB;UACF;QACF;MAAE,gBAEF5C,KAAA,CAAAgF,aAAA,CAACnE,KAAK;QAACoF,MAAM,EAAExD,YAAY,CAACyD,kBAAkB,CAACX,KAAK,CAAE;QAACN,KAAK,EAAE3B,MAAM,CAAC6C;MAAS,CAAE,CAAC,eACjFnG,KAAA,CAAAgF,aAAA,CAACjE,IAAI;QAACqF,MAAM;QAACtD,KAAK,EAAEsC,SAAS,GAAGtC,KAAK,CAACuD,QAAQ,CAACC,SAAS,GAAGxD,KAAK,CAACyD,OAAO,CAACD;MAAU,GAChFnF,cAAc,CAACD,gBAAgB,CAAC8B,QAAQ,CAAC,CACtC,CACG,CAAC;IAEhB,CAAC,CAAC,eACFhD,KAAA,CAAAgF,aAAA,CAAC5E,QAAQ,CAACK,IAAI;MACZwE,KAAK,EAAE,CACL3B,MAAM,CAACkD,YAAY,EACnB;QACE9B,KAAK,EAAEtC,oBAAoB,CAACC,CAAC;QAC7BR,KAAK,EAAEO,oBAAoB,CAACP,KAAK;QACjC4E,eAAe,EAAE3D,KAAK,CAACuD,QAAQ,CAACC;MAClC,CAAC;IACD,CACH,CACQ,CAAC;EAEhB,CAAC;EAED,MAAMI,UAAU,GAAGA,CAAA,KAAM;IACvB,MAAMC,mBAAmB,GAAG,CAAC,CAAAxD,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEyD,KAAK,KAAI,CAAC,KAAK,CAAAzD,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAE0D,mBAAmB,CAAC/B,MAAM,KAAI,CAAC,CAAC;IAE9G,oBACE9E,KAAA,CAAAgF,aAAA,CAAAhF,KAAA,CAAA8G,QAAA,QACG3D,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAE0D,mBAAmB,CAAC1B,GAAG,CAAE4B,eAAe,IAAK;MAC7D,IAAIrE,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEsE,cAAc,CAAC,CAAC,EAAE;QAC7B,oBACEhH,KAAA,CAAAgF,aAAA,CAACzE,SAAS;UACR8E,GAAG,EAAE0B,eAAe,CAACE,MAAO;UAC5BtB,OAAO,EAAE,MAAAA,CAAA,KAAY;YACnB,MAAMpE,OAAO,CAAC,CAAC;YACfK,kBAAkB,CAACmF,eAAe,CAAC;UACrC,CAAE;UACF9B,KAAK,EAAE3B,MAAM,CAAC4D;QAAS,gBAEvBlH,KAAA,CAAAgF,aAAA,CAACrE,MAAM;UAACwG,IAAI,EAAE,EAAG;UAACC,GAAG,EAAEL,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEM,UAAW;UAACC,cAAc,EAAEhE,MAAM,CAACiE;QAAO,CAAE,CAAC,eACrFvH,KAAA,CAAAgF,aAAA,CAACjE,IAAI;UAACyG,SAAS;UAACvC,KAAK,EAAE;YAAEwC,IAAI,EAAE;UAAE;QAAE,GAChC,CAAAV,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEW,QAAQ,KAAI7E,OAAO,CAAC8E,MAAM,CAACC,YACzC,CACG,CAAC;MAEhB;MACA,OAAO,IAAI;IACb,CAAC,CAAC,EACDjB,mBAAmB,GAAG,CAAC,iBACtB3G,KAAA,CAAAgF,aAAA,CAACvE,IAAI;MAACwE,KAAK,EAAE3B,MAAM,CAAC4D;IAAS,gBAC3BlH,KAAA,CAAAgF,aAAA,CAACjE,IAAI;MAAC8G,KAAK;MAAC/E,KAAK,EAAEf,MAAM,CAAC+F;IAAe,GACtCjF,OAAO,CAACkF,QAAQ,CAACC,UAAU,CAACrB,mBAAmB,CAC5C,CACF,CAER,CAAC;EAEP,CAAC;EAED,oBACE3G,KAAA,CAAAgF,aAAA,CAAClE,KAAK;IACJmH,IAAI,EAAE,kBAAmB;IACzB3G,OAAO,EAAEuD,OAAO,CAACvD,OAAO,IAAIoB,OAAO,IAAIC,OAAO,CAAE;IAChDpB,OAAO,EAAEA,OAAQ;IACjBC,SAAS,EAAEA,SAAU;IACrB0G,eAAe,EAAE5E,MAAM,CAAC6E;EAAM,gBAE9BnI,KAAA,CAAAgF,aAAA,CAACvE,IAAI;IACHwE,KAAK,EAAE,CACL3B,MAAM,CAAC8E,SAAS,EAChB;MAAEvG,KAAK;MAAEwG,aAAa,EAAEvG,QAAQ,CAACuG,aAAa;MAAE5B,eAAe,EAAE1E,MAAM,CAACgB,EAAE,CAACuF,MAAM,CAACrF,OAAO,CAACsF,IAAI,CAACC;IAAW,CAAC;EAC3G,gBAEFxI,KAAA,CAAAgF,aAAA,CAACxE,UAAU;IACTiI,GAAG,EAAEvG,SAAmB;IACxBwG,UAAU;IACVC,OAAO,EAAE,KAAM;IACfC,8BAA8B,EAAE,KAAM;IACtCC,qBAAqB,EAAE,CAACzF,iBAAiB,EAAEE,MAAM,CAACwF,aAAa;EAAE,GAEhE/D,UAAU,CAAC,CACF,CAAC,eACb/E,KAAA,CAAAgF,aAAA,CAACpE,OAAO;IAACqE,KAAK,EAAE;MAAE8D,GAAG,EAAE,CAAC;IAAE;EAAE,CAAE,CAAC,eAC/B/I,KAAA,CAAAgF,aAAA,CAACxE,UAAU;IACTmI,OAAO,EAAE,KAAM;IACfK,4BAA4B,EAAE,KAAM;IACpC/D,KAAK,EAAE3B,MAAM,CAAC2F,aAAc;IAC5BJ,qBAAqB,EAAEzF;EAAkB,GAExCsD,UAAU,CAAC,CACF,CACR,CACD,CAAC;AAEZ,CAAC;AAED,MAAMpD,MAAM,GAAGtC,gBAAgB,CAAC;EAC9BuC,MAAM,EAAE;IACNC,iBAAiB,EAAE,EAAE;IACrBkC,SAAS,EAAE;EACb,CAAC;EACD0C,SAAS,EAAE;IACTc,QAAQ,EAAE,QAAQ;IAClBC,oBAAoB,EAAE,CAAC;IACvBC,kBAAkB,EAAE,CAAC;IACrBC,UAAU,EAAE,EAAE;IACdC,UAAU,EAAE;EACd,CAAC;EACDnB,KAAK,EAAE;IACLmB,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB,CAAC;EACDT,aAAa,EAAE;IACbU,QAAQ,EAAE;EACZ,CAAC;EACDtE,WAAW,EAAE;IACXsE,QAAQ,EAAE,CAAC;IACXC,aAAa,EAAE,KAAK;IACpBH,UAAU,EAAE,YAAY;IACxBC,cAAc,EAAE,QAAQ;IACxBG,MAAM,EAAE;EACV,CAAC;EACDjE,OAAO,EAAE;IACPC,SAAS,EAAE,EAAE;IACb+D,aAAa,EAAE,KAAK;IACpBH,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB,CAAC;EACDpD,QAAQ,EAAE;IACRtE,KAAK,EAAE,EAAE;IACT6H,MAAM,EAAE,EAAE;IACVhE,SAAS,EAAE;EACb,CAAC;EACDc,YAAY,EAAE;IACZmD,QAAQ,EAAE,UAAU;IACpBC,MAAM,EAAE,CAAC;IACTF,MAAM,EAAE;EACV,CAAC;EACDT,aAAa,EAAE;IACbS,MAAM,EAAE,GAAG;IACX7H,KAAK,EAAE;EACT,CAAC;EACDqF,QAAQ,EAAE;IACRuC,aAAa,EAAE,KAAK;IACpB5H,KAAK,EAAE,MAAM;IACb6H,MAAM,EAAE,EAAE;IACVJ,UAAU,EAAE;EACd,CAAC;EACD/B,MAAM,EAAE;IACN7B,SAAS,EAAE;EACb;AACF,CAAC,CAAC;AAEF,eAAerE,2BAA2B","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"names":["ReactionList","UserList","ReactionBottomSheets"],"sources":["index.tsx"],"sourcesContent":["import type React from 'react';\n\nimport type { SendbirdMember, SendbirdUser } from '@sendbird/uikit-utils';\n\nimport type { LocalizationContext } from '../../contexts/LocalizationCtx';\nimport type { ReactionContext } from '../../contexts/ReactionCtx';\nimport type { SendbirdChatContext } from '../../contexts/SendbirdChatCtx';\nimport ReactionList from './ReactionListBottomSheet';\nimport UserList from './ReactionUserListBottomSheet';\n\ntype GetFromContext<T> = T extends React.Context<infer Value> ? NonNullable<Value> : never;\nexport type ReactionBottomSheetProps = {\n visible: boolean;\n onDismiss: () => void;\n onClose: () => Promise<void>;\n onPressUserProfile: (user: SendbirdUser | SendbirdMember) => void;\n chatCtx: GetFromContext<typeof SendbirdChatContext>;\n reactionCtx: GetFromContext<typeof ReactionContext>;\n localizationCtx: GetFromContext<typeof LocalizationContext>;\n};\n\nexport const ReactionBottomSheets = {\n ReactionList,\n UserList,\n};\n"],"mappings":"AAOA,OAAOA,YAAY,MAAM,2BAA2B;AACpD,OAAOC,QAAQ,MAAM,+BAA+B;AAapD,OAAO,MAAMC,oBAAoB,GAAG;EAClCF,YAAY;EACZC;AACF,CAAC"}
1
+ {"version":3,"names":["ReactionList","UserList","ReactionBottomSheets"],"sources":["index.tsx"],"sourcesContent":["import type React from 'react';\n\nimport { SendbirdReactedUserInfo } from '@sendbird/uikit-utils';\n\nimport type { LocalizationContext } from '../../contexts/LocalizationCtx';\nimport type { ReactionContext } from '../../contexts/ReactionCtx';\nimport type { SendbirdChatContext } from '../../contexts/SendbirdChatCtx';\nimport ReactionList from './ReactionListBottomSheet';\nimport UserList from './ReactionUserListBottomSheet';\n\ntype GetFromContext<T> = T extends React.Context<infer Value> ? NonNullable<Value> : never;\nexport type ReactionBottomSheetProps = {\n visible: boolean;\n onDismiss: () => void;\n onClose: () => Promise<void>;\n onPressUserProfile: (user: SendbirdReactedUserInfo) => void;\n chatCtx: GetFromContext<typeof SendbirdChatContext>;\n reactionCtx: GetFromContext<typeof ReactionContext>;\n localizationCtx: GetFromContext<typeof LocalizationContext>;\n};\n\nexport const ReactionBottomSheets = {\n ReactionList,\n UserList,\n};\n"],"mappings":"AAOA,OAAOA,YAAY,MAAM,2BAA2B;AACpD,OAAOC,QAAQ,MAAM,+BAA+B;AAapD,OAAO,MAAMC,oBAAoB,GAAG;EAClCF,YAAY;EACZC;AACF,CAAC","ignoreList":[]}