@tencentcloud/chat-uikit-react 2.2.6 → 2.2.8

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 (765) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/cjs/_virtual/index.js +1 -0
  3. package/dist/cjs/assets/fonts/iconfont.ttf +0 -0
  4. package/dist/cjs/assets/fonts/iconfont.woff +0 -0
  5. package/dist/cjs/assets/fonts/iconfont.woff2 +0 -0
  6. package/dist/cjs/components/Avatar/Avatar.d.ts +1 -1
  7. package/dist/cjs/components/{TUIChat/TUIChat.d.ts → Chat/Chat.d.ts} +11 -10
  8. package/dist/cjs/components/Chat/Chat.js +1 -0
  9. package/dist/cjs/components/Chat/ChatState.js +1 -0
  10. package/dist/cjs/components/Chat/index.js +1 -0
  11. package/dist/cjs/components/Chat/server.js +1 -0
  12. package/dist/cjs/components/Chat/utils.js +1 -0
  13. package/dist/cjs/components/{TUIChatHeader/TUIChatHeader.d.ts → ChatHeader/ChatHeader.d.ts} +4 -3
  14. package/dist/cjs/components/ChatHeader/ChatHeader.js +1 -0
  15. package/dist/cjs/components/{TUIChatHeader/TUIChatHeaderDefault.d.ts → ChatHeader/ChatHeaderDefault.d.ts} +4 -3
  16. package/dist/cjs/components/ChatHeader/ChatHeaderDefault.js +1 -0
  17. package/dist/cjs/components/ChatSetting/ChatSetting.d.ts +6 -0
  18. package/dist/cjs/components/ChatSetting/ChatSetting.js +1 -0
  19. package/dist/cjs/components/Contact/Contact.d.ts +6 -0
  20. package/dist/cjs/components/Contact/Contact.js +1 -0
  21. package/dist/cjs/components/Contact/ContactInfo/ContactInfo.d.ts +10 -0
  22. package/dist/cjs/components/Contact/ContactInfo/ContactInfo.js +1 -0
  23. package/dist/cjs/components/Contact/ContactInfo/basicInfo.js +1 -0
  24. package/dist/cjs/components/Contact/ContactInfo/blockInfo.js +1 -0
  25. package/dist/cjs/components/Contact/ContactInfo/friendApplication.js +1 -0
  26. package/dist/cjs/components/Contact/ContactInfo/friendInfo.js +1 -0
  27. package/dist/cjs/components/Contact/ContactInfo/groupInfo.js +1 -0
  28. package/dist/cjs/components/Contact/ContactInfo/hooks/useContactInfo.js +1 -0
  29. package/dist/cjs/components/Contact/ContactList/ContactList.d.ts +6 -0
  30. package/dist/cjs/components/Contact/ContactList/ContactList.js +1 -0
  31. package/dist/cjs/components/Contact/hooks/useTUIContact.js +1 -0
  32. package/dist/cjs/components/ContactSearch/ContactSearch.js +1 -0
  33. package/dist/cjs/components/ContactSearch/hooks/useContactSearch.js +1 -0
  34. package/dist/cjs/components/ConversationActions/ConversationActions.d.ts +52 -0
  35. package/dist/cjs/components/ConversationActions/ConversationActions.js +1 -0
  36. package/dist/cjs/components/ConversationCreate/ConversationCreate.d.ts +21 -0
  37. package/dist/cjs/components/ConversationCreate/ConversationCreate.js +1 -1
  38. package/dist/cjs/components/ConversationCreate/ConversationCreateButton.d.ts +13 -0
  39. package/dist/cjs/components/ConversationCreate/ConversationCreateButton.js +1 -0
  40. package/dist/cjs/components/ConversationCreate/ConversationCreateGroupDetail.d.ts +16 -0
  41. package/dist/cjs/components/ConversationCreate/ConversationCreateGroupDetail.js +1 -0
  42. package/dist/cjs/components/ConversationCreate/ConversationCreateSelectView.d.ts +15 -0
  43. package/dist/cjs/components/ConversationCreate/ConversationCreateUserSelectList.d.ts +18 -0
  44. package/dist/cjs/components/ConversationCreate/ConversationCreateUserSelectList.js +1 -1
  45. package/dist/cjs/components/ConversationCreate/ConversationGroupTypeInfo.d.ts +24 -0
  46. package/dist/cjs/components/ConversationCreate/ConversationGroupTypeInfo.js +1 -1
  47. package/dist/cjs/components/ConversationCreate/hooks/useConversationCreate.d.ts +14 -0
  48. package/dist/cjs/components/ConversationCreate/hooks/useConversationCreate.js +1 -1
  49. package/dist/cjs/components/ConversationList/ConversationList.d.ts +57 -0
  50. package/dist/cjs/components/ConversationList/ConversationList.js +1 -0
  51. package/dist/cjs/components/ConversationList/ConversationListContent/ConversationListContent.d.ts +23 -0
  52. package/dist/cjs/components/ConversationList/ConversationListContent/ConversationListContent.js +1 -0
  53. package/dist/cjs/components/ConversationList/ConversationListHeader/ConversationListHeader.d.ts +15 -0
  54. package/dist/cjs/components/ConversationList/ConversationListHeader/ConversationListHeader.js +1 -0
  55. package/dist/cjs/components/ConversationPreview/ConversationPreview.d.ts +39 -27
  56. package/dist/cjs/components/ConversationPreview/ConversationPreview.js +1 -1
  57. package/dist/cjs/components/ConversationPreview/utils.js +1 -1
  58. package/dist/cjs/components/ConversationSearch/ConversationSearch.d.ts +39 -0
  59. package/dist/cjs/components/ConversationSearch/ConversationSearch.js +1 -0
  60. package/dist/cjs/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.d.ts +7 -0
  61. package/dist/cjs/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.js +1 -0
  62. package/dist/cjs/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.d.ts +29 -0
  63. package/dist/cjs/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.js +1 -0
  64. package/dist/cjs/components/Icon/Icon.js +1 -1
  65. package/dist/cjs/components/Icon/config.js +1 -1
  66. package/dist/cjs/components/Icon/images/mute.svg.js +1 -0
  67. package/dist/cjs/components/Icon/images/video-call.svg.js +1 -0
  68. package/dist/cjs/components/Icon/images/voice-call.svg.js +1 -0
  69. package/dist/cjs/components/Icon/type.d.ts +5 -1
  70. package/dist/cjs/components/Icon/type.js +1 -1
  71. package/dist/cjs/components/Input/Input.d.ts +5 -2
  72. package/dist/cjs/components/Input/Input.js +1 -1
  73. package/dist/{esm/components/TUIMessage/TUIMessage.d.ts → cjs/components/MessageElement/Message.d.ts} +1 -1
  74. package/dist/cjs/components/MessageElement/Message.js +1 -0
  75. package/dist/cjs/components/MessageElement/MessageAudio.js +1 -0
  76. package/dist/cjs/components/MessageElement/MessageAvatar.js +1 -0
  77. package/dist/cjs/components/MessageElement/MessageBubble.js +1 -0
  78. package/dist/cjs/components/MessageElement/MessageContext.js +1 -0
  79. package/dist/cjs/components/MessageElement/MessageCustom.js +1 -0
  80. package/dist/cjs/components/MessageElement/MessageDefault.js +1 -0
  81. package/dist/cjs/components/MessageElement/MessageName.js +1 -0
  82. package/dist/cjs/components/MessageElement/MessagePlugins.js +1 -0
  83. package/dist/cjs/components/MessageElement/MessageProgress.js +1 -0
  84. package/dist/cjs/components/MessageElement/MessageRevoke.js +1 -0
  85. package/dist/cjs/components/MessageElement/MessageStatus.js +1 -0
  86. package/dist/cjs/components/MessageElement/MessageSystem.js +1 -0
  87. package/dist/cjs/components/MessageElement/MessageText.js +1 -0
  88. package/dist/cjs/components/MessageElement/MessageTip.js +1 -0
  89. package/dist/cjs/components/MessageElement/hooks/useMessageHandler.js +1 -0
  90. package/dist/cjs/components/MessageElement/hooks/useMessageReply.js +1 -0
  91. package/dist/cjs/components/MessageElement/utils/index.js +1 -0
  92. package/dist/cjs/components/MessageInput/EmojiPicker.js +1 -0
  93. package/dist/cjs/components/MessageInput/Forward.js +1 -0
  94. package/dist/cjs/components/MessageInput/InputPluginsDefalut.js +1 -0
  95. package/dist/cjs/components/MessageInput/InputQuoteDefalut.js +1 -0
  96. package/dist/cjs/components/{TUIMessageInput/TUIMessageInput.d.ts → MessageInput/MessageInput.d.ts} +4 -4
  97. package/dist/cjs/components/MessageInput/MessageInput.js +1 -0
  98. package/dist/cjs/components/MessageInput/MessageInputDefault.js +1 -0
  99. package/dist/cjs/components/MessageInput/Transmitter.js +1 -0
  100. package/dist/cjs/components/MessageInput/hooks/useEmojiPicker.js +1 -0
  101. package/dist/cjs/components/MessageInput/hooks/useHandleForwardMessage.js +1 -0
  102. package/dist/cjs/components/MessageInput/hooks/useHandleQuoteMessage.js +1 -0
  103. package/dist/cjs/components/MessageInput/hooks/useMessageInputText.js +1 -0
  104. package/dist/cjs/components/MessageInput/hooks/useUploadPicker.js +1 -0
  105. package/dist/cjs/components/{TUIMessageList/TUIMessageList.d.ts → MessageList/MessageList.d.ts} +3 -3
  106. package/dist/cjs/components/MessageList/MessageList.js +1 -0
  107. package/dist/cjs/components/MessageList/hooks/useMessageListElement.js +1 -0
  108. package/dist/cjs/components/PlaceHolder/index.d.ts +34 -0
  109. package/dist/cjs/components/PlaceHolder/index.js +1 -0
  110. package/dist/cjs/components/Plugins/index.d.ts +5 -2
  111. package/dist/cjs/components/Profile/Profile.d.ts +10 -0
  112. package/dist/cjs/components/Profile/Profile.js +1 -1
  113. package/dist/cjs/components/Profile/ProfileDefault.js +1 -0
  114. package/dist/cjs/components/Profile/myProfile/MyProfile.js +1 -0
  115. package/dist/cjs/components/{untils.js → utils.js} +1 -1
  116. package/dist/cjs/context/{TUIChatActionContext.d.ts → ChatActionContext.d.ts} +3 -2
  117. package/dist/{esm/context/TUIChatStateContext.d.ts → cjs/context/ChatStateContext.d.ts} +6 -6
  118. package/dist/cjs/context/ComponentContext.d.ts +3 -3
  119. package/dist/cjs/context/{TUIContactContext.d.ts → ContactContext.d.ts} +4 -4
  120. package/dist/cjs/context/ConversationListContext.d.ts +22 -0
  121. package/dist/cjs/context/ConversationListContext.js +1 -0
  122. package/dist/cjs/context/LanguageContext.js +1 -1
  123. package/dist/{esm/context/TUIMessageContext.d.ts → cjs/context/MessageContext.d.ts} +1 -1
  124. package/dist/{esm/context/TUIMessageInputContext.d.ts → cjs/context/MessageInputContext.d.ts} +4 -4
  125. package/dist/cjs/context/ThemeContext.js +1 -1
  126. package/dist/cjs/context/UIKitContext.d.ts +2 -2
  127. package/dist/cjs/context/UIKitContext.js +1 -1
  128. package/dist/cjs/hooks/useConversation.d.ts +4 -23
  129. package/dist/cjs/hooks/useConversation.js +1 -1
  130. package/dist/cjs/hooks/useLongPress.d.ts +3 -0
  131. package/dist/cjs/hooks/useLongPress.js +1 -0
  132. package/dist/cjs/hooks/useMouseHover.js +1 -0
  133. package/dist/cjs/index.css +2 -1
  134. package/dist/cjs/index.d.css +1376 -568
  135. package/dist/cjs/index.d.ts +41 -29
  136. package/dist/cjs/index.js +1 -1
  137. package/dist/cjs/locales/en-US/TUIConversation.js +1 -1
  138. package/dist/cjs/locales/en-US/index.js +1 -1
  139. package/dist/cjs/locales/index.js +1 -1
  140. package/dist/cjs/locales/ja-JP/TUIConversation.js +1 -1
  141. package/dist/cjs/locales/ja-JP/index.js +1 -1
  142. package/dist/cjs/locales/ko-KR/TUIConversation.js +1 -1
  143. package/dist/cjs/locales/ko-KR/index.js +1 -1
  144. package/dist/cjs/locales/zh-CN/TUIConversation.js +1 -1
  145. package/dist/cjs/locales/zh-CN/index.js +1 -1
  146. package/dist/cjs/locales/zh-TW/TUIChat.js +1 -0
  147. package/dist/cjs/locales/zh-TW/TUIContact.js +1 -0
  148. package/dist/cjs/locales/zh-TW/TUIConversation.js +1 -0
  149. package/dist/cjs/locales/zh-TW/TUIProfile.js +1 -0
  150. package/dist/cjs/locales/zh-TW/index.js +1 -0
  151. package/dist/esm/_virtual/index.js +1 -0
  152. package/dist/esm/assets/fonts/iconfont.ttf +0 -0
  153. package/dist/esm/assets/fonts/iconfont.woff +0 -0
  154. package/dist/esm/assets/fonts/iconfont.woff2 +0 -0
  155. package/dist/esm/components/Avatar/Avatar.d.ts +1 -1
  156. package/dist/esm/components/{TUIChat/TUIChat.d.ts → Chat/Chat.d.ts} +11 -10
  157. package/dist/esm/components/Chat/Chat.js +1 -0
  158. package/dist/esm/components/Chat/ChatState.js +1 -0
  159. package/dist/esm/components/Chat/index.js +1 -0
  160. package/dist/esm/components/Chat/server.js +1 -0
  161. package/dist/esm/components/Chat/utils.js +1 -0
  162. package/dist/esm/components/{TUIChatHeader/TUIChatHeader.d.ts → ChatHeader/ChatHeader.d.ts} +4 -3
  163. package/dist/esm/components/ChatHeader/ChatHeader.js +1 -0
  164. package/dist/esm/components/{TUIChatHeader/TUIChatHeaderDefault.d.ts → ChatHeader/ChatHeaderDefault.d.ts} +4 -3
  165. package/dist/esm/components/ChatHeader/ChatHeaderDefault.js +1 -0
  166. package/dist/esm/components/ChatSetting/ChatSetting.d.ts +6 -0
  167. package/dist/esm/components/ChatSetting/ChatSetting.js +1 -0
  168. package/dist/esm/components/Contact/Contact.d.ts +6 -0
  169. package/dist/esm/components/Contact/Contact.js +1 -0
  170. package/dist/esm/components/Contact/ContactInfo/ContactInfo.d.ts +10 -0
  171. package/dist/esm/components/Contact/ContactInfo/ContactInfo.js +1 -0
  172. package/dist/esm/components/Contact/ContactInfo/basicInfo.js +1 -0
  173. package/dist/esm/components/Contact/ContactInfo/blockInfo.js +1 -0
  174. package/dist/esm/components/Contact/ContactInfo/friendApplication.js +1 -0
  175. package/dist/esm/components/Contact/ContactInfo/friendInfo.js +1 -0
  176. package/dist/esm/components/Contact/ContactInfo/groupInfo.js +1 -0
  177. package/dist/esm/components/Contact/ContactInfo/hooks/useContactInfo.js +1 -0
  178. package/dist/esm/components/Contact/ContactList/ContactList.d.ts +6 -0
  179. package/dist/esm/components/Contact/ContactList/ContactList.js +1 -0
  180. package/dist/esm/components/Contact/hooks/useTUIContact.js +1 -0
  181. package/dist/esm/components/ContactSearch/ContactSearch.js +1 -0
  182. package/dist/esm/components/ContactSearch/hooks/useContactSearch.js +1 -0
  183. package/dist/esm/components/ConversationActions/ConversationActions.d.ts +52 -0
  184. package/dist/esm/components/ConversationActions/ConversationActions.js +1 -0
  185. package/dist/esm/components/ConversationCreate/ConversationCreate.d.ts +21 -0
  186. package/dist/esm/components/ConversationCreate/ConversationCreate.js +1 -1
  187. package/dist/esm/components/ConversationCreate/ConversationCreateButton.d.ts +13 -0
  188. package/dist/esm/components/ConversationCreate/ConversationCreateButton.js +1 -0
  189. package/dist/esm/components/ConversationCreate/ConversationCreateGroupDetail.d.ts +16 -0
  190. package/dist/esm/components/ConversationCreate/ConversationCreateGroupDetail.js +1 -0
  191. package/dist/esm/components/ConversationCreate/ConversationCreateSelectView.d.ts +15 -0
  192. package/dist/esm/components/ConversationCreate/ConversationCreateUserSelectList.d.ts +18 -0
  193. package/dist/esm/components/ConversationCreate/ConversationCreateUserSelectList.js +1 -1
  194. package/dist/esm/components/ConversationCreate/ConversationGroupTypeInfo.d.ts +24 -0
  195. package/dist/esm/components/ConversationCreate/ConversationGroupTypeInfo.js +1 -1
  196. package/dist/esm/components/ConversationCreate/hooks/useConversationCreate.d.ts +14 -0
  197. package/dist/esm/components/ConversationCreate/hooks/useConversationCreate.js +1 -1
  198. package/dist/esm/components/ConversationList/ConversationList.d.ts +57 -0
  199. package/dist/esm/components/ConversationList/ConversationList.js +1 -0
  200. package/dist/esm/components/ConversationList/ConversationListContent/ConversationListContent.d.ts +23 -0
  201. package/dist/esm/components/ConversationList/ConversationListContent/ConversationListContent.js +1 -0
  202. package/dist/esm/components/ConversationList/ConversationListHeader/ConversationListHeader.d.ts +15 -0
  203. package/dist/esm/components/ConversationList/ConversationListHeader/ConversationListHeader.js +1 -0
  204. package/dist/esm/components/ConversationPreview/ConversationPreview.d.ts +39 -27
  205. package/dist/esm/components/ConversationPreview/ConversationPreview.js +1 -1
  206. package/dist/esm/components/ConversationPreview/utils.js +1 -1
  207. package/dist/esm/components/ConversationSearch/ConversationSearch.d.ts +39 -0
  208. package/dist/esm/components/ConversationSearch/ConversationSearch.js +1 -0
  209. package/dist/esm/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.d.ts +7 -0
  210. package/dist/esm/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.js +1 -0
  211. package/dist/esm/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.d.ts +29 -0
  212. package/dist/esm/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.js +1 -0
  213. package/dist/esm/components/Icon/Icon.js +1 -1
  214. package/dist/esm/components/Icon/config.js +1 -1
  215. package/dist/esm/components/Icon/images/mute.svg.js +1 -0
  216. package/dist/esm/components/Icon/images/video-call.svg.js +1 -0
  217. package/dist/esm/components/Icon/images/voice-call.svg.js +1 -0
  218. package/dist/esm/components/Icon/type.d.ts +5 -1
  219. package/dist/esm/components/Icon/type.js +1 -1
  220. package/dist/esm/components/Input/Input.d.ts +5 -2
  221. package/dist/esm/components/Input/Input.js +1 -1
  222. package/dist/{cjs/components/TUIMessage/TUIMessage.d.ts → esm/components/MessageElement/Message.d.ts} +1 -1
  223. package/dist/esm/components/MessageElement/Message.js +1 -0
  224. package/dist/esm/components/MessageElement/MessageAudio.js +1 -0
  225. package/dist/esm/components/MessageElement/MessageAvatar.js +1 -0
  226. package/dist/esm/components/MessageElement/MessageBubble.js +1 -0
  227. package/dist/esm/components/MessageElement/MessageContext.js +1 -0
  228. package/dist/esm/components/MessageElement/MessageCustom.js +1 -0
  229. package/dist/esm/components/MessageElement/MessageDefault.js +1 -0
  230. package/dist/esm/components/MessageElement/MessageName.js +1 -0
  231. package/dist/esm/components/MessageElement/MessagePlugins.js +1 -0
  232. package/dist/esm/components/MessageElement/MessageProgress.js +1 -0
  233. package/dist/esm/components/MessageElement/MessageRevoke.js +1 -0
  234. package/dist/esm/components/MessageElement/MessageStatus.js +1 -0
  235. package/dist/esm/components/MessageElement/MessageSystem.js +1 -0
  236. package/dist/esm/components/MessageElement/MessageText.js +1 -0
  237. package/dist/esm/components/MessageElement/MessageTip.js +1 -0
  238. package/dist/esm/components/MessageElement/hooks/useMessageHandler.js +1 -0
  239. package/dist/esm/components/MessageElement/hooks/useMessageReply.js +1 -0
  240. package/dist/esm/components/MessageElement/utils/index.js +1 -0
  241. package/dist/esm/components/MessageInput/EmojiPicker.js +1 -0
  242. package/dist/esm/components/MessageInput/Forward.js +1 -0
  243. package/dist/esm/components/MessageInput/InputPluginsDefalut.js +1 -0
  244. package/dist/esm/components/MessageInput/InputQuoteDefalut.js +1 -0
  245. package/dist/esm/components/{TUIMessageInput/TUIMessageInput.d.ts → MessageInput/MessageInput.d.ts} +4 -4
  246. package/dist/esm/components/MessageInput/MessageInput.js +1 -0
  247. package/dist/esm/components/MessageInput/MessageInputDefault.js +1 -0
  248. package/dist/esm/components/MessageInput/Transmitter.js +1 -0
  249. package/dist/esm/components/MessageInput/hooks/useEmojiPicker.js +1 -0
  250. package/dist/esm/components/MessageInput/hooks/useHandleForwardMessage.js +1 -0
  251. package/dist/esm/components/MessageInput/hooks/useHandleQuoteMessage.js +1 -0
  252. package/dist/esm/components/MessageInput/hooks/useMessageInputText.js +1 -0
  253. package/dist/esm/components/MessageInput/hooks/useUploadPicker.js +1 -0
  254. package/dist/esm/components/{TUIMessageList/TUIMessageList.d.ts → MessageList/MessageList.d.ts} +3 -3
  255. package/dist/esm/components/MessageList/MessageList.js +1 -0
  256. package/dist/esm/components/MessageList/hooks/useMessageListElement.js +1 -0
  257. package/dist/esm/components/PlaceHolder/index.d.ts +34 -0
  258. package/dist/esm/components/PlaceHolder/index.js +1 -0
  259. package/dist/esm/components/Plugins/index.d.ts +5 -2
  260. package/dist/esm/components/Profile/Profile.d.ts +10 -0
  261. package/dist/esm/components/Profile/Profile.js +1 -1
  262. package/dist/esm/components/Profile/ProfileDefault.js +1 -0
  263. package/dist/esm/components/Profile/myProfile/MyProfile.js +1 -0
  264. package/dist/esm/components/utils.js +1 -0
  265. package/dist/esm/context/{TUIChatActionContext.d.ts → ChatActionContext.d.ts} +3 -2
  266. package/dist/{cjs/context/TUIChatStateContext.d.ts → esm/context/ChatStateContext.d.ts} +6 -6
  267. package/dist/esm/context/ComponentContext.d.ts +3 -3
  268. package/dist/esm/context/{TUIContactContext.d.ts → ContactContext.d.ts} +4 -4
  269. package/dist/esm/context/ConversationListContext.d.ts +22 -0
  270. package/dist/esm/context/ConversationListContext.js +1 -0
  271. package/dist/esm/context/LanguageContext.js +1 -1
  272. package/dist/{cjs/context/TUIMessageContext.d.ts → esm/context/MessageContext.d.ts} +1 -1
  273. package/dist/{cjs/context/TUIMessageInputContext.d.ts → esm/context/MessageInputContext.d.ts} +4 -4
  274. package/dist/esm/context/ThemeContext.js +1 -1
  275. package/dist/esm/context/UIKitContext.d.ts +2 -2
  276. package/dist/esm/context/UIKitContext.js +1 -1
  277. package/dist/esm/hooks/useConversation.d.ts +4 -23
  278. package/dist/esm/hooks/useConversation.js +1 -1
  279. package/dist/esm/hooks/useLongPress.d.ts +3 -0
  280. package/dist/esm/hooks/useLongPress.js +1 -0
  281. package/dist/esm/hooks/useMouseHover.js +1 -0
  282. package/dist/esm/index.css +2 -1
  283. package/dist/esm/index.d.css +1376 -568
  284. package/dist/esm/index.d.ts +41 -29
  285. package/dist/esm/index.js +1 -1
  286. package/dist/esm/locales/en-US/TUIConversation.js +1 -1
  287. package/dist/esm/locales/en-US/index.js +1 -1
  288. package/dist/esm/locales/index.js +1 -1
  289. package/dist/esm/locales/ja-JP/TUIConversation.js +1 -1
  290. package/dist/esm/locales/ja-JP/index.js +1 -1
  291. package/dist/esm/locales/ko-KR/TUIConversation.js +1 -1
  292. package/dist/esm/locales/ko-KR/index.js +1 -1
  293. package/dist/esm/locales/zh-CN/TUIConversation.js +1 -1
  294. package/dist/esm/locales/zh-CN/index.js +1 -1
  295. package/dist/esm/locales/zh-TW/TUIChat.js +1 -0
  296. package/dist/esm/locales/zh-TW/TUIContact.js +1 -0
  297. package/dist/esm/locales/zh-TW/TUIConversation.js +1 -0
  298. package/dist/esm/locales/zh-TW/TUIProfile.js +1 -0
  299. package/dist/esm/locales/zh-TW/index.js +1 -0
  300. package/package.json +3 -1
  301. package/rollup.config.js +1 -1
  302. package/src/assets/fonts/iconfont.ttf +0 -0
  303. package/src/assets/fonts/iconfont.woff +0 -0
  304. package/src/assets/fonts/iconfont.woff2 +0 -0
  305. package/src/components/Avatar/Avatar.tsx +33 -31
  306. package/src/components/Avatar/styles/index.scss +11 -4
  307. package/src/components/{TUIChat/TUIChat.tsx → Chat/Chat.tsx} +50 -46
  308. package/src/components/{TUIChat/TUIChatState.tsx → Chat/ChatState.tsx} +41 -41
  309. package/src/components/{TUIChat → Chat}/hooks/useHandleMessage.tsx +1 -1
  310. package/src/components/{TUIChat → Chat}/hooks/useHandleMessageList.tsx +1 -1
  311. package/src/components/Chat/index.ts +5 -0
  312. package/src/components/Chat/server.ts +44 -0
  313. package/src/components/{TUIChat → Chat}/styles/layout.scss +7 -2
  314. package/src/components/Chat/utils.ts +72 -0
  315. package/src/components/{TUIChatHeader/TUIChatHeader.tsx → ChatHeader/ChatHeader.tsx} +14 -11
  316. package/src/components/{TUIChatHeader/TUIChatHeaderDefault.tsx → ChatHeader/ChatHeaderDefault.tsx} +72 -29
  317. package/src/components/ChatHeader/index.ts +2 -0
  318. package/src/components/{TUIChatHeader → ChatHeader}/styles/layout.scss +12 -13
  319. package/src/components/{TUIManage/TUIManage.tsx → ChatSetting/ChatSetting.tsx} +17 -20
  320. package/src/components/ChatSetting/index.ts +1 -0
  321. package/src/components/{TUIManage → ChatSetting}/styles/index.scss +24 -16
  322. package/src/components/Checkbox/index.tsx +9 -9
  323. package/src/components/Checkbox/styles/color.scss +17 -6
  324. package/src/components/{TUIContact/TUIContact.tsx → Contact/Contact.tsx} +35 -35
  325. package/src/components/{TUIContact/TUIContactInfo/TUIContactInfo.tsx → Contact/ContactInfo/ContactInfo.tsx} +4 -4
  326. package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/index.scss +44 -21
  327. package/src/components/{TUIContact/TUIContactList/TUIContactList.tsx → Contact/ContactList/ContactList.tsx} +78 -74
  328. package/src/components/{TUIContact/TUIContactList → Contact/ContactList}/index.scss +40 -20
  329. package/src/components/{TUIContact → Contact}/hooks/useTUIContact.tsx +3 -3
  330. package/src/components/{TUIContact → Contact}/index.scss +30 -11
  331. package/src/components/Contact/index.ts +3 -0
  332. package/src/components/{TUIContactSearch/TUIContactSearch.tsx → ContactSearch/ContactSearch.tsx} +8 -7
  333. package/src/components/{TUIContactSearch → ContactSearch}/index.scss +12 -3
  334. package/src/components/ConversationActions/ConversationActions.scss +45 -0
  335. package/src/components/ConversationActions/ConversationActions.tsx +172 -0
  336. package/src/components/ConversationActions/index.ts +1 -0
  337. package/src/components/ConversationCreate/ConversationCreate.tsx +104 -49
  338. package/src/components/ConversationCreate/ConversationCreateButton.tsx +46 -0
  339. package/src/components/ConversationCreate/ConversationCreateGroupDetail.tsx +179 -0
  340. package/src/components/ConversationCreate/ConversationCreateSelectView.tsx +7 -7
  341. package/src/components/ConversationCreate/ConversationCreateUserSelectList.tsx +31 -29
  342. package/src/components/ConversationCreate/ConversationGroupTypeInfo.tsx +19 -19
  343. package/src/components/ConversationCreate/hooks/useConversationCreate.tsx +38 -31
  344. package/src/components/ConversationCreate/index.ts +2 -1
  345. package/src/components/ConversationCreate/styles/{ConversationCreatGroupDetail.scss → ConversationCreateGroupDetail.scss} +13 -17
  346. package/src/components/ConversationCreate/styles/conversationCreateButton.scss +5 -0
  347. package/src/components/ConversationCreate/styles/conversationCreateSelectView.scss +13 -8
  348. package/src/components/ConversationCreate/styles/conversationGroupTypeInfo.scss +20 -21
  349. package/src/components/ConversationCreate/styles/index.scss +64 -19
  350. package/src/components/ConversationList/ConversationList.scss +29 -0
  351. package/src/components/ConversationList/ConversationList.tsx +155 -0
  352. package/src/components/ConversationList/ConversationListContent/ConversationListContent.scss +16 -0
  353. package/src/components/ConversationList/ConversationListContent/ConversationListContent.tsx +63 -0
  354. package/src/components/ConversationList/ConversationListContent/index.ts +1 -0
  355. package/src/components/ConversationList/ConversationListHeader/ConversationListHeader.scss +28 -0
  356. package/src/components/ConversationList/ConversationListHeader/ConversationListHeader.tsx +43 -0
  357. package/src/components/ConversationList/ConversationListHeader/index.ts +1 -0
  358. package/src/components/ConversationList/index.ts +3 -0
  359. package/src/components/ConversationPreview/ConversationPreview.scss +137 -0
  360. package/src/components/ConversationPreview/ConversationPreview.tsx +245 -63
  361. package/src/components/ConversationPreview/index.ts +0 -1
  362. package/src/components/ConversationPreview/utils.tsx +80 -61
  363. package/src/components/ConversationSearch/ConversationSearch.scss +22 -0
  364. package/src/components/ConversationSearch/ConversationSearch.tsx +125 -0
  365. package/src/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.scss +13 -0
  366. package/src/components/ConversationSearch/ConversationSearchInput/ConversationSearchInput.tsx +42 -0
  367. package/src/components/ConversationSearch/ConversationSearchInput/index.ts +1 -0
  368. package/src/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.scss +15 -0
  369. package/src/components/ConversationSearch/ConversationSearchResult/ConversationSearchResult.tsx +72 -0
  370. package/src/components/ConversationSearch/ConversationSearchResult/index.ts +1 -0
  371. package/src/components/ConversationSearch/index.ts +3 -2
  372. package/src/components/DivWithEdit/styles/index.scss +30 -10
  373. package/src/components/EmptyStateIndicator/EmptyStateIndicator.tsx +2 -3
  374. package/src/components/Icon/Icon.tsx +8 -8
  375. package/src/components/Icon/config.ts +23 -4
  376. package/src/components/Icon/images/mute.svg +8 -0
  377. package/src/components/Icon/images/video-call.svg +3 -0
  378. package/src/components/Icon/images/voice-call.svg +3 -0
  379. package/src/components/Icon/styles/index.scss +41 -6
  380. package/src/components/Icon/type.ts +4 -0
  381. package/src/components/Input/Input.tsx +24 -23
  382. package/src/components/Input/styles/index.scss +22 -6
  383. package/src/components/{TUIMessage/TUIMessage.tsx → MessageElement/Message.tsx} +33 -33
  384. package/src/components/{TUIMessage → MessageElement}/MessageAvatar.tsx +7 -7
  385. package/src/components/{TUIMessage → MessageElement}/MessageBubble.tsx +22 -21
  386. package/src/components/{TUIMessage → MessageElement}/MessageCustom.tsx +26 -5
  387. package/src/components/{TUIMessage/TUIMessageDefault.tsx → MessageElement/MessageDefault.tsx} +24 -24
  388. package/src/components/{TUIMessage → MessageElement}/MessagePlugins.tsx +18 -18
  389. package/src/components/{TUIMessage → MessageElement}/MessageStatus.tsx +5 -5
  390. package/src/components/{TUIMessage → MessageElement}/hooks/useMessageHandler.ts +6 -6
  391. package/src/components/{TUIMessage → MessageElement}/hooks/useMessageReply.ts +6 -5
  392. package/src/components/{TUIMessage → MessageElement}/index.ts +1 -1
  393. package/src/components/{TUIMessage → MessageElement}/styles/color.scss +6 -5
  394. package/src/components/{TUIMessage → MessageElement}/styles/layout.scss +112 -43
  395. package/src/components/{TUIMessage → MessageElement}/utils/index.ts +23 -12
  396. package/src/components/{TUIMessageInput → MessageInput}/EmojiPicker.tsx +2 -2
  397. package/src/components/{TUIMessageInput/TUIForward.tsx → MessageInput/Forward.tsx} +41 -36
  398. package/src/components/{TUIMessageInput → MessageInput}/InputPluginsDefalut.tsx +14 -14
  399. package/src/components/{TUIMessageInput → MessageInput}/InputQuoteDefalut.tsx +1 -1
  400. package/src/components/{TUIMessageInput/TUIMessageInput.tsx → MessageInput/MessageInput.tsx} +25 -27
  401. package/src/components/{TUIMessageInput/TUIMessageInputDefault.tsx → MessageInput/MessageInputDefault.tsx} +14 -14
  402. package/src/components/{TUIMessageInput → MessageInput}/Transmitter.tsx +2 -2
  403. package/src/components/{TUIMessageInput → MessageInput}/hooks/useEmojiPicker.tsx +1 -1
  404. package/src/components/{TUIMessageInput → MessageInput}/hooks/useHandleForwardMessage.tsx +5 -4
  405. package/src/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputState.tsx +1 -1
  406. package/src/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputText.tsx +14 -14
  407. package/src/components/{TUIMessageInput → MessageInput}/hooks/useUploadPicker.tsx +4 -4
  408. package/src/components/MessageInput/index.ts +3 -0
  409. package/src/components/MessageInput/styles/color.scss +40 -0
  410. package/src/components/{TUIMessageInput → MessageInput}/styles/layout.scss +33 -17
  411. package/src/components/{TUIMessageList/TUIMessageList.tsx → MessageList/MessageList.tsx} +5 -5
  412. package/src/components/{TUIMessageList → MessageList}/hooks/useMessageListElement.tsx +14 -10
  413. package/src/components/MessageList/index.ts +1 -0
  414. package/src/components/{TUIMessageList → MessageList}/styles/layout.scss +16 -9
  415. package/src/components/PlaceHolder/index.tsx +79 -0
  416. package/src/components/PlaceHolder/styles/index.scss +36 -0
  417. package/src/components/Plugins/index.tsx +49 -45
  418. package/src/components/Plugins/styles/color.scss +3 -11
  419. package/src/components/Profile/Profile.tsx +46 -21
  420. package/src/components/{TUIProfile/TUIProfileDefault.tsx → Profile/ProfileDefault.tsx} +12 -11
  421. package/src/components/Profile/index.ts +2 -1
  422. package/src/components/Profile/myProfile/MyProfile.tsx +25 -0
  423. package/src/components/Profile/myProfile/index.ts +1 -0
  424. package/src/components/Profile/myProfile/styles/index.scss +32 -0
  425. package/src/components/Profile/styles/color.scss +7 -0
  426. package/src/components/Profile/styles/index.scss +2 -23
  427. package/src/components/{TUIProfile → Profile}/styles/layout.scss +17 -14
  428. package/src/components/index.ts +13 -11
  429. package/src/components/{untils.ts → utils.ts} +5 -4
  430. package/src/context/{TUIChatActionContext.tsx → ChatActionContext.tsx} +15 -14
  431. package/src/context/ChatStateContext.tsx +49 -0
  432. package/src/context/ComponentContext.tsx +13 -13
  433. package/src/context/{TUIContactContext.tsx → ContactContext.tsx} +10 -11
  434. package/src/context/ConversationListContext.tsx +113 -0
  435. package/src/context/LanguageContext.tsx +6 -4
  436. package/src/context/MessageContext.tsx +55 -0
  437. package/src/context/MessageInputContext.tsx +54 -0
  438. package/src/context/ThemeContext.tsx +12 -5
  439. package/src/context/UIKitContext.tsx +11 -2
  440. package/src/context/index.ts +6 -5
  441. package/src/hooks/index.ts +2 -0
  442. package/src/hooks/useConversation.tsx +26 -74
  443. package/src/hooks/useLongPress.tsx +117 -0
  444. package/src/hooks/useMouseHover.tsx +21 -0
  445. package/src/locales/en-US/TUIConversation.ts +4 -0
  446. package/src/locales/en-US/index.ts +0 -3
  447. package/src/locales/index.ts +16 -2
  448. package/src/locales/ja-JP/TUIConversation.ts +4 -0
  449. package/src/locales/ja-JP/index.ts +0 -2
  450. package/src/locales/ko-KR/TUIConversation.ts +4 -0
  451. package/src/locales/ko-KR/index.ts +0 -2
  452. package/src/locales/zh-CN/TUIConversation.ts +4 -0
  453. package/src/locales/zh-CN/index.ts +0 -2
  454. package/src/locales/zh-TW/TUIChat.ts +27 -0
  455. package/src/locales/zh-TW/TUIContact.ts +29 -0
  456. package/src/locales/zh-TW/TUIConversation.ts +36 -0
  457. package/src/locales/zh-TW/TUIProfile.ts +15 -0
  458. package/src/locales/zh-TW/index.ts +11 -0
  459. package/src/styles/colors/_color-dark.scss +31 -21
  460. package/src/styles/colors/_color-light.scss +31 -21
  461. package/src/styles/colors/_color-theme.scss +32 -21
  462. package/src/styles/normalize.scss +6 -0
  463. package/dist/cjs/components/ConversationCreate/ConversationCreatGroupDetail.js +0 -1
  464. package/dist/cjs/components/ConversationPreview/ConversationListContainer.d.ts +0 -10
  465. package/dist/cjs/components/ConversationPreview/ConversationListContainer.js +0 -1
  466. package/dist/cjs/components/ConversationPreview/ConversationPreviewContent.d.ts +0 -10
  467. package/dist/cjs/components/ConversationPreview/ConversationPreviewContent.js +0 -1
  468. package/dist/cjs/components/ConversationSearch/ConversationSearchInput.d.ts +0 -6
  469. package/dist/cjs/components/ConversationSearch/ConversationSearchInput.js +0 -1
  470. package/dist/cjs/components/ConversationSearch/ConversationSearchResult.d.ts +0 -12
  471. package/dist/cjs/components/ConversationSearch/ConversationSearchResult.js +0 -1
  472. package/dist/cjs/components/Icon/images/down-arrow.png.js +0 -1
  473. package/dist/cjs/components/Icon/images/right-arrow.svg.js +0 -1
  474. package/dist/cjs/components/TUIChat/TUIChat.js +0 -1
  475. package/dist/cjs/components/TUIChat/TUIChatState.js +0 -1
  476. package/dist/cjs/components/TUIChat/unitls.js +0 -1
  477. package/dist/cjs/components/TUIChatHeader/TUIChatHeader.js +0 -1
  478. package/dist/cjs/components/TUIChatHeader/TUIChatHeaderDefault.js +0 -1
  479. package/dist/cjs/components/TUIContact/TUIContact.d.ts +0 -6
  480. package/dist/cjs/components/TUIContact/TUIContact.js +0 -1
  481. package/dist/cjs/components/TUIContact/TUIContactInfo/TUIContactInfo.d.ts +0 -10
  482. package/dist/cjs/components/TUIContact/TUIContactInfo/TUIContactInfo.js +0 -1
  483. package/dist/cjs/components/TUIContact/TUIContactInfo/basicInfo.js +0 -1
  484. package/dist/cjs/components/TUIContact/TUIContactInfo/blockInfo.js +0 -1
  485. package/dist/cjs/components/TUIContact/TUIContactInfo/friendApplication.js +0 -1
  486. package/dist/cjs/components/TUIContact/TUIContactInfo/friendInfo.js +0 -1
  487. package/dist/cjs/components/TUIContact/TUIContactInfo/groupInfo.js +0 -1
  488. package/dist/cjs/components/TUIContact/TUIContactInfo/hooks/useContactInfo.js +0 -1
  489. package/dist/cjs/components/TUIContact/TUIContactList/TUIContactList.d.ts +0 -6
  490. package/dist/cjs/components/TUIContact/TUIContactList/TUIContactList.js +0 -1
  491. package/dist/cjs/components/TUIContact/hooks/useTUIContact.js +0 -1
  492. package/dist/cjs/components/TUIContactSearch/TUIContactSearch.js +0 -1
  493. package/dist/cjs/components/TUIContactSearch/hooks/useContactSearch.js +0 -1
  494. package/dist/cjs/components/TUIConversation/TUIConversation.d.ts +0 -12
  495. package/dist/cjs/components/TUIConversation/TUIConversation.js +0 -1
  496. package/dist/cjs/components/TUIConversationList/TUIConversationList.d.ts +0 -19
  497. package/dist/cjs/components/TUIConversationList/TUIConversationList.js +0 -1
  498. package/dist/cjs/components/TUIConversationList/hooks/useConversationList.js +0 -1
  499. package/dist/cjs/components/TUIConversationList/hooks/useConversationUpdate.js +0 -1
  500. package/dist/cjs/components/TUIManage/TUIManage.d.ts +0 -6
  501. package/dist/cjs/components/TUIManage/TUIManage.js +0 -1
  502. package/dist/cjs/components/TUIMessage/MessageAudio.js +0 -1
  503. package/dist/cjs/components/TUIMessage/MessageAvatar.js +0 -1
  504. package/dist/cjs/components/TUIMessage/MessageBubble.js +0 -1
  505. package/dist/cjs/components/TUIMessage/MessageContext.js +0 -1
  506. package/dist/cjs/components/TUIMessage/MessageCustom.js +0 -1
  507. package/dist/cjs/components/TUIMessage/MessageName.js +0 -1
  508. package/dist/cjs/components/TUIMessage/MessagePlugins.js +0 -1
  509. package/dist/cjs/components/TUIMessage/MessageProgress.js +0 -1
  510. package/dist/cjs/components/TUIMessage/MessageRevoke.js +0 -1
  511. package/dist/cjs/components/TUIMessage/MessageStatus.js +0 -1
  512. package/dist/cjs/components/TUIMessage/MessageSystem.js +0 -1
  513. package/dist/cjs/components/TUIMessage/MessageText.js +0 -1
  514. package/dist/cjs/components/TUIMessage/MessageTip.js +0 -1
  515. package/dist/cjs/components/TUIMessage/TUIMessage.js +0 -1
  516. package/dist/cjs/components/TUIMessage/TUIMessageDefault.js +0 -1
  517. package/dist/cjs/components/TUIMessage/hooks/useMessageHandler.js +0 -1
  518. package/dist/cjs/components/TUIMessage/hooks/useMessageReply.js +0 -1
  519. package/dist/cjs/components/TUIMessage/utils/index.js +0 -1
  520. package/dist/cjs/components/TUIMessageInput/EmojiPicker.js +0 -1
  521. package/dist/cjs/components/TUIMessageInput/InputPluginsDefalut.js +0 -1
  522. package/dist/cjs/components/TUIMessageInput/InputQuoteDefalut.js +0 -1
  523. package/dist/cjs/components/TUIMessageInput/TUIForward.js +0 -1
  524. package/dist/cjs/components/TUIMessageInput/TUIMessageInput.js +0 -1
  525. package/dist/cjs/components/TUIMessageInput/TUIMessageInputDefault.js +0 -1
  526. package/dist/cjs/components/TUIMessageInput/Transmitter.js +0 -1
  527. package/dist/cjs/components/TUIMessageInput/hooks/useEmojiPicker.js +0 -1
  528. package/dist/cjs/components/TUIMessageInput/hooks/useHandleForwardMessage.js +0 -1
  529. package/dist/cjs/components/TUIMessageInput/hooks/useHandleQuoteMessage.js +0 -1
  530. package/dist/cjs/components/TUIMessageInput/hooks/useMessageInputText.js +0 -1
  531. package/dist/cjs/components/TUIMessageInput/hooks/useUploadPicker.js +0 -1
  532. package/dist/cjs/components/TUIMessageList/TUIMessageList.js +0 -1
  533. package/dist/cjs/components/TUIMessageList/hooks/useMessageListElement.js +0 -1
  534. package/dist/cjs/components/TUIProfile/TUIProfile.d.ts +0 -10
  535. package/dist/cjs/components/TUIProfile/TUIProfile.js +0 -1
  536. package/dist/cjs/components/TUIProfile/TUIProfileDefault.js +0 -1
  537. package/dist/cjs/context/TUIConversationContext.js +0 -1
  538. package/dist/cjs/locales/en-US/TUIGlobal.js +0 -1
  539. package/dist/cjs/locales/ja-JP/TUIGlobal.js +0 -1
  540. package/dist/cjs/locales/ko-KR/TUIGlobal.js +0 -1
  541. package/dist/cjs/locales/zh-CN/TUIGlobal.js +0 -1
  542. package/dist/esm/components/ConversationCreate/ConversationCreatGroupDetail.js +0 -1
  543. package/dist/esm/components/ConversationPreview/ConversationListContainer.d.ts +0 -10
  544. package/dist/esm/components/ConversationPreview/ConversationListContainer.js +0 -1
  545. package/dist/esm/components/ConversationPreview/ConversationPreviewContent.d.ts +0 -10
  546. package/dist/esm/components/ConversationPreview/ConversationPreviewContent.js +0 -1
  547. package/dist/esm/components/ConversationSearch/ConversationSearchInput.d.ts +0 -6
  548. package/dist/esm/components/ConversationSearch/ConversationSearchInput.js +0 -1
  549. package/dist/esm/components/ConversationSearch/ConversationSearchResult.d.ts +0 -12
  550. package/dist/esm/components/ConversationSearch/ConversationSearchResult.js +0 -1
  551. package/dist/esm/components/Icon/images/down-arrow.png.js +0 -1
  552. package/dist/esm/components/Icon/images/right-arrow.svg.js +0 -1
  553. package/dist/esm/components/TUIChat/TUIChat.js +0 -1
  554. package/dist/esm/components/TUIChat/TUIChatState.js +0 -1
  555. package/dist/esm/components/TUIChat/unitls.js +0 -1
  556. package/dist/esm/components/TUIChatHeader/TUIChatHeader.js +0 -1
  557. package/dist/esm/components/TUIChatHeader/TUIChatHeaderDefault.js +0 -1
  558. package/dist/esm/components/TUIContact/TUIContact.d.ts +0 -6
  559. package/dist/esm/components/TUIContact/TUIContact.js +0 -1
  560. package/dist/esm/components/TUIContact/TUIContactInfo/TUIContactInfo.d.ts +0 -10
  561. package/dist/esm/components/TUIContact/TUIContactInfo/TUIContactInfo.js +0 -1
  562. package/dist/esm/components/TUIContact/TUIContactInfo/basicInfo.js +0 -1
  563. package/dist/esm/components/TUIContact/TUIContactInfo/blockInfo.js +0 -1
  564. package/dist/esm/components/TUIContact/TUIContactInfo/friendApplication.js +0 -1
  565. package/dist/esm/components/TUIContact/TUIContactInfo/friendInfo.js +0 -1
  566. package/dist/esm/components/TUIContact/TUIContactInfo/groupInfo.js +0 -1
  567. package/dist/esm/components/TUIContact/TUIContactInfo/hooks/useContactInfo.js +0 -1
  568. package/dist/esm/components/TUIContact/TUIContactList/TUIContactList.d.ts +0 -6
  569. package/dist/esm/components/TUIContact/TUIContactList/TUIContactList.js +0 -1
  570. package/dist/esm/components/TUIContact/hooks/useTUIContact.js +0 -1
  571. package/dist/esm/components/TUIContactSearch/TUIContactSearch.js +0 -1
  572. package/dist/esm/components/TUIContactSearch/hooks/useContactSearch.js +0 -1
  573. package/dist/esm/components/TUIConversation/TUIConversation.d.ts +0 -12
  574. package/dist/esm/components/TUIConversation/TUIConversation.js +0 -1
  575. package/dist/esm/components/TUIConversationList/TUIConversationList.d.ts +0 -19
  576. package/dist/esm/components/TUIConversationList/TUIConversationList.js +0 -1
  577. package/dist/esm/components/TUIConversationList/hooks/useConversationList.js +0 -1
  578. package/dist/esm/components/TUIConversationList/hooks/useConversationUpdate.js +0 -1
  579. package/dist/esm/components/TUIManage/TUIManage.d.ts +0 -6
  580. package/dist/esm/components/TUIManage/TUIManage.js +0 -1
  581. package/dist/esm/components/TUIMessage/MessageAudio.js +0 -1
  582. package/dist/esm/components/TUIMessage/MessageAvatar.js +0 -1
  583. package/dist/esm/components/TUIMessage/MessageBubble.js +0 -1
  584. package/dist/esm/components/TUIMessage/MessageContext.js +0 -1
  585. package/dist/esm/components/TUIMessage/MessageCustom.js +0 -1
  586. package/dist/esm/components/TUIMessage/MessageName.js +0 -1
  587. package/dist/esm/components/TUIMessage/MessagePlugins.js +0 -1
  588. package/dist/esm/components/TUIMessage/MessageProgress.js +0 -1
  589. package/dist/esm/components/TUIMessage/MessageRevoke.js +0 -1
  590. package/dist/esm/components/TUIMessage/MessageStatus.js +0 -1
  591. package/dist/esm/components/TUIMessage/MessageSystem.js +0 -1
  592. package/dist/esm/components/TUIMessage/MessageText.js +0 -1
  593. package/dist/esm/components/TUIMessage/MessageTip.js +0 -1
  594. package/dist/esm/components/TUIMessage/TUIMessage.js +0 -1
  595. package/dist/esm/components/TUIMessage/TUIMessageDefault.js +0 -1
  596. package/dist/esm/components/TUIMessage/hooks/useMessageHandler.js +0 -1
  597. package/dist/esm/components/TUIMessage/hooks/useMessageReply.js +0 -1
  598. package/dist/esm/components/TUIMessage/utils/index.js +0 -1
  599. package/dist/esm/components/TUIMessageInput/EmojiPicker.js +0 -1
  600. package/dist/esm/components/TUIMessageInput/InputPluginsDefalut.js +0 -1
  601. package/dist/esm/components/TUIMessageInput/InputQuoteDefalut.js +0 -1
  602. package/dist/esm/components/TUIMessageInput/TUIForward.js +0 -1
  603. package/dist/esm/components/TUIMessageInput/TUIMessageInput.js +0 -1
  604. package/dist/esm/components/TUIMessageInput/TUIMessageInputDefault.js +0 -1
  605. package/dist/esm/components/TUIMessageInput/Transmitter.js +0 -1
  606. package/dist/esm/components/TUIMessageInput/hooks/useEmojiPicker.js +0 -1
  607. package/dist/esm/components/TUIMessageInput/hooks/useHandleForwardMessage.js +0 -1
  608. package/dist/esm/components/TUIMessageInput/hooks/useHandleQuoteMessage.js +0 -1
  609. package/dist/esm/components/TUIMessageInput/hooks/useMessageInputText.js +0 -1
  610. package/dist/esm/components/TUIMessageInput/hooks/useUploadPicker.js +0 -1
  611. package/dist/esm/components/TUIMessageList/TUIMessageList.js +0 -1
  612. package/dist/esm/components/TUIMessageList/hooks/useMessageListElement.js +0 -1
  613. package/dist/esm/components/TUIProfile/TUIProfile.d.ts +0 -10
  614. package/dist/esm/components/TUIProfile/TUIProfile.js +0 -1
  615. package/dist/esm/components/TUIProfile/TUIProfileDefault.js +0 -1
  616. package/dist/esm/components/untils.js +0 -1
  617. package/dist/esm/context/TUIConversationContext.js +0 -1
  618. package/dist/esm/locales/en-US/TUIGlobal.js +0 -1
  619. package/dist/esm/locales/ja-JP/TUIGlobal.js +0 -1
  620. package/dist/esm/locales/ko-KR/TUIGlobal.js +0 -1
  621. package/dist/esm/locales/zh-CN/TUIGlobal.js +0 -1
  622. package/scripts/publish-github.js +0 -60
  623. package/scripts/publish-intl-demo.js +0 -14
  624. package/scripts/publish-intl-experience-demo.js +0 -14
  625. package/src/components/ConversationCreate/ConversationCreatGroupDetail.tsx +0 -170
  626. package/src/components/ConversationPreview/ConversationListContainer.tsx +0 -20
  627. package/src/components/ConversationPreview/ConversationPreviewContent.tsx +0 -190
  628. package/src/components/ConversationPreview/styles/index.scss +0 -171
  629. package/src/components/ConversationSearch/ConversationSearchInput.tsx +0 -27
  630. package/src/components/ConversationSearch/ConversationSearchResult.tsx +0 -39
  631. package/src/components/ConversationSearch/styles/index.scss +0 -20
  632. package/src/components/TUIChat/index.ts +0 -2
  633. package/src/components/TUIChat/unitls.ts +0 -39
  634. package/src/components/TUIChatHeader/index.ts +0 -2
  635. package/src/components/TUIContact/index.ts +0 -3
  636. package/src/components/TUIConversation/TUIConversation.tsx +0 -46
  637. package/src/components/TUIConversation/index.ts +0 -1
  638. package/src/components/TUIConversationList/TUIConversationList.tsx +0 -178
  639. package/src/components/TUIConversationList/hooks/useConversationList.tsx +0 -42
  640. package/src/components/TUIConversationList/hooks/useConversationUpdate.tsx +0 -38
  641. package/src/components/TUIConversationList/index.scss +0 -59
  642. package/src/components/TUIConversationList/index.ts +0 -2
  643. package/src/components/TUIManage/index.ts +0 -1
  644. package/src/components/TUIMessageInput/index.ts +0 -3
  645. package/src/components/TUIMessageInput/styles/color.scss +0 -36
  646. package/src/components/TUIMessageList/index.ts +0 -1
  647. package/src/components/TUIProfile/TUIProfile.tsx +0 -50
  648. package/src/components/TUIProfile/index.ts +0 -2
  649. package/src/components/TUIProfile/styles/color.scss +0 -6
  650. package/src/components/TUIProfile/styles/index.scss +0 -2
  651. package/src/context/TUIChatStateContext.tsx +0 -50
  652. package/src/context/TUIConversationContext.tsx +0 -29
  653. package/src/context/TUIMessageContext.tsx +0 -56
  654. package/src/context/TUIMessageInputContext.tsx +0 -55
  655. package/src/locales/en-US/TUIGlobal.ts +0 -6
  656. package/src/locales/ja-JP/TUIGlobal.ts +0 -6
  657. package/src/locales/ko-KR/TUIGlobal.ts +0 -6
  658. package/src/locales/zh-CN/TUIGlobal.ts +0 -6
  659. /package/dist/cjs/components/{TUIChat → Chat}/hooks/useCreateTUIChatStateContext.js +0 -0
  660. /package/dist/cjs/components/{TUIChat → Chat}/hooks/useHandleMessage.d.ts +0 -0
  661. /package/dist/cjs/components/{TUIChat → Chat}/hooks/useHandleMessage.js +0 -0
  662. /package/dist/cjs/components/{TUIChat → Chat}/hooks/useHandleMessageList.js +0 -0
  663. /package/dist/cjs/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/addFriendInfo.js +0 -0
  664. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageContext.d.ts +0 -0
  665. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageFace.js +0 -0
  666. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageFile.js +0 -0
  667. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageImage.js +0 -0
  668. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageLocation.js +0 -0
  669. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageMerger.js +0 -0
  670. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessagePlugins.d.ts +0 -0
  671. /package/dist/cjs/components/{TUIMessage → MessageElement}/MessageVideo.js +0 -0
  672. /package/dist/cjs/components/{TUIMessage → MessageElement}/hooks/useMessageContextHandler.js +0 -0
  673. /package/dist/cjs/components/{TUIMessage → MessageElement}/hooks/useMessagePluginElement.js +0 -0
  674. /package/dist/cjs/components/{TUIMessage → MessageElement}/utils/decodeText.js +0 -0
  675. /package/dist/cjs/components/{TUIMessage → MessageElement}/utils/emojiMap.js +0 -0
  676. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/InputPluginsDefalut.d.ts +0 -0
  677. /package/dist/cjs/components/{TUIMessageInput/TUIMessageInputDefault.d.ts → MessageInput/MessageInputDefault.d.ts} +0 -0
  678. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useCreateMessageInputContext.js +0 -0
  679. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useEmojiPicker.d.ts +0 -0
  680. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputState.d.ts +0 -0
  681. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputState.js +0 -0
  682. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useUploadElement.js +0 -0
  683. /package/dist/cjs/components/{TUIMessageInput → MessageInput}/hooks/useUploadPicker.d.ts +0 -0
  684. /package/dist/cjs/components/{TUIProfile/TUIProfileDefault.d.ts → Profile/ProfileDefault.d.ts} +0 -0
  685. /package/dist/cjs/components/{TUIProfile → Profile}/hooks/useMyProfile.js +0 -0
  686. /package/dist/cjs/context/{TUIChatActionContext.js → ChatActionContext.js} +0 -0
  687. /package/dist/cjs/context/{TUIChatStateContext.js → ChatStateContext.js} +0 -0
  688. /package/dist/cjs/context/{TUIContactContext.js → ContactContext.js} +0 -0
  689. /package/dist/cjs/context/{TUIMessageContext.js → MessageContext.js} +0 -0
  690. /package/dist/cjs/context/{TUIMessageInputContext.js → MessageInputContext.js} +0 -0
  691. /package/dist/esm/components/{TUIChat → Chat}/hooks/useCreateTUIChatStateContext.js +0 -0
  692. /package/dist/esm/components/{TUIChat → Chat}/hooks/useHandleMessage.d.ts +0 -0
  693. /package/dist/esm/components/{TUIChat → Chat}/hooks/useHandleMessage.js +0 -0
  694. /package/dist/esm/components/{TUIChat → Chat}/hooks/useHandleMessageList.js +0 -0
  695. /package/dist/esm/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/addFriendInfo.js +0 -0
  696. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageContext.d.ts +0 -0
  697. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageFace.js +0 -0
  698. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageFile.js +0 -0
  699. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageImage.js +0 -0
  700. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageLocation.js +0 -0
  701. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageMerger.js +0 -0
  702. /package/dist/esm/components/{TUIMessage → MessageElement}/MessagePlugins.d.ts +0 -0
  703. /package/dist/esm/components/{TUIMessage → MessageElement}/MessageVideo.js +0 -0
  704. /package/dist/esm/components/{TUIMessage → MessageElement}/hooks/useMessageContextHandler.js +0 -0
  705. /package/dist/esm/components/{TUIMessage → MessageElement}/hooks/useMessagePluginElement.js +0 -0
  706. /package/dist/esm/components/{TUIMessage → MessageElement}/utils/decodeText.js +0 -0
  707. /package/dist/esm/components/{TUIMessage → MessageElement}/utils/emojiMap.js +0 -0
  708. /package/dist/esm/components/{TUIMessageInput → MessageInput}/InputPluginsDefalut.d.ts +0 -0
  709. /package/dist/esm/components/{TUIMessageInput/TUIMessageInputDefault.d.ts → MessageInput/MessageInputDefault.d.ts} +0 -0
  710. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useCreateMessageInputContext.js +0 -0
  711. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useEmojiPicker.d.ts +0 -0
  712. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputState.d.ts +0 -0
  713. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useMessageInputState.js +0 -0
  714. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useUploadElement.js +0 -0
  715. /package/dist/esm/components/{TUIMessageInput → MessageInput}/hooks/useUploadPicker.d.ts +0 -0
  716. /package/dist/esm/components/{TUIProfile/TUIProfileDefault.d.ts → Profile/ProfileDefault.d.ts} +0 -0
  717. /package/dist/esm/components/{TUIProfile → Profile}/hooks/useMyProfile.js +0 -0
  718. /package/dist/esm/context/{TUIChatActionContext.js → ChatActionContext.js} +0 -0
  719. /package/dist/esm/context/{TUIChatStateContext.js → ChatStateContext.js} +0 -0
  720. /package/dist/esm/context/{TUIContactContext.js → ContactContext.js} +0 -0
  721. /package/dist/esm/context/{TUIMessageContext.js → MessageContext.js} +0 -0
  722. /package/dist/esm/context/{TUIMessageInputContext.js → MessageInputContext.js} +0 -0
  723. /package/src/components/{TUIChat → Chat}/hooks/useCreateTUIChatStateContext.tsx +0 -0
  724. /package/src/components/{TUIChat → Chat}/hooks/useIsMounted.ts +0 -0
  725. /package/src/components/{TUIChat → Chat}/styles/index.scss +0 -0
  726. /package/src/components/{TUIChatHeader → ChatHeader}/styles/color.scss +0 -0
  727. /package/src/components/{TUIChatHeader → ChatHeader}/styles/index.scss +0 -0
  728. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/addFriendInfo.tsx +0 -0
  729. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/basicInfo.tsx +0 -0
  730. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/blockInfo.tsx +0 -0
  731. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/friendApplication.tsx +0 -0
  732. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/friendInfo.tsx +0 -0
  733. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/groupInfo.tsx +0 -0
  734. /package/src/components/{TUIContact/TUIContactInfo → Contact/ContactInfo}/hooks/useContactInfo.tsx +0 -0
  735. /package/src/components/{TUIContactSearch → ContactSearch}/hooks/useContactSearch.tsx +0 -0
  736. /package/src/components/{TUIMessage → MessageElement}/MessageAudio.tsx +0 -0
  737. /package/src/components/{TUIMessage → MessageElement}/MessageContext.tsx +0 -0
  738. /package/src/components/{TUIMessage → MessageElement}/MessageFace.tsx +0 -0
  739. /package/src/components/{TUIMessage → MessageElement}/MessageFile.tsx +0 -0
  740. /package/src/components/{TUIMessage → MessageElement}/MessageImage.tsx +0 -0
  741. /package/src/components/{TUIMessage → MessageElement}/MessageLocation.tsx +0 -0
  742. /package/src/components/{TUIMessage → MessageElement}/MessageMerger.tsx +0 -0
  743. /package/src/components/{TUIMessage → MessageElement}/MessageName.tsx +0 -0
  744. /package/src/components/{TUIMessage → MessageElement}/MessageProgress.tsx +0 -0
  745. /package/src/components/{TUIMessage → MessageElement}/MessageRevoke.tsx +0 -0
  746. /package/src/components/{TUIMessage → MessageElement}/MessageSystem.tsx +0 -0
  747. /package/src/components/{TUIMessage → MessageElement}/MessageText.tsx +0 -0
  748. /package/src/components/{TUIMessage → MessageElement}/MessageTip.tsx +0 -0
  749. /package/src/components/{TUIMessage → MessageElement}/MessageVideo.tsx +0 -0
  750. /package/src/components/{TUIMessage → MessageElement}/hooks/index.ts +0 -0
  751. /package/src/components/{TUIMessage → MessageElement}/hooks/useMessageContextHandler.ts +0 -0
  752. /package/src/components/{TUIMessage → MessageElement}/hooks/useMessagePluginElement.tsx +0 -0
  753. /package/src/components/{TUIMessage → MessageElement}/styles/index.scss +0 -0
  754. /package/src/components/{TUIMessage → MessageElement}/utils/decodeText.ts +0 -0
  755. /package/src/components/{TUIMessage → MessageElement}/utils/emojiMap.ts +0 -0
  756. /package/src/components/{TUIMessageInput → MessageInput}/hooks/index.ts +0 -0
  757. /package/src/components/{TUIMessageInput → MessageInput}/hooks/useCreateMessageInputContext.ts +0 -0
  758. /package/src/components/{TUIMessageInput → MessageInput}/hooks/useHandleQuoteMessage.tsx +0 -0
  759. /package/src/components/{TUIMessageInput → MessageInput}/hooks/usePluginsElement.tsx +0 -0
  760. /package/src/components/{TUIMessageInput → MessageInput}/hooks/useUploadElement.tsx +0 -0
  761. /package/src/components/{TUIMessageInput → MessageInput}/styles/index.scss +0 -0
  762. /package/src/components/{TUIMessageList → MessageList}/styles/color.scss +0 -0
  763. /package/src/components/{TUIMessageList → MessageList}/styles/index.scss +0 -0
  764. /package/src/components/{TUIProfile → Profile}/hooks/index.ts +0 -0
  765. /package/src/components/{TUIProfile → Profile}/hooks/useMyProfile.tsx +0 -0
@@ -1,24 +1,33 @@
1
+ @use "../../styles/colors/color-theme" as *;
2
+
1
3
  .tui-contact-search {
2
4
  width: 100%;
3
5
  position: relative;
4
6
  text-align: initial;
5
7
  align-items: center;
6
8
  justify-content: space-between;
9
+
7
10
  .tui-contact-search-input {
8
11
  margin: 0 10px;
9
12
  }
13
+
10
14
  .tui-contact-search-text {
11
- color: #147AFF;
15
+ color: #147aff;
12
16
  font-size: 14px;
13
17
  }
18
+
14
19
  .tui-contact-search-item {
15
20
  position: absolute;
16
21
  margin: 10px 20px;
17
22
  display: flex;
18
23
  align-items: center;
24
+
25
+ @include theme() {
26
+ color: get(text-color-primary);
27
+ }
28
+
19
29
  .search-item-name {
20
- padding-left: 10px;
30
+ padding-left: 10px;
21
31
  }
22
32
  }
23
33
  }
24
-
@@ -0,0 +1,45 @@
1
+ @use "../../styles/colors/color-theme" as *;
2
+
3
+ .uikit-conversation-actions {
4
+ display: flex;
5
+ justify-content: flex-end;
6
+ flex: 1 1;
7
+
8
+ .uikit-conversation-actions__container {
9
+ top: 0;
10
+ right: 0;
11
+ box-shadow: 0 0 10px rgba(0, 0, 0, 10%);
12
+ bottom: initial;
13
+ padding: 14px 0;
14
+ box-sizing: border-box;
15
+ text-align: start;
16
+ white-space: nowrap;
17
+
18
+ .uikit-conversation-actions__item {
19
+ font-size: 16px;
20
+ /* stylelint-disable-next-line font-family-no-missing-generic-family-keyword */
21
+ font-family: PingFangSC-Medium;
22
+ line-height: 19px;
23
+ padding: 6px 16px;
24
+ cursor: pointer;
25
+ font-weight: 500;
26
+ box-sizing: border-box;
27
+
28
+ &:hover {
29
+ @include theme() {
30
+ background-color: get(dropdown-color-active);
31
+ }
32
+ }
33
+ }
34
+
35
+ .uikit-conversation-actions__item--delete {
36
+ @include theme() {
37
+ color: get(text-color-error);
38
+ }
39
+ }
40
+ }
41
+
42
+ .uikit-conversation-actions__popup-icon {
43
+ transform: scale(1.5);
44
+ }
45
+ }
@@ -0,0 +1,172 @@
1
+ // ConversationActions.tsx
2
+ import React, { useRef, useEffect } from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import { IConversationModel } from '@tencentcloud/chat-uikit-engine';
5
+ import cs from 'classnames';
6
+
7
+ import { Plugins } from '../Plugins';
8
+ import { Icon, IconTypes } from '../Icon';
9
+
10
+ import './ConversationActions.scss';
11
+
12
+ interface IConversationActionsConfig {
13
+ /** Determines whether the pin button appears on the conversation actions list view. (Default: True) */
14
+ enablePin?: boolean;
15
+ /** Determines whether the mute button appears on the conversation actions list view. (Default: True) */
16
+ enableMute?: boolean;
17
+ /** Determines whether the delete button appears on the conversation actions list view. (Default: True) */
18
+ enableDelete?: boolean;
19
+ /** Function to override the default behavior when user pin or unpin a conversation. */
20
+ onConversationPin?: (conversation: IConversationModel, e?: React.MouseEvent) => void;
21
+ /** Function to override the default behavior when user mute or unmute a conversation. */
22
+ onConversationMute?: (conversation: IConversationModel, e?: React.MouseEvent) => void;
23
+ /** Function to override the default behavior when user delete a conversation. */
24
+ onConversationDelete?: (conversation: IConversationModel, e?: React.MouseEvent) => void;
25
+ /**
26
+ * An object containing custom conversation actions (key) and object (value).
27
+ * Each value is an object with the following properties:
28
+ * enable: Determines whether the custom action is enabled. (Default: True)
29
+ * label: The label of the custom action.
30
+ * onClick: The function to be called when the custom action is clicked.
31
+ * Note: The key of the custom action must be unique.
32
+ */
33
+ customConversationActions?: Record<string, IConversationActionItem>;
34
+ /** The icon react element to be displayed in the action popup. */
35
+ PopupIcon?: React.ReactElement;
36
+ /** An array of react elements to be displayed in the action popup. */
37
+ PopupElements?: React.ReactElement[];
38
+ /** The function to be called when the action popup is clicked. */
39
+ onClick?: (e: React.MouseEvent, key?: string, conversation?: IConversationModel) => void;
40
+ }
41
+
42
+ interface IConversationActionsProps extends IConversationActionsConfig {
43
+ /** The conversation model. */
44
+ conversation: IConversationModel;
45
+ /** The class name of the root element. */
46
+ className?: string;
47
+ /** The style of the root element. */
48
+ style?: React.CSSProperties;
49
+ }
50
+
51
+ interface IConversationActionItem {
52
+ /** Determines whether the custom action is enabled. (Default: True) */
53
+ enable?: boolean;
54
+ /** label: The label of the custom action. */
55
+ label: string;
56
+ /** onClick: The function to be called when the custom action is clicked. */
57
+ onClick: (conversation: IConversationModel, e?: React.MouseEvent) => void;
58
+ }
59
+
60
+ interface IPluginsRef {
61
+ closeMore?: () => void;
62
+ }
63
+
64
+ const ConversationActions = (props: IConversationActionsProps) => {
65
+ const {
66
+ conversation,
67
+ PopupIcon,
68
+ enablePin = true,
69
+ enableMute: isMuteEnabled = true,
70
+ enableDelete: isDeleteEnabled = true,
71
+ onConversationPin,
72
+ onConversationMute,
73
+ onConversationDelete,
74
+ customConversationActions,
75
+ PopupElements,
76
+ onClick,
77
+ className,
78
+ style,
79
+ } = props;
80
+
81
+ const { t } = useTranslation();
82
+ const pluginsRef = useRef<IPluginsRef>(null);
83
+ const [conversationActions, setConversationActions] = React.useState<Record<string, IConversationActionItem>>({});
84
+
85
+ const defaultConversationActions: Record<string, IConversationActionItem> = {
86
+ delete: {
87
+ enable: isDeleteEnabled,
88
+ label: t('TUIConversation.Delete'),
89
+ onClick: onConversationDelete || ((_conversation: IConversationModel) => { _conversation.deleteConversation(); }),
90
+ },
91
+ pin: {
92
+ enable: enablePin,
93
+ label: t(conversation.isPinned ? 'TUIConversation.Unpin' : 'TUIConversation.Pin'),
94
+ onClick: onConversationPin || ((_conversation: IConversationModel) => { _conversation.pinConversation(); }),
95
+ },
96
+ mute: {
97
+ enable: isMuteEnabled,
98
+ label: t(conversation.isMuted ? 'TUIConversation.Unmute' : 'TUIConversation.Mute'),
99
+ onClick: onConversationMute || ((_conversation: IConversationModel) => { _conversation.muteConversation(); }),
100
+ },
101
+ };
102
+
103
+ useEffect(() => {
104
+ setConversationActions({
105
+ ...defaultConversationActions,
106
+ ...customConversationActions,
107
+ });
108
+ }, [conversation, customConversationActions]);
109
+
110
+ const onClickMenuItem = (e: React.MouseEvent, key: string) => {
111
+ pluginsRef?.current?.closeMore && pluginsRef.current.closeMore();
112
+ onClick?.(e, key, conversation);
113
+ conversationActions[key]?.onClick(conversation, e);
114
+ };
115
+
116
+ return (
117
+ <div
118
+ className={cs({
119
+ 'uikit-conversation-actions': true,
120
+ className,
121
+ })}
122
+ style={style}
123
+ onClick={(e: React.MouseEvent) => {
124
+ e.stopPropagation();
125
+ }}
126
+ >
127
+ <Plugins
128
+ customClass="uikit-conversation-actions__container"
129
+ ref={pluginsRef}
130
+ plugins={(
131
+ PopupElements
132
+ || (
133
+ Object.keys(conversationActions).map((key: string) => {
134
+ if (conversationActions[key].enable === false) return null;
135
+ return (
136
+ <div
137
+ key={key}
138
+ className={cs(
139
+ 'uikit-conversation-actions__item',
140
+ [`uikit-conversation-actions__item--${key}`],
141
+ )}
142
+ onClick={e => onClickMenuItem(e, key)}
143
+ >
144
+ {conversationActions[key].label}
145
+ </div>
146
+ );
147
+ })
148
+ )
149
+ )}
150
+ showNumber={0}
151
+ MoreIcon={(
152
+ PopupIcon
153
+ || (
154
+ <Icon
155
+ className="uikit-conversation-actions__popup-icon"
156
+ width={16}
157
+ height={16}
158
+ type={IconTypes.MORE}
159
+ />
160
+ )
161
+ )}
162
+ />
163
+ </div>
164
+ );
165
+ };
166
+
167
+ export {
168
+ ConversationActions,
169
+ IConversationActionsProps,
170
+ IConversationActionItem,
171
+ IConversationActionsConfig,
172
+ };
@@ -0,0 +1 @@
1
+ export * from './ConversationActions';
@@ -1,31 +1,56 @@
1
- import React, { useMemo, useState } from 'react';
1
+ import React, { useEffect, useMemo, useState } from 'react';
2
2
  import { useTranslation } from 'react-i18next';
3
- import './styles/index.scss';
4
- import { Conversation } from '@tencentcloud/chat';
3
+ import { CreateGroupParams, IConversationModel, TUIConversationService } from '@tencentcloud/chat-uikit-engine';
4
+ import cs from 'classnames';
5
+
5
6
  import { Icon, IconTypes } from '../Icon';
7
+ import { ConversationCreateButton } from './ConversationCreateButton';
6
8
  import { ConversationCreateUserSelectList } from './ConversationCreateUserSelectList';
7
- import { ConversationCreatGroupDetail } from './ConversationCreatGroupDetail';
8
- import { useUIKit } from '../../context';
9
- import { useConversation } from '../../hooks';
9
+ import { ConversationCreateGroupDetail } from './ConversationCreateGroupDetail';
10
+
11
+ import './styles/index.scss';
10
12
 
11
- export interface ConversationCreateProps {
12
- className?: string,
13
- setConversationCreated: React.Dispatch<React.SetStateAction<boolean>>,
14
- conversationList?: Array<Conversation>
13
+ export interface IConversationCreateProps {
14
+ visible?: boolean;
15
+ className?: string;
16
+ style?: React.CSSProperties;
17
+ onBeforeCreateConversation?: (params: string | CreateGroupParams) => string | CreateGroupParams;
18
+ onConversationCreated?: (conversation: IConversationModel) => void;
19
+ onChangeCreateModelVisible: (visible: boolean) => void;
20
+ conversationList?: IConversationModel[];
15
21
  }
16
22
  export enum PageStateTypes {
17
- USER_SELECT='Next',
18
- CREATE_DETAIL='Create',
19
- GROUP_TYPE='GroupType',
23
+ USER_SELECT = 'Next',
24
+ CREATE_DETAIL = 'Create',
25
+ GROUP_TYPE = 'GroupType',
20
26
  }
21
- export function ConversationCreate<T extends ConversationCreateProps>(props:T) {
22
- const { className = '', setConversationCreated, conversationList = [] } = props;
27
+ export function ConversationCreate<T extends IConversationCreateProps>(props: T) {
28
+ const {
29
+ visible = true,
30
+ className,
31
+ style,
32
+ onChangeCreateModelVisible,
33
+ conversationList = [],
34
+ onBeforeCreateConversation,
35
+ onConversationCreated,
36
+ } = props;
23
37
  const { t } = useTranslation();
38
+
39
+ const [showCreateModel, setShowCreateModel] = useState(false);
24
40
  const [isCreateGroup, setIsCreateGroup] = useState(false);
25
41
  const [pageState, setPageState] = useState<PageStateTypes>(PageStateTypes.USER_SELECT);
26
42
  const [selectList, setSelectList] = useState([]);
27
- const { chat } = useUIKit();
28
- const { createConversation } = useConversation(chat);
43
+
44
+ const _onConversationCreated = (conversation: IConversationModel) => {
45
+ setShowCreateModel(false);
46
+ resetCreatePageState();
47
+ TUIConversationService.switchConversation(conversation.conversationID);
48
+ onConversationCreated?.(conversation);
49
+ };
50
+
51
+ useEffect(() => {
52
+ onChangeCreateModelVisible(showCreateModel);
53
+ }, [onChangeCreateModelVisible, showCreateModel]);
29
54
 
30
55
  const back = () => {
31
56
  if (isCreateGroup) {
@@ -43,39 +68,69 @@ export function ConversationCreate<T extends ConversationCreateProps>(props:T) {
43
68
  default:
44
69
  }
45
70
  } else {
46
- setConversationCreated(false);
71
+ setShowCreateModel(false);
72
+ resetCreatePageState();
47
73
  }
48
74
  };
49
- return useMemo(() => (
50
- <>
51
- <div className="tui-conversation-create-header">
52
- <Icon onClick={back} type={IconTypes.BACK} width={9} height={16} />
53
- <div className="title">{ t(!isCreateGroup ? 'TUIConversation.Start chat' : 'TUIConversation.Add Participants')}</div>
75
+
76
+ function resetCreatePageState() {
77
+ setIsCreateGroup(false);
78
+ setPageState(PageStateTypes.USER_SELECT);
79
+ setSelectList([]);
80
+ }
81
+
82
+ return useMemo(() => {
83
+ if (!visible) {
84
+ return null;
85
+ }
86
+
87
+ return (
88
+ <div
89
+ className={cs(
90
+ 'uikit-conversation-create-container',
91
+ className,
92
+ )}
93
+ style={style}
94
+ >
95
+ {!showCreateModel && (
96
+ <ConversationCreateButton
97
+ onClick={() => setShowCreateModel(true)}
98
+ />
99
+ )}
100
+ {showCreateModel && (
101
+ <div className="tui-conversation-create">
102
+ <div className="tui-conversation-create-header">
103
+ <Icon onClick={back} type={IconTypes.BACK} width={9} height={16} />
104
+ <div className="title">{t(!isCreateGroup ? 'TUIConversation.Start chat' : 'TUIConversation.Add Participants')}</div>
105
+ </div>
106
+ {
107
+ pageState === PageStateTypes.USER_SELECT
108
+ ? (
109
+ <ConversationCreateUserSelectList
110
+ isCreateGroup={isCreateGroup}
111
+ setIsCreateGroup={setIsCreateGroup}
112
+ selectList={selectList}
113
+ setSelectList={setSelectList as React.Dispatch<React.SetStateAction<any[]>>}
114
+ conversationList={conversationList}
115
+ onBeforeCreateConversation={onBeforeCreateConversation}
116
+ onConversationCreated={_onConversationCreated}
117
+ setPageState={setPageState}
118
+ />
119
+ )
120
+ : (
121
+ <ConversationCreateGroupDetail
122
+ pageState={pageState}
123
+ setPageState={setPageState}
124
+ profileList={selectList.map((item: any) => item?.profile)}
125
+ onBeforeCreateConversation={onBeforeCreateConversation}
126
+ onConversationCreated={_onConversationCreated}
127
+ />
128
+ )
129
+ }
130
+ </div>
131
+ )}
54
132
  </div>
55
- {pageState === PageStateTypes.USER_SELECT ? (
56
- <ConversationCreateUserSelectList
57
- isCreateGroup={isCreateGroup}
58
- setIsCreateGroup={setIsCreateGroup}
59
- className={className}
60
- selectList={selectList}
61
- // eslint-disable-next-line
62
- // @ts-ignore
63
- setSelectList={setSelectList}
64
- conversationList={conversationList}
65
- setConversationCreated={setConversationCreated}
66
- setPageState={setPageState}
67
- />
68
- ) : (
69
- <ConversationCreatGroupDetail
70
- pageState={pageState}
71
- setPageState={setPageState}
72
- profileList={selectList.map((item: any) => item?.profile)}
73
- // eslint-disable-next-line
74
- // @ts-ignore
75
- createConversation={createConversation}
76
- setConversationCreated={setConversationCreated}
77
- />
78
- )}
79
- </>
80
- ), [isCreateGroup, selectList, pageState]);
133
+
134
+ );
135
+ }, [visible, className, showCreateModel, isCreateGroup, pageState, selectList, conversationList, onBeforeCreateConversation]);
81
136
  }
@@ -0,0 +1,46 @@
1
+ // ConversationSearch.tsx
2
+ import React from 'react';
3
+ import cs from 'classnames';
4
+ import { Icon, IconTypes } from '../Icon';
5
+ import './styles/conversationCreateButton.scss';
6
+
7
+ interface IConversationCreateButtonProps {
8
+ visible?: boolean;
9
+ onClick?: (event: React.BaseSyntheticEvent) => void;
10
+ height?: number;
11
+ width?: number;
12
+ className?: string;
13
+ }
14
+
15
+ const ConversationCreateButton = (props: IConversationCreateButtonProps) => {
16
+ const {
17
+ visible = true,
18
+ className,
19
+ onClick,
20
+ height = 24,
21
+ width = 24,
22
+ } = props;
23
+
24
+ if (!visible) {
25
+ return null;
26
+ }
27
+
28
+ return (
29
+ <div className={cs(
30
+ 'tui-conversation-create-button',
31
+ className)}
32
+ >
33
+ <Icon
34
+ onClick={onClick}
35
+ type={IconTypes.CREATE}
36
+ height={height}
37
+ width={width}
38
+ />
39
+ </div>
40
+ );
41
+ };
42
+
43
+ export {
44
+ ConversationCreateButton,
45
+ IConversationCreateButtonProps,
46
+ };
@@ -0,0 +1,179 @@
1
+ import React, { useState } from 'react';
2
+ import { useTranslation } from 'react-i18next';
3
+ import { Profile } from '@tencentcloud/chat';
4
+ import { CreateGroupParams, IConversationModel } from '@tencentcloud/chat-uikit-engine';
5
+ import { Input } from '../Input';
6
+ import './styles/ConversationCreateGroupDetail.scss';
7
+ import { Icon, IconTypes } from '../Icon';
8
+ import { Toast } from '../Toast';
9
+ import {
10
+ Avatar,
11
+ defaultGroupAvatarWork,
12
+ defaultGroupAvatarAVChatRoom,
13
+ defaultGroupAvatarMeeting,
14
+ defaultGroupAvatarPublic,
15
+ defaultUserAvatar,
16
+ } from '../Avatar';
17
+ import { PageStateTypes } from './ConversationCreate';
18
+ import { ConversationGroupTypeInfo, GroupType, typeInfoList } from './ConversationGroupTypeInfo';
19
+ import { useUIManager } from '../../context';
20
+ import { createGroupConversation } from '../../hooks/useConversation';
21
+
22
+ export interface ConversationCreateGroupDetailProps {
23
+ profileList: Profile[];
24
+ pageState: PageStateTypes;
25
+ setPageState: React.Dispatch<React.SetStateAction<PageStateTypes>>;
26
+ onBeforeCreateConversation?: (params: CreateGroupParams) => void;
27
+ onConversationCreated?: (conversation: IConversationModel) => void;
28
+ }
29
+ export function ConversationCreateGroupDetail(props: ConversationCreateGroupDetailProps) {
30
+ const {
31
+ profileList,
32
+ pageState,
33
+ setPageState,
34
+ onBeforeCreateConversation,
35
+ onConversationCreated,
36
+ } = props;
37
+ const { t } = useTranslation();
38
+ const { setActiveConversation, myProfile } = useUIManager();
39
+ const temp = [...profileList];
40
+ myProfile && temp.unshift(myProfile);
41
+ const name = temp.map(item => item.nick || item.userID).toString();
42
+ const [groupName, setGroupName] = useState(
43
+ name.length >= 15 ? `${name.slice(0, 12)}...` : name,
44
+ );
45
+ const [groupID, setGroupID] = useState('');
46
+ const [groupType, setGroupType] = useState<GroupType>(GroupType.Work);
47
+ const groupInfoChange = (e: any, type: string) => {
48
+ const { value } = e.target;
49
+ switch (type) {
50
+ case 'name':
51
+ setGroupName(value);
52
+ break;
53
+ case 'id':
54
+ setGroupID(value);
55
+ break;
56
+ case 'type':
57
+ setGroupType(value);
58
+ break;
59
+ default:
60
+ }
61
+ };
62
+ const showGroupTypeInfo = () => {
63
+ setPageState(PageStateTypes.GROUP_TYPE);
64
+ };
65
+ const getDefaultAvatar = (type: GroupType) => {
66
+ switch (type) {
67
+ case GroupType.Work:
68
+ return defaultGroupAvatarWork;
69
+ case GroupType.Public:
70
+ return defaultGroupAvatarPublic;
71
+ case GroupType.Meeting:
72
+ return defaultGroupAvatarMeeting;
73
+ case GroupType.AVChatRoom:
74
+ return defaultGroupAvatarAVChatRoom;
75
+ default:
76
+ return '';
77
+ }
78
+ };
79
+ // eslint-disable-next-line
80
+ // @ts-ignore
81
+ const getDes = () => typeInfoList?.find((item: any) => item.type === groupType).des;
82
+ const next = async () => {
83
+ const memberList = profileList.map(item => ({
84
+ userID: item.userID,
85
+ }));
86
+ const avatar = getDefaultAvatar(groupType);
87
+ const options: CreateGroupParams = {
88
+ name: groupName,
89
+ type: groupType,
90
+ groupID,
91
+ avatar,
92
+ memberList,
93
+ } as any;
94
+ const _options = onBeforeCreateConversation?.(options) || options;
95
+ createGroupConversation(_options)
96
+ .then((conversation: IConversationModel) => {
97
+ onConversationCreated?.(conversation);
98
+ })
99
+ .catch((error) => {
100
+ Toast({ text: error.message, type: 'error' });
101
+ });
102
+ };
103
+ return pageState !== PageStateTypes.GROUP_TYPE
104
+ ? (
105
+ <>
106
+ <div className="tui-conversation-create-group-detail">
107
+ <div className="create-group-box create-group-name">
108
+ <Input
109
+ maxLength={15}
110
+ value={groupName}
111
+ onChange={(e) => {
112
+ groupInfoChange(e, 'name');
113
+ }}
114
+ border="bottom"
115
+ inputClassName="input-group-name"
116
+ clearable
117
+ prefix={<div className="input-group-title">{t('TUIConversation.Group Name')}</div>}
118
+ />
119
+ </div>
120
+ <div className="create-group-box create-group-id">
121
+ <Input
122
+ border="bottom"
123
+ inputClassName="input-group-text"
124
+ clearable
125
+ value={groupID}
126
+ onChange={(e) => {
127
+ groupInfoChange(e, 'id');
128
+ }}
129
+ prefix={<div className="input-group-title">{t('TUIConversation.Group ID')}</div>}
130
+ />
131
+ </div>
132
+ <div className="create-group-box create-group-type" onClick={showGroupTypeInfo}>
133
+ <Input
134
+ readOnly
135
+ border="bottom"
136
+ inputClassName="input-group-text"
137
+ prefix={<div className="input-group-title">{t('TUIConversation.Group Type')}</div>}
138
+ suffix={(
139
+ <Icon
140
+ onClick={showGroupTypeInfo}
141
+ type={IconTypes.ARROW_RIGHT}
142
+ width={7}
143
+ height={12}
144
+ />
145
+ )}
146
+ value={t(`TUIConversation.${groupType}`)}
147
+ onChange={(e) => {
148
+ groupInfoChange(e, 'type');
149
+ }}
150
+ />
151
+ </div>
152
+ <div className="create-group-illustrate">
153
+ {t(`TUIConversation.${getDes()}`)}
154
+ </div>
155
+ <div className="create-group-portrait">
156
+ <div className="create-group-portrait-title">{t('TUIConversation.Participants')}</div>
157
+ <div className="create-group-portrait-info-container">
158
+ {profileList.map(({ avatar, userID, nick }) => (
159
+ <div className="create-group-portrait-info" key={userID}>
160
+ <Avatar shape="square" size={50} image={avatar || defaultUserAvatar} />
161
+ <div className="create-group-portrait-info-nick">{nick}</div>
162
+ </div>
163
+ ))}
164
+ </div>
165
+ </div>
166
+ </div>
167
+ <div className="tui-conversation-create-next-container">
168
+ <div role="presentation" className="tui-conversation-create-next" onClick={next}>{t('TUIConversation.Create')}</div>
169
+ </div>
170
+ </>
171
+ )
172
+ : (
173
+ <ConversationGroupTypeInfo
174
+ groupType={groupType}
175
+ setGroupType={setGroupType}
176
+ setPageState={setPageState}
177
+ />
178
+ );
179
+ }
@@ -5,16 +5,16 @@ import './styles/conversationCreateSelectView.scss';
5
5
  import { Icon, IconTypes } from '../Icon';
6
6
 
7
7
  interface ValueProps {
8
- profile: Profile,
9
- domList: Array<HTMLInputElement>,
8
+ profile: Profile;
9
+ domList: HTMLInputElement[];
10
10
  }
11
- export interface ConversationCreateSelectViewProps{
12
- selectList: Array<ValueProps>,
13
- setSelectList: React.Dispatch<React.SetStateAction<Array<ValueProps>>>,
11
+ export interface ConversationCreateSelectViewProps {
12
+ selectList: ValueProps[];
13
+ setSelectList: React.Dispatch<React.SetStateAction<ValueProps[]>>;
14
14
  }
15
- export function ConversationCreateSelectView(props:ConversationCreateSelectViewProps) {
15
+ export function ConversationCreateSelectView(props: ConversationCreateSelectViewProps) {
16
16
  const { selectList, setSelectList } = props;
17
- const close = (domList:Array<HTMLInputElement>, index: number) => {
17
+ const close = (domList: HTMLInputElement[], index: number) => {
18
18
  // eslint-disable-next-line no-param-reassign
19
19
  domList.forEach((dom: HTMLInputElement) => { dom.checked = false; });
20
20
  selectList.splice(index, 1);