@sendbird/uikit-react-native 2.0.2 → 2.1.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 (399) hide show
  1. package/lib/commonjs/components/ChannelCover.js +22 -1
  2. package/lib/commonjs/components/ChannelCover.js.map +1 -1
  3. package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js +1 -1
  4. package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
  5. package/lib/commonjs/components/MessageRenderer/index.js +1 -1
  6. package/lib/commonjs/components/MessageRenderer/index.js.map +1 -1
  7. package/lib/commonjs/components/TypedPlaceholder.js +2 -2
  8. package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
  9. package/lib/commonjs/containers/GroupChannelPreviewContainer.js +4 -18
  10. package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
  11. package/lib/commonjs/containers/SendbirdUIKitContainer.js +8 -7
  12. package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
  13. package/lib/commonjs/contexts/SendbirdChatCtx.js +4 -2
  14. package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -1
  15. package/lib/commonjs/contexts/{ProfileCardCtx.js → UserProfileCtx.js} +16 -19
  16. package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -0
  17. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +3 -1
  18. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  19. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +4 -2
  20. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  21. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +15 -10
  22. package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  23. package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
  24. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +39 -0
  25. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
  26. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +53 -0
  27. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
  28. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +34 -0
  29. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
  30. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +38 -0
  31. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
  32. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +34 -0
  33. package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
  34. package/lib/commonjs/domain/groupChannelBannedUsers/index.js +62 -0
  35. package/lib/commonjs/domain/groupChannelBannedUsers/index.js.map +1 -0
  36. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +45 -0
  37. package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
  38. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js +45 -0
  39. package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
  40. package/lib/commonjs/domain/groupChannelBannedUsers/types.js +6 -0
  41. package/lib/commonjs/domain/groupChannelBannedUsers/types.js.map +1 -0
  42. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js +32 -30
  43. package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  44. package/lib/commonjs/domain/groupChannelList/types.js.map +1 -1
  45. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +39 -0
  46. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
  47. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +103 -0
  48. package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
  49. package/lib/commonjs/domain/groupChannelModeration/index.js +46 -0
  50. package/lib/commonjs/domain/groupChannelModeration/index.js.map +1 -0
  51. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +33 -0
  52. package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
  53. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js +46 -0
  54. package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
  55. package/lib/commonjs/domain/groupChannelModeration/types.js +6 -0
  56. package/lib/commonjs/domain/groupChannelModeration/types.js.map +1 -0
  57. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +39 -0
  58. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
  59. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +51 -0
  60. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
  61. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +34 -0
  62. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
  63. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +38 -0
  64. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
  65. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +34 -0
  66. package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
  67. package/lib/commonjs/domain/groupChannelMutedMembers/index.js +70 -0
  68. package/lib/commonjs/domain/groupChannelMutedMembers/index.js.map +1 -0
  69. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +45 -0
  70. package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
  71. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js +45 -0
  72. package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
  73. package/lib/commonjs/domain/groupChannelMutedMembers/types.js +6 -0
  74. package/lib/commonjs/domain/groupChannelMutedMembers/types.js.map +1 -0
  75. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +44 -0
  76. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
  77. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +51 -0
  78. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
  79. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +34 -0
  80. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
  81. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +38 -0
  82. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
  83. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +34 -0
  84. package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
  85. package/lib/commonjs/domain/groupChannelOperators/index.js +70 -0
  86. package/lib/commonjs/domain/groupChannelOperators/index.js.map +1 -0
  87. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +45 -0
  88. package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
  89. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js +45 -0
  90. package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
  91. package/lib/commonjs/domain/groupChannelOperators/types.js +6 -0
  92. package/lib/commonjs/domain/groupChannelOperators/types.js.map +1 -0
  93. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -8
  94. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  95. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +11 -0
  96. package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  97. package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
  98. package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
  99. package/lib/commonjs/domain/userList/component/UserListStatusError.js +2 -2
  100. package/lib/commonjs/domain/userList/component/UserListStatusError.js.map +1 -1
  101. package/lib/commonjs/domain/userList/types.js.map +1 -1
  102. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js +101 -0
  103. package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
  104. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +9 -25
  105. package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
  106. package/lib/commonjs/fragments/createGroupChannelFragment.js +4 -5
  107. package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
  108. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js +21 -37
  109. package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
  110. package/lib/commonjs/fragments/createGroupChannelListFragment.js +2 -9
  111. package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
  112. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +93 -49
  113. package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
  114. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js +68 -0
  115. package/lib/commonjs/fragments/createGroupChannelModerationFragment.js.map +1 -0
  116. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js +116 -0
  117. package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
  118. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js +129 -0
  119. package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
  120. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js +114 -0
  121. package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
  122. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +2 -0
  123. package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  124. package/lib/commonjs/hooks/useConnection.js +4 -0
  125. package/lib/commonjs/hooks/useConnection.js.map +1 -1
  126. package/lib/commonjs/hooks/useContext.js +7 -7
  127. package/lib/commonjs/hooks/useContext.js.map +1 -1
  128. package/lib/commonjs/index.js +67 -22
  129. package/lib/commonjs/index.js.map +1 -1
  130. package/lib/commonjs/localization/StringSet.type.js +54 -11
  131. package/lib/commonjs/localization/StringSet.type.js.map +1 -1
  132. package/lib/commonjs/version.js +1 -1
  133. package/lib/commonjs/version.js.map +1 -1
  134. package/lib/module/components/ChannelCover.js +22 -2
  135. package/lib/module/components/ChannelCover.js.map +1 -1
  136. package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js +2 -2
  137. package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
  138. package/lib/module/components/MessageRenderer/index.js +1 -1
  139. package/lib/module/components/MessageRenderer/index.js.map +1 -1
  140. package/lib/module/components/TypedPlaceholder.js +2 -2
  141. package/lib/module/components/TypedPlaceholder.js.map +1 -1
  142. package/lib/module/containers/GroupChannelPreviewContainer.js +4 -18
  143. package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
  144. package/lib/module/containers/SendbirdUIKitContainer.js +7 -6
  145. package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
  146. package/lib/module/contexts/SendbirdChatCtx.js +4 -2
  147. package/lib/module/contexts/SendbirdChatCtx.js.map +1 -1
  148. package/lib/module/contexts/{ProfileCardCtx.js → UserProfileCtx.js} +14 -17
  149. package/lib/module/contexts/UserProfileCtx.js.map +1 -0
  150. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +3 -1
  151. package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
  152. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +4 -2
  153. package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
  154. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +16 -11
  155. package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
  156. package/lib/module/domain/groupChannel/types.js.map +1 -1
  157. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +25 -0
  158. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
  159. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +40 -0
  160. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
  161. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +21 -0
  162. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
  163. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +25 -0
  164. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
  165. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +21 -0
  166. package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
  167. package/lib/module/domain/groupChannelBannedUsers/index.js +7 -0
  168. package/lib/module/domain/groupChannelBannedUsers/index.js.map +1 -0
  169. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +30 -0
  170. package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
  171. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js +25 -0
  172. package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
  173. package/lib/module/domain/groupChannelBannedUsers/types.js +2 -0
  174. package/lib/module/domain/groupChannelBannedUsers/types.js.map +1 -0
  175. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js +34 -33
  176. package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
  177. package/lib/module/domain/groupChannelList/types.js.map +1 -1
  178. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +25 -0
  179. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
  180. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +87 -0
  181. package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
  182. package/lib/module/domain/groupChannelModeration/index.js +5 -0
  183. package/lib/module/domain/groupChannelModeration/index.js.map +1 -0
  184. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +21 -0
  185. package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
  186. package/lib/module/domain/groupChannelModeration/module/moduleContext.js +26 -0
  187. package/lib/module/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
  188. package/lib/module/domain/groupChannelModeration/types.js +2 -0
  189. package/lib/module/domain/groupChannelModeration/types.js.map +1 -0
  190. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +25 -0
  191. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
  192. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +38 -0
  193. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
  194. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +21 -0
  195. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
  196. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +25 -0
  197. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
  198. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +21 -0
  199. package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
  200. package/lib/module/domain/groupChannelMutedMembers/index.js +8 -0
  201. package/lib/module/domain/groupChannelMutedMembers/index.js.map +1 -0
  202. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +30 -0
  203. package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
  204. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js +25 -0
  205. package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
  206. package/lib/module/domain/groupChannelMutedMembers/types.js +2 -0
  207. package/lib/module/domain/groupChannelMutedMembers/types.js.map +1 -0
  208. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +30 -0
  209. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
  210. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +38 -0
  211. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
  212. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +21 -0
  213. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
  214. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +25 -0
  215. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
  216. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +21 -0
  217. package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
  218. package/lib/module/domain/groupChannelOperators/index.js +8 -0
  219. package/lib/module/domain/groupChannelOperators/index.js.map +1 -0
  220. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +30 -0
  221. package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
  222. package/lib/module/domain/groupChannelOperators/module/moduleContext.js +25 -0
  223. package/lib/module/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
  224. package/lib/module/domain/groupChannelOperators/types.js +2 -0
  225. package/lib/module/domain/groupChannelOperators/types.js.map +1 -0
  226. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +2 -8
  227. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
  228. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +11 -0
  229. package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
  230. package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
  231. package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
  232. package/lib/module/domain/userList/component/UserListStatusError.js +2 -2
  233. package/lib/module/domain/userList/component/UserListStatusError.js.map +1 -1
  234. package/lib/module/domain/userList/types.js.map +1 -1
  235. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js +84 -0
  236. package/lib/module/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
  237. package/lib/module/fragments/createGroupChannelCreateFragment.js +10 -26
  238. package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
  239. package/lib/module/fragments/createGroupChannelFragment.js +4 -5
  240. package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
  241. package/lib/module/fragments/createGroupChannelInviteFragment.js +22 -37
  242. package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
  243. package/lib/module/fragments/createGroupChannelListFragment.js +3 -9
  244. package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
  245. package/lib/module/fragments/createGroupChannelMembersFragment.js +92 -53
  246. package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
  247. package/lib/module/fragments/createGroupChannelModerationFragment.js +53 -0
  248. package/lib/module/fragments/createGroupChannelModerationFragment.js.map +1 -0
  249. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js +98 -0
  250. package/lib/module/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
  251. package/lib/module/fragments/createGroupChannelOperatorsFragment.js +111 -0
  252. package/lib/module/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
  253. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js +94 -0
  254. package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
  255. package/lib/module/fragments/createGroupChannelSettingsFragment.js +2 -0
  256. package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
  257. package/lib/module/hooks/useConnection.js +4 -0
  258. package/lib/module/hooks/useConnection.js.map +1 -1
  259. package/lib/module/hooks/useContext.js +4 -4
  260. package/lib/module/hooks/useContext.js.map +1 -1
  261. package/lib/module/index.js +7 -2
  262. package/lib/module/index.js.map +1 -1
  263. package/lib/module/localization/StringSet.type.js +54 -11
  264. package/lib/module/localization/StringSet.type.js.map +1 -1
  265. package/lib/module/version.js +1 -1
  266. package/lib/module/version.js.map +1 -1
  267. package/lib/typescript/src/components/ChannelCover.d.ts +1 -1
  268. package/lib/typescript/src/components/TypedPlaceholder.d.ts +1 -1
  269. package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +7 -9
  270. package/lib/typescript/src/contexts/SendbirdChatCtx.d.ts +8 -4
  271. package/lib/typescript/src/contexts/{ProfileCardCtx.d.ts → UserProfileCtx.d.ts} +3 -3
  272. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +2 -1
  273. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +3 -1
  274. package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +1 -1
  275. package/lib/typescript/src/domain/groupChannel/types.d.ts +1 -1
  276. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.d.ts +3 -0
  277. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.d.ts +3 -0
  278. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.d.ts +2 -0
  279. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.d.ts +3 -0
  280. package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.d.ts +2 -0
  281. package/lib/typescript/src/domain/groupChannelBannedUsers/index.d.ts +6 -0
  282. package/lib/typescript/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.d.ts +3 -0
  283. package/lib/typescript/src/domain/groupChannelBannedUsers/module/moduleContext.d.ts +3 -0
  284. package/lib/typescript/src/domain/groupChannelBannedUsers/types.d.ts +47 -0
  285. package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListTypeSelector.d.ts +1 -1
  286. package/lib/typescript/src/domain/groupChannelList/types.d.ts +1 -9
  287. package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.d.ts +3 -0
  288. package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.d.ts +3 -0
  289. package/lib/typescript/src/domain/groupChannelModeration/index.d.ts +4 -0
  290. package/lib/typescript/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.d.ts +3 -0
  291. package/lib/typescript/src/domain/groupChannelModeration/module/moduleContext.d.ts +3 -0
  292. package/lib/typescript/src/domain/groupChannelModeration/types.d.ts +43 -0
  293. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.d.ts +3 -0
  294. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.d.ts +3 -0
  295. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.d.ts +2 -0
  296. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.d.ts +3 -0
  297. package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.d.ts +2 -0
  298. package/lib/typescript/src/domain/groupChannelMutedMembers/index.d.ts +7 -0
  299. package/lib/typescript/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.d.ts +3 -0
  300. package/lib/typescript/src/domain/groupChannelMutedMembers/module/moduleContext.d.ts +3 -0
  301. package/lib/typescript/src/domain/groupChannelMutedMembers/types.d.ts +47 -0
  302. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.d.ts +3 -0
  303. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.d.ts +3 -0
  304. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.d.ts +2 -0
  305. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.d.ts +3 -0
  306. package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.d.ts +2 -0
  307. package/lib/typescript/src/domain/groupChannelOperators/index.d.ts +7 -0
  308. package/lib/typescript/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.d.ts +3 -0
  309. package/lib/typescript/src/domain/groupChannelOperators/module/moduleContext.d.ts +3 -0
  310. package/lib/typescript/src/domain/groupChannelOperators/types.d.ts +49 -0
  311. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.d.ts +1 -1
  312. package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -1
  313. package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +2 -0
  314. package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +18 -12
  315. package/lib/typescript/src/domain/userList/component/UserListStatusError.d.ts +2 -2
  316. package/lib/typescript/src/domain/userList/types.d.ts +4 -3
  317. package/lib/typescript/src/fragments/createGroupChannelBannedUsersFragment.d.ts +3 -0
  318. package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +2 -1
  319. package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +2 -1
  320. package/lib/typescript/src/fragments/createGroupChannelModerationFragment.d.ts +3 -0
  321. package/lib/typescript/src/fragments/createGroupChannelMutedMembersFragment.d.ts +3 -0
  322. package/lib/typescript/src/fragments/createGroupChannelOperatorsFragment.d.ts +3 -0
  323. package/lib/typescript/src/fragments/createGroupChannelRegisterOperatorFragment.d.ts +5 -0
  324. package/lib/typescript/src/hooks/useContext.d.ts +2 -1
  325. package/lib/typescript/src/index.d.ts +7 -2
  326. package/lib/typescript/src/localization/StringSet.type.d.ts +41 -6
  327. package/lib/typescript/src/version.d.ts +1 -1
  328. package/package.json +6 -6
  329. package/src/components/ChannelCover.tsx +23 -3
  330. package/src/components/MessageRenderer/MessageIncomingAvatar.tsx +2 -2
  331. package/src/components/MessageRenderer/index.tsx +1 -1
  332. package/src/components/TypedPlaceholder.tsx +4 -4
  333. package/src/containers/GroupChannelPreviewContainer.tsx +1 -15
  334. package/src/containers/SendbirdUIKitContainer.tsx +12 -13
  335. package/src/contexts/SendbirdChatCtx.tsx +10 -4
  336. package/src/contexts/{ProfileCardCtx.tsx → UserProfileCtx.tsx} +17 -16
  337. package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +3 -1
  338. package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +17 -3
  339. package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +11 -8
  340. package/src/domain/groupChannel/types.ts +1 -1
  341. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.tsx +14 -0
  342. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +32 -0
  343. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.tsx +18 -0
  344. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.tsx +19 -0
  345. package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.tsx +18 -0
  346. package/src/domain/groupChannelBannedUsers/index.ts +6 -0
  347. package/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.tsx +21 -0
  348. package/src/domain/groupChannelBannedUsers/module/moduleContext.tsx +30 -0
  349. package/src/domain/groupChannelBannedUsers/types.ts +50 -0
  350. package/src/domain/groupChannelList/component/GroupChannelListTypeSelector.tsx +37 -43
  351. package/src/domain/groupChannelList/types.ts +1 -7
  352. package/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.tsx +14 -0
  353. package/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.tsx +84 -0
  354. package/src/domain/groupChannelModeration/index.ts +4 -0
  355. package/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.tsx +15 -0
  356. package/src/domain/groupChannelModeration/module/moduleContext.tsx +33 -0
  357. package/src/domain/groupChannelModeration/types.ts +48 -0
  358. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.tsx +14 -0
  359. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +30 -0
  360. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.tsx +18 -0
  361. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.tsx +19 -0
  362. package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.tsx +18 -0
  363. package/src/domain/groupChannelMutedMembers/index.ts +7 -0
  364. package/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.tsx +21 -0
  365. package/src/domain/groupChannelMutedMembers/module/moduleContext.tsx +30 -0
  366. package/src/domain/groupChannelMutedMembers/types.ts +50 -0
  367. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.tsx +25 -0
  368. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +29 -0
  369. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.tsx +18 -0
  370. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.tsx +19 -0
  371. package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.tsx +18 -0
  372. package/src/domain/groupChannelOperators/index.ts +7 -0
  373. package/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.tsx +21 -0
  374. package/src/domain/groupChannelOperators/module/moduleContext.tsx +30 -0
  375. package/src/domain/groupChannelOperators/types.ts +52 -0
  376. package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +2 -7
  377. package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +9 -0
  378. package/src/domain/groupChannelSettings/types.ts +2 -0
  379. package/src/domain/groupChannelUserList/types.ts +27 -12
  380. package/src/domain/userList/component/UserListStatusError.tsx +2 -2
  381. package/src/domain/userList/types.ts +4 -1
  382. package/src/fragments/createGroupChannelBannedUsersFragment.tsx +80 -0
  383. package/src/fragments/createGroupChannelCreateFragment.tsx +13 -33
  384. package/src/fragments/createGroupChannelFragment.tsx +9 -12
  385. package/src/fragments/createGroupChannelInviteFragment.tsx +28 -50
  386. package/src/fragments/createGroupChannelListFragment.tsx +3 -8
  387. package/src/fragments/createGroupChannelMembersFragment.tsx +94 -51
  388. package/src/fragments/createGroupChannelModerationFragment.tsx +57 -0
  389. package/src/fragments/createGroupChannelMutedMembersFragment.tsx +93 -0
  390. package/src/fragments/createGroupChannelOperatorsFragment.tsx +101 -0
  391. package/src/fragments/createGroupChannelRegisterOperatorFragment.tsx +94 -0
  392. package/src/fragments/createGroupChannelSettingsFragment.tsx +9 -1
  393. package/src/hooks/useConnection.ts +2 -0
  394. package/src/hooks/useContext.ts +4 -4
  395. package/src/index.ts +7 -2
  396. package/src/localization/StringSet.type.ts +87 -14
  397. package/src/version.ts +1 -1
  398. package/lib/commonjs/contexts/ProfileCardCtx.js.map +0 -1
  399. package/lib/module/contexts/ProfileCardCtx.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"names":["React","useMemo","useGroupChannelMessages","NOOP","PASS","messageComparator","useFreshCallback","MessageRenderer","NewMessagesButton","ScrollToBottomButton","StatusComposition","createGroupChannelModule","useSendbirdChat","createGroupChannelFragment","initModule","GroupChannelModule","renderNewMessagesButton","props","renderScrollToBottomButton","renderMessage","enableMessageGrouping","enableTypingIndicator","onPressHeaderLeft","onPressHeaderRight","onPressImageMessage","onPressMediaMessage","onChannelDeleted","onBeforeSendFileMessage","onBeforeSendUserMessage","channel","keyboardAvoidOffset","queryCreator","collectionCreator","sortComparator","flatListProps","sdk","currentUser","activeChannel","messages","nextMessages","newMessagesFromMembers","next","prev","sendFileMessage","sendUserMessage","updateFileMessage","updateUserMessage","resendMessage","deleteMessage","loading","userId","enableCollectionWithoutLocalCache","_renderMessage","memoizedFlatListProps","ListEmptyComponent","contentContainerStyle","flexGrow","onSendFileMessage","file","processedParams","onSendUserMessage","text","message","onUpdateFileMessage","editedFile","messageId","onUpdateUserMessage","editedText","shouldRenderInput","isBroadcast","myRole"],"sources":["createGroupChannelFragment.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport { useGroupChannelMessages } from '@sendbird/uikit-chat-hooks';\nimport { NOOP, PASS, SendbirdGroupChannel, messageComparator, useFreshCallback } from '@sendbird/uikit-utils';\n\nimport MessageRenderer from '../components/MessageRenderer';\nimport NewMessagesButton from '../components/NewMessagesButton';\nimport ScrollToBottomButton from '../components/ScrollToBottomButton';\nimport StatusComposition from '../components/StatusComposition';\nimport createGroupChannelModule from '../domain/groupChannel/module/createGroupChannelModule';\nimport type { GroupChannelFragment, GroupChannelModule, GroupChannelProps } from '../domain/groupChannel/types';\nimport { useSendbirdChat } from '../hooks/useContext';\n\nconst createGroupChannelFragment = (initModule?: Partial<GroupChannelModule>): GroupChannelFragment => {\n const GroupChannelModule = createGroupChannelModule(initModule);\n\n return ({\n renderNewMessagesButton = (props) => <NewMessagesButton {...props} />,\n renderScrollToBottomButton = (props) => <ScrollToBottomButton {...props} />,\n renderMessage,\n enableMessageGrouping = true,\n enableTypingIndicator = true,\n onPressHeaderLeft = NOOP,\n onPressHeaderRight = NOOP,\n onPressImageMessage,\n onPressMediaMessage = NOOP,\n onChannelDeleted = NOOP,\n onBeforeSendFileMessage = PASS,\n onBeforeSendUserMessage = PASS,\n channel,\n keyboardAvoidOffset,\n queryCreator,\n collectionCreator,\n sortComparator = messageComparator,\n flatListProps,\n }) => {\n const { sdk, currentUser } = useSendbirdChat();\n\n const {\n activeChannel,\n messages,\n nextMessages,\n newMessagesFromMembers,\n next,\n prev,\n sendFileMessage,\n sendUserMessage,\n updateFileMessage,\n updateUserMessage,\n resendMessage,\n deleteMessage,\n loading,\n } = useGroupChannelMessages(sdk, channel, currentUser?.userId, {\n collectionCreator,\n queryCreator,\n sortComparator,\n onChannelDeleted,\n enableCollectionWithoutLocalCache: !queryCreator,\n });\n\n const _renderMessage: GroupChannelProps['MessageList']['renderMessage'] = useFreshCallback((props) => {\n if (renderMessage) return renderMessage(props);\n return <MessageRenderer {...props} />;\n });\n\n const memoizedFlatListProps = useMemo(\n () => ({\n ListEmptyComponent: <GroupChannelModule.StatusEmpty />,\n contentContainerStyle: { flexGrow: 1 },\n ...flatListProps,\n }),\n [loading, flatListProps],\n );\n\n const onSendFileMessage: GroupChannelProps['Input']['onSendFileMessage'] = useFreshCallback(async (file) => {\n const processedParams = await onBeforeSendFileMessage({ file });\n await sendFileMessage(processedParams);\n });\n const onSendUserMessage: GroupChannelProps['Input']['onSendUserMessage'] = useFreshCallback(async (text) => {\n const processedParams = await onBeforeSendUserMessage({ message: text });\n await sendUserMessage(processedParams);\n });\n const onUpdateFileMessage: GroupChannelProps['Input']['onUpdateFileMessage'] = useFreshCallback(\n async (editedFile, message) => {\n const processedParams = await onBeforeSendFileMessage({ file: editedFile });\n await updateFileMessage(message.messageId, processedParams);\n },\n );\n const onUpdateUserMessage: GroupChannelProps['Input']['onUpdateUserMessage'] = useFreshCallback(\n async (editedText, message) => {\n const processedParams = await onBeforeSendUserMessage({ message: editedText });\n await updateUserMessage(message.messageId, processedParams);\n },\n );\n\n return (\n <GroupChannelModule.Provider\n channel={activeChannel}\n enableTypingIndicator={enableTypingIndicator}\n keyboardAvoidOffset={keyboardAvoidOffset}\n >\n <GroupChannelModule.Header onPressHeaderLeft={onPressHeaderLeft} onPressHeaderRight={onPressHeaderRight} />\n <StatusComposition loading={loading} LoadingComponent={<GroupChannelModule.StatusLoading />}>\n <GroupChannelModule.MessageList\n enableMessageGrouping={enableMessageGrouping}\n currentUserId={currentUser?.userId}\n channel={activeChannel}\n renderMessage={_renderMessage}\n messages={messages}\n nextMessages={nextMessages}\n newMessagesFromMembers={newMessagesFromMembers}\n onTopReached={prev}\n onBottomReached={next}\n renderNewMessagesButton={renderNewMessagesButton}\n renderScrollToBottomButton={renderScrollToBottomButton}\n onResendFailedMessage={resendMessage}\n onDeleteMessage={deleteMessage}\n onPressImageMessage={onPressImageMessage}\n onPressMediaMessage={onPressMediaMessage}\n flatListProps={memoizedFlatListProps}\n />\n {shouldRenderInput(channel) && (\n <GroupChannelModule.Input\n channel={activeChannel}\n onSendFileMessage={onSendFileMessage}\n onSendUserMessage={onSendUserMessage}\n onUpdateFileMessage={onUpdateFileMessage}\n onUpdateUserMessage={onUpdateUserMessage}\n />\n )}\n </StatusComposition>\n </GroupChannelModule.Provider>\n );\n };\n};\n\nfunction shouldRenderInput(channel: SendbirdGroupChannel) {\n if (channel.isBroadcast) {\n return channel.myRole === 'operator';\n }\n\n return true;\n}\n\nexport default createGroupChannelFragment;\n"],"mappings":"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"}
1
+ {"version":3,"names":["React","useMemo","useGroupChannelMessages","NOOP","PASS","messageComparator","useFreshCallback","MessageRenderer","NewMessagesButton","ScrollToBottomButton","StatusComposition","createGroupChannelModule","useSendbirdChat","createGroupChannelFragment","initModule","GroupChannelModule","renderNewMessagesButton","props","renderScrollToBottomButton","renderMessage","enableMessageGrouping","enableTypingIndicator","onPressHeaderLeft","onPressHeaderRight","onPressImageMessage","onPressMediaMessage","onChannelDeleted","onBeforeSendFileMessage","onBeforeSendUserMessage","channel","keyboardAvoidOffset","queryCreator","collectionCreator","sortComparator","flatListProps","sdk","currentUser","messages","nextMessages","newMessagesFromMembers","next","prev","sendFileMessage","sendUserMessage","updateFileMessage","updateUserMessage","resendMessage","deleteMessage","loading","userId","enableCollectionWithoutLocalCache","_renderMessage","memoizedFlatListProps","ListEmptyComponent","contentContainerStyle","flexGrow","onSendFileMessage","file","processedParams","onSendUserMessage","text","message","onUpdateFileMessage","editedFile","messageId","onUpdateUserMessage","editedText","shouldRenderInput","isBroadcast","myRole"],"sources":["createGroupChannelFragment.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport { useGroupChannelMessages } from '@sendbird/uikit-chat-hooks';\nimport { NOOP, PASS, SendbirdGroupChannel, messageComparator, useFreshCallback } from '@sendbird/uikit-utils';\n\nimport MessageRenderer from '../components/MessageRenderer';\nimport NewMessagesButton from '../components/NewMessagesButton';\nimport ScrollToBottomButton from '../components/ScrollToBottomButton';\nimport StatusComposition from '../components/StatusComposition';\nimport createGroupChannelModule from '../domain/groupChannel/module/createGroupChannelModule';\nimport type { GroupChannelFragment, GroupChannelModule, GroupChannelProps } from '../domain/groupChannel/types';\nimport { useSendbirdChat } from '../hooks/useContext';\n\nconst createGroupChannelFragment = (initModule?: Partial<GroupChannelModule>): GroupChannelFragment => {\n const GroupChannelModule = createGroupChannelModule(initModule);\n\n return ({\n renderNewMessagesButton = (props) => <NewMessagesButton {...props} />,\n renderScrollToBottomButton = (props) => <ScrollToBottomButton {...props} />,\n renderMessage,\n enableMessageGrouping = true,\n enableTypingIndicator = true,\n onPressHeaderLeft = NOOP,\n onPressHeaderRight = NOOP,\n onPressImageMessage,\n onPressMediaMessage = NOOP,\n onChannelDeleted = NOOP,\n onBeforeSendFileMessage = PASS,\n onBeforeSendUserMessage = PASS,\n channel,\n keyboardAvoidOffset,\n queryCreator,\n collectionCreator,\n sortComparator = messageComparator,\n flatListProps,\n }) => {\n const { sdk, currentUser } = useSendbirdChat();\n\n const {\n messages,\n nextMessages,\n newMessagesFromMembers,\n next,\n prev,\n sendFileMessage,\n sendUserMessage,\n updateFileMessage,\n updateUserMessage,\n resendMessage,\n deleteMessage,\n loading,\n } = useGroupChannelMessages(sdk, channel, currentUser?.userId, {\n collectionCreator,\n queryCreator,\n sortComparator,\n onChannelDeleted,\n enableCollectionWithoutLocalCache: !queryCreator,\n });\n\n const _renderMessage: GroupChannelProps['MessageList']['renderMessage'] = useFreshCallback((props) => {\n if (renderMessage) return renderMessage(props);\n return <MessageRenderer {...props} />;\n });\n\n const memoizedFlatListProps = useMemo(\n () => ({\n ListEmptyComponent: <GroupChannelModule.StatusEmpty />,\n contentContainerStyle: { flexGrow: 1 },\n ...flatListProps,\n }),\n [loading, flatListProps],\n );\n\n const onSendFileMessage: GroupChannelProps['Input']['onSendFileMessage'] = useFreshCallback(async (file) => {\n const processedParams = await onBeforeSendFileMessage({ file });\n await sendFileMessage(processedParams);\n });\n const onSendUserMessage: GroupChannelProps['Input']['onSendUserMessage'] = useFreshCallback(async (text) => {\n const processedParams = await onBeforeSendUserMessage({ message: text });\n await sendUserMessage(processedParams);\n });\n const onUpdateFileMessage: GroupChannelProps['Input']['onUpdateFileMessage'] = useFreshCallback(\n async (editedFile, message) => {\n const processedParams = await onBeforeSendFileMessage({ file: editedFile });\n await updateFileMessage(message.messageId, processedParams);\n },\n );\n const onUpdateUserMessage: GroupChannelProps['Input']['onUpdateUserMessage'] = useFreshCallback(\n async (editedText, message) => {\n const processedParams = await onBeforeSendUserMessage({ message: editedText });\n await updateUserMessage(message.messageId, processedParams);\n },\n );\n\n return (\n <GroupChannelModule.Provider\n channel={channel}\n enableTypingIndicator={enableTypingIndicator}\n keyboardAvoidOffset={keyboardAvoidOffset}\n >\n <GroupChannelModule.Header onPressHeaderLeft={onPressHeaderLeft} onPressHeaderRight={onPressHeaderRight} />\n <StatusComposition loading={loading} LoadingComponent={<GroupChannelModule.StatusLoading />}>\n <GroupChannelModule.MessageList\n channel={channel}\n enableMessageGrouping={enableMessageGrouping}\n currentUserId={currentUser?.userId}\n renderMessage={_renderMessage}\n messages={messages}\n nextMessages={nextMessages}\n newMessagesFromMembers={newMessagesFromMembers}\n onTopReached={prev}\n onBottomReached={next}\n renderNewMessagesButton={renderNewMessagesButton}\n renderScrollToBottomButton={renderScrollToBottomButton}\n onResendFailedMessage={resendMessage}\n onDeleteMessage={deleteMessage}\n onPressImageMessage={onPressImageMessage}\n onPressMediaMessage={onPressMediaMessage}\n flatListProps={memoizedFlatListProps}\n />\n <GroupChannelModule.Input\n shouldRenderInput={shouldRenderInput(channel)}\n onSendFileMessage={onSendFileMessage}\n onSendUserMessage={onSendUserMessage}\n onUpdateFileMessage={onUpdateFileMessage}\n onUpdateUserMessage={onUpdateUserMessage}\n />\n </StatusComposition>\n </GroupChannelModule.Provider>\n );\n };\n};\n\nfunction shouldRenderInput(channel: SendbirdGroupChannel) {\n if (channel.isBroadcast) {\n return channel.myRole === 'operator';\n }\n\n return true;\n}\n\nexport default createGroupChannelFragment;\n"],"mappings":"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"}
@@ -1,25 +1,11 @@
1
1
  import React, { useCallback } from 'react';
2
2
  import { TouchableOpacity } from 'react-native';
3
- import { useActiveGroupChannel, useUserList } from '@sendbird/uikit-chat-hooks';
4
- import { Logger } from '@sendbird/uikit-utils';
3
+ import { useUserList } from '@sendbird/uikit-chat-hooks';
5
4
  import StatusComposition from '../components/StatusComposition';
6
5
  import UserSelectableBar from '../components/UserSelectableBar';
7
6
  import createUserListModule from '../domain/userList/module/createUserListModule';
8
7
  import { useLocalization, useSendbirdChat } from '../hooks/useContext';
9
8
 
10
- const defaultUserIdsGenerator = users => {
11
- const userIds = users.map(user => {
12
- // @ts-ignore
13
- return user.userId;
14
- }).filter(u => Boolean(u));
15
-
16
- if (userIds.length === 0) {
17
- Logger.warn('GroupChannelInviteFragment: Couldn\'t find user id to invite! if you provided "queryCreator", please provide "userIdsGenerator" as well');
18
- }
19
-
20
- return userIds;
21
- };
22
-
23
9
  const createGroupChannelInviteFragment = initModule => {
24
10
  const UserListModule = createUserListModule(initModule);
25
11
  return _ref => {
@@ -27,7 +13,6 @@ const createGroupChannelInviteFragment = initModule => {
27
13
  channel,
28
14
  onPressHeaderLeft,
29
15
  onInviteMembers,
30
- userIdsGenerator = defaultUserIdsGenerator,
31
16
  sortComparator,
32
17
  queryCreator,
33
18
  renderUser
@@ -49,40 +34,36 @@ const createGroupChannelInviteFragment = initModule => {
49
34
  queryCreator,
50
35
  sortComparator
51
36
  });
52
- const {
53
- activeChannel
54
- } = useActiveGroupChannel(sdk, channel);
37
+ const memberIds = shouldFilterMember(channel) ? channel.members.map(it => it.userId) : [];
55
38
 
56
39
  const _renderUser = useCallback((user, selectedUsers, setSelectedUsers) => {
57
40
  if (queryCreator && !renderUser) {
58
- throw new Error('You should provide "renderUser" when providing "queryCreator"');
41
+ const hasRequiredKey = Object.hasOwn(user, 'profileUrl') && Object.hasOwn(user, 'nickname');
42
+ if (!hasRequiredKey) throw new Error('You should provide "renderUser" when providing "queryCreator"');
59
43
  }
60
44
 
61
45
  if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);
62
- const sbUser = user;
63
- const sbSelectedUsers = selectedUsers;
64
- const sbSetSelectedUsers = setSelectedUsers;
65
- const joinedUserIds = activeChannel.members.map(u => u.userId);
66
- const userIdx = sbSelectedUsers.findIndex(u => u.userId === sbUser.userId);
67
- const isSelected = userIdx > -1;
68
- const isAlreadyJoined = joinedUserIds.includes(sbUser.userId);
46
+ const userIdxInMembers = memberIds.indexOf(user.userId);
47
+ const userIdxInSelectedUsers = selectedUsers.findIndex(it => it.userId === user.userId);
48
+ const isMember = userIdxInMembers > -1;
49
+ const isSelected = userIdxInSelectedUsers > -1;
69
50
  return /*#__PURE__*/React.createElement(TouchableOpacity, {
70
51
  activeOpacity: 0.7,
71
- disabled: isAlreadyJoined,
52
+ disabled: isMember,
72
53
  onPress: () => {
73
- sbSetSelectedUsers(_ref2 => {
54
+ setSelectedUsers(_ref2 => {
74
55
  let [...draft] = _ref2;
75
- if (isSelected) draft.splice(userIdx, 1);else draft.push(sbUser);
56
+ if (isSelected) draft.splice(userIdxInSelectedUsers, 1);else draft.push(user);
76
57
  return draft;
77
58
  });
78
59
  }
79
60
  }, /*#__PURE__*/React.createElement(UserSelectableBar, {
80
- uri: sbUser.profileUrl,
81
- name: sbUser.nickname || STRINGS.LABELS.USER_NO_NAME,
82
- selected: isAlreadyJoined || isSelected,
83
- disabled: isAlreadyJoined
61
+ uri: user.profileUrl,
62
+ name: user.nickname || STRINGS.LABELS.USER_NO_NAME,
63
+ selected: isMember || isSelected,
64
+ disabled: isMember
84
65
  }));
85
- }, [activeChannel, renderUser, queryCreator]);
66
+ }, [channel, renderUser, queryCreator]);
86
67
 
87
68
  return /*#__PURE__*/React.createElement(UserListModule.Provider, {
88
69
  headerRight: selectedUsers => STRINGS.GROUP_CHANNEL_INVITE.HEADER_RIGHT({
@@ -92,8 +73,8 @@ const createGroupChannelInviteFragment = initModule => {
92
73
  }, /*#__PURE__*/React.createElement(UserListModule.Header, {
93
74
  onPressHeaderLeft: onPressHeaderLeft,
94
75
  onPressHeaderRight: async users => {
95
- const userIds = userIdsGenerator(users);
96
- const updatedChannel = await activeChannel.inviteWithUserIds(userIds);
76
+ const userIds = users.map(it => it.userId);
77
+ const updatedChannel = await channel.inviteWithUserIds(userIds);
97
78
  onInviteMembers(updatedChannel);
98
79
  }
99
80
  }), /*#__PURE__*/React.createElement(StatusComposition, {
@@ -114,5 +95,9 @@ const createGroupChannelInviteFragment = initModule => {
114
95
  };
115
96
  };
116
97
 
98
+ function shouldFilterMember(channel) {
99
+ return !channel.isSuper && !channel.isBroadcast;
100
+ }
101
+
117
102
  export default createGroupChannelInviteFragment;
118
103
  //# sourceMappingURL=createGroupChannelInviteFragment.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["React","useCallback","TouchableOpacity","useActiveGroupChannel","useUserList","Logger","StatusComposition","UserSelectableBar","createUserListModule","useLocalization","useSendbirdChat","defaultUserIdsGenerator","users","userIds","map","user","userId","filter","u","Boolean","length","warn","createGroupChannelInviteFragment","initModule","UserListModule","channel","onPressHeaderLeft","onInviteMembers","userIdsGenerator","sortComparator","queryCreator","renderUser","sdk","STRINGS","refreshing","refresh","next","error","loading","activeChannel","_renderUser","selectedUsers","setSelectedUsers","Error","sbUser","sbSelectedUsers","sbSetSelectedUsers","joinedUserIds","members","userIdx","findIndex","isSelected","isAlreadyJoined","includes","draft","splice","push","profileUrl","nickname","LABELS","USER_NO_NAME","GROUP_CHANNEL_INVITE","HEADER_RIGHT","HEADER_TITLE","updatedChannel","inviteWithUserIds"],"sources":["createGroupChannelInviteFragment.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { TouchableOpacity } from 'react-native';\n\nimport { useActiveGroupChannel, useUserList } from '@sendbird/uikit-chat-hooks';\nimport { Logger, SendbirdUser } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserSelectableBar from '../components/UserSelectableBar';\nimport type { GroupChannelInviteFragment } from '../domain/groupChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useSendbirdChat } from '../hooks/useContext';\n\nconst defaultUserIdsGenerator = <T,>(users: T[]) => {\n const userIds = users\n .map((user) => {\n // @ts-ignore\n return user.userId as string | undefined;\n })\n .filter((u): u is string => Boolean(u));\n\n if (userIds.length === 0) {\n Logger.warn(\n 'GroupChannelInviteFragment: Couldn\\'t find user id to invite! if you provided \"queryCreator\", please provide \"userIdsGenerator\" as well',\n );\n }\n\n return userIds;\n};\n\nconst createGroupChannelInviteFragment = <UserType,>(\n initModule?: Partial<UserListModule<UserType>>,\n): GroupChannelInviteFragment<UserType> => {\n const UserListModule = createUserListModule<UserType>(initModule);\n\n return ({\n channel,\n onPressHeaderLeft,\n onInviteMembers,\n userIdsGenerator = defaultUserIdsGenerator,\n sortComparator,\n queryCreator,\n renderUser,\n }) => {\n const { sdk } = useSendbirdChat();\n const { STRINGS } = useLocalization();\n const { users, refreshing, refresh, next, error, loading } = useUserList(sdk, {\n queryCreator,\n sortComparator,\n });\n\n const { activeChannel } = useActiveGroupChannel(sdk, channel);\n\n const _renderUser: NonNullable<typeof renderUser> = useCallback(\n (user, selectedUsers, setSelectedUsers) => {\n if (queryCreator && !renderUser) {\n throw new Error('You should provide \"renderUser\" when providing \"queryCreator\"');\n }\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n const sbUser = user as unknown as SendbirdUser;\n const sbSelectedUsers = selectedUsers as unknown as SendbirdUser[];\n const sbSetSelectedUsers = setSelectedUsers as unknown as React.Dispatch<React.SetStateAction<SendbirdUser[]>>;\n\n const joinedUserIds = activeChannel.members.map((u) => u.userId);\n const userIdx = sbSelectedUsers.findIndex((u) => u.userId === sbUser.userId);\n const isSelected = userIdx > -1;\n\n const isAlreadyJoined = joinedUserIds.includes(sbUser.userId);\n\n return (\n <TouchableOpacity\n activeOpacity={0.7}\n disabled={isAlreadyJoined}\n onPress={() => {\n sbSetSelectedUsers(([...draft]) => {\n if (isSelected) draft.splice(userIdx, 1);\n else draft.push(sbUser);\n return draft;\n });\n }}\n >\n <UserSelectableBar\n uri={sbUser.profileUrl}\n name={sbUser.nickname || STRINGS.LABELS.USER_NO_NAME}\n selected={isAlreadyJoined || isSelected}\n disabled={isAlreadyJoined}\n />\n </TouchableOpacity>\n );\n },\n [activeChannel, renderUser, queryCreator],\n );\n return (\n <UserListModule.Provider\n headerRight={(selectedUsers) => STRINGS.GROUP_CHANNEL_INVITE.HEADER_RIGHT({ selectedUsers })}\n headerTitle={STRINGS.GROUP_CHANNEL_INVITE.HEADER_TITLE}\n >\n <UserListModule.Header\n onPressHeaderLeft={onPressHeaderLeft}\n onPressHeaderRight={async (users) => {\n const userIds = userIdsGenerator(users);\n const updatedChannel = await activeChannel.inviteWithUserIds(userIds);\n onInviteMembers(updatedChannel);\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 createGroupChannelInviteFragment;\n"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,WAAhB,QAAmC,OAAnC;AACA,SAASC,gBAAT,QAAiC,cAAjC;AAEA,SAASC,qBAAT,EAAgCC,WAAhC,QAAmD,4BAAnD;AACA,SAASC,MAAT,QAAqC,uBAArC;AAEA,OAAOC,iBAAP,MAA8B,iCAA9B;AACA,OAAOC,iBAAP,MAA8B,iCAA9B;AAEA,OAAOC,oBAAP,MAAiC,gDAAjC;AAEA,SAASC,eAAT,EAA0BC,eAA1B,QAAiD,qBAAjD;;AAEA,MAAMC,uBAAuB,GAAQC,KAAL,IAAoB;EAClD,MAAMC,OAAO,GAAGD,KAAK,CAClBE,GADa,CACRC,IAAD,IAAU;IACb;IACA,OAAOA,IAAI,CAACC,MAAZ;EACD,CAJa,EAKbC,MALa,CAKLC,CAAD,IAAoBC,OAAO,CAACD,CAAD,CALrB,CAAhB;;EAOA,IAAIL,OAAO,CAACO,MAAR,KAAmB,CAAvB,EAA0B;IACxBf,MAAM,CAACgB,IAAP,CACE,yIADF;EAGD;;EAED,OAAOR,OAAP;AACD,CAfD;;AAiBA,MAAMS,gCAAgC,GACpCC,UADuC,IAEE;EACzC,MAAMC,cAAc,GAAGhB,oBAAoB,CAAWe,UAAX,CAA3C;EAEA,OAAO,QAQD;IAAA,IARE;MACNE,OADM;MAENC,iBAFM;MAGNC,eAHM;MAINC,gBAAgB,GAAGjB,uBAJb;MAKNkB,cALM;MAMNC,YANM;MAONC;IAPM,CAQF;IACJ,MAAM;MAAEC;IAAF,IAAUtB,eAAe,EAA/B;IACA,MAAM;MAAEuB;IAAF,IAAcxB,eAAe,EAAnC;IACA,MAAM;MAAEG,KAAF;MAASsB,UAAT;MAAqBC,OAArB;MAA8BC,IAA9B;MAAoCC,KAApC;MAA2CC;IAA3C,IAAuDlC,WAAW,CAAC4B,GAAD,EAAM;MAC5EF,YAD4E;MAE5ED;IAF4E,CAAN,CAAxE;IAKA,MAAM;MAAEU;IAAF,IAAoBpC,qBAAqB,CAAC6B,GAAD,EAAMP,OAAN,CAA/C;;IAEA,MAAMe,WAA2C,GAAGvC,WAAW,CAC7D,CAACc,IAAD,EAAO0B,aAAP,EAAsBC,gBAAtB,KAA2C;MACzC,IAAIZ,YAAY,IAAI,CAACC,UAArB,EAAiC;QAC/B,MAAM,IAAIY,KAAJ,CAAU,+DAAV,CAAN;MACD;;MACD,IAAIZ,UAAJ,EAAgB,OAAOA,UAAU,CAAChB,IAAD,EAAO0B,aAAP,EAAsBC,gBAAtB,CAAjB;MAEhB,MAAME,MAAM,GAAG7B,IAAf;MACA,MAAM8B,eAAe,GAAGJ,aAAxB;MACA,MAAMK,kBAAkB,GAAGJ,gBAA3B;MAEA,MAAMK,aAAa,GAAGR,aAAa,CAACS,OAAd,CAAsBlC,GAAtB,CAA2BI,CAAD,IAAOA,CAAC,CAACF,MAAnC,CAAtB;MACA,MAAMiC,OAAO,GAAGJ,eAAe,CAACK,SAAhB,CAA2BhC,CAAD,IAAOA,CAAC,CAACF,MAAF,KAAa4B,MAAM,CAAC5B,MAArD,CAAhB;MACA,MAAMmC,UAAU,GAAGF,OAAO,GAAG,CAAC,CAA9B;MAEA,MAAMG,eAAe,GAAGL,aAAa,CAACM,QAAd,CAAuBT,MAAM,CAAC5B,MAA9B,CAAxB;MAEA,oBACE,oBAAC,gBAAD;QACE,aAAa,EAAE,GADjB;QAEE,QAAQ,EAAEoC,eAFZ;QAGE,OAAO,EAAE,MAAM;UACbN,kBAAkB,CAAC,SAAgB;YAAA,IAAf,CAAC,GAAGQ,KAAJ,CAAe;YACjC,IAAIH,UAAJ,EAAgBG,KAAK,CAACC,MAAN,CAAaN,OAAb,EAAsB,CAAtB,EAAhB,KACKK,KAAK,CAACE,IAAN,CAAWZ,MAAX;YACL,OAAOU,KAAP;UACD,CAJiB,CAAlB;QAKD;MATH,gBAWE,oBAAC,iBAAD;QACE,GAAG,EAAEV,MAAM,CAACa,UADd;QAEE,IAAI,EAAEb,MAAM,CAACc,QAAP,IAAmBzB,OAAO,CAAC0B,MAAR,CAAeC,YAF1C;QAGE,QAAQ,EAAER,eAAe,IAAID,UAH/B;QAIE,QAAQ,EAAEC;MAJZ,EAXF,CADF;IAoBD,CArC4D,EAsC7D,CAACb,aAAD,EAAgBR,UAAhB,EAA4BD,YAA5B,CAtC6D,CAA/D;;IAwCA,oBACE,oBAAC,cAAD,CAAgB,QAAhB;MACE,WAAW,EAAGW,aAAD,IAAmBR,OAAO,CAAC4B,oBAAR,CAA6BC,YAA7B,CAA0C;QAAErB;MAAF,CAA1C,CADlC;MAEE,WAAW,EAAER,OAAO,CAAC4B,oBAAR,CAA6BE;IAF5C,gBAIE,oBAAC,cAAD,CAAgB,MAAhB;MACE,iBAAiB,EAAErC,iBADrB;MAEE,kBAAkB,EAAE,MAAOd,KAAP,IAAiB;QACnC,MAAMC,OAAO,GAAGe,gBAAgB,CAAChB,KAAD,CAAhC;QACA,MAAMoD,cAAc,GAAG,MAAMzB,aAAa,CAAC0B,iBAAd,CAAgCpD,OAAhC,CAA7B;QACAc,eAAe,CAACqC,cAAD,CAAf;MACD;IANH,EAJF,eAYE,oBAAC,iBAAD;MACE,OAAO,EAAE1B,OADX;MAEE,KAAK,EAAEnB,OAAO,CAACkB,KAAD,CAFhB;MAGE,gBAAgB,eAAE,oBAAC,cAAD,CAAgB,aAAhB,OAHpB;MAIE,cAAc,eAAE,oBAAC,cAAD,CAAgB,WAAhB;QAA4B,YAAY,EAAE,MAAMF,OAAO;MAAvD;IAJlB,gBAME,oBAAC,cAAD,CAAgB,IAAhB;MACE,UAAU,EAAEC,IADd;MAEE,KAAK,EAAExB,KAFT;MAGE,UAAU,EAAE4B,WAHd;MAIE,SAAS,EAAEL,OAJb;MAKE,UAAU,EAAED,UALd;MAME,kBAAkB,eAAE,oBAAC,cAAD,CAAgB,WAAhB;IANtB,EANF,CAZF,CADF;EA8BD,CAxFD;AAyFD,CA9FD;;AAgGA,eAAeZ,gCAAf"}
1
+ {"version":3,"names":["React","useCallback","TouchableOpacity","useUserList","StatusComposition","UserSelectableBar","createUserListModule","useLocalization","useSendbirdChat","createGroupChannelInviteFragment","initModule","UserListModule","channel","onPressHeaderLeft","onInviteMembers","sortComparator","queryCreator","renderUser","sdk","STRINGS","users","refreshing","refresh","next","error","loading","memberIds","shouldFilterMember","members","map","it","userId","_renderUser","user","selectedUsers","setSelectedUsers","hasRequiredKey","Object","hasOwn","Error","userIdxInMembers","indexOf","userIdxInSelectedUsers","findIndex","isMember","isSelected","draft","splice","push","profileUrl","nickname","LABELS","USER_NO_NAME","GROUP_CHANNEL_INVITE","HEADER_RIGHT","HEADER_TITLE","userIds","updatedChannel","inviteWithUserIds","Boolean","isSuper","isBroadcast"],"sources":["createGroupChannelInviteFragment.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { TouchableOpacity } from 'react-native';\n\nimport { UserStruct, useUserList } from '@sendbird/uikit-chat-hooks';\nimport type { SendbirdGroupChannel, SendbirdUser } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserSelectableBar from '../components/UserSelectableBar';\nimport type { GroupChannelInviteFragment } from '../domain/groupChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useSendbirdChat } from '../hooks/useContext';\n\nconst createGroupChannelInviteFragment = <UserType extends UserStruct>(\n initModule?: Partial<UserListModule<UserType>>,\n): GroupChannelInviteFragment<UserType> => {\n const UserListModule = createUserListModule<UserType>(initModule);\n\n return ({ channel, onPressHeaderLeft, onInviteMembers, sortComparator, queryCreator, renderUser }) => {\n const { sdk } = useSendbirdChat();\n const { STRINGS } = useLocalization();\n const { users, refreshing, refresh, next, error, loading } = useUserList(sdk, {\n queryCreator,\n sortComparator,\n });\n\n const memberIds = shouldFilterMember(channel) ? channel.members.map((it) => it.userId) : [];\n\n const _renderUser: NonNullable<typeof renderUser> = useCallback(\n (user, selectedUsers, setSelectedUsers) => {\n if (queryCreator && !renderUser) {\n const hasRequiredKey = Object.hasOwn(user, 'profileUrl') && Object.hasOwn(user, 'nickname');\n if (!hasRequiredKey) throw new Error('You should provide \"renderUser\" when providing \"queryCreator\"');\n }\n\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n const userIdxInMembers = memberIds.indexOf(user.userId);\n const userIdxInSelectedUsers = selectedUsers.findIndex((it) => it.userId === user.userId);\n\n const isMember = userIdxInMembers > -1;\n const isSelected = userIdxInSelectedUsers > -1;\n\n return (\n <TouchableOpacity\n activeOpacity={0.7}\n disabled={isMember}\n onPress={() => {\n setSelectedUsers(([...draft]) => {\n if (isSelected) draft.splice(userIdxInSelectedUsers, 1);\n else draft.push(user);\n return draft;\n });\n }}\n >\n <UserSelectableBar\n uri={(user as unknown as SendbirdUser).profileUrl}\n name={(user as unknown as SendbirdUser).nickname || STRINGS.LABELS.USER_NO_NAME}\n selected={isMember || isSelected}\n disabled={isMember}\n />\n </TouchableOpacity>\n );\n },\n [channel, renderUser, queryCreator],\n );\n\n return (\n <UserListModule.Provider\n headerRight={(selectedUsers) => STRINGS.GROUP_CHANNEL_INVITE.HEADER_RIGHT({ selectedUsers })}\n headerTitle={STRINGS.GROUP_CHANNEL_INVITE.HEADER_TITLE}\n >\n <UserListModule.Header\n onPressHeaderLeft={onPressHeaderLeft}\n onPressHeaderRight={async (users) => {\n const userIds = users.map((it) => it.userId);\n const updatedChannel = await channel.inviteWithUserIds(userIds);\n onInviteMembers(updatedChannel);\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\nfunction shouldFilterMember(channel: SendbirdGroupChannel) {\n return !channel.isSuper && !channel.isBroadcast;\n}\n\nexport default createGroupChannelInviteFragment;\n"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,WAAhB,QAAmC,OAAnC;AACA,SAASC,gBAAT,QAAiC,cAAjC;AAEA,SAAqBC,WAArB,QAAwC,4BAAxC;AAGA,OAAOC,iBAAP,MAA8B,iCAA9B;AACA,OAAOC,iBAAP,MAA8B,iCAA9B;AAEA,OAAOC,oBAAP,MAAiC,gDAAjC;AAEA,SAASC,eAAT,EAA0BC,eAA1B,QAAiD,qBAAjD;;AAEA,MAAMC,gCAAgC,GACpCC,UADuC,IAEE;EACzC,MAAMC,cAAc,GAAGL,oBAAoB,CAAWI,UAAX,CAA3C;EAEA,OAAO,QAA+F;IAAA,IAA9F;MAAEE,OAAF;MAAWC,iBAAX;MAA8BC,eAA9B;MAA+CC,cAA/C;MAA+DC,YAA/D;MAA6EC;IAA7E,CAA8F;IACpG,MAAM;MAAEC;IAAF,IAAUV,eAAe,EAA/B;IACA,MAAM;MAAEW;IAAF,IAAcZ,eAAe,EAAnC;IACA,MAAM;MAAEa,KAAF;MAASC,UAAT;MAAqBC,OAArB;MAA8BC,IAA9B;MAAoCC,KAApC;MAA2CC;IAA3C,IAAuDtB,WAAW,CAACe,GAAD,EAAM;MAC5EF,YAD4E;MAE5ED;IAF4E,CAAN,CAAxE;IAKA,MAAMW,SAAS,GAAGC,kBAAkB,CAACf,OAAD,CAAlB,GAA8BA,OAAO,CAACgB,OAAR,CAAgBC,GAAhB,CAAqBC,EAAD,IAAQA,EAAE,CAACC,MAA/B,CAA9B,GAAuE,EAAzF;;IAEA,MAAMC,WAA2C,GAAG/B,WAAW,CAC7D,CAACgC,IAAD,EAAOC,aAAP,EAAsBC,gBAAtB,KAA2C;MACzC,IAAInB,YAAY,IAAI,CAACC,UAArB,EAAiC;QAC/B,MAAMmB,cAAc,GAAGC,MAAM,CAACC,MAAP,CAAcL,IAAd,EAAoB,YAApB,KAAqCI,MAAM,CAACC,MAAP,CAAcL,IAAd,EAAoB,UAApB,CAA5D;QACA,IAAI,CAACG,cAAL,EAAqB,MAAM,IAAIG,KAAJ,CAAU,+DAAV,CAAN;MACtB;;MAED,IAAItB,UAAJ,EAAgB,OAAOA,UAAU,CAACgB,IAAD,EAAOC,aAAP,EAAsBC,gBAAtB,CAAjB;MAEhB,MAAMK,gBAAgB,GAAGd,SAAS,CAACe,OAAV,CAAkBR,IAAI,CAACF,MAAvB,CAAzB;MACA,MAAMW,sBAAsB,GAAGR,aAAa,CAACS,SAAd,CAAyBb,EAAD,IAAQA,EAAE,CAACC,MAAH,KAAcE,IAAI,CAACF,MAAnD,CAA/B;MAEA,MAAMa,QAAQ,GAAGJ,gBAAgB,GAAG,CAAC,CAArC;MACA,MAAMK,UAAU,GAAGH,sBAAsB,GAAG,CAAC,CAA7C;MAEA,oBACE,oBAAC,gBAAD;QACE,aAAa,EAAE,GADjB;QAEE,QAAQ,EAAEE,QAFZ;QAGE,OAAO,EAAE,MAAM;UACbT,gBAAgB,CAAC,SAAgB;YAAA,IAAf,CAAC,GAAGW,KAAJ,CAAe;YAC/B,IAAID,UAAJ,EAAgBC,KAAK,CAACC,MAAN,CAAaL,sBAAb,EAAqC,CAArC,EAAhB,KACKI,KAAK,CAACE,IAAN,CAAWf,IAAX;YACL,OAAOa,KAAP;UACD,CAJe,CAAhB;QAKD;MATH,gBAWE,oBAAC,iBAAD;QACE,GAAG,EAAGb,IAAD,CAAkCgB,UADzC;QAEE,IAAI,EAAGhB,IAAD,CAAkCiB,QAAlC,IAA8C/B,OAAO,CAACgC,MAAR,CAAeC,YAFrE;QAGE,QAAQ,EAAER,QAAQ,IAAIC,UAHxB;QAIE,QAAQ,EAAED;MAJZ,EAXF,CADF;IAoBD,CAnC4D,EAoC7D,CAAChC,OAAD,EAAUK,UAAV,EAAsBD,YAAtB,CApC6D,CAA/D;;IAuCA,oBACE,oBAAC,cAAD,CAAgB,QAAhB;MACE,WAAW,EAAGkB,aAAD,IAAmBf,OAAO,CAACkC,oBAAR,CAA6BC,YAA7B,CAA0C;QAAEpB;MAAF,CAA1C,CADlC;MAEE,WAAW,EAAEf,OAAO,CAACkC,oBAAR,CAA6BE;IAF5C,gBAIE,oBAAC,cAAD,CAAgB,MAAhB;MACE,iBAAiB,EAAE1C,iBADrB;MAEE,kBAAkB,EAAE,MAAOO,KAAP,IAAiB;QACnC,MAAMoC,OAAO,GAAGpC,KAAK,CAACS,GAAN,CAAWC,EAAD,IAAQA,EAAE,CAACC,MAArB,CAAhB;QACA,MAAM0B,cAAc,GAAG,MAAM7C,OAAO,CAAC8C,iBAAR,CAA0BF,OAA1B,CAA7B;QACA1C,eAAe,CAAC2C,cAAD,CAAf;MACD;IANH,EAJF,eAYE,oBAAC,iBAAD;MACE,OAAO,EAAEhC,OADX;MAEE,KAAK,EAAEkC,OAAO,CAACnC,KAAD,CAFhB;MAGE,gBAAgB,eAAE,oBAAC,cAAD,CAAgB,aAAhB,OAHpB;MAIE,cAAc,eAAE,oBAAC,cAAD,CAAgB,WAAhB;QAA4B,YAAY,EAAE,MAAMF,OAAO;MAAvD;IAJlB,gBAME,oBAAC,cAAD,CAAgB,IAAhB;MACE,UAAU,EAAEC,IADd;MAEE,KAAK,EAAEH,KAFT;MAGE,UAAU,EAAEY,WAHd;MAIE,SAAS,EAAEV,OAJb;MAKE,UAAU,EAAED,UALd;MAME,kBAAkB,eAAE,oBAAC,cAAD,CAAgB,WAAhB;IANtB,EANF,CAZF,CADF;EA8BD,CA/ED;AAgFD,CArFD;;AAuFA,SAASM,kBAAT,CAA4Bf,OAA5B,EAA2D;EACzD,OAAO,CAACA,OAAO,CAACgD,OAAT,IAAoB,CAAChD,OAAO,CAACiD,WAApC;AACD;;AAED,eAAepD,gCAAf"}
@@ -1,7 +1,7 @@
1
1
  import React, { useEffect } from 'react';
2
2
  import { AppState } from 'react-native';
3
3
  import { useGroupChannelList } from '@sendbird/uikit-chat-hooks';
4
- import { Logger, PASS, useFreshCallback } from '@sendbird/uikit-utils';
4
+ import { PASS, useFreshCallback } from '@sendbird/uikit-utils';
5
5
  import StatusComposition from '../components/StatusComposition';
6
6
  import GroupChannelPreviewContainer from '../containers/GroupChannelPreviewContainer';
7
7
  import createGroupChannelListModule from '../domain/groupChannelList/module/createGroupChannelListModule';
@@ -11,7 +11,6 @@ const createGroupChannelListFragment = initModule => {
11
11
  const GroupChannelListModule = createGroupChannelListModule(initModule);
12
12
  return _ref => {
13
13
  let {
14
- TypeSelectorHeader,
15
14
  onPressChannel,
16
15
  onPressCreateChannel,
17
16
  queryCreator,
@@ -55,11 +54,7 @@ const createGroupChannelListFragment = initModule => {
55
54
  });
56
55
  });
57
56
 
58
- if (!currentUser) {
59
- Logger.warn('Cannot render GroupChannelListFragment, please connect using `useConnection()` hook first');
60
- return null;
61
- }
62
-
57
+ const isChannelTypeAvailable = features.broadcastChannelEnabled || features.superGroupChannelEnabled;
63
58
  return /*#__PURE__*/React.createElement(GroupChannelListModule.Provider, null, /*#__PURE__*/React.createElement(GroupChannelListModule.Header, null), /*#__PURE__*/React.createElement(StatusComposition, {
64
59
  loading: loading,
65
60
  LoadingComponent: /*#__PURE__*/React.createElement(GroupChannelListModule.StatusLoading, null)
@@ -76,8 +71,7 @@ const createGroupChannelListFragment = initModule => {
76
71
  ...flatListProps
77
72
  }
78
73
  })), /*#__PURE__*/React.createElement(GroupChannelListModule.TypeSelector, {
79
- skipTypeSelection: skipTypeSelection,
80
- Header: TypeSelectorHeader,
74
+ skipTypeSelection: isChannelTypeAvailable ? skipTypeSelection : true,
81
75
  onSelectType: onPressCreateChannel
82
76
  }));
83
77
  };
@@ -1 +1 @@
1
- {"version":3,"names":["React","useEffect","AppState","useGroupChannelList","Logger","PASS","useFreshCallback","StatusComposition","GroupChannelPreviewContainer","createGroupChannelListModule","useSendbirdChat","createGroupChannelListFragment","initModule","GroupChannelListModule","TypeSelectorHeader","onPressChannel","onPressCreateChannel","queryCreator","collectionCreator","renderGroupChannelPreview","skipTypeSelection","flatListProps","menuItemCreator","sdk","currentUser","features","markAsDeliveredWithChannel","groupChannels","next","loading","userId","enableCollectionWithoutLocalCache","deliveryReceiptEnabled","listener","addEventListener","status","forEach","remove","_renderGroupChannelPreview","channel","onLongPressChannel","warn","ListEmptyComponent","contentContainerStyle","flexGrow"],"sources":["createGroupChannelListFragment.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { AppState } from 'react-native';\n\nimport { useGroupChannelList } from '@sendbird/uikit-chat-hooks';\nimport { Logger, PASS, useFreshCallback } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport GroupChannelPreviewContainer from '../containers/GroupChannelPreviewContainer';\nimport createGroupChannelListModule from '../domain/groupChannelList/module/createGroupChannelListModule';\nimport type {\n GroupChannelListFragment,\n GroupChannelListModule,\n GroupChannelListProps,\n} from '../domain/groupChannelList/types';\nimport { useSendbirdChat } from '../hooks/useContext';\n\nconst createGroupChannelListFragment = (initModule?: Partial<GroupChannelListModule>): GroupChannelListFragment => {\n const GroupChannelListModule = createGroupChannelListModule(initModule);\n return ({\n TypeSelectorHeader,\n onPressChannel,\n onPressCreateChannel,\n queryCreator,\n collectionCreator,\n renderGroupChannelPreview,\n skipTypeSelection = false,\n flatListProps = {},\n menuItemCreator = PASS,\n }) => {\n const { sdk, currentUser, features, markAsDeliveredWithChannel } = useSendbirdChat();\n const { groupChannels, next, loading } = useGroupChannelList(sdk, currentUser?.userId, {\n queryCreator,\n collectionCreator,\n enableCollectionWithoutLocalCache: !queryCreator,\n });\n\n if (features.deliveryReceiptEnabled) {\n useEffect(() => {\n const listener = AppState.addEventListener('change', (status) => {\n if (status === 'active') groupChannels.forEach(markAsDeliveredWithChannel);\n });\n return () => listener.remove();\n }, []);\n }\n\n const _renderGroupChannelPreview: GroupChannelListProps['List']['renderGroupChannelPreview'] = useFreshCallback(\n (channel, onLongPressChannel) => {\n if (renderGroupChannelPreview) return renderGroupChannelPreview(channel, onLongPressChannel);\n return (\n <GroupChannelPreviewContainer\n channel={channel}\n onPress={() => onPressChannel(channel)}\n onLongPress={() => onLongPressChannel()}\n />\n );\n },\n );\n\n if (!currentUser) {\n Logger.warn('Cannot render GroupChannelListFragment, please connect using `useConnection()` hook first');\n return null;\n }\n\n return (\n <GroupChannelListModule.Provider>\n <GroupChannelListModule.Header />\n <StatusComposition loading={loading} LoadingComponent={<GroupChannelListModule.StatusLoading />}>\n <GroupChannelListModule.List\n menuItemCreator={menuItemCreator}\n renderGroupChannelPreview={_renderGroupChannelPreview}\n groupChannels={groupChannels}\n onLoadNext={next}\n flatListProps={{\n ListEmptyComponent: <GroupChannelListModule.StatusEmpty />,\n contentContainerStyle: { flexGrow: 1 },\n ...flatListProps,\n }}\n />\n </StatusComposition>\n <GroupChannelListModule.TypeSelector\n skipTypeSelection={skipTypeSelection}\n Header={TypeSelectorHeader}\n onSelectType={onPressCreateChannel}\n />\n </GroupChannelListModule.Provider>\n );\n };\n};\n\nexport default createGroupChannelListFragment;\n"],"mappings":"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"}
1
+ {"version":3,"names":["React","useEffect","AppState","useGroupChannelList","PASS","useFreshCallback","StatusComposition","GroupChannelPreviewContainer","createGroupChannelListModule","useSendbirdChat","createGroupChannelListFragment","initModule","GroupChannelListModule","onPressChannel","onPressCreateChannel","queryCreator","collectionCreator","renderGroupChannelPreview","skipTypeSelection","flatListProps","menuItemCreator","sdk","currentUser","features","markAsDeliveredWithChannel","groupChannels","next","loading","userId","enableCollectionWithoutLocalCache","deliveryReceiptEnabled","listener","addEventListener","status","forEach","remove","_renderGroupChannelPreview","channel","onLongPressChannel","isChannelTypeAvailable","broadcastChannelEnabled","superGroupChannelEnabled","ListEmptyComponent","contentContainerStyle","flexGrow"],"sources":["createGroupChannelListFragment.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { AppState } from 'react-native';\n\nimport { useGroupChannelList } from '@sendbird/uikit-chat-hooks';\nimport { PASS, useFreshCallback } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport GroupChannelPreviewContainer from '../containers/GroupChannelPreviewContainer';\nimport createGroupChannelListModule from '../domain/groupChannelList/module/createGroupChannelListModule';\nimport type {\n GroupChannelListFragment,\n GroupChannelListModule,\n GroupChannelListProps,\n} from '../domain/groupChannelList/types';\nimport { useSendbirdChat } from '../hooks/useContext';\n\nconst createGroupChannelListFragment = (initModule?: Partial<GroupChannelListModule>): GroupChannelListFragment => {\n const GroupChannelListModule = createGroupChannelListModule(initModule);\n return ({\n onPressChannel,\n onPressCreateChannel,\n queryCreator,\n collectionCreator,\n renderGroupChannelPreview,\n skipTypeSelection = false,\n flatListProps = {},\n menuItemCreator = PASS,\n }) => {\n const { sdk, currentUser, features, markAsDeliveredWithChannel } = useSendbirdChat();\n const { groupChannels, next, loading } = useGroupChannelList(sdk, currentUser?.userId, {\n queryCreator,\n collectionCreator,\n enableCollectionWithoutLocalCache: !queryCreator,\n });\n\n if (features.deliveryReceiptEnabled) {\n useEffect(() => {\n const listener = AppState.addEventListener('change', (status) => {\n if (status === 'active') groupChannels.forEach(markAsDeliveredWithChannel);\n });\n return () => listener.remove();\n }, []);\n }\n\n const _renderGroupChannelPreview: GroupChannelListProps['List']['renderGroupChannelPreview'] = useFreshCallback(\n (channel, onLongPressChannel) => {\n if (renderGroupChannelPreview) return renderGroupChannelPreview(channel, onLongPressChannel);\n return (\n <GroupChannelPreviewContainer\n channel={channel}\n onPress={() => onPressChannel(channel)}\n onLongPress={() => onLongPressChannel()}\n />\n );\n },\n );\n\n const isChannelTypeAvailable = features.broadcastChannelEnabled || features.superGroupChannelEnabled;\n\n return (\n <GroupChannelListModule.Provider>\n <GroupChannelListModule.Header />\n <StatusComposition loading={loading} LoadingComponent={<GroupChannelListModule.StatusLoading />}>\n <GroupChannelListModule.List\n menuItemCreator={menuItemCreator}\n renderGroupChannelPreview={_renderGroupChannelPreview}\n groupChannels={groupChannels}\n onLoadNext={next}\n flatListProps={{\n ListEmptyComponent: <GroupChannelListModule.StatusEmpty />,\n contentContainerStyle: { flexGrow: 1 },\n ...flatListProps,\n }}\n />\n </StatusComposition>\n <GroupChannelListModule.TypeSelector\n skipTypeSelection={isChannelTypeAvailable ? skipTypeSelection : true}\n onSelectType={onPressCreateChannel}\n />\n </GroupChannelListModule.Provider>\n );\n };\n};\n\nexport default createGroupChannelListFragment;\n"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,SAAhB,QAAiC,OAAjC;AACA,SAASC,QAAT,QAAyB,cAAzB;AAEA,SAASC,mBAAT,QAAoC,4BAApC;AACA,SAASC,IAAT,EAAeC,gBAAf,QAAuC,uBAAvC;AAEA,OAAOC,iBAAP,MAA8B,iCAA9B;AACA,OAAOC,4BAAP,MAAyC,4CAAzC;AACA,OAAOC,4BAAP,MAAyC,gEAAzC;AAMA,SAASC,eAAT,QAAgC,qBAAhC;;AAEA,MAAMC,8BAA8B,GAAIC,UAAD,IAA4E;EACjH,MAAMC,sBAAsB,GAAGJ,4BAA4B,CAACG,UAAD,CAA3D;EACA,OAAO,QASD;IAAA,IATE;MACNE,cADM;MAENC,oBAFM;MAGNC,YAHM;MAINC,iBAJM;MAKNC,yBALM;MAMNC,iBAAiB,GAAG,KANd;MAONC,aAAa,GAAG,EAPV;MAQNC,eAAe,GAAGhB;IARZ,CASF;IACJ,MAAM;MAAEiB,GAAF;MAAOC,WAAP;MAAoBC,QAApB;MAA8BC;IAA9B,IAA6Df,eAAe,EAAlF;IACA,MAAM;MAAEgB,aAAF;MAAiBC,IAAjB;MAAuBC;IAAvB,IAAmCxB,mBAAmB,CAACkB,GAAD,EAAMC,WAAN,aAAMA,WAAN,uBAAMA,WAAW,CAAEM,MAAnB,EAA2B;MACrFb,YADqF;MAErFC,iBAFqF;MAGrFa,iCAAiC,EAAE,CAACd;IAHiD,CAA3B,CAA5D;;IAMA,IAAIQ,QAAQ,CAACO,sBAAb,EAAqC;MACnC7B,SAAS,CAAC,MAAM;QACd,MAAM8B,QAAQ,GAAG7B,QAAQ,CAAC8B,gBAAT,CAA0B,QAA1B,EAAqCC,MAAD,IAAY;UAC/D,IAAIA,MAAM,KAAK,QAAf,EAAyBR,aAAa,CAACS,OAAd,CAAsBV,0BAAtB;QAC1B,CAFgB,CAAjB;QAGA,OAAO,MAAMO,QAAQ,CAACI,MAAT,EAAb;MACD,CALQ,EAKN,EALM,CAAT;IAMD;;IAED,MAAMC,0BAAsF,GAAG/B,gBAAgB,CAC7G,CAACgC,OAAD,EAAUC,kBAAV,KAAiC;MAC/B,IAAIrB,yBAAJ,EAA+B,OAAOA,yBAAyB,CAACoB,OAAD,EAAUC,kBAAV,CAAhC;MAC/B,oBACE,oBAAC,4BAAD;QACE,OAAO,EAAED,OADX;QAEE,OAAO,EAAE,MAAMxB,cAAc,CAACwB,OAAD,CAF/B;QAGE,WAAW,EAAE,MAAMC,kBAAkB;MAHvC,EADF;IAOD,CAV4G,CAA/G;;IAaA,MAAMC,sBAAsB,GAAGhB,QAAQ,CAACiB,uBAAT,IAAoCjB,QAAQ,CAACkB,wBAA5E;IAEA,oBACE,oBAAC,sBAAD,CAAwB,QAAxB,qBACE,oBAAC,sBAAD,CAAwB,MAAxB,OADF,eAEE,oBAAC,iBAAD;MAAmB,OAAO,EAAEd,OAA5B;MAAqC,gBAAgB,eAAE,oBAAC,sBAAD,CAAwB,aAAxB;IAAvD,gBACE,oBAAC,sBAAD,CAAwB,IAAxB;MACE,eAAe,EAAEP,eADnB;MAEE,yBAAyB,EAAEgB,0BAF7B;MAGE,aAAa,EAAEX,aAHjB;MAIE,UAAU,EAAEC,IAJd;MAKE,aAAa,EAAE;QACbgB,kBAAkB,eAAE,oBAAC,sBAAD,CAAwB,WAAxB,OADP;QAEbC,qBAAqB,EAAE;UAAEC,QAAQ,EAAE;QAAZ,CAFV;QAGb,GAAGzB;MAHU;IALjB,EADF,CAFF,eAeE,oBAAC,sBAAD,CAAwB,YAAxB;MACE,iBAAiB,EAAEoB,sBAAsB,GAAGrB,iBAAH,GAAuB,IADlE;MAEE,YAAY,EAAEJ;IAFhB,EAfF,CADF;EAsBD,CA/DD;AAgED,CAlED;;AAoEA,eAAeJ,8BAAf"}
@@ -1,14 +1,15 @@
1
- import React from 'react';
2
- import { useActiveGroupChannel, useChannelHandler } from '@sendbird/uikit-chat-hooks';
3
- import { Icon } from '@sendbird/uikit-react-native-foundation';
4
- import { useForceUpdate, useFreshCallback, useUniqId } from '@sendbird/uikit-utils';
1
+ import React, { useRef } from 'react';
2
+ import { useChannelHandler, useUserList } from '@sendbird/uikit-chat-hooks';
3
+ import { Icon, useActionMenu } from '@sendbird/uikit-react-native-foundation';
4
+ import { ifMuted, ifOperator, isDifferentChannel, useFreshCallback, useUniqId } from '@sendbird/uikit-utils';
5
+ import StatusComposition from '../components/StatusComposition';
5
6
  import UserActionBar from '../components/UserActionBar';
6
7
  import createUserListModule from '../domain/userList/module/createUserListModule';
7
- import { useLocalization, useProfileCard, useSendbirdChat } from '../hooks/useContext';
8
+ import { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';
8
9
 
9
10
  const noop = () => '';
10
11
 
11
- const name = 'createGroupChannelMembersFragment';
12
+ const HOOK_NAME = 'createGroupChannelMembersFragment';
12
13
 
13
14
  const createGroupChannelMembersFragment = initModule => {
14
15
  const UserListModule = createUserListModule(initModule);
@@ -19,8 +20,8 @@ const createGroupChannelMembersFragment = initModule => {
19
20
  onPressHeaderRight,
20
21
  renderUser
21
22
  } = _ref;
22
- const uniqId = useUniqId(name);
23
- const forceUpdate = useForceUpdate();
23
+ const uniqId = useUniqId(HOOK_NAME);
24
+ const refreshSchedule = useRef();
24
25
  const {
25
26
  STRINGS
26
27
  } = useLocalization();
@@ -28,55 +29,64 @@ const createGroupChannelMembersFragment = initModule => {
28
29
  sdk,
29
30
  currentUser
30
31
  } = useSendbirdChat();
32
+ const {
33
+ openMenu
34
+ } = useActionMenu();
31
35
  const {
32
36
  show
33
- } = useProfileCard();
37
+ } = useUserProfile();
34
38
  const {
35
- activeChannel
36
- } = useActiveGroupChannel(sdk, channel);
37
- useChannelHandler(sdk, `${name}_${uniqId}`, {
38
- // Note: Removed from v4
39
- // onUserEntered(channel) {
40
- // if (channel.url === activeChannel.url) forceUpdate();
41
- // },
42
- onUserLeft(channel) {
43
- if (channel.url === activeChannel.url) forceUpdate();
44
- },
45
-
46
- onUserJoined(channel) {
47
- if (channel.url === activeChannel.url) forceUpdate();
48
- },
49
-
50
- onUserUnmuted(channel) {
51
- if (channel.url === activeChannel.url) forceUpdate();
39
+ users,
40
+ refresh,
41
+ loading,
42
+ next,
43
+ error,
44
+ upsertUser,
45
+ deleteUser
46
+ } = useUserList(sdk, {
47
+ queryCreator: () => channel.createMemberListQuery({
48
+ limit: 20
49
+ })
50
+ });
51
+ useChannelHandler(sdk, `${HOOK_NAME}_${uniqId}`, {
52
+ onUserLeft(eventChannel, user) {
53
+ if (isDifferentChannel(eventChannel, channel)) return;
54
+ deleteUser(user.userId);
52
55
  },
53
56
 
54
- onUserUnbanned(channel) {
55
- if (channel.url === activeChannel.url) forceUpdate();
57
+ onUserBanned(eventChannel, user) {
58
+ if (isDifferentChannel(eventChannel, channel)) return;
59
+ deleteUser(user.userId);
56
60
  },
57
61
 
58
- onUserBanned(channel) {
59
- if (channel.url === activeChannel.url) forceUpdate();
62
+ onOperatorUpdated(eventChannel) {
63
+ if (isDifferentChannel(eventChannel, channel)) return;
64
+ if (refreshSchedule.current) clearTimeout(refreshSchedule.current);
65
+ refreshSchedule.current = setTimeout(() => refresh(), 500);
60
66
  },
61
67
 
62
- onUserMuted(channel) {
63
- if (channel.url === activeChannel.url) forceUpdate();
64
- },
68
+ onUserMuted(eventChannel, user) {
69
+ if (isDifferentChannel(eventChannel, channel) || !eventChannel.isGroupChannel()) return;
70
+ const memberFromChannel = eventChannel.members.find(it => it.userId === user.userId);
71
+ if (memberFromChannel) return upsertUser(memberFromChannel);
72
+ const memberFromList = users.find(it => it.userId === user.userId);
65
73
 
66
- onChannelMemberCountChanged(channels) {
67
- if (channels.find(c => c.url === channel.url)) forceUpdate();
74
+ if (memberFromList) {
75
+ memberFromList.isMuted = true;
76
+ upsertUser(memberFromList);
77
+ }
68
78
  },
69
79
 
70
- onChannelChanged(channel) {
71
- if (channel.url === activeChannel.url) forceUpdate();
72
- },
73
-
74
- onChannelFrozen(channel) {
75
- if (channel.url === activeChannel.url) forceUpdate();
76
- },
80
+ onUserUnmuted(eventChannel, user) {
81
+ if (isDifferentChannel(eventChannel, channel) || !eventChannel.isGroupChannel()) return;
82
+ const memberFromChannel = eventChannel.members.find(it => it.userId === user.userId);
83
+ if (memberFromChannel) return upsertUser(memberFromChannel);
84
+ const memberFromList = users.find(it => it.userId === user.userId);
77
85
 
78
- onChannelUnfrozen(channel) {
79
- if (channel.url === activeChannel.url) forceUpdate();
86
+ if (memberFromList) {
87
+ memberFromList.isMuted = false;
88
+ upsertUser(memberFromList);
89
+ }
80
90
  }
81
91
 
82
92
  });
@@ -86,11 +96,33 @@ const createGroupChannelMembersFragment = initModule => {
86
96
  return /*#__PURE__*/React.createElement(UserActionBar, {
87
97
  muted: user.isMuted,
88
98
  uri: user.profileUrl,
89
- label: user.role === 'operator' ? STRINGS.GROUP_CHANNEL_MEMBERS.USER_BAR_OPERATOR : '',
90
- name: (user.nickname || STRINGS.LABELS.USER_NO_NAME) + (user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) ? STRINGS.GROUP_CHANNEL_MEMBERS.USER_BAR_ME_POSTFIX : ''),
91
- disabled: user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId) // TODO: implement ban/mute actions, use channel.members with handlers instead member query
92
- ,
93
- onPressActionMenu: undefined,
99
+ label: user.role === 'operator' ? STRINGS.LABELS.USER_BAR_OPERATOR : '',
100
+ 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 : ''),
101
+ disabled: user.userId === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId),
102
+ onPressActionMenu: ifOperator(channel.myRole, () => {
103
+ const menuItems = [];
104
+ menuItems.push({
105
+ title: ifOperator(user.role, STRINGS.LABELS.UNREGISTER_OPERATOR, STRINGS.LABELS.REGISTER_AS_OPERATOR),
106
+ onPress: ifOperator(user.role, () => channel.removeOperators([user.userId]), () => channel.addOperators([user.userId]))
107
+ });
108
+
109
+ if (!channel.isBroadcast) {
110
+ menuItems.push({
111
+ title: ifMuted(user.isMuted, STRINGS.LABELS.UNMUTE, STRINGS.LABELS.MUTE),
112
+ onPress: ifMuted(user.isMuted, () => channel.unmuteUser(user), () => channel.muteUser(user))
113
+ });
114
+ }
115
+
116
+ menuItems.push({
117
+ title: STRINGS.LABELS.BAN,
118
+ style: 'destructive',
119
+ onPress: () => channel.banUser(user)
120
+ });
121
+ openMenu({
122
+ title: user.nickname || STRINGS.LABELS.USER_NO_NAME,
123
+ menuItems
124
+ });
125
+ }),
94
126
  onPressAvatar: () => show(user)
95
127
  });
96
128
  });
@@ -105,12 +137,19 @@ const createGroupChannelMembersFragment = initModule => {
105
137
  icon: 'plus'
106
138
  }),
107
139
  onPressHeaderRight: async () => onPressHeaderRight()
108
- }), /*#__PURE__*/React.createElement(UserListModule.List, {
109
- users: activeChannel.members,
140
+ }), /*#__PURE__*/React.createElement(StatusComposition, {
141
+ loading: loading,
142
+ LoadingComponent: /*#__PURE__*/React.createElement(UserListModule.StatusLoading, null),
143
+ error: Boolean(error),
144
+ ErrorComponent: /*#__PURE__*/React.createElement(UserListModule.StatusError, {
145
+ onPressRetry: refresh
146
+ })
147
+ }, /*#__PURE__*/React.createElement(UserListModule.List, {
148
+ users: users,
110
149
  renderUser: _renderUser,
111
- onLoadNext: async () => void 0,
150
+ onLoadNext: next,
112
151
  ListEmptyComponent: /*#__PURE__*/React.createElement(UserListModule.StatusEmpty, null)
113
- }));
152
+ })));
114
153
  };
115
154
  };
116
155
 
@@ -1 +1 @@
1
- {"version":3,"names":["React","useActiveGroupChannel","useChannelHandler","Icon","useForceUpdate","useFreshCallback","useUniqId","UserActionBar","createUserListModule","useLocalization","useProfileCard","useSendbirdChat","noop","name","createGroupChannelMembersFragment","initModule","UserListModule","channel","onPressHeaderLeft","onPressHeaderRight","renderUser","uniqId","forceUpdate","STRINGS","sdk","currentUser","show","activeChannel","onUserLeft","url","onUserJoined","onUserUnmuted","onUserUnbanned","onUserBanned","onUserMuted","onChannelMemberCountChanged","channels","find","c","onChannelChanged","onChannelFrozen","onChannelUnfrozen","_renderUser","user","selectedUsers","setSelectedUsers","isMuted","profileUrl","role","GROUP_CHANNEL_MEMBERS","USER_BAR_OPERATOR","nickname","LABELS","USER_NO_NAME","userId","USER_BAR_ME_POSTFIX","undefined","HEADER_TITLE","members"],"sources":["createGroupChannelMembersFragment.tsx"],"sourcesContent":["import React from 'react';\n\nimport { useActiveGroupChannel, useChannelHandler } from '@sendbird/uikit-chat-hooks';\nimport { Icon } from '@sendbird/uikit-react-native-foundation';\nimport type { SendbirdMember } from '@sendbird/uikit-utils';\nimport { useForceUpdate, useFreshCallback, useUniqId } from '@sendbird/uikit-utils';\n\nimport UserActionBar from '../components/UserActionBar';\nimport type { GroupChannelMembersFragment } from '../domain/groupChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useProfileCard, useSendbirdChat } from '../hooks/useContext';\n\nconst noop = () => '';\nconst name = 'createGroupChannelMembersFragment';\nconst createGroupChannelMembersFragment = (\n initModule?: Partial<UserListModule<SendbirdMember>>,\n): GroupChannelMembersFragment<SendbirdMember> => {\n const UserListModule = createUserListModule<SendbirdMember>(initModule);\n\n return ({ channel, onPressHeaderLeft, onPressHeaderRight, renderUser }) => {\n const uniqId = useUniqId(name);\n const forceUpdate = useForceUpdate();\n\n const { STRINGS } = useLocalization();\n const { sdk, currentUser } = useSendbirdChat();\n const { show } = useProfileCard();\n\n const { activeChannel } = useActiveGroupChannel(sdk, channel);\n\n useChannelHandler(sdk, `${name}_${uniqId}`, {\n // Note: Removed from v4\n // onUserEntered(channel) {\n // if (channel.url === activeChannel.url) forceUpdate();\n // },\n onUserLeft(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onUserJoined(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onUserUnmuted(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onUserUnbanned(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onUserBanned(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onUserMuted(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onChannelMemberCountChanged(channels) {\n if (channels.find((c) => c.url === channel.url)) forceUpdate();\n },\n onChannelChanged(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onChannelFrozen(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n onChannelUnfrozen(channel) {\n if (channel.url === activeChannel.url) forceUpdate();\n },\n });\n\n const _renderUser: NonNullable<typeof renderUser> = useFreshCallback((user, selectedUsers, setSelectedUsers) => {\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n return (\n <UserActionBar\n muted={user.isMuted}\n uri={user.profileUrl}\n label={user.role === 'operator' ? STRINGS.GROUP_CHANNEL_MEMBERS.USER_BAR_OPERATOR : ''}\n name={\n (user.nickname || STRINGS.LABELS.USER_NO_NAME) +\n (user.userId === currentUser?.userId ? STRINGS.GROUP_CHANNEL_MEMBERS.USER_BAR_ME_POSTFIX : '')\n }\n disabled={user.userId === currentUser?.userId}\n // TODO: implement ban/mute actions, use channel.members with handlers instead member query\n onPressActionMenu={undefined}\n onPressAvatar={() => show(user)}\n />\n );\n });\n\n return (\n <UserListModule.Provider headerRight={noop} headerTitle={STRINGS.GROUP_CHANNEL_MEMBERS.HEADER_TITLE}>\n <UserListModule.Header\n shouldActivateHeaderRight={() => true}\n onPressHeaderLeft={onPressHeaderLeft}\n right={<Icon icon={'plus'} />}\n onPressHeaderRight={async () => onPressHeaderRight()}\n />\n\n <UserListModule.List\n users={activeChannel.members}\n renderUser={_renderUser}\n onLoadNext={async () => void 0}\n ListEmptyComponent={<UserListModule.StatusEmpty />}\n />\n </UserListModule.Provider>\n );\n };\n};\n\nexport default createGroupChannelMembersFragment;\n"],"mappings":"AAAA,OAAOA,KAAP,MAAkB,OAAlB;AAEA,SAASC,qBAAT,EAAgCC,iBAAhC,QAAyD,4BAAzD;AACA,SAASC,IAAT,QAAqB,yCAArB;AAEA,SAASC,cAAT,EAAyBC,gBAAzB,EAA2CC,SAA3C,QAA4D,uBAA5D;AAEA,OAAOC,aAAP,MAA0B,6BAA1B;AAEA,OAAOC,oBAAP,MAAiC,gDAAjC;AAEA,SAASC,eAAT,EAA0BC,cAA1B,EAA0CC,eAA1C,QAAiE,qBAAjE;;AAEA,MAAMC,IAAI,GAAG,MAAM,EAAnB;;AACA,MAAMC,IAAI,GAAG,mCAAb;;AACA,MAAMC,iCAAiC,GACrCC,UADwC,IAEQ;EAChD,MAAMC,cAAc,GAAGR,oBAAoB,CAAiBO,UAAjB,CAA3C;EAEA,OAAO,QAAoE;IAAA,IAAnE;MAAEE,OAAF;MAAWC,iBAAX;MAA8BC,kBAA9B;MAAkDC;IAAlD,CAAmE;IACzE,MAAMC,MAAM,GAAGf,SAAS,CAACO,IAAD,CAAxB;IACA,MAAMS,WAAW,GAAGlB,cAAc,EAAlC;IAEA,MAAM;MAAEmB;IAAF,IAAcd,eAAe,EAAnC;IACA,MAAM;MAAEe,GAAF;MAAOC;IAAP,IAAuBd,eAAe,EAA5C;IACA,MAAM;MAAEe;IAAF,IAAWhB,cAAc,EAA/B;IAEA,MAAM;MAAEiB;IAAF,IAAoB1B,qBAAqB,CAACuB,GAAD,EAAMP,OAAN,CAA/C;IAEAf,iBAAiB,CAACsB,GAAD,EAAO,GAAEX,IAAK,IAAGQ,MAAO,EAAxB,EAA2B;MAC1C;MACA;MACA;MACA;MACAO,UAAU,CAACX,OAAD,EAAU;QAClB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAPyC;;MAQ1CQ,YAAY,CAACb,OAAD,EAAU;QACpB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAVyC;;MAW1CS,aAAa,CAACd,OAAD,EAAU;QACrB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAbyC;;MAc1CU,cAAc,CAACf,OAAD,EAAU;QACtB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAhByC;;MAiB1CW,YAAY,CAAChB,OAAD,EAAU;QACpB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAnByC;;MAoB1CY,WAAW,CAACjB,OAAD,EAAU;QACnB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CAtByC;;MAuB1Ca,2BAA2B,CAACC,QAAD,EAAW;QACpC,IAAIA,QAAQ,CAACC,IAAT,CAAeC,CAAD,IAAOA,CAAC,CAACT,GAAF,KAAUZ,OAAO,CAACY,GAAvC,CAAJ,EAAiDP,WAAW;MAC7D,CAzByC;;MA0B1CiB,gBAAgB,CAACtB,OAAD,EAAU;QACxB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CA5ByC;;MA6B1CkB,eAAe,CAACvB,OAAD,EAAU;QACvB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD,CA/ByC;;MAgC1CmB,iBAAiB,CAACxB,OAAD,EAAU;QACzB,IAAIA,OAAO,CAACY,GAAR,KAAgBF,aAAa,CAACE,GAAlC,EAAuCP,WAAW;MACnD;;IAlCyC,CAA3B,CAAjB;;IAqCA,MAAMoB,WAA2C,GAAGrC,gBAAgB,CAAC,CAACsC,IAAD,EAAOC,aAAP,EAAsBC,gBAAtB,KAA2C;MAC9G,IAAIzB,UAAJ,EAAgB,OAAOA,UAAU,CAACuB,IAAD,EAAOC,aAAP,EAAsBC,gBAAtB,CAAjB;MAEhB,oBACE,oBAAC,aAAD;QACE,KAAK,EAAEF,IAAI,CAACG,OADd;QAEE,GAAG,EAAEH,IAAI,CAACI,UAFZ;QAGE,KAAK,EAAEJ,IAAI,CAACK,IAAL,KAAc,UAAd,GAA2BzB,OAAO,CAAC0B,qBAAR,CAA8BC,iBAAzD,GAA6E,EAHtF;QAIE,IAAI,EACF,CAACP,IAAI,CAACQ,QAAL,IAAiB5B,OAAO,CAAC6B,MAAR,CAAeC,YAAjC,KACCV,IAAI,CAACW,MAAL,MAAgB7B,WAAhB,aAAgBA,WAAhB,uBAAgBA,WAAW,CAAE6B,MAA7B,IAAsC/B,OAAO,CAAC0B,qBAAR,CAA8BM,mBAApE,GAA0F,EAD3F,CALJ;QAQE,QAAQ,EAAEZ,IAAI,CAACW,MAAL,MAAgB7B,WAAhB,aAAgBA,WAAhB,uBAAgBA,WAAW,CAAE6B,MAA7B,CARZ,CASE;QATF;QAUE,iBAAiB,EAAEE,SAVrB;QAWE,aAAa,EAAE,MAAM9B,IAAI,CAACiB,IAAD;MAX3B,EADF;IAeD,CAlBmE,CAApE;;IAoBA,oBACE,oBAAC,cAAD,CAAgB,QAAhB;MAAyB,WAAW,EAAE/B,IAAtC;MAA4C,WAAW,EAAEW,OAAO,CAAC0B,qBAAR,CAA8BQ;IAAvF,gBACE,oBAAC,cAAD,CAAgB,MAAhB;MACE,yBAAyB,EAAE,MAAM,IADnC;MAEE,iBAAiB,EAAEvC,iBAFrB;MAGE,KAAK,eAAE,oBAAC,IAAD;QAAM,IAAI,EAAE;MAAZ,EAHT;MAIE,kBAAkB,EAAE,YAAYC,kBAAkB;IAJpD,EADF,eAQE,oBAAC,cAAD,CAAgB,IAAhB;MACE,KAAK,EAAEQ,aAAa,CAAC+B,OADvB;MAEE,UAAU,EAAEhB,WAFd;MAGE,UAAU,EAAE,YAAY,KAAK,CAH/B;MAIE,kBAAkB,eAAE,oBAAC,cAAD,CAAgB,WAAhB;IAJtB,EARF,CADF;EAiBD,CApFD;AAqFD,CA1FD;;AA4FA,eAAe5B,iCAAf"}
1
+ {"version":3,"names":["React","useRef","useChannelHandler","useUserList","Icon","useActionMenu","ifMuted","ifOperator","isDifferentChannel","useFreshCallback","useUniqId","StatusComposition","UserActionBar","createUserListModule","useLocalization","useSendbirdChat","useUserProfile","noop","HOOK_NAME","createGroupChannelMembersFragment","initModule","UserListModule","channel","onPressHeaderLeft","onPressHeaderRight","renderUser","uniqId","refreshSchedule","STRINGS","sdk","currentUser","openMenu","show","users","refresh","loading","next","error","upsertUser","deleteUser","queryCreator","createMemberListQuery","limit","onUserLeft","eventChannel","user","userId","onUserBanned","onOperatorUpdated","current","clearTimeout","setTimeout","onUserMuted","isGroupChannel","memberFromChannel","members","find","it","memberFromList","isMuted","onUserUnmuted","_renderUser","selectedUsers","setSelectedUsers","profileUrl","role","LABELS","USER_BAR_OPERATOR","nickname","USER_NO_NAME","USER_BAR_ME_POSTFIX","myRole","menuItems","push","title","UNREGISTER_OPERATOR","REGISTER_AS_OPERATOR","onPress","removeOperators","addOperators","isBroadcast","UNMUTE","MUTE","unmuteUser","muteUser","BAN","style","banUser","GROUP_CHANNEL_MEMBERS","HEADER_TITLE","Boolean"],"sources":["createGroupChannelMembersFragment.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 { Icon, useActionMenu } from '@sendbird/uikit-react-native-foundation';\nimport type { SendbirdMember } from '@sendbird/uikit-utils';\nimport { ifMuted, ifOperator, isDifferentChannel, useFreshCallback, useUniqId } from '@sendbird/uikit-utils';\n\nimport StatusComposition from '../components/StatusComposition';\nimport UserActionBar from '../components/UserActionBar';\nimport type { GroupChannelMembersFragment } from '../domain/groupChannelUserList/types';\nimport createUserListModule from '../domain/userList/module/createUserListModule';\nimport type { UserListModule } from '../domain/userList/types';\nimport { useLocalization, useSendbirdChat, useUserProfile } from '../hooks/useContext';\n\nconst noop = () => '';\nconst HOOK_NAME = 'createGroupChannelMembersFragment';\nconst createGroupChannelMembersFragment = (\n initModule?: Partial<UserListModule<SendbirdMember>>,\n): GroupChannelMembersFragment<SendbirdMember> => {\n const UserListModule = createUserListModule<SendbirdMember>(initModule);\n\n return ({ channel, onPressHeaderLeft, onPressHeaderRight, renderUser }) => {\n const uniqId = useUniqId(HOOK_NAME);\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.createMemberListQuery({ limit: 20 }),\n });\n\n useChannelHandler(sdk, `${HOOK_NAME}_${uniqId}`, {\n onUserLeft(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.isGroupChannel()) return;\n\n const memberFromChannel = eventChannel.members.find((it) => it.userId === user.userId);\n if (memberFromChannel) return upsertUser(memberFromChannel);\n\n const memberFromList = users.find((it) => it.userId === user.userId);\n if (memberFromList) {\n memberFromList.isMuted = true;\n upsertUser(memberFromList);\n }\n },\n onUserUnmuted(eventChannel, user) {\n if (isDifferentChannel(eventChannel, channel) || !eventChannel.isGroupChannel()) return;\n\n const memberFromChannel = eventChannel.members.find((it) => it.userId === user.userId);\n if (memberFromChannel) return upsertUser(memberFromChannel);\n\n const memberFromList = users.find((it) => it.userId === user.userId);\n if (memberFromList) {\n memberFromList.isMuted = false;\n upsertUser(memberFromList);\n }\n },\n });\n\n const _renderUser: NonNullable<typeof renderUser> = useFreshCallback((user, selectedUsers, setSelectedUsers) => {\n if (renderUser) return renderUser(user, selectedUsers, setSelectedUsers);\n\n return (\n <UserActionBar\n muted={user.isMuted}\n uri={user.profileUrl}\n label={user.role === 'operator' ? 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={ifOperator(channel.myRole, () => {\n const menuItems: ActionMenuItem['menuItems'] = [];\n\n menuItems.push({\n title: ifOperator(user.role, STRINGS.LABELS.UNREGISTER_OPERATOR, STRINGS.LABELS.REGISTER_AS_OPERATOR),\n onPress: ifOperator(\n user.role,\n () => channel.removeOperators([user.userId]),\n () => channel.addOperators([user.userId]),\n ),\n });\n\n if (!channel.isBroadcast) {\n menuItems.push({\n title: ifMuted(user.isMuted, STRINGS.LABELS.UNMUTE, STRINGS.LABELS.MUTE),\n onPress: ifMuted(\n user.isMuted,\n () => channel.unmuteUser(user),\n () => channel.muteUser(user),\n ),\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 headerRight={noop} headerTitle={STRINGS.GROUP_CHANNEL_MEMBERS.HEADER_TITLE}>\n <UserListModule.Header\n shouldActivateHeaderRight={() => true}\n onPressHeaderLeft={onPressHeaderLeft}\n right={<Icon icon={'plus'} />}\n onPressHeaderRight={async () => onPressHeaderRight()}\n />\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}\n renderUser={_renderUser}\n onLoadNext={next}\n ListEmptyComponent={<UserListModule.StatusEmpty />}\n />\n </StatusComposition>\n </UserListModule.Provider>\n );\n };\n};\n\nexport default createGroupChannelMembersFragment;\n"],"mappings":"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"}
@@ -0,0 +1,53 @@
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 { createGroupChannelModerationModule } from '../domain/groupChannelModeration';
7
+
8
+ const createGroupChannelModerationFragment = initModule => {
9
+ const GroupChannelModerationModule = createGroupChannelModerationModule(initModule);
10
+ return _ref => {
11
+ let {
12
+ channel,
13
+ onPressHeaderLeft = NOOP,
14
+ onPressMenuBannedUsers,
15
+ onPressMenuMutedMembers,
16
+ onPressMenuOperators,
17
+ menuItemsCreator
18
+ } = _ref;
19
+ const {
20
+ left,
21
+ right
22
+ } = useSafeAreaInsets();
23
+ const {
24
+ colors
25
+ } = useUIKitTheme();
26
+ return /*#__PURE__*/React.createElement(GroupChannelModerationModule.Provider, {
27
+ channel: channel
28
+ }, /*#__PURE__*/React.createElement(GroupChannelModerationModule.Header, {
29
+ onPressHeaderLeft: onPressHeaderLeft
30
+ }), /*#__PURE__*/React.createElement(ScrollView, {
31
+ style: {
32
+ backgroundColor: colors.background
33
+ },
34
+ contentContainerStyle: {
35
+ paddingLeft: left + styles.viewContainer.paddingHorizontal,
36
+ paddingRight: right + styles.viewContainer.paddingHorizontal
37
+ }
38
+ }, /*#__PURE__*/React.createElement(GroupChannelModerationModule.Menu, {
39
+ onPressMenuBannedUsers: onPressMenuBannedUsers,
40
+ onPressMenuMutedMembers: onPressMenuMutedMembers,
41
+ onPressMenuOperators: onPressMenuOperators,
42
+ menuItemsCreator: menuItemsCreator
43
+ })));
44
+ };
45
+ };
46
+
47
+ const styles = createStyleSheet({
48
+ viewContainer: {
49
+ paddingHorizontal: 16
50
+ }
51
+ });
52
+ export default createGroupChannelModerationFragment;
53
+ //# sourceMappingURL=createGroupChannelModerationFragment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","ScrollView","useSafeAreaInsets","createStyleSheet","useUIKitTheme","NOOP","createGroupChannelModerationModule","createGroupChannelModerationFragment","initModule","GroupChannelModerationModule","channel","onPressHeaderLeft","onPressMenuBannedUsers","onPressMenuMutedMembers","onPressMenuOperators","menuItemsCreator","left","right","colors","backgroundColor","background","paddingLeft","styles","viewContainer","paddingHorizontal","paddingRight"],"sources":["createGroupChannelModerationFragment.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 { createGroupChannelModerationModule } from '../domain/groupChannelModeration';\nimport type {\n GroupChannelModerationFragment,\n GroupChannelModerationModule,\n} from '../domain/groupChannelModeration/types';\n\nconst createGroupChannelModerationFragment = (\n initModule?: Partial<GroupChannelModerationModule>,\n): GroupChannelModerationFragment => {\n const GroupChannelModerationModule = createGroupChannelModerationModule(initModule);\n\n return ({\n channel,\n onPressHeaderLeft = NOOP,\n onPressMenuBannedUsers,\n onPressMenuMutedMembers,\n onPressMenuOperators,\n menuItemsCreator,\n }) => {\n const { left, right } = useSafeAreaInsets();\n const { colors } = useUIKitTheme();\n return (\n <GroupChannelModerationModule.Provider channel={channel}>\n <GroupChannelModerationModule.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 <GroupChannelModerationModule.Menu\n onPressMenuBannedUsers={onPressMenuBannedUsers}\n onPressMenuMutedMembers={onPressMenuMutedMembers}\n onPressMenuOperators={onPressMenuOperators}\n menuItemsCreator={menuItemsCreator}\n />\n </ScrollView>\n </GroupChannelModerationModule.Provider>\n );\n };\n};\n\nconst styles = createStyleSheet({\n viewContainer: {\n paddingHorizontal: 16,\n },\n});\n\nexport default createGroupChannelModerationFragment;\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,kCAAT,QAAmD,kCAAnD;;AAMA,MAAMC,oCAAoC,GACxCC,UAD2C,IAER;EACnC,MAAMC,4BAA4B,GAAGH,kCAAkC,CAACE,UAAD,CAAvE;EAEA,OAAO,QAOD;IAAA,IAPE;MACNE,OADM;MAENC,iBAAiB,GAAGN,IAFd;MAGNO,sBAHM;MAINC,uBAJM;MAKNC,oBALM;MAMNC;IANM,CAOF;IACJ,MAAM;MAAEC,IAAF;MAAQC;IAAR,IAAkBf,iBAAiB,EAAzC;IACA,MAAM;MAAEgB;IAAF,IAAad,aAAa,EAAhC;IACA,oBACE,oBAAC,4BAAD,CAA8B,QAA9B;MAAuC,OAAO,EAAEM;IAAhD,gBACE,oBAAC,4BAAD,CAA8B,MAA9B;MAAqC,iBAAiB,EAAEC;IAAxD,EADF,eAEE,oBAAC,UAAD;MACE,KAAK,EAAE;QAAEQ,eAAe,EAAED,MAAM,CAACE;MAA1B,CADT;MAEE,qBAAqB,EAAE;QACrBC,WAAW,EAAEL,IAAI,GAAGM,MAAM,CAACC,aAAP,CAAqBC,iBADpB;QAErBC,YAAY,EAAER,KAAK,GAAGK,MAAM,CAACC,aAAP,CAAqBC;MAFtB;IAFzB,gBAOE,oBAAC,4BAAD,CAA8B,IAA9B;MACE,sBAAsB,EAAEZ,sBAD1B;MAEE,uBAAuB,EAAEC,uBAF3B;MAGE,oBAAoB,EAAEC,oBAHxB;MAIE,gBAAgB,EAAEC;IAJpB,EAPF,CAFF,CADF;EAmBD,CA7BD;AA8BD,CAnCD;;AAqCA,MAAMO,MAAM,GAAGnB,gBAAgB,CAAC;EAC9BoB,aAAa,EAAE;IACbC,iBAAiB,EAAE;EADN;AADe,CAAD,CAA/B;AAMA,eAAejB,oCAAf"}