@sendbird/uikit-react-native 2.2.0 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (774) hide show
  1. package/README.md +55 -33
  2. package/lib/commonjs/components/ChannelCover.js +54 -40
  3. package/lib/commonjs/components/ChannelCover.js.map +1 -1
  4. package/lib/commonjs/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/EditInput.js +28 -13
  5. package/lib/commonjs/components/ChannelInput/EditInput.js.map +1 -0
  6. package/lib/commonjs/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/SendInput.js +126 -37
  7. package/lib/commonjs/components/ChannelInput/SendInput.js.map +1 -0
  8. package/lib/commonjs/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/index.js +34 -34
  9. package/lib/commonjs/components/ChannelInput/index.js.map +1 -0
  10. package/lib/commonjs/components/FileViewer.js +5 -8
  11. package/lib/commonjs/components/FileViewer.js.map +1 -1
  12. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +1 -1
  13. package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  14. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +1 -1
  15. package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  16. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +3 -3
  17. package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  18. package/lib/commonjs/components/MessageRenderer/FileMessage/index.js +1 -6
  19. package/lib/commonjs/components/MessageRenderer/FileMessage/index.js.map +1 -1
  20. package/lib/commonjs/components/MessageRenderer/MessageDateSeparator.js.map +1 -1
  21. package/lib/commonjs/components/MessageRenderer/MessageIncomingSenderName.js +1 -1
  22. package/lib/commonjs/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -1
  23. package/lib/commonjs/components/MessageRenderer/MessageTime.js +1 -1
  24. package/lib/commonjs/components/MessageRenderer/MessageTime.js.map +1 -1
  25. package/lib/commonjs/components/MessageRenderer/UnknownMessage/index.js +1 -1
  26. package/lib/commonjs/components/MessageRenderer/UnknownMessage/index.js.map +1 -1
  27. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +3 -3
  28. package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  29. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +6 -4
  30. package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  31. package/lib/commonjs/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js +58 -0
  32. package/lib/commonjs/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js.map +1 -0
  33. package/lib/commonjs/components/OpenChannelMessageRenderer/index.js +135 -0
  34. package/lib/commonjs/components/OpenChannelMessageRenderer/index.js.map +1 -0
  35. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +2 -4
  36. package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -1
  37. package/lib/commonjs/components/TypedPlaceholder.js +6 -0
  38. package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
  39. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +2 -2
  40. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  41. package/lib/commonjs/containers/SendbirdUIKitContainer.js +29 -6
  42. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  43. package/lib/commonjs/contexts/PlatformServiceCtx.js.map +1 -1
  44. package/lib/commonjs/contexts/SendbirdChatCtx.js +10 -14
  45. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -1
  46. package/lib/commonjs/contexts/UserProfileCtx.js +20 -10
  47. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -1
  48. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput.js +54 -0
  49. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput.js.map +1 -0
  50. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +13 -11
  51. package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  52. package/lib/commonjs/domain/groupChannel/module/moduleContext.js +2 -2
  53. package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
  54. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  55. package/lib/commonjs/domain/groupChannelBannedUsers/index.js +8 -0
  56. package/lib/commonjs/domain/groupChannelBannedUsers/index.js.map +1 -1
  57. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +1 -1
  58. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  59. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +4 -2
  60. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  61. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +4 -2
  62. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  63. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -1
  64. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  65. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +4 -5
  66. package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  67. package/lib/commonjs/domain/openChannel/component/OpenChannelHeader.js +83 -0
  68. package/lib/commonjs/domain/openChannel/component/OpenChannelHeader.js.map +1 -0
  69. package/lib/commonjs/domain/openChannel/component/OpenChannelInput.js +95 -0
  70. package/lib/commonjs/domain/openChannel/component/OpenChannelInput.js.map +1 -0
  71. package/lib/commonjs/domain/openChannel/component/OpenChannelMessageList.js +351 -0
  72. package/lib/commonjs/domain/openChannel/component/OpenChannelMessageList.js.map +1 -0
  73. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusEmpty.js +34 -0
  74. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusEmpty.js.map +1 -0
  75. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusLoading.js +34 -0
  76. package/lib/commonjs/domain/openChannel/component/OpenChannelStatusLoading.js.map +1 -0
  77. package/lib/commonjs/domain/openChannel/index.js +62 -0
  78. package/lib/commonjs/domain/openChannel/index.js.map +1 -0
  79. package/lib/commonjs/domain/openChannel/module/createOpenChannelModule.js +45 -0
  80. package/lib/commonjs/domain/openChannel/module/createOpenChannelModule.js.map +1 -0
  81. package/lib/commonjs/domain/openChannel/module/moduleContext.js +53 -0
  82. package/lib/commonjs/domain/openChannel/module/moduleContext.js.map +1 -0
  83. package/lib/commonjs/domain/openChannel/types.js +6 -0
  84. package/lib/commonjs/domain/openChannel/types.js.map +1 -0
  85. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js +39 -0
  86. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js.map +1 -0
  87. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js +54 -0
  88. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js.map +1 -0
  89. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js +28 -0
  90. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js.map +1 -0
  91. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js +32 -0
  92. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js.map +1 -0
  93. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js +28 -0
  94. package/lib/commonjs/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js.map +1 -0
  95. package/lib/commonjs/domain/openChannelBannedUsers/index.js +70 -0
  96. package/lib/commonjs/domain/openChannelBannedUsers/index.js.map +1 -0
  97. package/lib/commonjs/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js +45 -0
  98. package/lib/commonjs/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js.map +1 -0
  99. package/lib/commonjs/domain/openChannelBannedUsers/module/moduleContext.js +45 -0
  100. package/lib/commonjs/domain/openChannelBannedUsers/module/moduleContext.js.map +1 -0
  101. package/lib/commonjs/domain/openChannelBannedUsers/types.js +6 -0
  102. package/lib/commonjs/domain/openChannelBannedUsers/types.js.map +1 -0
  103. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateHeader.js +53 -0
  104. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateHeader.js.map +1 -0
  105. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js +169 -0
  106. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js.map +1 -0
  107. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js +22 -0
  108. package/lib/commonjs/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js.map +1 -0
  109. package/lib/commonjs/domain/openChannelCreate/index.js +54 -0
  110. package/lib/commonjs/domain/openChannelCreate/index.js.map +1 -0
  111. package/lib/commonjs/domain/openChannelCreate/module/createOpenChannelCreateModule.js +37 -0
  112. package/lib/commonjs/domain/openChannelCreate/module/createOpenChannelCreateModule.js.map +1 -0
  113. package/lib/commonjs/domain/openChannelCreate/module/moduleContext.js +44 -0
  114. package/lib/commonjs/domain/openChannelCreate/module/moduleContext.js.map +1 -0
  115. package/lib/commonjs/domain/openChannelCreate/types.js +6 -0
  116. package/lib/commonjs/domain/openChannelCreate/types.js.map +1 -0
  117. package/lib/commonjs/domain/openChannelList/component/OpenChannelListHeader.js +39 -0
  118. package/lib/commonjs/domain/openChannelList/component/OpenChannelListHeader.js.map +1 -0
  119. package/lib/commonjs/domain/openChannelList/component/OpenChannelListList.js +58 -0
  120. package/lib/commonjs/domain/openChannelList/component/OpenChannelListList.js.map +1 -0
  121. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusEmpty.js +34 -0
  122. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusEmpty.js.map +1 -0
  123. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusError.js +32 -0
  124. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusError.js.map +1 -0
  125. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusLoading.js +34 -0
  126. package/lib/commonjs/domain/openChannelList/component/OpenChannelListStatusLoading.js.map +1 -0
  127. package/lib/commonjs/domain/openChannelList/index.js +70 -0
  128. package/lib/commonjs/domain/openChannelList/index.js.map +1 -0
  129. package/lib/commonjs/domain/openChannelList/module/createOpenChannelListModule.js +45 -0
  130. package/lib/commonjs/domain/openChannelList/module/createOpenChannelListModule.js.map +1 -0
  131. package/lib/commonjs/domain/openChannelList/module/moduleContext.js +42 -0
  132. package/lib/commonjs/domain/openChannelList/module/moduleContext.js.map +1 -0
  133. package/lib/commonjs/domain/openChannelList/types.js +6 -0
  134. package/lib/commonjs/domain/openChannelList/types.js.map +1 -0
  135. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationHeader.js +39 -0
  136. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationHeader.js.map +1 -0
  137. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationMenu.js +74 -0
  138. package/lib/commonjs/domain/openChannelModeration/component/OpenChannelModerationMenu.js.map +1 -0
  139. package/lib/commonjs/domain/openChannelModeration/index.js +46 -0
  140. package/lib/commonjs/domain/openChannelModeration/index.js.map +1 -0
  141. package/lib/commonjs/domain/openChannelModeration/module/createOpenChannelModerationModule.js +33 -0
  142. package/lib/commonjs/domain/openChannelModeration/module/createOpenChannelModerationModule.js.map +1 -0
  143. package/lib/commonjs/domain/openChannelModeration/module/moduleContext.js +45 -0
  144. package/lib/commonjs/domain/openChannelModeration/module/moduleContext.js.map +1 -0
  145. package/lib/commonjs/domain/openChannelModeration/types.js +6 -0
  146. package/lib/commonjs/domain/openChannelModeration/types.js.map +1 -0
  147. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js +39 -0
  148. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js.map +1 -0
  149. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js +54 -0
  150. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js.map +1 -0
  151. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js +28 -0
  152. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js.map +1 -0
  153. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js +32 -0
  154. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js.map +1 -0
  155. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js +28 -0
  156. package/lib/commonjs/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js.map +1 -0
  157. package/lib/commonjs/domain/openChannelMutedParticipants/index.js +62 -0
  158. package/lib/commonjs/domain/openChannelMutedParticipants/index.js.map +1 -0
  159. package/lib/commonjs/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js +45 -0
  160. package/lib/commonjs/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js.map +1 -0
  161. package/lib/commonjs/domain/openChannelMutedParticipants/module/moduleContext.js +45 -0
  162. package/lib/commonjs/domain/openChannelMutedParticipants/module/moduleContext.js.map +1 -0
  163. package/lib/commonjs/domain/openChannelMutedParticipants/types.js +6 -0
  164. package/lib/commonjs/domain/openChannelMutedParticipants/types.js.map +1 -0
  165. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js +44 -0
  166. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js.map +1 -0
  167. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsList.js +54 -0
  168. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsList.js.map +1 -0
  169. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js +28 -0
  170. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js.map +1 -0
  171. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js +32 -0
  172. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js.map +1 -0
  173. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js +28 -0
  174. package/lib/commonjs/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js.map +1 -0
  175. package/lib/commonjs/domain/openChannelOperators/index.js +62 -0
  176. package/lib/commonjs/domain/openChannelOperators/index.js.map +1 -0
  177. package/lib/commonjs/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js +45 -0
  178. package/lib/commonjs/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js.map +1 -0
  179. package/lib/commonjs/domain/openChannelOperators/module/moduleContext.js +45 -0
  180. package/lib/commonjs/domain/openChannelOperators/module/moduleContext.js.map +1 -0
  181. package/lib/commonjs/domain/openChannelOperators/types.js +6 -0
  182. package/lib/commonjs/domain/openChannelOperators/types.js.map +1 -0
  183. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsHeader.js +49 -0
  184. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsHeader.js.map +1 -0
  185. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsInfo.js +68 -0
  186. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsInfo.js.map +1 -0
  187. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsMenu.js +118 -0
  188. package/lib/commonjs/domain/openChannelSettings/component/OpenChannelSettingsMenu.js.map +1 -0
  189. package/lib/commonjs/domain/openChannelSettings/index.js +54 -0
  190. package/lib/commonjs/domain/openChannelSettings/index.js.map +1 -0
  191. package/lib/commonjs/domain/openChannelSettings/module/createOpenChannelSettingsModule.js +37 -0
  192. package/lib/commonjs/domain/openChannelSettings/module/createOpenChannelSettingsModule.js.map +1 -0
  193. package/lib/commonjs/domain/openChannelSettings/module/moduleContext.js +186 -0
  194. package/lib/commonjs/domain/openChannelSettings/module/moduleContext.js.map +1 -0
  195. package/lib/commonjs/domain/openChannelSettings/types.js +6 -0
  196. package/lib/commonjs/domain/openChannelSettings/types.js.map +1 -0
  197. package/lib/commonjs/domain/openChannelUserList/types.js +6 -0
  198. package/lib/commonjs/domain/openChannelUserList/types.js.map +1 -0
  199. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +3 -6
  200. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  201. package/lib/commonjs/fragments/createGroupChannelFragment.js +33 -3
  202. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  203. package/lib/commonjs/fragments/createGroupChannelListFragment.js +4 -14
  204. package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
  205. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +6 -8
  206. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
  207. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js +13 -4
  208. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js.map +1 -1
  209. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js +2 -4
  210. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js.map +1 -1
  211. package/lib/commonjs/fragments/createOpenChannelBannedUsersFragment.js +101 -0
  212. package/lib/commonjs/fragments/createOpenChannelBannedUsersFragment.js.map +1 -0
  213. package/lib/commonjs/fragments/createOpenChannelCreateFragment.js +86 -0
  214. package/lib/commonjs/fragments/createOpenChannelCreateFragment.js.map +1 -0
  215. package/lib/commonjs/fragments/createOpenChannelFragment.js +177 -0
  216. package/lib/commonjs/fragments/createOpenChannelFragment.js.map +1 -0
  217. package/lib/commonjs/fragments/createOpenChannelListFragment.js +93 -0
  218. package/lib/commonjs/fragments/createOpenChannelListFragment.js.map +1 -0
  219. package/lib/commonjs/fragments/createOpenChannelModerationFragment.js +68 -0
  220. package/lib/commonjs/fragments/createOpenChannelModerationFragment.js.map +1 -0
  221. package/lib/commonjs/fragments/createOpenChannelMutedParticipantsFragment.js +117 -0
  222. package/lib/commonjs/fragments/createOpenChannelMutedParticipantsFragment.js.map +1 -0
  223. package/lib/commonjs/fragments/createOpenChannelOperatorsFragment.js +124 -0
  224. package/lib/commonjs/fragments/createOpenChannelOperatorsFragment.js.map +1 -0
  225. package/lib/commonjs/fragments/createOpenChannelParticipantsFragment.js +162 -0
  226. package/lib/commonjs/fragments/createOpenChannelParticipantsFragment.js.map +1 -0
  227. package/lib/commonjs/fragments/createOpenChannelRegisterOperatorFragment.js +116 -0
  228. package/lib/commonjs/fragments/createOpenChannelRegisterOperatorFragment.js.map +1 -0
  229. package/lib/commonjs/fragments/createOpenChannelSettingsFragment.js +70 -0
  230. package/lib/commonjs/fragments/createOpenChannelSettingsFragment.js.map +1 -0
  231. package/lib/commonjs/hooks/useKeyboardStatus.js +13 -9
  232. package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -1
  233. package/lib/commonjs/hooks/useMentionSuggestion.js +3 -12
  234. package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -1
  235. package/lib/commonjs/index.js +475 -46
  236. package/lib/commonjs/index.js.map +1 -1
  237. package/lib/commonjs/libs/ImageCompressionConfig.js +38 -0
  238. package/lib/commonjs/libs/ImageCompressionConfig.js.map +1 -0
  239. package/lib/commonjs/libs/SBUUtils.js +27 -0
  240. package/lib/commonjs/libs/SBUUtils.js.map +1 -1
  241. package/lib/commonjs/localization/StringSet.en.js +2 -2
  242. package/lib/commonjs/localization/StringSet.en.js.map +1 -1
  243. package/lib/commonjs/localization/StringSet.type.js +0 -247
  244. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  245. package/lib/commonjs/localization/createBaseStringSet.js +393 -0
  246. package/lib/commonjs/localization/createBaseStringSet.js.map +1 -0
  247. package/lib/commonjs/platform/createFileService.native.js +5 -0
  248. package/lib/commonjs/platform/createFileService.native.js.map +1 -1
  249. package/lib/commonjs/platform/createMediaService.expo.js +35 -1
  250. package/lib/commonjs/platform/createMediaService.expo.js.map +1 -1
  251. package/lib/commonjs/platform/createMediaService.native.js +41 -6
  252. package/lib/commonjs/platform/createMediaService.native.js.map +1 -1
  253. package/lib/commonjs/platform/dynamicModule.js +9 -57
  254. package/lib/commonjs/platform/dynamicModule.js.map +1 -1
  255. package/lib/commonjs/platform/types.js.map +1 -1
  256. package/lib/commonjs/version.js +1 -1
  257. package/lib/commonjs/version.js.map +1 -1
  258. package/lib/module/components/ChannelCover.js +47 -33
  259. package/lib/module/components/ChannelCover.js.map +1 -1
  260. package/lib/module/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/EditInput.js +28 -13
  261. package/lib/module/components/ChannelInput/EditInput.js.map +1 -0
  262. package/lib/module/components/ChannelInput/SendInput.js +267 -0
  263. package/lib/module/components/ChannelInput/SendInput.js.map +1 -0
  264. package/lib/module/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/index.js +36 -35
  265. package/lib/module/components/ChannelInput/index.js.map +1 -0
  266. package/lib/module/components/FileViewer.js +5 -8
  267. package/lib/module/components/FileViewer.js.map +1 -1
  268. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +1 -1
  269. package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
  270. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +1 -1
  271. package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
  272. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +3 -3
  273. package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
  274. package/lib/module/components/MessageRenderer/FileMessage/index.js +1 -5
  275. package/lib/module/components/MessageRenderer/FileMessage/index.js.map +1 -1
  276. package/lib/module/components/MessageRenderer/MessageDateSeparator.js.map +1 -1
  277. package/lib/module/components/MessageRenderer/MessageIncomingSenderName.js +1 -1
  278. package/lib/module/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -1
  279. package/lib/module/components/MessageRenderer/MessageTime.js +1 -1
  280. package/lib/module/components/MessageRenderer/MessageTime.js.map +1 -1
  281. package/lib/module/components/MessageRenderer/UnknownMessage/index.js +1 -1
  282. package/lib/module/components/MessageRenderer/UnknownMessage/index.js.map +1 -1
  283. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +3 -3
  284. package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
  285. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +5 -5
  286. package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
  287. package/lib/module/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js +44 -0
  288. package/lib/module/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.js.map +1 -0
  289. package/lib/module/components/OpenChannelMessageRenderer/index.js +119 -0
  290. package/lib/module/components/OpenChannelMessageRenderer/index.js.map +1 -0
  291. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +3 -4
  292. package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -1
  293. package/lib/module/components/TypedPlaceholder.js +6 -0
  294. package/lib/module/components/TypedPlaceholder.js.map +1 -1
  295. package/lib/module/containers/GroupChannelPreviewContainer.js +3 -3
  296. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  297. package/lib/module/containers/SendbirdUIKitContainer.js +28 -6
  298. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  299. package/lib/module/contexts/PlatformServiceCtx.js.map +1 -1
  300. package/lib/module/contexts/SendbirdChatCtx.js +12 -14
  301. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -1
  302. package/lib/module/contexts/UserProfileCtx.js +21 -11
  303. package/lib/module/contexts/UserProfileCtx.js.map +1 -1
  304. package/lib/module/domain/groupChannel/component/GroupChannelInput.js +36 -0
  305. package/lib/module/domain/groupChannel/component/GroupChannelInput.js.map +1 -0
  306. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +13 -12
  307. package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
  308. package/lib/module/domain/groupChannel/module/moduleContext.js +3 -3
  309. package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
  310. package/lib/module/domain/groupChannel/types.js.map +1 -1
  311. package/lib/module/domain/groupChannelBannedUsers/index.js +1 -0
  312. package/lib/module/domain/groupChannelBannedUsers/index.js.map +1 -1
  313. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +2 -2
  314. package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
  315. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +4 -2
  316. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -1
  317. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +4 -2
  318. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -1
  319. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -1
  320. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  321. package/lib/module/domain/groupChannelSettings/module/moduleContext.js +5 -6
  322. package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
  323. package/lib/module/domain/openChannel/component/OpenChannelHeader.js +63 -0
  324. package/lib/module/domain/openChannel/component/OpenChannelHeader.js.map +1 -0
  325. package/lib/module/domain/openChannel/component/OpenChannelInput.js +74 -0
  326. package/lib/module/domain/openChannel/component/OpenChannelInput.js.map +1 -0
  327. package/lib/module/domain/openChannel/component/OpenChannelMessageList.js +325 -0
  328. package/lib/module/domain/openChannel/component/OpenChannelMessageList.js.map +1 -0
  329. package/lib/module/domain/openChannel/component/OpenChannelStatusEmpty.js +21 -0
  330. package/lib/module/domain/openChannel/component/OpenChannelStatusEmpty.js.map +1 -0
  331. package/lib/module/domain/openChannel/component/OpenChannelStatusLoading.js +21 -0
  332. package/lib/module/domain/openChannel/component/OpenChannelStatusLoading.js.map +1 -0
  333. package/lib/module/domain/openChannel/index.js +7 -0
  334. package/lib/module/domain/openChannel/index.js.map +1 -0
  335. package/lib/module/domain/openChannel/module/createOpenChannelModule.js +30 -0
  336. package/lib/module/domain/openChannel/module/createOpenChannelModule.js.map +1 -0
  337. package/lib/module/domain/openChannel/module/moduleContext.js +32 -0
  338. package/lib/module/domain/openChannel/module/moduleContext.js.map +1 -0
  339. package/lib/module/domain/openChannel/types.js +2 -0
  340. package/lib/module/domain/openChannel/types.js.map +1 -0
  341. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js +25 -0
  342. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.js.map +1 -0
  343. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js +41 -0
  344. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.js.map +1 -0
  345. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js +16 -0
  346. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.js.map +1 -0
  347. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js +20 -0
  348. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.js.map +1 -0
  349. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js +16 -0
  350. package/lib/module/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.js.map +1 -0
  351. package/lib/module/domain/openChannelBannedUsers/index.js +8 -0
  352. package/lib/module/domain/openChannelBannedUsers/index.js.map +1 -0
  353. package/lib/module/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js +30 -0
  354. package/lib/module/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.js.map +1 -0
  355. package/lib/module/domain/openChannelBannedUsers/module/moduleContext.js +25 -0
  356. package/lib/module/domain/openChannelBannedUsers/module/moduleContext.js.map +1 -0
  357. package/lib/module/domain/openChannelBannedUsers/types.js +2 -0
  358. package/lib/module/domain/openChannelBannedUsers/types.js.map +1 -0
  359. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateHeader.js +38 -0
  360. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateHeader.js.map +1 -0
  361. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js +153 -0
  362. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateProfileInput.js.map +1 -0
  363. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js +11 -0
  364. package/lib/module/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.js.map +1 -0
  365. package/lib/module/domain/openChannelCreate/index.js +6 -0
  366. package/lib/module/domain/openChannelCreate/index.js.map +1 -0
  367. package/lib/module/domain/openChannelCreate/module/createOpenChannelCreateModule.js +24 -0
  368. package/lib/module/domain/openChannelCreate/module/createOpenChannelCreateModule.js.map +1 -0
  369. package/lib/module/domain/openChannelCreate/module/moduleContext.js +24 -0
  370. package/lib/module/domain/openChannelCreate/module/moduleContext.js.map +1 -0
  371. package/lib/module/domain/openChannelCreate/types.js +2 -0
  372. package/lib/module/domain/openChannelCreate/types.js.map +1 -0
  373. package/lib/module/domain/openChannelList/component/OpenChannelListHeader.js +25 -0
  374. package/lib/module/domain/openChannelList/component/OpenChannelListHeader.js.map +1 -0
  375. package/lib/module/domain/openChannelList/component/OpenChannelListList.js +45 -0
  376. package/lib/module/domain/openChannelList/component/OpenChannelListList.js.map +1 -0
  377. package/lib/module/domain/openChannelList/component/OpenChannelListStatusEmpty.js +21 -0
  378. package/lib/module/domain/openChannelList/component/OpenChannelListStatusEmpty.js.map +1 -0
  379. package/lib/module/domain/openChannelList/component/OpenChannelListStatusError.js +20 -0
  380. package/lib/module/domain/openChannelList/component/OpenChannelListStatusError.js.map +1 -0
  381. package/lib/module/domain/openChannelList/component/OpenChannelListStatusLoading.js +21 -0
  382. package/lib/module/domain/openChannelList/component/OpenChannelListStatusLoading.js.map +1 -0
  383. package/lib/module/domain/openChannelList/index.js +8 -0
  384. package/lib/module/domain/openChannelList/index.js.map +1 -0
  385. package/lib/module/domain/openChannelList/module/createOpenChannelListModule.js +30 -0
  386. package/lib/module/domain/openChannelList/module/createOpenChannelListModule.js.map +1 -0
  387. package/lib/module/domain/openChannelList/module/moduleContext.js +22 -0
  388. package/lib/module/domain/openChannelList/module/moduleContext.js.map +1 -0
  389. package/lib/module/domain/openChannelList/types.js +2 -0
  390. package/lib/module/domain/openChannelList/types.js.map +1 -0
  391. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationHeader.js +25 -0
  392. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationHeader.js.map +1 -0
  393. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationMenu.js +61 -0
  394. package/lib/module/domain/openChannelModeration/component/OpenChannelModerationMenu.js.map +1 -0
  395. package/lib/module/domain/openChannelModeration/index.js +5 -0
  396. package/lib/module/domain/openChannelModeration/index.js.map +1 -0
  397. package/lib/module/domain/openChannelModeration/module/createOpenChannelModerationModule.js +21 -0
  398. package/lib/module/domain/openChannelModeration/module/createOpenChannelModerationModule.js.map +1 -0
  399. package/lib/module/domain/openChannelModeration/module/moduleContext.js +25 -0
  400. package/lib/module/domain/openChannelModeration/module/moduleContext.js.map +1 -0
  401. package/lib/module/domain/openChannelModeration/types.js +2 -0
  402. package/lib/module/domain/openChannelModeration/types.js.map +1 -0
  403. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js +25 -0
  404. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.js.map +1 -0
  405. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js +41 -0
  406. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.js.map +1 -0
  407. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js +16 -0
  408. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.js.map +1 -0
  409. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js +20 -0
  410. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.js.map +1 -0
  411. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js +16 -0
  412. package/lib/module/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.js.map +1 -0
  413. package/lib/module/domain/openChannelMutedParticipants/index.js +7 -0
  414. package/lib/module/domain/openChannelMutedParticipants/index.js.map +1 -0
  415. package/lib/module/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js +30 -0
  416. package/lib/module/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.js.map +1 -0
  417. package/lib/module/domain/openChannelMutedParticipants/module/moduleContext.js +25 -0
  418. package/lib/module/domain/openChannelMutedParticipants/module/moduleContext.js.map +1 -0
  419. package/lib/module/domain/openChannelMutedParticipants/types.js +2 -0
  420. package/lib/module/domain/openChannelMutedParticipants/types.js.map +1 -0
  421. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js +30 -0
  422. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsHeader.js.map +1 -0
  423. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsList.js +41 -0
  424. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsList.js.map +1 -0
  425. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js +16 -0
  426. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.js.map +1 -0
  427. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js +20 -0
  428. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.js.map +1 -0
  429. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js +16 -0
  430. package/lib/module/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.js.map +1 -0
  431. package/lib/module/domain/openChannelOperators/index.js +7 -0
  432. package/lib/module/domain/openChannelOperators/index.js.map +1 -0
  433. package/lib/module/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js +30 -0
  434. package/lib/module/domain/openChannelOperators/module/createOpenChannelOperatorsModule.js.map +1 -0
  435. package/lib/module/domain/openChannelOperators/module/moduleContext.js +25 -0
  436. package/lib/module/domain/openChannelOperators/module/moduleContext.js.map +1 -0
  437. package/lib/module/domain/openChannelOperators/types.js +2 -0
  438. package/lib/module/domain/openChannelOperators/types.js.map +1 -0
  439. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsHeader.js +35 -0
  440. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsHeader.js.map +1 -0
  441. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsInfo.js +49 -0
  442. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsInfo.js.map +1 -0
  443. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsMenu.js +99 -0
  444. package/lib/module/domain/openChannelSettings/component/OpenChannelSettingsMenu.js.map +1 -0
  445. package/lib/module/domain/openChannelSettings/index.js +6 -0
  446. package/lib/module/domain/openChannelSettings/index.js.map +1 -0
  447. package/lib/module/domain/openChannelSettings/module/createOpenChannelSettingsModule.js +24 -0
  448. package/lib/module/domain/openChannelSettings/module/createOpenChannelSettingsModule.js.map +1 -0
  449. package/lib/module/domain/openChannelSettings/module/moduleContext.js +161 -0
  450. package/lib/module/domain/openChannelSettings/module/moduleContext.js.map +1 -0
  451. package/lib/module/domain/openChannelSettings/types.js +2 -0
  452. package/lib/module/domain/openChannelSettings/types.js.map +1 -0
  453. package/lib/module/domain/openChannelUserList/types.js +2 -0
  454. package/lib/module/domain/openChannelUserList/types.js.map +1 -0
  455. package/lib/module/fragments/createGroupChannelCreateFragment.js +4 -7
  456. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  457. package/lib/module/fragments/createGroupChannelFragment.js +33 -3
  458. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  459. package/lib/module/fragments/createGroupChannelListFragment.js +5 -9
  460. package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
  461. package/lib/module/fragments/createGroupChannelMembersFragment.js +7 -9
  462. package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
  463. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js +14 -4
  464. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js.map +1 -1
  465. package/lib/module/fragments/createGroupChannelOperatorsFragment.js +3 -4
  466. package/lib/module/fragments/createGroupChannelOperatorsFragment.js.map +1 -1
  467. package/lib/module/fragments/createOpenChannelBannedUsersFragment.js +84 -0
  468. package/lib/module/fragments/createOpenChannelBannedUsersFragment.js.map +1 -0
  469. package/lib/module/fragments/createOpenChannelCreateFragment.js +69 -0
  470. package/lib/module/fragments/createOpenChannelCreateFragment.js.map +1 -0
  471. package/lib/module/fragments/createOpenChannelFragment.js +153 -0
  472. package/lib/module/fragments/createOpenChannelFragment.js.map +1 -0
  473. package/lib/module/fragments/createOpenChannelListFragment.js +77 -0
  474. package/lib/module/fragments/createOpenChannelListFragment.js.map +1 -0
  475. package/lib/module/fragments/createOpenChannelModerationFragment.js +53 -0
  476. package/lib/module/fragments/createOpenChannelModerationFragment.js.map +1 -0
  477. package/lib/module/fragments/createOpenChannelMutedParticipantsFragment.js +100 -0
  478. package/lib/module/fragments/createOpenChannelMutedParticipantsFragment.js.map +1 -0
  479. package/lib/module/fragments/createOpenChannelOperatorsFragment.js +106 -0
  480. package/lib/module/fragments/createOpenChannelOperatorsFragment.js.map +1 -0
  481. package/lib/module/fragments/createOpenChannelParticipantsFragment.js +140 -0
  482. package/lib/module/fragments/createOpenChannelParticipantsFragment.js.map +1 -0
  483. package/lib/module/fragments/createOpenChannelRegisterOperatorFragment.js +96 -0
  484. package/lib/module/fragments/createOpenChannelRegisterOperatorFragment.js.map +1 -0
  485. package/lib/module/fragments/createOpenChannelSettingsFragment.js +55 -0
  486. package/lib/module/fragments/createOpenChannelSettingsFragment.js.map +1 -0
  487. package/lib/module/hooks/useKeyboardStatus.js +12 -9
  488. package/lib/module/hooks/useKeyboardStatus.js.map +1 -1
  489. package/lib/module/hooks/useMentionSuggestion.js +5 -14
  490. package/lib/module/hooks/useMentionSuggestion.js.map +1 -1
  491. package/lib/module/index.js +48 -6
  492. package/lib/module/index.js.map +1 -1
  493. package/lib/module/libs/ImageCompressionConfig.js +30 -0
  494. package/lib/module/libs/ImageCompressionConfig.js.map +1 -0
  495. package/lib/module/libs/SBUUtils.js +26 -1
  496. package/lib/module/libs/SBUUtils.js.map +1 -1
  497. package/lib/module/localization/StringSet.en.js +1 -1
  498. package/lib/module/localization/StringSet.en.js.map +1 -1
  499. package/lib/module/localization/StringSet.type.js +1 -247
  500. package/lib/module/localization/StringSet.type.js.map +1 -1
  501. package/lib/module/localization/createBaseStringSet.js +384 -0
  502. package/lib/module/localization/createBaseStringSet.js.map +1 -0
  503. package/lib/module/platform/createFileService.native.js +5 -0
  504. package/lib/module/platform/createFileService.native.js.map +1 -1
  505. package/lib/module/platform/createMediaService.expo.js +33 -1
  506. package/lib/module/platform/createMediaService.expo.js.map +1 -1
  507. package/lib/module/platform/createMediaService.native.js +38 -5
  508. package/lib/module/platform/createMediaService.native.js.map +1 -1
  509. package/lib/module/platform/dynamicModule.js +10 -56
  510. package/lib/module/platform/dynamicModule.js.map +1 -1
  511. package/lib/module/platform/types.js.map +1 -1
  512. package/lib/module/version.js +1 -1
  513. package/lib/module/version.js.map +1 -1
  514. package/lib/typescript/src/components/ChannelCover.d.ts +2 -2
  515. package/lib/typescript/src/components/ChannelInput/EditInput.d.ts +16 -0
  516. package/lib/typescript/src/components/ChannelInput/SendInput.d.ts +12 -0
  517. package/lib/typescript/src/components/ChannelInput/index.d.ts +43 -0
  518. package/lib/typescript/src/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.d.ts +6 -0
  519. package/lib/typescript/src/components/OpenChannelMessageRenderer/index.d.ts +16 -0
  520. package/lib/typescript/src/components/TypedPlaceholder.d.ts +1 -1
  521. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +13 -9
  522. package/lib/typescript/src/contexts/PlatformServiceCtx.d.ts +8 -2
  523. package/lib/typescript/src/contexts/SendbirdChatCtx.d.ts +8 -3
  524. package/lib/typescript/src/contexts/UserProfileCtx.d.ts +6 -2
  525. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput.d.ts +3 -0
  526. package/lib/typescript/src/domain/groupChannel/types.d.ts +9 -28
  527. package/lib/typescript/src/domain/groupChannelBannedUsers/index.d.ts +1 -0
  528. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.d.ts +1 -1
  529. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.d.ts +1 -1
  530. package/lib/typescript/src/domain/openChannel/component/OpenChannelHeader.d.ts +7 -0
  531. package/lib/typescript/src/domain/openChannel/component/OpenChannelInput.d.ts +3 -0
  532. package/lib/typescript/src/domain/openChannel/component/OpenChannelMessageList.d.ts +39 -0
  533. package/lib/typescript/src/domain/openChannel/component/OpenChannelStatusEmpty.d.ts +2 -0
  534. package/lib/typescript/src/domain/openChannel/component/OpenChannelStatusLoading.d.ts +2 -0
  535. package/lib/typescript/src/domain/openChannel/index.d.ts +6 -0
  536. package/lib/typescript/src/domain/openChannel/module/createOpenChannelModule.d.ts +3 -0
  537. package/lib/typescript/src/domain/openChannel/module/moduleContext.d.ts +3 -0
  538. package/lib/typescript/src/domain/openChannel/types.d.ts +97 -0
  539. package/lib/typescript/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.d.ts +3 -0
  540. package/lib/typescript/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.d.ts +3 -0
  541. package/lib/typescript/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.d.ts +2 -0
  542. package/lib/typescript/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.d.ts +3 -0
  543. package/lib/typescript/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.d.ts +2 -0
  544. package/lib/typescript/src/domain/openChannelBannedUsers/index.d.ts +7 -0
  545. package/lib/typescript/src/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.d.ts +3 -0
  546. package/lib/typescript/src/domain/openChannelBannedUsers/module/moduleContext.d.ts +3 -0
  547. package/lib/typescript/src/domain/openChannelBannedUsers/types.d.ts +47 -0
  548. package/lib/typescript/src/domain/openChannelCreate/component/OpenChannelCreateHeader.d.ts +3 -0
  549. package/lib/typescript/src/domain/openChannelCreate/component/OpenChannelCreateProfileInput.d.ts +3 -0
  550. package/lib/typescript/src/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.d.ts +2 -0
  551. package/lib/typescript/src/domain/openChannelCreate/index.d.ts +5 -0
  552. package/lib/typescript/src/domain/openChannelCreate/module/createOpenChannelCreateModule.d.ts +3 -0
  553. package/lib/typescript/src/domain/openChannelCreate/module/moduleContext.d.ts +3 -0
  554. package/lib/typescript/src/domain/openChannelCreate/types.d.ts +40 -0
  555. package/lib/typescript/src/domain/openChannelList/component/OpenChannelListHeader.d.ts +3 -0
  556. package/lib/typescript/src/domain/openChannelList/component/OpenChannelListList.d.ts +3 -0
  557. package/lib/typescript/src/domain/openChannelList/component/OpenChannelListStatusEmpty.d.ts +2 -0
  558. package/lib/typescript/src/domain/openChannelList/component/OpenChannelListStatusError.d.ts +3 -0
  559. package/lib/typescript/src/domain/openChannelList/component/OpenChannelListStatusLoading.d.ts +2 -0
  560. package/lib/typescript/src/domain/openChannelList/index.d.ts +7 -0
  561. package/lib/typescript/src/domain/openChannelList/module/createOpenChannelListModule.d.ts +3 -0
  562. package/lib/typescript/src/domain/openChannelList/module/moduleContext.d.ts +3 -0
  563. package/lib/typescript/src/domain/openChannelList/types.d.ts +60 -0
  564. package/lib/typescript/src/domain/openChannelModeration/component/OpenChannelModerationHeader.d.ts +3 -0
  565. package/lib/typescript/src/domain/openChannelModeration/component/OpenChannelModerationMenu.d.ts +3 -0
  566. package/lib/typescript/src/domain/openChannelModeration/index.d.ts +4 -0
  567. package/lib/typescript/src/domain/openChannelModeration/module/createOpenChannelModerationModule.d.ts +3 -0
  568. package/lib/typescript/src/domain/openChannelModeration/module/moduleContext.d.ts +3 -0
  569. package/lib/typescript/src/domain/openChannelModeration/types.d.ts +43 -0
  570. package/lib/typescript/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.d.ts +3 -0
  571. package/lib/typescript/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.d.ts +3 -0
  572. package/lib/typescript/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.d.ts +2 -0
  573. package/lib/typescript/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.d.ts +3 -0
  574. package/lib/typescript/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.d.ts +2 -0
  575. package/lib/typescript/src/domain/openChannelMutedParticipants/index.d.ts +6 -0
  576. package/lib/typescript/src/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.d.ts +3 -0
  577. package/lib/typescript/src/domain/openChannelMutedParticipants/module/moduleContext.d.ts +3 -0
  578. package/lib/typescript/src/domain/openChannelMutedParticipants/types.d.ts +47 -0
  579. package/lib/typescript/src/domain/openChannelOperators/component/OpenChannelOperatorsHeader.d.ts +3 -0
  580. package/lib/typescript/src/domain/openChannelOperators/component/OpenChannelOperatorsList.d.ts +3 -0
  581. package/lib/typescript/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.d.ts +2 -0
  582. package/lib/typescript/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.d.ts +3 -0
  583. package/lib/typescript/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.d.ts +2 -0
  584. package/lib/typescript/src/domain/openChannelOperators/index.d.ts +6 -0
  585. package/lib/typescript/src/domain/openChannelOperators/module/createOpenChannelOperatorsModule.d.ts +3 -0
  586. package/lib/typescript/src/domain/openChannelOperators/module/moduleContext.d.ts +3 -0
  587. package/lib/typescript/src/domain/openChannelOperators/types.d.ts +49 -0
  588. package/lib/typescript/src/domain/openChannelSettings/component/OpenChannelSettingsHeader.d.ts +3 -0
  589. package/lib/typescript/src/domain/openChannelSettings/component/OpenChannelSettingsInfo.d.ts +3 -0
  590. package/lib/typescript/src/domain/openChannelSettings/component/OpenChannelSettingsMenu.d.ts +3 -0
  591. package/lib/typescript/src/domain/openChannelSettings/index.d.ts +5 -0
  592. package/lib/typescript/src/domain/openChannelSettings/module/createOpenChannelSettingsModule.d.ts +3 -0
  593. package/lib/typescript/src/domain/openChannelSettings/module/moduleContext.d.ts +3 -0
  594. package/lib/typescript/src/domain/openChannelSettings/types.d.ts +49 -0
  595. package/lib/typescript/src/domain/openChannelUserList/types.d.ts +23 -0
  596. package/lib/typescript/src/fragments/createOpenChannelBannedUsersFragment.d.ts +3 -0
  597. package/lib/typescript/src/fragments/createOpenChannelCreateFragment.d.ts +3 -0
  598. package/lib/typescript/src/fragments/createOpenChannelFragment.d.ts +3 -0
  599. package/lib/typescript/src/fragments/createOpenChannelListFragment.d.ts +3 -0
  600. package/lib/typescript/src/fragments/createOpenChannelModerationFragment.d.ts +3 -0
  601. package/lib/typescript/src/fragments/createOpenChannelMutedParticipantsFragment.d.ts +3 -0
  602. package/lib/typescript/src/fragments/createOpenChannelOperatorsFragment.d.ts +3 -0
  603. package/lib/typescript/src/fragments/createOpenChannelParticipantsFragment.d.ts +5 -0
  604. package/lib/typescript/src/fragments/createOpenChannelRegisterOperatorFragment.d.ts +5 -0
  605. package/lib/typescript/src/fragments/createOpenChannelSettingsFragment.d.ts +3 -0
  606. package/lib/typescript/src/hooks/useContext.d.ts +2 -29
  607. package/lib/typescript/src/index.d.ts +44 -11
  608. package/lib/typescript/src/libs/ImageCompressionConfig.d.ts +16 -0
  609. package/lib/typescript/src/libs/MentionManager.d.ts +1 -1
  610. package/lib/typescript/src/libs/SBUUtils.d.ts +6 -0
  611. package/lib/typescript/src/localization/StringSet.type.d.ts +139 -26
  612. package/lib/typescript/src/localization/createBaseStringSet.d.ts +16 -0
  613. package/lib/typescript/src/platform/createMediaService.expo.d.ts +5 -1
  614. package/lib/typescript/src/platform/createMediaService.native.d.ts +7 -5
  615. package/lib/typescript/src/platform/dynamicModule.d.ts +7 -12
  616. package/lib/typescript/src/platform/types.d.ts +28 -3
  617. package/lib/typescript/src/version.d.ts +1 -1
  618. package/package.json +19 -8
  619. package/src/components/ChannelCover.tsx +46 -37
  620. package/src/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/EditInput.tsx +30 -19
  621. package/src/components/ChannelInput/SendInput.tsx +302 -0
  622. package/src/{domain/groupChannel/component/GroupChannelInput → components/ChannelInput}/index.tsx +93 -37
  623. package/src/components/FileViewer.tsx +5 -8
  624. package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +1 -1
  625. package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +10 -1
  626. package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +7 -3
  627. package/src/components/MessageRenderer/FileMessage/index.tsx +1 -4
  628. package/src/components/MessageRenderer/MessageDateSeparator.tsx +1 -0
  629. package/src/components/MessageRenderer/MessageIncomingSenderName.tsx +1 -1
  630. package/src/components/MessageRenderer/MessageTime.tsx +1 -1
  631. package/src/components/MessageRenderer/UnknownMessage/index.tsx +1 -1
  632. package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +3 -3
  633. package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +5 -5
  634. package/src/components/OpenChannelMessageRenderer/OpenChannelMessageDateSeparator.tsx +46 -0
  635. package/src/components/OpenChannelMessageRenderer/index.tsx +91 -0
  636. package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +3 -4
  637. package/src/components/TypedPlaceholder.tsx +3 -0
  638. package/src/containers/GroupChannelPreviewContainer.tsx +3 -3
  639. package/src/containers/SendbirdUIKitContainer.tsx +42 -12
  640. package/src/contexts/PlatformServiceCtx.tsx +9 -2
  641. package/src/contexts/SendbirdChatCtx.tsx +22 -19
  642. package/src/contexts/UserProfileCtx.tsx +27 -12
  643. package/src/domain/groupChannel/component/GroupChannelInput.tsx +42 -0
  644. package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +13 -12
  645. package/src/domain/groupChannel/module/moduleContext.tsx +3 -3
  646. package/src/domain/groupChannel/types.ts +24 -37
  647. package/src/domain/groupChannelBannedUsers/index.ts +1 -0
  648. package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -2
  649. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +2 -0
  650. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +2 -0
  651. package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +1 -1
  652. package/src/domain/groupChannelSettings/module/moduleContext.tsx +11 -6
  653. package/src/domain/openChannel/component/OpenChannelHeader.tsx +47 -0
  654. package/src/domain/openChannel/component/OpenChannelInput.tsx +80 -0
  655. package/src/domain/openChannel/component/OpenChannelMessageList.tsx +322 -0
  656. package/src/domain/openChannel/component/OpenChannelStatusEmpty.tsx +18 -0
  657. package/src/domain/openChannel/component/OpenChannelStatusLoading.tsx +18 -0
  658. package/src/domain/openChannel/index.ts +6 -0
  659. package/src/domain/openChannel/module/createOpenChannelModule.tsx +21 -0
  660. package/src/domain/openChannel/module/moduleContext.tsx +41 -0
  661. package/src/domain/openChannel/types.ts +127 -0
  662. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersHeader.tsx +14 -0
  663. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersList.tsx +33 -0
  664. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusEmpty.tsx +15 -0
  665. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusError.tsx +16 -0
  666. package/src/domain/openChannelBannedUsers/component/OpenChannelBannedUsersStatusLoading.tsx +15 -0
  667. package/src/domain/openChannelBannedUsers/index.ts +7 -0
  668. package/src/domain/openChannelBannedUsers/module/createOpenChannelBannedUsersModule.tsx +21 -0
  669. package/src/domain/openChannelBannedUsers/module/moduleContext.tsx +30 -0
  670. package/src/domain/openChannelBannedUsers/types.ts +50 -0
  671. package/src/domain/openChannelCreate/component/OpenChannelCreateHeader.tsx +35 -0
  672. package/src/domain/openChannelCreate/component/OpenChannelCreateProfileInput.tsx +155 -0
  673. package/src/domain/openChannelCreate/component/OpenChannelCreateStatusLoading.tsx +9 -0
  674. package/src/domain/openChannelCreate/index.ts +5 -0
  675. package/src/domain/openChannelCreate/module/createOpenChannelCreateModule.tsx +17 -0
  676. package/src/domain/openChannelCreate/module/moduleContext.tsx +28 -0
  677. package/src/domain/openChannelCreate/types.ts +45 -0
  678. package/src/domain/openChannelList/component/OpenChannelListHeader.tsx +14 -0
  679. package/src/domain/openChannelList/component/OpenChannelListList.tsx +37 -0
  680. package/src/domain/openChannelList/component/OpenChannelListStatusEmpty.tsx +18 -0
  681. package/src/domain/openChannelList/component/OpenChannelListStatusError.tsx +16 -0
  682. package/src/domain/openChannelList/component/OpenChannelListStatusLoading.tsx +18 -0
  683. package/src/domain/openChannelList/index.ts +7 -0
  684. package/src/domain/openChannelList/module/createOpenChannelListModule.tsx +21 -0
  685. package/src/domain/openChannelList/module/moduleContext.tsx +22 -0
  686. package/src/domain/openChannelList/types.ts +63 -0
  687. package/src/domain/openChannelModeration/component/OpenChannelModerationHeader.tsx +15 -0
  688. package/src/domain/openChannelModeration/component/OpenChannelModerationMenu.tsx +62 -0
  689. package/src/domain/openChannelModeration/index.ts +4 -0
  690. package/src/domain/openChannelModeration/module/createOpenChannelModerationModule.tsx +15 -0
  691. package/src/domain/openChannelModeration/module/moduleContext.tsx +33 -0
  692. package/src/domain/openChannelModeration/types.ts +48 -0
  693. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsHeader.tsx +14 -0
  694. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsList.tsx +33 -0
  695. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusEmpty.tsx +15 -0
  696. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusError.tsx +18 -0
  697. package/src/domain/openChannelMutedParticipants/component/OpenChannelMutedParticipantsStatusLoading.tsx +15 -0
  698. package/src/domain/openChannelMutedParticipants/index.ts +9 -0
  699. package/src/domain/openChannelMutedParticipants/module/createOpenChannelMutedParticipantsModule.tsx +21 -0
  700. package/src/domain/openChannelMutedParticipants/module/moduleContext.tsx +30 -0
  701. package/src/domain/openChannelMutedParticipants/types.ts +50 -0
  702. package/src/domain/openChannelOperators/component/OpenChannelOperatorsHeader.tsx +22 -0
  703. package/src/domain/openChannelOperators/component/OpenChannelOperatorsList.tsx +31 -0
  704. package/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusEmpty.tsx +15 -0
  705. package/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusError.tsx +16 -0
  706. package/src/domain/openChannelOperators/component/OpenChannelOperatorsStatusLoading.tsx +15 -0
  707. package/src/domain/openChannelOperators/index.ts +6 -0
  708. package/src/domain/openChannelOperators/module/createOpenChannelOperatorsModule.tsx +21 -0
  709. package/src/domain/openChannelOperators/module/moduleContext.tsx +27 -0
  710. package/src/domain/openChannelOperators/types.ts +52 -0
  711. package/src/domain/openChannelSettings/component/OpenChannelSettingsHeader.tsx +29 -0
  712. package/src/domain/openChannelSettings/component/OpenChannelSettingsInfo.tsx +47 -0
  713. package/src/domain/openChannelSettings/component/OpenChannelSettingsMenu.tsx +105 -0
  714. package/src/domain/openChannelSettings/index.ts +5 -0
  715. package/src/domain/openChannelSettings/module/createOpenChannelSettingsModule.tsx +17 -0
  716. package/src/domain/openChannelSettings/module/moduleContext.tsx +171 -0
  717. package/src/domain/openChannelSettings/types.ts +54 -0
  718. package/src/domain/openChannelUserList/types.ts +30 -0
  719. package/src/fragments/createGroupChannelCreateFragment.tsx +4 -7
  720. package/src/fragments/createGroupChannelFragment.tsx +37 -2
  721. package/src/fragments/createGroupChannelListFragment.tsx +5 -9
  722. package/src/fragments/createGroupChannelMembersFragment.tsx +11 -8
  723. package/src/fragments/createGroupChannelMutedMembersFragment.tsx +12 -5
  724. package/src/fragments/createGroupChannelOperatorsFragment.tsx +3 -4
  725. package/src/fragments/createOpenChannelBannedUsersFragment.tsx +80 -0
  726. package/src/fragments/createOpenChannelCreateFragment.tsx +77 -0
  727. package/src/fragments/createOpenChannelFragment.tsx +157 -0
  728. package/src/fragments/createOpenChannelListFragment.tsx +67 -0
  729. package/src/fragments/createOpenChannelModerationFragment.tsx +55 -0
  730. package/src/fragments/createOpenChannelMutedParticipantsFragment.tsx +100 -0
  731. package/src/fragments/createOpenChannelOperatorsFragment.tsx +101 -0
  732. package/src/fragments/createOpenChannelParticipantsFragment.tsx +144 -0
  733. package/src/fragments/createOpenChannelRegisterOperatorFragment.tsx +99 -0
  734. package/src/fragments/createOpenChannelSettingsFragment.tsx +57 -0
  735. package/src/hooks/useKeyboardStatus.ts +10 -5
  736. package/src/hooks/useMentionSuggestion.ts +10 -17
  737. package/src/index.ts +55 -48
  738. package/src/libs/ImageCompressionConfig.ts +31 -0
  739. package/src/libs/SBUUtils.ts +28 -1
  740. package/src/localization/StringSet.en.ts +1 -1
  741. package/src/localization/StringSet.type.ts +150 -255
  742. package/src/localization/createBaseStringSet.ts +369 -0
  743. package/src/platform/createFileService.native.ts +8 -0
  744. package/src/platform/createMediaService.expo.tsx +24 -1
  745. package/src/platform/createMediaService.native.tsx +31 -9
  746. package/src/platform/dynamicModule.ts +17 -59
  747. package/src/platform/types.ts +29 -7
  748. package/src/version.ts +1 -1
  749. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +0 -1
  750. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +0 -1
  751. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +0 -1
  752. package/lib/commonjs/utils/common.js +0 -19
  753. package/lib/commonjs/utils/common.js.map +0 -1
  754. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +0 -1
  755. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +0 -178
  756. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +0 -1
  757. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +0 -1
  758. package/lib/module/utils/common.js +0 -7
  759. package/lib/module/utils/common.js.map +0 -1
  760. package/lib/typescript/__template__/component/__domain__Header.d.ts +0 -3
  761. package/lib/typescript/__template__/component/__domain__StatusEmpty.d.ts +0 -2
  762. package/lib/typescript/__template__/component/__domain__StatusLoading.d.ts +0 -2
  763. package/lib/typescript/__template__/component/__domain__View.d.ts +0 -3
  764. package/lib/typescript/__template__/create__domain__Fragment.d.ts +0 -2
  765. package/lib/typescript/__template__/index.d.ts +0 -6
  766. package/lib/typescript/__template__/module/create__domain__Module.d.ts +0 -3
  767. package/lib/typescript/__template__/module/moduleContext.d.ts +0 -3
  768. package/lib/typescript/__template__/types.d.ts +0 -31
  769. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +0 -39
  770. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +0 -37
  771. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +0 -26
  772. package/lib/typescript/src/utils/common.d.ts +0 -1
  773. package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +0 -208
  774. package/src/utils/common.ts +0 -8
@@ -0,0 +1,100 @@
1
+ import React from 'react';
2
+ import { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';
3
+ import { useActionMenu } from '@sendbird/uikit-react-native-foundation';
4
+ import { NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';
5
+ import StatusComposition from '../components/StatusComposition';
6
+ import UserActionBar from '../components/UserActionBar';
7
+ import { createOpenChannelMutedParticipantsModule } from '../domain/openChannelMutedParticipants';
8
+ import { useLocalization, useSendbirdChat } from '../hooks/useContext';
9
+
10
+ const createOpenChannelMutedParticipantsFragment = initModule => {
11
+ const OpenChannelMutedParticipantsModule = createOpenChannelMutedParticipantsModule(initModule);
12
+ return _ref => {
13
+ let {
14
+ onPressHeaderLeft = NOOP,
15
+ channel,
16
+ renderUser
17
+ } = _ref;
18
+ const handlerId = useUniqHandlerId('OpenChannelMutedParticipants');
19
+ const {
20
+ STRINGS
21
+ } = useLocalization();
22
+ const {
23
+ sdk,
24
+ currentUser
25
+ } = useSendbirdChat();
26
+ const {
27
+ openMenu
28
+ } = useActionMenu();
29
+ const {
30
+ users,
31
+ deleteUser,
32
+ upsertUser,
33
+ loading,
34
+ refresh,
35
+ error,
36
+ next
37
+ } = useUserList(sdk, {
38
+ queryCreator: () => channel.createMutedUserListQuery({
39
+ limit: 20
40
+ })
41
+ });
42
+ useChannelHandler(sdk, handlerId, {
43
+ onUserMuted(eventChannel, user) {
44
+ if (isDifferentChannel(eventChannel, channel)) return;
45
+ upsertUser(user);
46
+ },
47
+
48
+ onUserUnmuted(eventChannel, user) {
49
+ if (isDifferentChannel(eventChannel, channel)) return;
50
+ deleteUser(user.userId);
51
+ }
52
+
53
+ }, 'open');
54
+
55
+ const _renderUser = useFreshCallback(props => {
56
+ if (renderUser) return renderUser(props);
57
+ const {
58
+ user
59
+ } = props;
60
+ const isUserOperator = channel.isOperator(user.userId);
61
+ return /*#__PURE__*/React.createElement(UserActionBar, {
62
+ muted: true,
63
+ uri: user.profileUrl,
64
+ label: ifThenOr(isUserOperator, STRINGS.LABELS.USER_BAR_OPERATOR, ''),
65
+ name: (user.nickname || STRINGS.LABELS.USER_NO_NAME) + (user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : ''),
66
+ disabled: user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId),
67
+ onPressActionMenu: () => {
68
+ openMenu({
69
+ title: user.nickname || STRINGS.LABELS.USER_NO_NAME,
70
+ menuItems: [{
71
+ title: STRINGS.LABELS.UNMUTE,
72
+ onPress: () => channel.unmuteUser(user).then(() => deleteUser(user.userId))
73
+ }]
74
+ });
75
+ }
76
+ });
77
+ });
78
+
79
+ return /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.Provider, {
80
+ channel: channel
81
+ }, /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.Header, {
82
+ onPressHeaderLeft: onPressHeaderLeft
83
+ }), /*#__PURE__*/React.createElement(StatusComposition, {
84
+ loading: loading,
85
+ LoadingComponent: /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.StatusLoading, null),
86
+ error: Boolean(error),
87
+ ErrorComponent: /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.StatusError, {
88
+ onPressRetry: refresh
89
+ })
90
+ }, /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.List, {
91
+ renderUser: _renderUser,
92
+ mutedParticipants: users,
93
+ onLoadNext: next,
94
+ ListEmptyComponent: /*#__PURE__*/React.createElement(OpenChannelMutedParticipantsModule.StatusEmpty, null)
95
+ })));
96
+ };
97
+ };
98
+
99
+ export default createOpenChannelMutedParticipantsFragment;
100
+ //# sourceMappingURL=createOpenChannelMutedParticipantsFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useChannelHandler","useUserList","useActionMenu","NOOP","ifThenOr","isDifferentChannel","useFreshCallback","useUniqHandlerId","StatusComposition","UserActionBar","createOpenChannelMutedParticipantsModule","useLocalization","useSendbirdChat","createOpenChannelMutedParticipantsFragment","initModule","OpenChannelMutedParticipantsModule","onPressHeaderLeft","channel","renderUser","handlerId","STRINGS","sdk","currentUser","openMenu","users","deleteUser","upsertUser","loading","refresh","error","next","queryCreator","createMutedUserListQuery","limit","onUserMuted","eventChannel","user","onUserUnmuted","userId","_renderUser","props","isUserOperator","isOperator","profileUrl","LABELS","USER_BAR_OPERATOR","nickname","USER_NO_NAME","USER_BAR_ME_POSTFIX","title","menuItems","UNMUTE","onPress","unmuteUser","then","Boolean"],"sources":["createOpenChannelMutedParticipantsFragment.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';\nimport { useActionMenu } from '@sendbird/uikit-react-native-foundation';\nimport { NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserActionBar from '../components/UserActionBar';\nimport { createOpenChannelMutedParticipantsModule } from '../domain/openChannelMutedParticipants';\nimport type {\n OpenChannelMutedParticipantsFragment,\n OpenChannelMutedParticipantsModule,\n} from '../domain/openChannelMutedParticipants/types';\nimport { useLocalization, useSendbirdChat } from '../hooks/useContext';\n\nconst createOpenChannelMutedParticipantsFragment = (\n initModule?: Partial<OpenChannelMutedParticipantsModule>,\n): OpenChannelMutedParticipantsFragment => {\n const OpenChannelMutedParticipantsModule = createOpenChannelMutedParticipantsModule(initModule);\n\n return ({ onPressHeaderLeft = NOOP, channel, renderUser }) => {\n const handlerId = useUniqHandlerId('OpenChannelMutedParticipants');\n\n const { STRINGS } = useLocalization();\n const { sdk, currentUser } = useSendbirdChat();\n const { openMenu } = useActionMenu();\n\n const { users, deleteUser, upsertUser, loading, refresh, error, next } = useUserList(sdk, {\n queryCreator: () => channel.createMutedUserListQuery({ limit: 20 }),\n });\n\n useChannelHandler(\n sdk,\n handlerId,\n {\n onUserMuted(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel)) return;\n upsertUser(user);\n },\n onUserUnmuted(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel)) return;\n deleteUser(user.userId);\n },\n },\n 'open',\n );\n\n const _renderUser: NonNullable<typeof renderUser> = useFreshCallback((props) => {\n if (renderUser) return renderUser(props);\n\n const { user } = props;\n const isUserOperator = channel.isOperator(user.userId);\n\n return (\n <UserActionBar\n muted\n uri={user.profileUrl}\n label={ifThenOr(isUserOperator, STRINGS.LABELS.USER_BAR_OPERATOR, '')}\n name={\n (user.nickname || STRINGS.LABELS.USER_NO_NAME) +\n (user.userId === currentUser?.userId ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : '')\n }\n disabled={user.userId === currentUser?.userId}\n onPressActionMenu={() => {\n openMenu({\n title: user.nickname || STRINGS.LABELS.USER_NO_NAME,\n menuItems: [\n {\n title: STRINGS.LABELS.UNMUTE,\n onPress: () => channel.unmuteUser(user).then(() => deleteUser(user.userId)),\n },\n ],\n });\n }}\n />\n );\n });\n\n return (\n <OpenChannelMutedParticipantsModule.Provider channel={channel}>\n <OpenChannelMutedParticipantsModule.Header onPressHeaderLeft={onPressHeaderLeft} />\n <StatusComposition\n loading={loading}\n LoadingComponent={<OpenChannelMutedParticipantsModule.StatusLoading />}\n error={Boolean(error)}\n ErrorComponent={<OpenChannelMutedParticipantsModule.StatusError onPressRetry={refresh} />}\n >\n <OpenChannelMutedParticipantsModule.List\n renderUser={_renderUser}\n mutedParticipants={users}\n onLoadNext={next}\n ListEmptyComponent={<OpenChannelMutedParticipantsModule.StatusEmpty />}\n />\n </StatusComposition>\n </OpenChannelMutedParticipantsModule.Provider>\n );\n };\n};\n\nexport default createOpenChannelMutedParticipantsFragment;\n"],"mappings":"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"}
@@ -0,0 +1,106 @@
1
+ import React from 'react';
2
+ import { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';
3
+ import { useActionMenu } from '@sendbird/uikit-react-native-foundation';
4
+ import { NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';
5
+ import StatusComposition from '../components/StatusComposition';
6
+ import UserActionBar from '../components/UserActionBar';
7
+ import { UNKNOWN_USER_ID } from '../constants';
8
+ import { createOpenChannelOperatorsModule } from '../domain/openChannelOperators';
9
+ import { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';
10
+
11
+ const createOpenChannelOperatorsFragment = initModule => {
12
+ const OpenChannelOperatorsModule = createOpenChannelOperatorsModule(initModule);
13
+ return _ref => {
14
+ let {
15
+ onPressHeaderLeft = NOOP,
16
+ onPressHeaderRight = NOOP,
17
+ channel,
18
+ renderUser
19
+ } = _ref;
20
+ const handlerId = useUniqHandlerId('OpenChannelOperatorsFragment');
21
+ const {
22
+ STRINGS
23
+ } = useLocalization();
24
+ const {
25
+ sdk,
26
+ currentUser
27
+ } = useSendbirdChat();
28
+ const {
29
+ openMenu
30
+ } = useActionMenu();
31
+ const {
32
+ show
33
+ } = useUserProfile();
34
+ const {
35
+ users,
36
+ deleteUser,
37
+ upsertUser,
38
+ loading,
39
+ refresh,
40
+ next,
41
+ error
42
+ } = useUserList(sdk, {
43
+ queryCreator: () => channel.createOperatorListQuery({
44
+ limit: 20
45
+ })
46
+ });
47
+ useChannelHandler(sdk, handlerId, {
48
+ onUserBanned(eventChannel, user) {
49
+ if (isDifferentChannel(eventChannel, channel)) return;
50
+ deleteUser(user.userId);
51
+ },
52
+
53
+ onOperatorUpdated(eventChannel, updatedUsers) {
54
+ if (isDifferentChannel(eventChannel, channel)) return;
55
+ const operatorsAdded = users.length < updatedUsers.length;
56
+ if (operatorsAdded) updatedUsers.forEach(upsertUser);
57
+ }
58
+
59
+ }, 'open');
60
+
61
+ const _renderUser = useFreshCallback(props => {
62
+ if (renderUser) return renderUser(props);
63
+ const {
64
+ user
65
+ } = props;
66
+ return /*#__PURE__*/React.createElement(UserActionBar, {
67
+ muted: false,
68
+ uri: user.profileUrl,
69
+ name: (user.nickname || STRINGS.LABELS.USER_NO_NAME) + (user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : ''),
70
+ disabled: user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId),
71
+ onPressAvatar: () => show(user),
72
+ onPressActionMenu: ifThenOr(channel.isOperator((currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ?? UNKNOWN_USER_ID), () => {
73
+ openMenu({
74
+ title: user.nickname || STRINGS.LABELS.USER_NO_NAME,
75
+ menuItems: [{
76
+ title: STRINGS.LABELS.UNREGISTER_OPERATOR,
77
+ onPress: () => channel.removeOperators([user.userId]).then(() => deleteUser(user.userId))
78
+ }]
79
+ });
80
+ })
81
+ });
82
+ });
83
+
84
+ return /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.Provider, {
85
+ channel: channel
86
+ }, /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.Header, {
87
+ onPressHeaderLeft: onPressHeaderLeft,
88
+ onPressHeaderRight: onPressHeaderRight
89
+ }), /*#__PURE__*/React.createElement(StatusComposition, {
90
+ loading: loading,
91
+ LoadingComponent: /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.StatusLoading, null),
92
+ error: Boolean(error),
93
+ ErrorComponent: /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.StatusError, {
94
+ onPressRetry: refresh
95
+ })
96
+ }, /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.List, {
97
+ operators: users,
98
+ renderUser: _renderUser,
99
+ onLoadNext: next,
100
+ ListEmptyComponent: /*#__PURE__*/React.createElement(OpenChannelOperatorsModule.StatusEmpty, null)
101
+ })));
102
+ };
103
+ };
104
+
105
+ export default createOpenChannelOperatorsFragment;
106
+ //# sourceMappingURL=createOpenChannelOperatorsFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useChannelHandler","useUserList","useActionMenu","NOOP","ifThenOr","isDifferentChannel","useFreshCallback","useUniqHandlerId","StatusComposition","UserActionBar","UNKNOWN_USER_ID","createOpenChannelOperatorsModule","useLocalization","useSendbirdChat","useUserProfile","createOpenChannelOperatorsFragment","initModule","OpenChannelOperatorsModule","onPressHeaderLeft","onPressHeaderRight","channel","renderUser","handlerId","STRINGS","sdk","currentUser","openMenu","show","users","deleteUser","upsertUser","loading","refresh","next","error","queryCreator","createOperatorListQuery","limit","onUserBanned","eventChannel","user","userId","onOperatorUpdated","updatedUsers","operatorsAdded","length","forEach","_renderUser","props","profileUrl","nickname","LABELS","USER_NO_NAME","USER_BAR_ME_POSTFIX","isOperator","title","menuItems","UNREGISTER_OPERATOR","onPress","removeOperators","then","Boolean"],"sources":["createOpenChannelOperatorsFragment.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';\nimport { useActionMenu } from '@sendbird/uikit-react-native-foundation';\nimport { NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserActionBar from '../components/UserActionBar';\nimport { UNKNOWN_USER_ID } from '../constants';\nimport { createOpenChannelOperatorsModule } from '../domain/openChannelOperators';\nimport type { OpenChannelOperatorsFragment, OpenChannelOperatorsModule } from '../domain/openChannelOperators/types';\nimport { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';\n\nconst createOpenChannelOperatorsFragment = (\n initModule?: Partial<OpenChannelOperatorsModule>,\n): OpenChannelOperatorsFragment => {\n const OpenChannelOperatorsModule = createOpenChannelOperatorsModule(initModule);\n\n return ({ onPressHeaderLeft = NOOP, onPressHeaderRight = NOOP, channel, renderUser }) => {\n const handlerId = useUniqHandlerId('OpenChannelOperatorsFragment');\n\n const { STRINGS } = useLocalization();\n const { sdk, currentUser } = useSendbirdChat();\n const { openMenu } = useActionMenu();\n const { show } = useUserProfile();\n\n const { users, deleteUser, upsertUser, loading, refresh, next, error } = useUserList(sdk, {\n queryCreator: () => channel.createOperatorListQuery({ limit: 20 }),\n });\n\n useChannelHandler(\n sdk,\n handlerId,\n {\n onUserBanned(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel)) return;\n deleteUser(user.userId);\n },\n onOperatorUpdated(eventChannel, updatedUsers) {\n if (isDifferentChannel(eventChannel, channel)) return;\n const operatorsAdded = users.length < updatedUsers.length;\n if (operatorsAdded) updatedUsers.forEach(upsertUser);\n },\n },\n 'open',\n );\n\n const _renderUser: NonNullable<typeof renderUser> = useFreshCallback((props) => {\n if (renderUser) return renderUser(props);\n\n const { user } = props;\n return (\n <UserActionBar\n muted={false}\n uri={user.profileUrl}\n name={\n (user.nickname || STRINGS.LABELS.USER_NO_NAME) +\n (user.userId === currentUser?.userId ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : '')\n }\n disabled={user.userId === currentUser?.userId}\n onPressAvatar={() => show(user)}\n onPressActionMenu={ifThenOr(channel.isOperator(currentUser?.userId ?? UNKNOWN_USER_ID), () => {\n openMenu({\n title: user.nickname || STRINGS.LABELS.USER_NO_NAME,\n menuItems: [\n {\n title: STRINGS.LABELS.UNREGISTER_OPERATOR,\n onPress: () => channel.removeOperators([user.userId]).then(() => deleteUser(user.userId)),\n },\n ],\n });\n })}\n />\n );\n });\n\n return (\n <OpenChannelOperatorsModule.Provider channel={channel}>\n <OpenChannelOperatorsModule.Header\n onPressHeaderLeft={onPressHeaderLeft}\n onPressHeaderRight={onPressHeaderRight}\n />\n <StatusComposition\n loading={loading}\n LoadingComponent={<OpenChannelOperatorsModule.StatusLoading />}\n error={Boolean(error)}\n ErrorComponent={<OpenChannelOperatorsModule.StatusError onPressRetry={refresh} />}\n >\n <OpenChannelOperatorsModule.List\n operators={users}\n renderUser={_renderUser}\n onLoadNext={next}\n ListEmptyComponent={<OpenChannelOperatorsModule.StatusEmpty />}\n />\n </StatusComposition>\n </OpenChannelOperatorsModule.Provider>\n );\n };\n};\n\nexport default createOpenChannelOperatorsFragment;\n"],"mappings":"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"}
@@ -0,0 +1,140 @@
1
+ import React, { useRef } from 'react';
2
+ import { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';
3
+ import { useActionMenu } from '@sendbird/uikit-react-native-foundation';
4
+ import { ASYNC_NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';
5
+ import StatusComposition from '../components/StatusComposition';
6
+ import UserActionBar from '../components/UserActionBar';
7
+ import { UNKNOWN_USER_ID } from '../constants';
8
+ import createUserListModule from '../domain/userList/module/createUserListModule';
9
+ import { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';
10
+
11
+ const RETURN_EMPTY_STRING = () => '';
12
+
13
+ const createOpenChannelParticipantsFragment = initModule => {
14
+ const UserListModule = createUserListModule(initModule);
15
+ return _ref => {
16
+ let {
17
+ channel,
18
+ onPressHeaderLeft,
19
+ renderUser
20
+ } = _ref;
21
+ const handlerId = useUniqHandlerId('OpenChannelParticipantsFragment');
22
+ const refreshSchedule = useRef();
23
+ const {
24
+ STRINGS
25
+ } = useLocalization();
26
+ const {
27
+ sdk,
28
+ currentUser
29
+ } = useSendbirdChat();
30
+ const {
31
+ openMenu
32
+ } = useActionMenu();
33
+ const {
34
+ show
35
+ } = useUserProfile();
36
+ const {
37
+ users,
38
+ refresh,
39
+ loading,
40
+ next,
41
+ error,
42
+ upsertUser,
43
+ deleteUser
44
+ } = useUserList(sdk, {
45
+ queryCreator: () => channel.createParticipantListQuery({
46
+ limit: 20
47
+ })
48
+ });
49
+ useChannelHandler(sdk, handlerId, {
50
+ onUserExited(eventChannel, user) {
51
+ if (isDifferentChannel(eventChannel, channel)) return;
52
+ deleteUser(user.userId);
53
+ },
54
+
55
+ onUserBanned(eventChannel, user) {
56
+ if (isDifferentChannel(eventChannel, channel)) return;
57
+ deleteUser(user.userId);
58
+ },
59
+
60
+ onOperatorUpdated(eventChannel) {
61
+ if (isDifferentChannel(eventChannel, channel)) return;
62
+ if (refreshSchedule.current) clearTimeout(refreshSchedule.current);
63
+ refreshSchedule.current = setTimeout(() => refresh(), 500);
64
+ },
65
+
66
+ onUserMuted(eventChannel, user) {
67
+ if (isDifferentChannel(eventChannel, channel) || !eventChannel.isOpenChannel()) return; // @ts-ignore - SDK should migrate User to Participant
68
+
69
+ user.isMuted = true;
70
+ upsertUser(user);
71
+ },
72
+
73
+ onUserUnmuted(eventChannel, user) {
74
+ if (isDifferentChannel(eventChannel, channel) || !eventChannel.isOpenChannel()) return; // @ts-ignore - SDK should migrate User to Participant
75
+
76
+ user.isMuted = false;
77
+ upsertUser(user);
78
+ }
79
+
80
+ }, 'open');
81
+
82
+ const _renderUser = useFreshCallback((user, selectedUsers, setSelectedUsers) => {
83
+ if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);
84
+ const isUserMuted = user.isMuted;
85
+ const isUserOperator = channel.isOperator(user.userId);
86
+ const isCurrentUserOperator = channel.isOperator((currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ?? UNKNOWN_USER_ID);
87
+ return /*#__PURE__*/React.createElement(UserActionBar, {
88
+ muted: isUserMuted,
89
+ uri: user.profileUrl,
90
+ label: ifThenOr(isUserOperator, STRINGS.LABELS.USER_BAR_OPERATOR, ''),
91
+ name: (user.nickname || STRINGS.LABELS.USER_NO_NAME) + ifThenOr(user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId), STRINGS.LABELS.USER_BAR_ME_POSTFIX, ''),
92
+ disabled: user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId),
93
+ onPressActionMenu: ifThenOr(isCurrentUserOperator, () => {
94
+ const menuItems = [];
95
+ menuItems.push({
96
+ title: ifThenOr(isUserOperator, STRINGS.LABELS.UNREGISTER_OPERATOR, STRINGS.LABELS.REGISTER_AS_OPERATOR),
97
+ onPress: ifThenOr(isUserOperator, () => channel.removeOperators([user.userId]), () => channel.addOperators([user.userId]))
98
+ });
99
+ menuItems.push({
100
+ title: ifThenOr(isUserMuted, STRINGS.LABELS.UNMUTE, STRINGS.LABELS.MUTE),
101
+ onPress: ifThenOr(isUserMuted, () => channel.unmuteUser(user), () => channel.muteUser(user))
102
+ });
103
+ menuItems.push({
104
+ title: STRINGS.LABELS.BAN,
105
+ style: 'destructive',
106
+ onPress: () => channel.banUser(user)
107
+ });
108
+ openMenu({
109
+ title: user.nickname || STRINGS.LABELS.USER_NO_NAME,
110
+ menuItems
111
+ });
112
+ }),
113
+ onPressAvatar: () => show(user)
114
+ });
115
+ });
116
+
117
+ return /*#__PURE__*/React.createElement(UserListModule.Provider, {
118
+ headerRight: RETURN_EMPTY_STRING,
119
+ headerTitle: STRINGS.OPEN_CHANNEL_PARTICIPANTS.HEADER_TITLE
120
+ }, /*#__PURE__*/React.createElement(UserListModule.Header, {
121
+ onPressHeaderRight: ASYNC_NOOP,
122
+ onPressHeaderLeft: onPressHeaderLeft
123
+ }), /*#__PURE__*/React.createElement(StatusComposition, {
124
+ loading: loading,
125
+ LoadingComponent: /*#__PURE__*/React.createElement(UserListModule.StatusLoading, null),
126
+ error: Boolean(error),
127
+ ErrorComponent: /*#__PURE__*/React.createElement(UserListModule.StatusError, {
128
+ onPressRetry: refresh
129
+ })
130
+ }, /*#__PURE__*/React.createElement(UserListModule.List, {
131
+ users: users,
132
+ renderUser: _renderUser,
133
+ onLoadNext: next,
134
+ ListEmptyComponent: /*#__PURE__*/React.createElement(UserListModule.StatusEmpty, null)
135
+ })));
136
+ };
137
+ };
138
+
139
+ export default createOpenChannelParticipantsFragment;
140
+ //# sourceMappingURL=createOpenChannelParticipantsFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useRef","useChannelHandler","useUserList","useActionMenu","ASYNC_NOOP","ifThenOr","isDifferentChannel","useFreshCallback","useUniqHandlerId","StatusComposition","UserActionBar","UNKNOWN_USER_ID","createUserListModule","useLocalization","useSendbirdChat","useUserProfile","RETURN_EMPTY_STRING","createOpenChannelParticipantsFragment","initModule","UserListModule","channel","onPressHeaderLeft","renderUser","handlerId","refreshSchedule","STRINGS","sdk","currentUser","openMenu","show","users","refresh","loading","next","error","upsertUser","deleteUser","queryCreator","createParticipantListQuery","limit","onUserExited","eventChannel","user","userId","onUserBanned","onOperatorUpdated","current","clearTimeout","setTimeout","onUserMuted","isOpenChannel","isMuted","onUserUnmuted","_renderUser","selectedUsers","setSelectedUsers","isUserMuted","isUserOperator","isOperator","isCurrentUserOperator","profileUrl","LABELS","USER_BAR_OPERATOR","nickname","USER_NO_NAME","USER_BAR_ME_POSTFIX","menuItems","push","title","UNREGISTER_OPERATOR","REGISTER_AS_OPERATOR","onPress","removeOperators","addOperators","UNMUTE","MUTE","unmuteUser","muteUser","BAN","style","banUser","OPEN_CHANNEL_PARTICIPANTS","HEADER_TITLE","Boolean"],"sources":["createOpenChannelParticipantsFragment.tsx"],"sourcesContent":["import React, { useRef } from 'react';\n\nimport { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';\nimport type { ActionMenuItem } from '@sendbird/uikit-react-native-foundation';\nimport { useActionMenu } from '@sendbird/uikit-react-native-foundation';\nimport type { SendbirdParticipant } from '@sendbird/uikit-utils';\nimport { ASYNC_NOOP, ifThenOr, isDifferentChannel, useFreshCallback, useUniqHandlerId } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserActionBar from '../components/UserActionBar';\nimport { UNKNOWN_USER_ID } from '../constants';\nimport type { OpenChannelParticipantsFragment } from '../domain/openChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';\n\nconst RETURN_EMPTY_STRING = () => '';\nconst createOpenChannelParticipantsFragment = (\n initModule?: Partial<UserListModule<SendbirdParticipant>>,\n): OpenChannelParticipantsFragment<SendbirdParticipant> => {\n const UserListModule = createUserListModule<SendbirdParticipant>(initModule);\n\n return ({ channel, onPressHeaderLeft, renderUser }) => {\n const handlerId = useUniqHandlerId('OpenChannelParticipantsFragment');\n\n const refreshSchedule = useRef<NodeJS.Timeout>();\n const { STRINGS } = useLocalization();\n const { sdk, currentUser } = useSendbirdChat();\n const { openMenu } = useActionMenu();\n const { show } = useUserProfile();\n\n const { users, refresh, loading, next, error, upsertUser, deleteUser } = useUserList(sdk, {\n queryCreator: () => channel.createParticipantListQuery({ limit: 20 }),\n });\n\n useChannelHandler(\n sdk,\n handlerId,\n {\n onUserExited(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel)) return;\n deleteUser(user.userId);\n },\n onUserBanned(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel)) return;\n deleteUser(user.userId);\n },\n onOperatorUpdated(eventChannel) {\n if (isDifferentChannel(eventChannel, channel)) return;\n if (refreshSchedule.current) clearTimeout(refreshSchedule.current);\n refreshSchedule.current = setTimeout(() => refresh(), 500);\n },\n onUserMuted(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel) || !eventChannel.isOpenChannel()) return;\n // @ts-ignore - SDK should migrate User to Participant\n user.isMuted = true;\n upsertUser(user);\n },\n onUserUnmuted(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel) || !eventChannel.isOpenChannel()) return;\n // @ts-ignore - SDK should migrate User to Participant\n user.isMuted = false;\n upsertUser(user);\n },\n },\n 'open',\n );\n\n const _renderUser: NonNullable<typeof renderUser> = useFreshCallback((user, selectedUsers, setSelectedUsers) => {\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n const isUserMuted = user.isMuted;\n const isUserOperator = channel.isOperator(user.userId);\n const isCurrentUserOperator = channel.isOperator(currentUser?.userId ?? UNKNOWN_USER_ID);\n\n return (\n <UserActionBar\n muted={isUserMuted}\n uri={user.profileUrl}\n label={ifThenOr(isUserOperator, STRINGS.LABELS.USER_BAR_OPERATOR, '')}\n name={\n (user.nickname || STRINGS.LABELS.USER_NO_NAME) +\n ifThenOr(user.userId === currentUser?.userId, STRINGS.LABELS.USER_BAR_ME_POSTFIX, '')\n }\n disabled={user.userId === currentUser?.userId}\n onPressActionMenu={ifThenOr(isCurrentUserOperator, () => {\n const menuItems: ActionMenuItem['menuItems'] = [];\n\n menuItems.push({\n title: ifThenOr(isUserOperator, STRINGS.LABELS.UNREGISTER_OPERATOR, STRINGS.LABELS.REGISTER_AS_OPERATOR),\n onPress: ifThenOr(\n isUserOperator,\n () => channel.removeOperators([user.userId]),\n () => channel.addOperators([user.userId]),\n ),\n });\n\n menuItems.push({\n title: ifThenOr(isUserMuted, STRINGS.LABELS.UNMUTE, STRINGS.LABELS.MUTE),\n onPress: ifThenOr(\n isUserMuted,\n () => channel.unmuteUser(user),\n () => channel.muteUser(user),\n ),\n });\n\n menuItems.push({\n title: STRINGS.LABELS.BAN,\n style: 'destructive',\n onPress: () => channel.banUser(user),\n });\n\n openMenu({ title: user.nickname || STRINGS.LABELS.USER_NO_NAME, menuItems });\n })}\n onPressAvatar={() => show(user)}\n />\n );\n });\n\n return (\n <UserListModule.Provider\n headerRight={RETURN_EMPTY_STRING}\n headerTitle={STRINGS.OPEN_CHANNEL_PARTICIPANTS.HEADER_TITLE}\n >\n <UserListModule.Header onPressHeaderRight={ASYNC_NOOP} onPressHeaderLeft={onPressHeaderLeft} />\n <StatusComposition\n loading={loading}\n LoadingComponent={<UserListModule.StatusLoading />}\n error={Boolean(error)}\n ErrorComponent={<UserListModule.StatusError onPressRetry={refresh} />}\n >\n <UserListModule.List\n users={users as SendbirdParticipant[]}\n renderUser={_renderUser}\n onLoadNext={next}\n ListEmptyComponent={<UserListModule.StatusEmpty />}\n />\n </StatusComposition>\n </UserListModule.Provider>\n );\n };\n};\n\nexport default createOpenChannelParticipantsFragment;\n"],"mappings":"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"}
@@ -0,0 +1,96 @@
1
+ import React, { useCallback } from 'react';
2
+ import { TouchableOpacity } from 'react-native';
3
+ import { useUserList } from '@sendbird/uikit-chat-hooks';
4
+ import StatusComposition from '../components/StatusComposition';
5
+ import UserSelectableBar from '../components/UserSelectableBar';
6
+ import createUserListModule from '../domain/userList/module/createUserListModule';
7
+ import { useLocalization, useSendbirdChat } from '../hooks/useContext';
8
+
9
+ const createOpenChannelRegisterOperatorFragment = initModule => {
10
+ const UserListModule = createUserListModule(initModule);
11
+ return _ref => {
12
+ let {
13
+ channel,
14
+ onPressHeaderLeft,
15
+ sortComparator,
16
+ renderUser,
17
+ onPressHeaderRight
18
+ } = _ref;
19
+ const {
20
+ sdk,
21
+ currentUser
22
+ } = useSendbirdChat();
23
+ const {
24
+ STRINGS
25
+ } = useLocalization();
26
+ const {
27
+ users,
28
+ refreshing,
29
+ refresh,
30
+ next,
31
+ error,
32
+ loading
33
+ } = useUserList(sdk, {
34
+ queryCreator: () => {
35
+ return channel.createParticipantListQuery({
36
+ limit: 20
37
+ });
38
+ },
39
+ sortComparator
40
+ });
41
+
42
+ const _renderUser = useCallback((user, selectedUsers, setSelectedUsers) => {
43
+ if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);
44
+ const userIdx = selectedUsers.findIndex(u => u.userId === user.userId);
45
+ const isSelected = userIdx > -1;
46
+ const isOperator = channel.isOperator(user);
47
+ return /*#__PURE__*/React.createElement(TouchableOpacity, {
48
+ activeOpacity: 0.7,
49
+ disabled: isOperator,
50
+ onPress: () => {
51
+ setSelectedUsers(_ref2 => {
52
+ let [...draft] = _ref2;
53
+ if (isSelected) draft.splice(userIdx, 1);else draft.push(user);
54
+ return draft;
55
+ });
56
+ }
57
+ }, /*#__PURE__*/React.createElement(UserSelectableBar, {
58
+ uri: user.profileUrl,
59
+ name: (user.nickname || STRINGS.LABELS.USER_NO_NAME) + (user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : ''),
60
+ selected: isOperator || isSelected,
61
+ disabled: isOperator
62
+ }));
63
+ }, [channel, renderUser]);
64
+
65
+ return /*#__PURE__*/React.createElement(UserListModule.Provider, {
66
+ headerRight: selectedUsers => STRINGS.OPEN_CHANNEL_REGISTER_OPERATOR.HEADER_RIGHT({
67
+ selectedUsers
68
+ }),
69
+ headerTitle: STRINGS.OPEN_CHANNEL_REGISTER_OPERATOR.HEADER_TITLE
70
+ }, /*#__PURE__*/React.createElement(UserListModule.Header, {
71
+ shouldActivateHeaderRight: selectedUsers => selectedUsers.length > 0,
72
+ onPressHeaderLeft: onPressHeaderLeft,
73
+ onPressHeaderRight: async users => {
74
+ await channel.addOperators(users.map(it => it.userId));
75
+ onPressHeaderRight(channel);
76
+ }
77
+ }), /*#__PURE__*/React.createElement(StatusComposition, {
78
+ loading: loading,
79
+ error: Boolean(error),
80
+ LoadingComponent: /*#__PURE__*/React.createElement(UserListModule.StatusLoading, null),
81
+ ErrorComponent: /*#__PURE__*/React.createElement(UserListModule.StatusError, {
82
+ onPressRetry: () => refresh()
83
+ })
84
+ }, /*#__PURE__*/React.createElement(UserListModule.List, {
85
+ onLoadNext: next,
86
+ users: users,
87
+ renderUser: _renderUser,
88
+ onRefresh: refresh,
89
+ refreshing: refreshing,
90
+ ListEmptyComponent: /*#__PURE__*/React.createElement(UserListModule.StatusEmpty, null)
91
+ })));
92
+ };
93
+ };
94
+
95
+ export default createOpenChannelRegisterOperatorFragment;
96
+ //# sourceMappingURL=createOpenChannelRegisterOperatorFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useCallback","TouchableOpacity","useUserList","StatusComposition","UserSelectableBar","createUserListModule","useLocalization","useSendbirdChat","createOpenChannelRegisterOperatorFragment","initModule","UserListModule","channel","onPressHeaderLeft","sortComparator","renderUser","onPressHeaderRight","sdk","currentUser","STRINGS","users","refreshing","refresh","next","error","loading","queryCreator","createParticipantListQuery","limit","_renderUser","user","selectedUsers","setSelectedUsers","userIdx","findIndex","u","userId","isSelected","isOperator","draft","splice","push","profileUrl","nickname","LABELS","USER_NO_NAME","USER_BAR_ME_POSTFIX","OPEN_CHANNEL_REGISTER_OPERATOR","HEADER_RIGHT","HEADER_TITLE","length","addOperators","map","it","Boolean"],"sources":["createOpenChannelRegisterOperatorFragment.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { TouchableOpacity } from 'react-native';\n\nimport { CustomQueryInterface, useUserList } from '@sendbird/uikit-chat-hooks';\nimport type { SendbirdParticipant } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserSelectableBar from '../components/UserSelectableBar';\nimport type { OpenChannelRegisterOperatorFragment } from '../domain/openChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useSendbirdChat } from '../hooks/useContext';\n\nconst createOpenChannelRegisterOperatorFragment = (\n initModule?: Partial<UserListModule<SendbirdParticipant>>,\n): OpenChannelRegisterOperatorFragment<SendbirdParticipant> => {\n const UserListModule = createUserListModule<SendbirdParticipant>(initModule);\n\n return ({ channel, onPressHeaderLeft, sortComparator, renderUser, onPressHeaderRight }) => {\n const { sdk, currentUser } = useSendbirdChat();\n const { STRINGS } = useLocalization();\n const { users, refreshing, refresh, next, error, loading } = useUserList(sdk, {\n queryCreator: () => {\n return channel.createParticipantListQuery({\n limit: 20,\n }) as unknown as CustomQueryInterface<SendbirdParticipant>;\n },\n sortComparator,\n });\n\n const _renderUser: NonNullable<typeof renderUser> = useCallback(\n (user, selectedUsers, setSelectedUsers) => {\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n const userIdx = selectedUsers.findIndex((u) => u.userId === user.userId);\n const isSelected = userIdx > -1;\n const isOperator = channel.isOperator(user);\n\n return (\n <TouchableOpacity\n activeOpacity={0.7}\n disabled={isOperator}\n onPress={() => {\n setSelectedUsers(([...draft]) => {\n if (isSelected) draft.splice(userIdx, 1);\n else draft.push(user);\n return draft;\n });\n }}\n >\n <UserSelectableBar\n uri={user.profileUrl}\n name={\n (user.nickname || STRINGS.LABELS.USER_NO_NAME) +\n (user.userId === currentUser?.userId ? STRINGS.LABELS.USER_BAR_ME_POSTFIX : '')\n }\n selected={isOperator || isSelected}\n disabled={isOperator}\n />\n </TouchableOpacity>\n );\n },\n [channel, renderUser],\n );\n\n return (\n <UserListModule.Provider\n headerRight={(selectedUsers) => STRINGS.OPEN_CHANNEL_REGISTER_OPERATOR.HEADER_RIGHT({ selectedUsers })}\n headerTitle={STRINGS.OPEN_CHANNEL_REGISTER_OPERATOR.HEADER_TITLE}\n >\n <UserListModule.Header\n shouldActivateHeaderRight={(selectedUsers) => selectedUsers.length > 0}\n onPressHeaderLeft={onPressHeaderLeft}\n onPressHeaderRight={async (users) => {\n await channel.addOperators(users.map((it) => it.userId));\n onPressHeaderRight(channel);\n }}\n />\n <StatusComposition\n loading={loading}\n error={Boolean(error)}\n LoadingComponent={<UserListModule.StatusLoading />}\n ErrorComponent={<UserListModule.StatusError onPressRetry={() => refresh()} />}\n >\n <UserListModule.List\n onLoadNext={next}\n users={users}\n renderUser={_renderUser}\n onRefresh={refresh}\n refreshing={refreshing}\n ListEmptyComponent={<UserListModule.StatusEmpty />}\n />\n </StatusComposition>\n </UserListModule.Provider>\n );\n };\n};\n\nexport default createOpenChannelRegisterOperatorFragment;\n"],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ import React from 'react';
2
+ import { ScrollView } from 'react-native';
3
+ import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
+ import { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
5
+ import { NOOP } from '@sendbird/uikit-utils';
6
+ import { createOpenChannelSettingsModule } from '../domain/openChannelSettings';
7
+
8
+ const createOpenChannelSettingsFragment = initModule => {
9
+ const OpenChannelSettingsModule = createOpenChannelSettingsModule(initModule);
10
+ return _ref => {
11
+ let {
12
+ onPressHeaderLeft = NOOP,
13
+ channel,
14
+ onPressMenuModeration,
15
+ onPressMenuParticipants,
16
+ onPressMenuDeleteChannel,
17
+ onNavigateToOpenChannel,
18
+ menuItemsCreator
19
+ } = _ref;
20
+ const {
21
+ colors
22
+ } = useUIKitTheme();
23
+ const {
24
+ left,
25
+ right
26
+ } = useSafeAreaInsets();
27
+ return /*#__PURE__*/React.createElement(OpenChannelSettingsModule.Provider, {
28
+ channel: channel,
29
+ onNavigateToOpenChannel: onNavigateToOpenChannel
30
+ }, /*#__PURE__*/React.createElement(OpenChannelSettingsModule.Header, {
31
+ onPressHeaderLeft: onPressHeaderLeft
32
+ }), /*#__PURE__*/React.createElement(ScrollView, {
33
+ style: {
34
+ backgroundColor: colors.background
35
+ },
36
+ contentContainerStyle: {
37
+ paddingLeft: left + styles.viewContainer.paddingHorizontal,
38
+ paddingRight: right + styles.viewContainer.paddingHorizontal
39
+ }
40
+ }, /*#__PURE__*/React.createElement(OpenChannelSettingsModule.Info, null), /*#__PURE__*/React.createElement(OpenChannelSettingsModule.Menu, {
41
+ menuItemsCreator: menuItemsCreator,
42
+ onPressMenuModeration: onPressMenuModeration,
43
+ onPressMenuParticipants: onPressMenuParticipants,
44
+ onPressMenuDeleteChannel: onPressMenuDeleteChannel
45
+ })));
46
+ };
47
+ };
48
+
49
+ const styles = createStyleSheet({
50
+ viewContainer: {
51
+ paddingHorizontal: 16
52
+ }
53
+ });
54
+ export default createOpenChannelSettingsFragment;
55
+ //# sourceMappingURL=createOpenChannelSettingsFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","ScrollView","useSafeAreaInsets","createStyleSheet","useUIKitTheme","NOOP","createOpenChannelSettingsModule","createOpenChannelSettingsFragment","initModule","OpenChannelSettingsModule","onPressHeaderLeft","channel","onPressMenuModeration","onPressMenuParticipants","onPressMenuDeleteChannel","onNavigateToOpenChannel","menuItemsCreator","colors","left","right","backgroundColor","background","paddingLeft","styles","viewContainer","paddingHorizontal","paddingRight"],"sources":["createOpenChannelSettingsFragment.tsx"],"sourcesContent":["import React from 'react';\nimport { ScrollView } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\n\nimport { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';\nimport { NOOP } from '@sendbird/uikit-utils';\n\nimport { createOpenChannelSettingsModule } from '../domain/openChannelSettings';\nimport type { OpenChannelSettingsFragment, OpenChannelSettingsModule } from '../domain/openChannelSettings/types';\n\nconst createOpenChannelSettingsFragment = (\n initModule?: Partial<OpenChannelSettingsModule>,\n): OpenChannelSettingsFragment => {\n const OpenChannelSettingsModule = createOpenChannelSettingsModule(initModule);\n\n return ({\n onPressHeaderLeft = NOOP,\n channel,\n onPressMenuModeration,\n onPressMenuParticipants,\n onPressMenuDeleteChannel,\n onNavigateToOpenChannel,\n menuItemsCreator,\n }) => {\n const { colors } = useUIKitTheme();\n const { left, right } = useSafeAreaInsets();\n\n return (\n <OpenChannelSettingsModule.Provider channel={channel} onNavigateToOpenChannel={onNavigateToOpenChannel}>\n <OpenChannelSettingsModule.Header onPressHeaderLeft={onPressHeaderLeft} />\n <ScrollView\n style={{ backgroundColor: colors.background }}\n contentContainerStyle={{\n paddingLeft: left + styles.viewContainer.paddingHorizontal,\n paddingRight: right + styles.viewContainer.paddingHorizontal,\n }}\n >\n <OpenChannelSettingsModule.Info />\n <OpenChannelSettingsModule.Menu\n menuItemsCreator={menuItemsCreator}\n onPressMenuModeration={onPressMenuModeration}\n onPressMenuParticipants={onPressMenuParticipants}\n onPressMenuDeleteChannel={onPressMenuDeleteChannel}\n />\n </ScrollView>\n </OpenChannelSettingsModule.Provider>\n );\n };\n};\n\nconst styles = createStyleSheet({\n viewContainer: {\n paddingHorizontal: 16,\n },\n});\n\nexport default createOpenChannelSettingsFragment;\n"],"mappings":"AAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,SAASC,UAAT,QAA2B,cAA3B;AACA,SAASC,iBAAT,QAAkC,gCAAlC;AAEA,SAASC,gBAAT,EAA2BC,aAA3B,QAAgD,yCAAhD;AACA,SAASC,IAAT,QAAqB,uBAArB;AAEA,SAASC,+BAAT,QAAgD,+BAAhD;;AAGA,MAAMC,iCAAiC,GACrCC,UADwC,IAER;EAChC,MAAMC,yBAAyB,GAAGH,+BAA+B,CAACE,UAAD,CAAjE;EAEA,OAAO,QAQD;IAAA,IARE;MACNE,iBAAiB,GAAGL,IADd;MAENM,OAFM;MAGNC,qBAHM;MAINC,uBAJM;MAKNC,wBALM;MAMNC,uBANM;MAONC;IAPM,CAQF;IACJ,MAAM;MAAEC;IAAF,IAAab,aAAa,EAAhC;IACA,MAAM;MAAEc,IAAF;MAAQC;IAAR,IAAkBjB,iBAAiB,EAAzC;IAEA,oBACE,oBAAC,yBAAD,CAA2B,QAA3B;MAAoC,OAAO,EAAES,OAA7C;MAAsD,uBAAuB,EAAEI;IAA/E,gBACE,oBAAC,yBAAD,CAA2B,MAA3B;MAAkC,iBAAiB,EAAEL;IAArD,EADF,eAEE,oBAAC,UAAD;MACE,KAAK,EAAE;QAAEU,eAAe,EAAEH,MAAM,CAACI;MAA1B,CADT;MAEE,qBAAqB,EAAE;QACrBC,WAAW,EAAEJ,IAAI,GAAGK,MAAM,CAACC,aAAP,CAAqBC,iBADpB;QAErBC,YAAY,EAAEP,KAAK,GAAGI,MAAM,CAACC,aAAP,CAAqBC;MAFtB;IAFzB,gBAOE,oBAAC,yBAAD,CAA2B,IAA3B,OAPF,eAQE,oBAAC,yBAAD,CAA2B,IAA3B;MACE,gBAAgB,EAAET,gBADpB;MAEE,qBAAqB,EAAEJ,qBAFzB;MAGE,uBAAuB,EAAEC,uBAH3B;MAIE,wBAAwB,EAAEC;IAJ5B,EARF,CAFF,CADF;EAoBD,CAhCD;AAiCD,CAtCD;;AAwCA,MAAMS,MAAM,GAAGpB,gBAAgB,CAAC;EAC9BqB,aAAa,EAAE;IACbC,iBAAiB,EAAE;EADN;AADe,CAAD,CAA/B;AAMA,eAAelB,iCAAf"}
@@ -2,10 +2,16 @@ import { useEffect, useState } from 'react';
2
2
  import { Keyboard, LayoutAnimation, Platform } from 'react-native';
3
3
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
4
4
  import { NOOP } from '@sendbird/uikit-utils';
5
+ let isLayoutAnimationConfigured = false;
5
6
 
6
7
  const configureNextLayoutAnimation = event => {
7
- const config = LayoutAnimation.create(event.duration, event.easing);
8
- LayoutAnimation.configureNext(config);
8
+ if (isLayoutAnimationConfigured) return;
9
+ const config = LayoutAnimation.create(event.duration, event.easing, LayoutAnimation.Properties.scaleY);
10
+ isLayoutAnimationConfigured = true;
11
+
12
+ const onEnd = () => isLayoutAnimationConfigured = false;
13
+
14
+ LayoutAnimation.configureNext(config, onEnd, onEnd);
9
15
  };
10
16
 
11
17
  const {
@@ -48,16 +54,13 @@ const useKeyboardStatus = () => {
48
54
  height,
49
55
  bottomSpace
50
56
  });
51
- }), Keyboard.addListener(hideEvent, event => {
57
+ }), Keyboard.addListener(hideEvent, () => {
52
58
  const height = 0;
53
59
  const bottomSpace = Platform.select({
54
60
  default: height
55
- });
56
- const nextLayoutAnimation = Platform.select({
57
- ios: configureNextLayoutAnimation,
58
- default: NOOP
59
- });
60
- nextLayoutAnimation(event);
61
+ }); // const nextLayoutAnimation = Platform.select({ ios: configureNextLayoutAnimation, default: NOOP });
62
+ // nextLayoutAnimation(event);
63
+
61
64
  setKeyboardStatus({
62
65
  visible: false,
63
66
  height,